diff options
author | Lukas Fleischer <calcurse@cryptocrack.de> | 2011-11-11 10:04:16 +0100 |
---|---|---|
committer | Lukas Fleischer <calcurse@cryptocrack.de> | 2011-11-14 11:08:14 +0100 |
commit | 349bd3f88b094d3e17a84308f9ae4cf0a16d6727 (patch) | |
tree | 2e7a59eb27b432e1893126e7818b1ff0da58f620 /src/utils.c | |
parent | d32d811623ac130df58a5f02f168f48caa23ef9a (diff) | |
download | calcurse-349bd3f88b094d3e17a84308f9ae4cf0a16d6727.zip |
Use a dynamic method to print todo items to stdout
This goes in line with the other commits adding print_*() support.
Following format specifiers are allowed:
* p: Print the priority of the item
* m: Print the description of the item
* n: Print the name of the note file belonging to the item
Signed-off-by: Lukas Fleischer <calcurse@cryptocrack.de>
Diffstat (limited to 'src/utils.c')
-rw-r--r-- | src/utils.c | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/src/utils.c b/src/utils.c index e94c7fa..f2f6305 100644 --- a/src/utils.c +++ b/src/utils.c @@ -1060,3 +1060,37 @@ print_recur_event (const char *format, long day, struct recur_event *rev) print_event (format, day, &ev); } + +/* Print a formatted todo item to stdout. */ +void +print_todo (const char *format, struct todo *todo) +{ + const char *p; + + for (p = format; *p; p++) + { + if (*p == '%') { + p++; + switch (*p) + { + case 'p': + printf ("%d", abs (todo->id)); + break; + case 'm': + printf ("%s", todo->mesg); + break; + case 'n': + printf ("%s", todo->note); + break; + case '\0': + return; + break; + default: + putchar ('?'); + break; + } + } + else + putchar (*p); + } +} |