#include <json/json.h>
+#include <list.h>
#include <log.h>
#include "note.h"
#include <pstr.h>
size_t s;
char *str, *tmp, *cmd, buf[1024];
+ log_fct_enter();
+
cmd = malloc(strlen("task ") + strlen(opts) + 1);
strcpy(cmd, "task ");
strcat(cmd, opts);
if (ret == -1)
log_err("pclose fails");
+ log_fct_exit();
+
return str;
}
tasks[i]->project
= strdup(json_object_get_string(json));
else
- tasks[i]->project = NULL;
+ tasks[i]->project = strdup("");
json = json_object_object_get(jtask, "priority");
if (json)
json = json_object_object_get(jtask, "uuid");
tasks[i]->uuid = strdup(json_object_get_string(json));
+ json = json_object_object_get(jtask, "urgency");
+ tasks[i]->urgency = strdup(json_object_get_string(json));
+
tasks[i]->note = note_get(tasks[i]->uuid);
}
char *str;
char *opts;
+ log_fct_enter();
+
str = escape(priority);
opts = malloc(1
free(str);
free(opts);
+
+ log_fct_exit();
}
void tw_add(const char *newdesc, const char *prj, const char *prio)
{
char *opts, *eprj;
+ log_fct_enter();
+
eprj = escape(prj);
- opts = malloc(strlen(" add")
+ opts = malloc(strlen("add")
+ strlen(" priority:")
+ 1
+ strlen(" project:\\\"")
+ strlen("\"")
+ 1);
- strcpy(opts, " add");
+ strcpy(opts, "add");
if (prio && strlen(prio) == 1) {
strcat(opts, " priority:");
strcat(opts, " \"");
strcat(opts, newdesc);
- strcat(opts, " \"");
+ strcat(opts, "\"");
tw_exec(opts);
free(opts);
free(eprj);
+
+ log_fct_exit();
}
void tw_done(const char *uuid)
free(opts);
}
+void tw_task_remove(const char *uuid)
+{
+ char *opts;
+
+ opts = malloc(1
+ + strlen(uuid)
+ + strlen(" delete")
+ + 1);
+ sprintf(opts, " %s delete", uuid);
+
+ tw_exec(opts);
+
+ free(opts);
+}
+
static void task_free(struct task *task)
{
if (!task)
free(task->note);
free(task->project);
free(task->priority);
+ free(task->urgency);
free(task);
}
free(tasks);
}
+
+static void project_free(struct project *p)
+{
+ if (!p)
+ return ;
+
+ free(p->name);
+ free(p);
+}
+
+void tw_project_list_free(struct project **prjs)
+{
+ struct project **cur;
+
+ if (!prjs)
+ return ;
+
+ for (cur = prjs; *cur; cur++)
+ project_free(*cur);
+
+ free(prjs);
+}
+
+static struct project *project_list_get(struct project **prjs, const char *name)
+{
+ struct project **cur;
+
+ for (cur = prjs; *cur; cur++)
+ if (!strcmp((*cur)->name, name))
+ return *cur;
+
+ return NULL;
+}
+
+static struct project *project_new(const char *name, int count)
+{
+ struct project *prj;
+
+ prj = malloc(sizeof(struct project));
+
+ prj->name = strdup(name);
+ prj->count = count;
+
+ return prj;
+}
+
+struct project **tw_get_projects(struct task **tasks)
+{
+ struct task **t_cur;
+ struct project **prjs, **tmp, *prj;
+ const char *prj_name;
+
+ log_fct_enter();
+
+ prjs = malloc(2 * sizeof(struct project *));
+ prjs[0] = project_new("ALL", 0);
+ prjs[1] = NULL;
+
+ for (t_cur = tasks; *t_cur; t_cur++) {
+ prj_name = (*t_cur)->project;
+ prj = project_list_get(prjs, prj_name);
+ if (prj) {
+ prj->count++;
+ } else {
+ prj = project_new(prj_name, 1);
+
+ tmp = (struct project **)list_add((void **)prjs, prj);
+
+ free(prjs);
+ prjs = tmp;
+ }
+ prjs[0]->count++;
+ }
+
+ log_fct_exit();
+
+ return prjs;
+}