mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-14 03:23:29 +00:00
Workaround for the problem that $goto only moves the first rss-item by making
it possible to specify the number of spaces you want in front of each rss-item
This commit is contained in:
parent
86b91db305
commit
6bc19d0396
@ -1,3 +1,9 @@
|
|||||||
|
2009-04-19
|
||||||
|
* Make it possible to place spaces in front of RSS-items as a workaround
|
||||||
|
for the problem that $goto only moves the first RSS-item. This is only a
|
||||||
|
workaround and should be replaced by a permanent fix that makes $goto move
|
||||||
|
all RSS-items !
|
||||||
|
|
||||||
2009-04-13
|
2009-04-13
|
||||||
* Fix broken compilation without X11
|
* Fix broken compilation without X11
|
||||||
|
|
||||||
|
@ -1416,8 +1416,8 @@ Runs a command at an interval inside a thread and displays the output. Same as $
|
|||||||
Move text over by N pixels. See also $voffset.
|
Move text over by N pixels. See also $voffset.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fB\*(T<\fBrss\fR\*(T>\fR \*(T<\fBurl delay_in_minutes action item_num\fR\*(T>
|
\fB\*(T<\fBrss\fR\*(T>\fR \*(T<\fBurl delay_in_minutes action (num_par (spaces_in_front))\fR\*(T>
|
||||||
Download and parse RSS feeds. Action may be one of the following: feed_title, item_title (with num par), item_desc (with num par) and item_titles.
|
Download and parse RSS feeds. Action may be one of the following: feed_title, item_title (with num par), item_desc (with num par) and item_titles (when using this action and spaces_in_front is given conky places that many spaces in front of each item).
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
\fB\*(T<\fBtab\fR\*(T>\fR \*(T<\fB(width, (start))\fR\*(T>
|
\fB\*(T<\fBtab\fR\*(T>\fR \*(T<\fB(width, (start))\fR\*(T>
|
||||||
|
@ -2175,10 +2175,10 @@
|
|||||||
<varlistentry>
|
<varlistentry>
|
||||||
<term>
|
<term>
|
||||||
<command><option>rss</option></command>
|
<command><option>rss</option></command>
|
||||||
<option>url delay_in_minutes action item_num</option>
|
<option>url delay_in_minutes action (num_par (spaces_in_front))</option>
|
||||||
</term>
|
</term>
|
||||||
<listitem>
|
<listitem>
|
||||||
Download and parse RSS feeds. Action may be one of the following: feed_title, item_title (with num par), item_desc (with num par) and item_titles.
|
Download and parse RSS feeds. Action may be one of the following: feed_title, item_title (with num par), item_desc (with num par) and item_titles (when using this action and spaces_in_front is given conky places that many spaces in front of each item).
|
||||||
<para></para></listitem>
|
<para></para></listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
14
src/conky.c
14
src/conky.c
@ -2475,20 +2475,22 @@ static struct text_object *construct_text_object(const char *s,
|
|||||||
END OBJ(rss, 0)
|
END OBJ(rss, 0)
|
||||||
if (arg) {
|
if (arg) {
|
||||||
int argc, delay, act_par;
|
int argc, delay, act_par;
|
||||||
|
unsigned int nrspaces = 0;
|
||||||
char *uri = (char *) malloc(128 * sizeof(char));
|
char *uri = (char *) malloc(128 * sizeof(char));
|
||||||
char *action = (char *) malloc(64 * sizeof(char));
|
char *action = (char *) malloc(64 * sizeof(char));
|
||||||
|
|
||||||
argc = sscanf(arg, "%127s %d %63s %d", uri, &delay, action,
|
argc = sscanf(arg, "%127s %d %63s %d %u", uri, &delay, action,
|
||||||
&act_par);
|
&act_par, &nrspaces);
|
||||||
obj->data.rss.uri = uri;
|
obj->data.rss.uri = uri;
|
||||||
obj->data.rss.delay = delay;
|
obj->data.rss.delay = delay;
|
||||||
obj->data.rss.action = action;
|
obj->data.rss.action = action;
|
||||||
obj->data.rss.act_par = act_par;
|
obj->data.rss.act_par = act_par;
|
||||||
|
obj->data.rss.nrspaces = nrspaces;
|
||||||
|
|
||||||
init_rss_info();
|
init_rss_info();
|
||||||
} else {
|
} else {
|
||||||
CRIT_ERR("rss needs arguments: <uri> <delay in minutes> <action> "
|
CRIT_ERR("rss needs arguments: <uri> <delay in minutes> <action> "
|
||||||
"[act_par]");
|
"[act_par] [spaces in front]");
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
#ifdef HDDTEMP
|
#ifdef HDDTEMP
|
||||||
@ -3890,6 +3892,10 @@ static void generate_text_internal(char *p, int p_max_size,
|
|||||||
if (data->item_count > 0) {
|
if (data->item_count > 0) {
|
||||||
int itmp;
|
int itmp;
|
||||||
int show;
|
int show;
|
||||||
|
//'tmpspaces' is a string with spaces too be placed in front of each title
|
||||||
|
char *tmpspaces = malloc(obj->data.rss.nrspaces + 1);
|
||||||
|
memset(tmpspaces, ' ', obj->data.rss.nrspaces);
|
||||||
|
tmpspaces[obj->data.rss.nrspaces]=0;
|
||||||
|
|
||||||
p[0] = 0;
|
p[0] = 0;
|
||||||
|
|
||||||
@ -3912,9 +3918,11 @@ static void generate_text_internal(char *p, int p_max_size,
|
|||||||
if (str[strlen(str) - 1] == '\n') {
|
if (str[strlen(str) - 1] == '\n') {
|
||||||
str[strlen(str) - 1] = 0;
|
str[strlen(str) - 1] = 0;
|
||||||
}
|
}
|
||||||
|
strncat(p, tmpspaces, p_max_size);
|
||||||
strncat(p, str, p_max_size);
|
strncat(p, str, p_max_size);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
free(tmpspaces);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -482,6 +482,7 @@ struct text_object {
|
|||||||
char *action;
|
char *action;
|
||||||
int act_par;
|
int act_par;
|
||||||
int delay;
|
int delay;
|
||||||
|
unsigned int nrspaces;
|
||||||
} rss;
|
} rss;
|
||||||
#endif
|
#endif
|
||||||
struct {
|
struct {
|
||||||
|
Loading…
Reference in New Issue
Block a user