mirror of
https://github.com/Llewellynvdm/conky.git
synced 2025-01-14 19:39:47 +00:00
Add --for-scripts support
This commit is contained in:
parent
0627946ca1
commit
99b5352cff
@ -106,6 +106,19 @@
|
|||||||
<listitem>Create own window to draw
|
<listitem>Create own window to draw
|
||||||
<para></para></listitem>
|
<para></para></listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
<varlistentry>
|
||||||
|
<term>
|
||||||
|
<command>
|
||||||
|
<option>-s | --for-scripts</option>
|
||||||
|
</command>
|
||||||
|
<option>TEXT</option>
|
||||||
|
</term>
|
||||||
|
<listitem>Prints TEXT on the standard output and exits.
|
||||||
|
(This option makes conky useful in scripts)
|
||||||
|
TEXT has to be enclosed by single quotes. Example:
|
||||||
|
conky -s 'Your uptime is: $uptime'
|
||||||
|
<para></para></listitem>
|
||||||
|
</varlistentry>
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
<term>
|
<term>
|
||||||
<command>
|
<command>
|
||||||
|
31
src/conky.cc
31
src/conky.cc
@ -3944,6 +3944,7 @@ static void print_help(const char *prog_name) {
|
|||||||
" -x X x position\n"
|
" -x X x position\n"
|
||||||
" -y Y y position\n"
|
" -y Y y position\n"
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
|
" -s, --for-scripts=TEXT render TEXT on stdout and exit, enclose TEXT by single quotes\n"
|
||||||
" -t, --text=TEXT text to render, remember single quotes, like -t '$uptime'\n"
|
" -t, --text=TEXT text to render, remember single quotes, like -t '$uptime'\n"
|
||||||
" -u, --interval=SECS update interval\n"
|
" -u, --interval=SECS update interval\n"
|
||||||
" -i COUNT number of times to update "PACKAGE_NAME" (and quit)\n"
|
" -i COUNT number of times to update "PACKAGE_NAME" (and quit)\n"
|
||||||
@ -3953,7 +3954,7 @@ static void print_help(const char *prog_name) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* : means that character before that takes an argument */
|
/* : means that character before that takes an argument */
|
||||||
static const char *getopt_string = "vVqdDt:u:i:hc:p:"
|
static const char *getopt_string = "vVqdDs:t:u:i:hc:p:"
|
||||||
#ifdef BUILD_X11
|
#ifdef BUILD_X11
|
||||||
"x:y:w:a:f:X:"
|
"x:y:w:a:f:X:"
|
||||||
#ifdef OWN_WINDOW
|
#ifdef OWN_WINDOW
|
||||||
@ -3989,6 +3990,7 @@ static const struct option longopts[] = {
|
|||||||
#endif
|
#endif
|
||||||
{ "window-id", 1, NULL, 'w' },
|
{ "window-id", 1, NULL, 'w' },
|
||||||
#endif /* BUILD_X11 */
|
#endif /* BUILD_X11 */
|
||||||
|
{ "for-scripts", 1, NULL, 's' },
|
||||||
{ "text", 1, NULL, 't' },
|
{ "text", 1, NULL, 't' },
|
||||||
{ "interval", 0, NULL, 'u' },
|
{ "interval", 0, NULL, 'u' },
|
||||||
{ "pause", 0, NULL, 'p' },
|
{ "pause", 0, NULL, 'p' },
|
||||||
@ -3997,10 +3999,37 @@ static const struct option longopts[] = {
|
|||||||
|
|
||||||
void initialisation(int argc, char **argv) {
|
void initialisation(int argc, char **argv) {
|
||||||
struct sigaction act, oact;
|
struct sigaction act, oact;
|
||||||
|
bool for_scripts = false;
|
||||||
|
|
||||||
set_default_configurations();
|
set_default_configurations();
|
||||||
|
#if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__OpenBSD__) \
|
||||||
|
|| defined(__NetBSD__)
|
||||||
|
optind = optreset = 1;
|
||||||
|
#else
|
||||||
|
optind = 0;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
while (1) {
|
||||||
|
int c = getopt_long(argc, argv, getopt_string, longopts, NULL);
|
||||||
|
|
||||||
|
if (c == -1) {
|
||||||
|
break;
|
||||||
|
}else if (c == 's') {
|
||||||
|
if (global_text) {
|
||||||
|
free(global_text);
|
||||||
|
global_text = 0;
|
||||||
|
}
|
||||||
|
global_text = strndup(optarg, max_user_text);
|
||||||
|
convert_escapes(global_text);
|
||||||
|
total_run_times = 1;
|
||||||
|
output_methods = TO_STDOUT;
|
||||||
|
for_scripts = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if(for_scripts == false) {
|
||||||
load_config_file(current_config);
|
load_config_file(current_config);
|
||||||
currentconffile = conftree_add(currentconffile, current_config);
|
currentconffile = conftree_add(currentconffile, current_config);
|
||||||
|
}
|
||||||
|
|
||||||
/* init specials array */
|
/* init specials array */
|
||||||
if ((specials = (special_t*)calloc(sizeof(struct special_t), max_specials)) == 0) {
|
if ((specials = (special_t*)calloc(sizeof(struct special_t), max_specials)) == 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user