X-Git-Url: https://git.wpitchoune.net/gitweb/?a=blobdiff_plain;f=src%2Ftw.c;h=3049c0bd0f62b75b85e1e01b21789b9c335d6262;hb=2336c8428b6fff8f97cb71bfbe4472080ac92938;hp=abc98082da4d951a24f801ee4e735f2218eb98f4;hpb=8d43529da6a9a3a469b107ab07f52991e9f18e75;p=ptask.git diff --git a/src/tw.c b/src/tw.c index abc9808..3049c0b 100644 --- a/src/tw.c +++ b/src/tw.c @@ -24,9 +24,8 @@ #include #include -#include +#include -#include #include #include "note.h" #include @@ -109,7 +108,9 @@ static int task_check_version() log_debug("task version: %s", ver); - if (!strcmp(ver, "2.2.0") || !strcmp(ver, "2.0.0")) + if (!strcmp(ver, "2.2.0") + || !strcmp(ver, "2.0.0") + || !strcmp(ver, "2.3.0")) return 1; else return 0; @@ -154,6 +155,9 @@ static struct json_object *task_exec_json(const char *opts) free(cmd); + if (o && is_error(o)) + return NULL; + return o; } @@ -236,6 +240,12 @@ struct task **tw_get_all_tasks(const char *status) = parse_time(json_object_get_string(json)); else tasks[i]->start = NULL; + + json = json_object_object_get(jtask, "recur"); + if (json) + tasks[i]->recur = strdup(json_object_get_string(json)); + else + tasks[i]->recur = NULL; } tasks[n] = NULL; @@ -382,7 +392,7 @@ void tw_add(const char *newdesc, const char *prj, const char *prio) log_fct_exit(); } -void tw_done(const char *uuid) +void tw_task_done(const char *uuid) { char *opts; @@ -397,6 +407,36 @@ void tw_done(const char *uuid) free(opts); } +void tw_task_start(const char *uuid) +{ + char *opts; + + opts = malloc(1 + + strlen(uuid) + + strlen(" start") + + 1); + sprintf(opts, " %s start", uuid); + + tw_exec(opts); + + free(opts); +} + +void tw_task_stop(const char *uuid) +{ + char *opts; + + opts = malloc(1 + + strlen(uuid) + + strlen(" stop") + + 1); + sprintf(opts, " %s stop", uuid); + + tw_exec(opts); + + free(opts); +} + void tw_task_remove(const char *uuid) { char *opts; @@ -427,6 +467,7 @@ static void task_free(struct task *task) free(task->entry); free(task->due); free(task->start); + free(task->recur); free(task); } @@ -489,6 +530,41 @@ static struct project *project_new(const char *name, int count) return prj; } +static int projects_length(struct project **list) +{ + int n; + + if (!list) + return 0; + + n = 0; + while (*list) { + n++; + list++; + } + + return n; +} + +static struct project **projects_add(struct project **list, void *item) +{ + int n; + struct project **result; + + n = projects_length(list); + + result = (struct project **)malloc + ((n + 1 + 1) * sizeof(struct project *)); + + if (list) + memcpy(result, list, n * sizeof(struct project *)); + + result[n] = item; + result[n + 1] = NULL; + + return result; +} + struct project **tw_get_projects(struct task **tasks) { struct task **t_cur; @@ -509,7 +585,7 @@ struct project **tw_get_projects(struct task **tasks) } else { prj = project_new(prj_name, 1); - tmp = (struct project **)list_add((void **)prjs, prj); + tmp = projects_add(prjs, prj); free(prjs); prjs = tmp;