/*
- * 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 <stdio.h>
#include <stdlib.h>
#include <string.h>
+#include <getopt.h>
#include <json/json.h>
+#include <glib/gi18n.h>
#include <gtk/gtk.h>
+#include "note.h"
#include "tw.h"
+static const char *program_name;
static struct task **tasks;
static GtkTextView *w_note;
static GtkEntry *w_description;
static GtkEntry *w_project;
static GtkTreeView *w_treeview;
static GtkWidget *w_tasksave_btn;
+static GtkWidget *w_taskdone_btn;
static GtkComboBox *w_status;
static GtkComboBox *w_priority;
COL_PRIORITY
};
+static struct option long_options[] = {
+ {"version", no_argument, 0, 'v'},
+ {"help", no_argument, 0, 'h'},
+ {0, 0, 0, 0}
+};
+
+static void print_version()
+{
+ printf("ptask %s\n", VERSION);
+ printf(_("Copyright (C) %s jeanfi@gmail.com\n"
+ "License GPLv2: GNU GPL version 2 or later "
+ "<http://www.gnu.org/licenses/old-licenses/gpl-2.0.html>\n"
+ "This is free software: you are free to change and "
+ " redistribute it.\n"
+ "There is NO WARRANTY, to the extent permitted by law.\n"),
+ "2012-2013");
+}
+
+static void print_help()
+{
+ printf(_("Usage: %s [OPTION]...\n"), program_name);
+
+ puts(_("Ptask is a task management UI based on taskwarrior."));
+
+ puts("");
+ puts(_("Options:"));
+ puts(_(" -h, --help display this help and exit\n"
+ " -v, --version display version information and exit"));
+
+ puts("");
+
+ printf(_("Report bugs to: %s\n"), PACKAGE_BUGREPORT);
+ puts("");
+ printf(_("%s home page: <%s>\n"), PACKAGE_NAME, PACKAGE_URL);
+}
+
static struct task *get_selected_task(GtkTreeView *treeview)
{
GtkTreePath *path;
GtkTextBuffer *buf;
gtk_widget_set_sensitive(w_tasksave_btn, 0);
+ gtk_widget_set_sensitive(w_taskdone_btn, 0);
buf = gtk_text_view_get_buffer(w_note);
gtk_text_buffer_set_text(buf, "", 0);
status = gtk_combo_box_get_active(w_status);
printf("status: %d\n", status);
+ if (tasks)
+ tw_task_list_free(tasks);
+
switch (status) {
case 0:
tasks = tw_get_all_tasks("pending");
printf("refresh done\n");
}
+int taskdone_clicked_cbk(GtkButton *btn, gpointer data)
+{
+ struct task *task;
+
+ task = get_selected_task(GTK_TREE_VIEW(w_treeview));
+ tw_done(task->uuid);
+ refresh();
+
+ return FALSE;
+}
+
static int tasksave_clicked_cbk(GtkButton *btn, gpointer data)
{
struct task *task;
printf("tasksave_clicked_cbk %d\n", task->id);
- if (task->note) {
- buf = gtk_text_view_get_buffer(w_note);
+ buf = gtk_text_view_get_buffer(w_note);
- gtk_text_buffer_get_iter_at_offset(buf, &sIter, 0);
- gtk_text_buffer_get_iter_at_offset(buf, &eIter, -1);
- txt = gtk_text_buffer_get_text(buf, &sIter, &eIter, TRUE);
+ gtk_text_buffer_get_iter_at_offset(buf, &sIter, 0);
+ gtk_text_buffer_get_iter_at_offset(buf, &eIter, -1);
+ txt = gtk_text_buffer_get_text(buf, &sIter, &eIter, TRUE);
- txt = escape(txt);
+ printf("note=%s\n", txt);
- printf("%s\n", txt);
- }
+ if (!task->note || strcmp(txt, task->note))
+ note_put(task->uuid, txt);
ctxt = gtk_entry_get_text(w_description);
if (!task->description || strcmp(ctxt, task->description))
return FALSE;
}
+static gboolean delete_event_cbk(GtkWidget *w, GdkEvent *evt, gpointer data)
+{
+ gtk_widget_destroy(w);
+ gtk_main_quit();
+
+ return FALSE;
+}
+
+
int newtask_clicked_cbk(GtkButton *btn, gpointer data)
{
gint result;
builder = gtk_builder_new();
gtk_builder_add_from_file
(builder,
- PACKAGE_DATA_DIR G_DIR_SEPARATOR_S "gtask.glade",
+ PACKAGE_DATA_DIR G_DIR_SEPARATOR_S "ptask.glade",
NULL);
diag = GTK_DIALOG(gtk_builder_get_object(builder, "diag_tasknew"));
gtk_builder_connect_signals(builder, NULL);
gtk_widget_set_sensitive(GTK_WIDGET(w_project), 1);
gtk_widget_set_sensitive(w_tasksave_btn, 1);
+ gtk_widget_set_sensitive(w_taskdone_btn, 1);
gtk_widget_set_sensitive(GTK_WIDGET(w_priority), 1);
priority = priority_to_int(task->priority);
int main(int argc, char **argv)
{
- GtkWidget *window;
- GtkWidget *btn;
+ GtkWidget *window, *btn;
GtkBuilder *builder;
GtkTreeModel *model;
+ int optc, cmdok, opti;
+
+ program_name = argv[0];
+
+ setlocale(LC_ALL, "");
+
+#if ENABLE_NLS
+ bindtextdomain(PACKAGE, LOCALEDIR);
+ textdomain(PACKAGE);
+#endif
+
+ cmdok = 1;
+ while ((optc = getopt_long(argc, argv, "vh", long_options,
+ &opti)) != -1) {
+ switch (optc) {
+ case 'h':
+ print_help();
+ exit(EXIT_SUCCESS);
+ case 'v':
+ print_version();
+ exit(EXIT_SUCCESS);
+ default:
+ cmdok = 0;
+ break;
+ }
+ }
+
+ if (!cmdok || optind != argc) {
+ fprintf(stderr, _("Try `%s --help' for more information.\n"),
+ program_name);
+ exit(EXIT_FAILURE);
+ }
gtk_init(NULL, NULL);
builder = gtk_builder_new();
gtk_builder_add_from_file
(builder,
- PACKAGE_DATA_DIR G_DIR_SEPARATOR_S "gtask.glade",
+ PACKAGE_DATA_DIR G_DIR_SEPARATOR_S "ptask.glade",
NULL);
window = GTK_WIDGET(gtk_builder_get_object(builder, "window"));
+ g_signal_connect(window, "delete_event",
+ G_CALLBACK(delete_event_cbk), NULL);
+
w_treeview = GTK_TREE_VIEW(gtk_builder_get_object(builder, "treeview"));
model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_treeview));
gtk_tree_sortable_set_sort_func(GTK_TREE_SORTABLE(model),
g_signal_connect(w_status,
"changed", (GCallback)status_changed_cbk,
tasks);
+
btn = GTK_WIDGET(gtk_builder_get_object(builder, "tasksave"));
g_signal_connect(btn,
"clicked", (GCallback)tasksave_clicked_cbk, tasks);
gtk_widget_set_sensitive(btn, 0);
w_tasksave_btn = btn;
- /*btn = GTK_WIDGET(gtk_builder_get_object(builder, "refresh"));
- g_signal_connect(btn,
- "clicked", (GCallback)refresh_clicked_cbk, tasks);*/
+ w_taskdone_btn = GTK_WIDGET(gtk_builder_get_object(builder,
+ "taskdone"));
+ gtk_widget_set_sensitive(w_taskdone_btn, 0);
g_object_unref(G_OBJECT(builder));