X-Git-Url: http://git.wpitchoune.net/gitweb/?a=blobdiff_plain;f=src%2Fmain.c;h=b7a2e65632178819e8124d1743f4b49d55ab6fc8;hb=6ccb17c2d686381c564a33e84962199ef3e4019f;hp=39ad7c38b31e0b4ced8854987b997a4cbd65c57c;hpb=05d4d920a38f57f2afc0ef349d8f4c96a5852878;p=prss.git
diff --git a/src/main.c b/src/main.c
index 39ad7c3..b7a2e65 100644
--- a/src/main.c
+++ b/src/main.c
@@ -51,7 +51,8 @@ enum {
enum {
COL_HEADLINE_TITLE,
- COL_HEADLINE_ID
+ COL_HEADLINE_ID,
+ COL_HEADLINE_DATE
};
static struct option long_options[] = {
@@ -97,46 +98,50 @@ static void print_help()
GtkTreeView *w_feedtree;
GtkTreeView *w_headlinetree;
+static char *feed_get_formated_title(struct feed *f)
+{
+ if (f->unread)
+ return g_strdup_printf("%s (%d)",
+ f->title,
+ f->unread);
+ else
+ return strdup(f->title);
+}
+
void update()
{
struct feed **feeds;
- GtkTreeModel *model, *headlinemodel;
+ GtkListStore *model, *headline_model;
GtkTreeIter iter;
char *title;
- model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_feedtree));
+ model = GTK_LIST_STORE(gtk_tree_view_get_model(w_feedtree));
+ headline_model
+ = GTK_LIST_STORE(gtk_tree_view_get_model(w_headlinetree));
log_debug("update(): clear feed tree.");
model_state = 1;
- gtk_list_store_clear(GTK_LIST_STORE(model));
- headlinemodel = gtk_tree_view_get_model(w_headlinetree);
- gtk_list_store_clear(GTK_LIST_STORE(headlinemodel));
+ gtk_list_store_clear(model);
+ gtk_list_store_clear(headline_model);
log_debug("update(): clear feed tree done.");
feeds = ttrss_get_feeds();
while (feeds && *feeds) {
- if ((*feeds)->unread)
- title = g_strdup_printf("%s (%d)",
- (*feeds)->title,
- (*feeds)->unread);
- else
- title = strdup((*feeds)->title);
+ title = feed_get_formated_title(*feeds);
+ gtk_list_store_append(model, &iter);
- gtk_list_store_append(GTK_LIST_STORE(model), &iter);
-
- gtk_list_store_set(GTK_LIST_STORE(model),
+ gtk_list_store_set(model,
&iter,
COL_FEED_TITLE, title,
COL_FEED_ID, (*feeds)->id,
-1);
- free(title);
+ g_free(title);
feeds++;
}
- model_state = 0;
- feeds = ttrss_get_feeds();
- if (feeds)
- ttrs_download_headline_content(feeds);
+ ttrs_download_headline_content(feeds);
+
+ model_state = 0;
log_debug("update() done");
}
@@ -273,14 +278,37 @@ static struct headline *get_selected_headline(GtkTreeIter *iter)
return NULL;
}
+static char *headline_get_formated_headline(struct headline *h)
+{
+ if (h->unread)
+ return g_strdup_printf("%s", h->title);
+ else
+ return strdup(h->title);
+}
+
+static char *headline_get_date(struct headline *h)
+{
+ struct tm *tmp;
+ char date[200];
+
+ tmp = localtime(&h->date);
+
+ if (h->unread)
+ strftime(date, sizeof(date), "%D", tmp);
+ else
+ strftime(date, sizeof(date), "%D", tmp);
+
+ return strdup(date);
+}
+
int feed_cursor_changed_cbk(GtkTreeView *treeview, gpointer data)
{
GtkTreeIter iter;
GtkTreeModel *headline_model;
GtkListStore *headline_store;
struct feed *feed;
- struct headline **headlines;
- char *title;
+ struct headline **headlines, *h;
+ char *title, *date;
if (model_state)
return TRUE;
@@ -300,22 +328,23 @@ int feed_cursor_changed_cbk(GtkTreeView *treeview, gpointer data)
while (headlines && *headlines) {
gtk_list_store_append(headline_store, &iter);
- if ((*headlines)->unread)
- title = g_strdup_printf
- ("%s",
- (*headlines)->title);
- else
- title = strdup((*headlines)->title);
+ h = *headlines;
+
+ title = headline_get_formated_headline(h);
+ date = headline_get_date(h);
gtk_list_store_set(headline_store,
&iter,
COL_HEADLINE_TITLE,
title,
COL_HEADLINE_ID,
- (*headlines)->id,
+ h->id,
+ COL_HEADLINE_DATE,
+ date,
-1);
- free(title);
+ g_free(title);
+ free(date);
headlines++;
}
@@ -345,7 +374,6 @@ int headline_cursor_changed_cbk(GtkTreeView *treeview, gpointer data)
gtk_label_set_text(w_headline_title, headline->title);
gtk_label_set_text(w_headline_date, ctime(&headline->date));
-
str = ttrss_get_headline_content(headline);
if (str) {