From 2acb4f4b249348eeb6ca4bf37836889be55418ff Mon Sep 17 00:00:00 2001 From: Jean-Philippe Orsini Date: Tue, 23 Apr 2013 08:25:51 +0000 Subject: [PATCH] --- src/main.c | 16 +++++++++++++++- src/phttp.c | 6 ++++-- src/ttrss.c | 18 ++++++++++++++++++ src/ttrss.h | 1 + 4 files changed, 38 insertions(+), 3 deletions(-) diff --git a/src/main.c b/src/main.c index 861309d..e202433 100644 --- a/src/main.c +++ b/src/main.c @@ -33,6 +33,7 @@ static const char *program_name; static GSettings *settings; +static int model_state; static struct option long_options[] = { {"version", no_argument, 0, 'v'}, @@ -86,7 +87,10 @@ void update() model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_treeview)); + printf("update(): clear feed tree\n"); + model_state = 1; gtk_list_store_clear(GTK_LIST_STORE(model)); + printf("update(): clear feed tree done\n"); feeds = ttrss_get_feeds(); while(feeds && *feeds) { if ((*feeds)->unread) @@ -107,6 +111,8 @@ void update() free(title); feeds++; } + model_state = 0; + printf("refresh done\n"); } @@ -183,6 +189,7 @@ int feed_cursor_changed_cbk(GtkTreeView *treeview, gpointer data) headline_model = gtk_tree_view_get_model(w_headlineview); headline_store = GTK_LIST_STORE(headline_model); + model_state = 1; gtk_list_store_clear(headline_store); headlines = ttrss_get_headlines(feed); @@ -206,6 +213,7 @@ int feed_cursor_changed_cbk(GtkTreeView *treeview, gpointer data) headlines++; } + model_state = 0; gtk_tree_path_free(path); } @@ -222,6 +230,9 @@ int headline_cursor_changed_cbk(GtkTreeView *treeview, gpointer data) const char *str; printf("headline_cursor_changed_cbk\n"); + + if (model_state) + return TRUE; gtk_tree_view_get_cursor(treeview, &path, &cols); @@ -230,7 +241,10 @@ int headline_cursor_changed_cbk(GtkTreeView *treeview, gpointer data) gtk_tree_model_get_iter(model, &iter, path); gtk_tree_model_get(model, &iter, 1, &headline, -1); - str = ttrss_get_headline_content((struct headline *)headline); + str = ttrss_get_headline_content(headline); + + if (headline->unread) + ttrss_set_article_unread(headline->id, 0); if (str) web_load(str); diff --git a/src/phttp.c b/src/phttp.c index 81c8ad7..a1d0211 100644 --- a/src/phttp.c +++ b/src/phttp.c @@ -103,8 +103,10 @@ static json_object *post(const char *url, const char *body) curl_easy_setopt(curl, CURLOPT_URL, url); curl_easy_setopt(curl, CURLOPT_VERBOSE, 0); - curl_easy_setopt(curl, CURLOPT_POSTFIELDS, body); - curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, (long)strlen(body)); + if (body) { + curl_easy_setopt(curl, CURLOPT_POSTFIELDS, body); + curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, (long)strlen(body)); + } curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, cbk_curl); curl_easy_setopt(curl, CURLOPT_WRITEDATA, (void *)&chunk); diff --git a/src/ttrss.c b/src/ttrss.c index 2c57b4e..2a94e99 100644 --- a/src/ttrss.c +++ b/src/ttrss.c @@ -21,6 +21,7 @@ #include #include +#include #include "phttp.h" #include "ttrss.h" @@ -277,3 +278,20 @@ struct headline **ttrss_get_headlines(struct feed *f) return f->headlines; } + +void ttrss_set_article_unread(int id, int unread) +{ + struct json_object *rp, *rq; + + printf("ttrss_set_article_unread %d %d\n", id, unread); + + rq = create_op("updateArticle"); + json_object_object_add(rq, "article_ids", json_object_new_int(id)); + json_object_object_add(rq, "field", json_object_new_int(2)); + json_object_object_add(rq, "mode", json_object_new_int(unread)); + + rp = post_json_object(session_url, rq); + + json_object_put(rq); + json_object_put(rp); +} diff --git a/src/ttrss.h b/src/ttrss.h index 801485e..817be41 100644 --- a/src/ttrss.h +++ b/src/ttrss.h @@ -44,4 +44,5 @@ struct feed **ttrss_get_feeds(); struct headline **ttrss_get_headlines(struct feed *); const char *ttrss_get_headline_content(struct headline *); +void ttrss_set_article_unread(int id, int unread); #endif -- 2.7.4