diff options
author | Frederic Culot <calcurse@culot.org> | 2007-02-25 19:32:30 +0000 |
---|---|---|
committer | Frederic Culot <calcurse@culot.org> | 2007-02-25 19:32:30 +0000 |
commit | 58401dead825de58f6b340b15f14073bfa95d480 (patch) | |
tree | d987a1f61d67e377f7ff47f47db5d8464db8d246 | |
parent | eed40f2fbedd71aafa9bdc3114437ec422688182 (diff) | |
download | calcurse-58401dead825de58f6b340b15f14073bfa95d480.zip |
updated call to notify_check_added()
call to notify_catch_children() added
print_notify_options() improved to avoid display problems with long options
init_notify_bar() updated to get user shell
-rwxr-xr-x | src/calcurse.c | 26 |
1 files changed, 20 insertions, 6 deletions
diff --git a/src/calcurse.c b/src/calcurse.c index ba7285b..cdb78d8 100755 --- a/src/calcurse.c +++ b/src/calcurse.c @@ -1,4 +1,4 @@ -/* $calcurse: calcurse.c,v 1.35 2007/02/24 17:32:55 culot Exp $ */ +/* $calcurse: calcurse.c,v 1.36 2007/02/25 19:32:30 culot Exp $ */ /* * Calcurse - text-based organizer @@ -195,7 +195,9 @@ int main(int argc, char **argv) custom_init_attr(colr); nb_tod = load_todo(colr); load_app(); - if (notify_bar()) notify_start_main_thread(); + notify_catch_children(); + if (notify_bar()) + notify_start_main_thread(); get_screen_config(); reinit_wins(); startup_screen(skip_system_dialogs, no_data_file, colr); @@ -595,7 +597,7 @@ void init_notify_bar(void) { char *time_format = "%T"; char *date_format = "%a %F"; - char *cmd = "calcurse --next | mail name@domain.com"; + char *cmd = "printf '\\a'"; nbar = (struct nbar_s *) malloc(sizeof(struct nbar_s)); pthread_mutex_init(&nbar->mutex, NULL); @@ -604,6 +606,9 @@ void init_notify_bar(void) strncpy(nbar->datefmt, date_format, strlen(date_format) + 1); strncpy(nbar->timefmt, time_format, strlen(time_format) + 1); strncpy(nbar->cmd, cmd, strlen(cmd) + 1); + + if ((nbar->shell = getenv("SHELL")) == NULL) + nbar->shell = "/bin/sh"; } /* @@ -984,7 +989,8 @@ print_notify_options(WINDOW *win, int col) char value[MAX_LENGTH]; } opt[NB_OPT]; - int i, y, x, l, x_pos, y_pos, x_offset, y_offset, maxcol; + int i, y, x, l, x_pos, y_pos, x_offset, y_offset, maxcol, maxlen; + char buf[MAX_LENGTH]; x_pos = 3; x_offset = 4; @@ -1033,10 +1039,18 @@ print_notify_options(WINDOW *win, int col) l = strlen(opt[i].name); y = y_pos + i * y_offset; x = x_pos + x_offset + l; + maxlen = maxcol - x - 2; + mvwprintw(win, y, x_pos, "[%d] %s", i + 1, opt[i].name); erase_window_part(win, x, y, maxcol, y); custom_apply_attr(win, ATTR_HIGHEST); - mvwprintw(win, y, x, "%s", opt[i].value); + if (strlen(opt[i].value) < maxlen) + mvwprintw(win, y, x, "%s", opt[i].value); + else { + strncpy(buf, opt[i].value, maxlen - 1); + buf[maxlen - 1] = '\0'; + mvwprintw(win, y, x, "%s...", buf); + } custom_remove_attr(win, ATTR_HIGHEST); mvwprintw(win, y + 1, x_pos, opt[i].desc); } @@ -1242,7 +1256,7 @@ void add_item(void) apoint_pointeur = apoint_new(item_mesg, apoint_start, min2sec(apoint_duration), 0L); if (notify_bar()) - notify_check_added(item_mesg, apoint_start); + notify_check_added(item_mesg, apoint_start, 0L); } else event_pointeur = event_new(item_mesg, date2sec( sel_year, sel_month, sel_day, 12, 0), Id); |