enum {
COL_HEADLINE_TITLE,
- COL_HEADLINE_ID
+ COL_HEADLINE_ID,
+ COL_HEADLINE_DATE
};
static struct option long_options[] = {
GtkTreeView *w_feedtree;
GtkTreeView *w_headlinetree;
+static char *feed_get_formated_title(struct feed *f)
+{
+ if (f->unread)
+ return g_strdup_printf("<b>%s (%d)</b>",
+ f->title,
+ f->unread);
+ else
+ return strdup(f->title);
+}
+
void update()
{
struct feed **feeds;
- GtkTreeModel *model, *headlinemodel;
+ GtkTreeModel *model, *headline_model;
GtkTreeIter iter;
char *title;
model = gtk_tree_view_get_model(GTK_TREE_VIEW(w_feedtree));
+ headline_model = gtk_tree_view_get_model(GTK_TREE_VIEW(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(GTK_LIST_STORE(headline_model));
log_debug("update(): clear feed tree done.");
feeds = ttrss_get_feeds();
while (feeds && *feeds) {
- if ((*feeds)->unread)
- title = g_strdup_printf("<b>%s (%d)</b>",
- (*feeds)->title,
- (*feeds)->unread);
- else
- title = strdup((*feeds)->title);
-
+ title = feed_get_formated_title(*feeds);
gtk_list_store_append(GTK_LIST_STORE(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");
}
return NULL;
}
+static char *headline_get_formated_headline(struct headline *h)
+{
+ if (h->unread)
+ return g_strdup_printf("<b>%s</b>", 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), "<b>%D</b>", 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;
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);
+ 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++;
}
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) {