#include <string.h>
#include <getopt.h>
+#include <sys/stat.h>
+#include <sys/types.h>
+
#include <json/json.h>
#include <webkit/webkit.h>
#include <glib/gi18n.h>
#include <gtk/gtk.h>
#include "http.h"
+#include "log.h"
#include "ttrss.h"
+#include "ttrss_ws.h"
#include "webbrowser.h"
static const char *program_name;
static struct option long_options[] = {
{"version", no_argument, 0, 'v'},
{"help", no_argument, 0, 'h'},
+ {"debug", required_argument, 0, 'd'},
{0, 0, 0, 0}
};
puts(_("Options:"));
puts(_(" -h, --help display this help and exit\n"
" -v, --version display version information and exit"));
+ puts("");
+ puts(_(" -d, --debug=LEVEL "
+ "set the debug level, integer between 0 and 3"));
puts("");
void update()
{
struct feed **feeds;
- GtkTreeModel *model;
+ GtkTreeModel *model, *headlinemodel;
GtkTreeIter iter;
char *title;
model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_feedtree));
- printf("update(): clear feed tree\n");
+ log_debug("update(): clear feed tree.");
model_state = 1;
gtk_list_store_clear(GTK_LIST_STORE(model));
- gtk_list_store_clear(GTK_LIST_STORE(gtk_tree_view_get_model(w_headlinetree)));
- printf("update(): clear feed tree done\n");
+ headlinemodel = gtk_tree_view_get_model(w_headlinetree);
+ gtk_list_store_clear(GTK_LIST_STORE(headlinemodel));
+ log_debug("update(): clear feed tree done.");
feeds = ttrss_get_feeds();
while (feeds && *feeds) {
if ((*feeds)->unread)
}
model_state = 0;
- printf("refresh done\n");
+ log_debug("update() done");
}
void refresh_clicked_cbk(GtkWidget *btn, gpointer data)
{
- printf("refresh_clicked_cbk\n");
+ log_debug("refresh_clicked_cbk()");
update();
+ log_debug("refresh_clicked_cbk() done");
}
void settings_activate_cbk(GtkWidget *menu_item, gpointer data)
GtkBuilder *builder;
GtkEntry *login, *url, *pwd;
- printf("settings_activate_cbk\n");
+ log_debug("settings_activate_cbk()");
builder = gtk_builder_new();
"user",
gtk_entry_get_text(login));
+ ttrss_set_config(g_settings_get_string(settings, "url"),
+ g_settings_get_string(settings, "user"),
+ g_settings_get_string(settings, "password"));
+ ws_open_session();
+
update();
}
if (model_state)
return TRUE;
- printf("feed_cursor_changed_cbk\n");
+ log_debug("feed_cursor_changed_cbk()");
feed = get_selected_feed();
headlines = ttrss_feed_get_headlines(feed);
while (headlines && *headlines) {
gtk_list_store_append(headline_store, &iter);
-
+
if ((*headlines)->unread)
title = g_strdup_printf
("<b>%s</b>",
(*headlines)->title);
else
title = strdup((*headlines)->title);
-
+
gtk_list_store_set(headline_store,
&iter,
0, title,
1, (*headlines)->id,
-1);
-
+
free(title);
-
+
headlines++;
}
}
GtkTreeIter iter;
GtkTreeModel *model;
struct headline *headline;
- const char *str;
+ char *str;
- printf("headline_cursor_changed_cbk\n");
+ log_debug("headline_cursor_changed_cbk()");
if (model_state)
return TRUE;
else
web_load("");
+ free(str);
+
if (headline->unread) {
ttrss_set_article_unread(headline->id, 0);
headline->unread = 0;
0, headline->title,
-1);
} else {
- printf("headline not found\n");
- }
-
+ log_debug("headline not found");
+ }
return TRUE;
}
const char *url;
int id;
- printf("headline_row_activated_cbk\n");
+ printf("headline_row_activated_cbk()");
selection = gtk_tree_view_get_selection(w_headlinetree);
model = gtk_tree_view_get_model(w_headlinetree);
h = ttrss_get_headline(id);
if (h) {
url = h->url;
-
+
if (gtk_widget_has_screen(widget))
- screen = gtk_widget_get_screen(widget);
+ screen = gtk_widget_get_screen(widget);
else
screen = gdk_screen_get_default();
-
+
error = NULL;
- gtk_show_uri(screen, url,
+ gtk_show_uri(screen, url,
gtk_get_current_event_time(), &error);
}
}
gboolean
window_delete_event_cbk(GtkWidget *widget, GdkEvent *event, gpointer data)
{
- printf("window_delete_event_cbk\n");
+ log_debug("window_delete_event_cbk");
gtk_main_quit();
return TRUE;
}
+void quit_activate_cbk(GtkWidget *menu_item, gpointer data)
+{
+ log_debug("quit_activate_cbk");
+
+ gtk_main_quit();
+}
+
+void help_activate_cbk(GtkWidget *menu_item, gpointer data)
+{
+ log_debug("help_activate_cbk");
+
+ gtk_show_about_dialog
+ (NULL,
+ "comments",
+ _("PRSS is a GTK+ client application for Tiny Tiny RSS"),
+ "copyright",
+ _("Copyright(c) 2010-2013\njeanfi@gmail.com"),
+ "logo-icon-name", "prss",
+ "program-name", "PRSS",
+ "title", _("About PRSS"),
+ "version", VERSION,
+ "website", PACKAGE_URL,
+ "website-label", _("PRSS Homepage"),
+ NULL);
+}
+
+static void log_init()
+{
+ char *home, *path, *dir;
+
+ home = getenv("HOME");
+
+ if (!home)
+ return ;
+
+ dir = malloc(strlen(home)+1+strlen(".prss")+1);
+ sprintf(dir, "%s/%s", home, ".prss");
+ mkdir(dir, 0777);
+
+ path = malloc(strlen(dir)+1+strlen("log")+1);
+ sprintf(path, "%s/%s", dir, "log");
+
+ log_open(path);
+
+ free(dir);
+ free(path);
+}
+
int main(int argc, char **argv)
{
GtkWidget *window, *panh;
#endif
cmdok = 1;
- while ((optc = getopt_long(argc, argv, "vh", long_options,
+ while ((optc = getopt_long(argc, argv, "vhd:", long_options,
&opti)) != -1) {
switch (optc) {
+ case 'd':
+ log_level = atoi(optarg);
+ log_info(_("Enables debug mode."));
+ break;
case 'h':
print_help();
exit(EXIT_SUCCESS);
exit(EXIT_FAILURE);
}
+ log_init();
+
http_init();
+ ws_init();
gtk_init(NULL, NULL);
settings = g_settings_new("prss");