/*
- * Copyright (C) 2010-2012 jeanfi@gmail.com
+ * Copyright (C) 2012-2013 jeanfi@gmail.com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
#include <stdlib.h>
#include <string.h>
+#include <json/json.h>
+
+#include "note.h"
+#include "tw.h"
-char *task_exec(char *opts)
+static char *task_exec(char *opts)
{
FILE *f;
int ret;
return str;
}
-#include <json/json.h>
-
-#include "tw.h"
-
static struct json_object *task_exec_json(char *opts)
{
struct json_object *o;
else
tasks[i]->project = NULL;
+ json = json_object_object_get(jtask, "priority");
+ if (json)
+ tasks[i]->priority
+ = strdup(json_object_get_string(json));
+ else
+ tasks[i]->priority = strdup("");
+
json = json_object_object_get(jtask, "uuid");
tasks[i]->uuid = strdup(json_object_get_string(json));
- tasks[i]->note = NULL;
+ tasks[i]->note = note_get(tasks[i]->uuid);
}
tasks[n] = NULL;
free(str);
free(opts);
}
+
+void tw_modify_priority(const char *uuid, const char *priority)
+{
+ char *str;
+ char *opts;
+
+ str = escape(priority);
+
+ opts = malloc(1
+ + strlen(uuid)
+ + strlen(" modify priority:\"")
+ + strlen(str)
+ + strlen("\"")
+ + 1);
+ sprintf(opts, " %s modify priority:\"%s\"", uuid, str);
+
+ task_exec(opts);
+
+ free(str);
+ free(opts);
+}
+
+void tw_add(const char *newdesc)
+{
+ char *str;
+ char *opts;
+
+ str = escape(newdesc);
+
+ opts = malloc(1
+ + strlen(" add \"")
+ + strlen(str)
+ + strlen("\"")
+ + 1);
+ sprintf(opts, " add \"%s\"", str);
+
+ task_exec(opts);
+
+ free(str);
+ free(opts);
+}
+
+void tw_done(const char *uuid)
+{
+ char *opts;
+
+ opts = malloc(1
+ + strlen(uuid)
+ + strlen(" done")
+ + 1);
+ sprintf(opts, " %s done", uuid);
+
+ task_exec(opts);
+
+ free(opts);
+}
+
+static void task_free(struct task *task)
+{
+ if (!task)
+ return ;
+
+ free(task->description);
+ free(task->status);
+ free(task->uuid);
+ free(task->note);
+ free(task->project);
+ free(task->priority);
+
+ free(task);
+}
+
+void tw_task_list_free(struct task **tasks)
+{
+ struct task **cur;
+
+ if (!tasks)
+ return ;
+
+ for (cur = tasks; *cur; cur++)
+ task_free(*cur);
+
+ free(tasks);
+}