diff options
Diffstat (limited to 'src/blocks')
| -rw-r--r-- | src/blocks/date.c | 1 | ||||
| -rw-r--r-- | src/blocks/fs.c | 1 | ||||
| -rw-r--r-- | src/blocks/ram.c | 1 | ||||
| -rw-r--r-- | src/blocks/script.c | 87 |
4 files changed, 90 insertions, 0 deletions
diff --git a/src/blocks/date.c b/src/blocks/date.c index adb248e..f4dbc72 100644 --- a/src/blocks/date.c +++ b/src/blocks/date.c @@ -44,6 +44,7 @@ static void block_date_clean(block_t *block) { block_date_t *date = (block_date_t *)block; free(date->format); + free(date->block.text); } static bool block_date_validate(block_t *block, const block_scheme_t *scheme) diff --git a/src/blocks/fs.c b/src/blocks/fs.c index 45ea0a3..7cd3bc8 100644 --- a/src/blocks/fs.c +++ b/src/blocks/fs.c @@ -67,6 +67,7 @@ static void block_fs_clean(block_t *block) block_fs_t *fs = (block_fs_t *)block; free(fs->format); free(fs->path); + free(fs->block.text); } static bool block_fs_validate(block_t *block, const block_scheme_t *scheme) diff --git a/src/blocks/ram.c b/src/blocks/ram.c index 158583c..5ea7760 100644 --- a/src/blocks/ram.c +++ b/src/blocks/ram.c @@ -77,6 +77,7 @@ static void block_ram_clean(block_t *block) { block_ram_t *ram = (block_ram_t *)block; free(ram->format); + free(ram->block.text); } static bool block_ram_validate(block_t *block, const block_scheme_t *scheme) diff --git a/src/blocks/script.c b/src/blocks/script.c new file mode 100644 index 0000000..fa3a9d9 --- /dev/null +++ b/src/blocks/script.c @@ -0,0 +1,87 @@ +#include <string.h> +#include <stdio.h> +#include <assert.h> +#include <stdlib.h> + +#include "../block.h" + +#include "../any_log.h" + +typedef struct { + block_text_t block; + char *script; +} block_script_t; + +static const struct timespec block_script_interval = { + .tv_sec = 30, + .tv_nsec = 0, +}; + +static void block_script_update(block_t *block) +{ + block_script_t *script = (block_script_t *)block; + + FILE *output = popen(script->script, "r"); + if (output == NULL) { + log_value_debug("Failed to execute a script", + "s:label", block->label, + "s:script", script->script, + "i:errno", errno); + return; + } + + char buffer[128] = { 0 }; + fgets(buffer, sizeof(buffer), output); + pclose(output); + + log_value_debug("Executed a script", + "s:label", block->label, + "s:script", script->script); + + free(script->block.text); + script->block.text = strcopy(buffer); + assert(script->block.text != NULL); +} + +static block_t *block_script_alloc(const block_scheme_t *scheme) +{ + block_t *block = calloc(1, sizeof(block_script_t)); + block->type = BLOCK_TEXT; + block->update_interval = block_script_interval; + block->update_fn = block_script_update; + return block; +} + +static void block_script_clean(block_t *block) +{ + block_script_t *script = (block_script_t *)block; + free(script->script); + free(script->block.text); +} + +static bool block_script_validate(block_t *block, const block_scheme_t *scheme) +{ + block_script_t *script = (block_script_t *)block; + + if (script->block.text == NULL) { + log_error("Block '%s' requires key '%s'", block->label, "text"); + return false; + } + + script->script = script->block.text; + script->block.text = NULL; + return true; +} + +static const config_entry_t block_script_entries[] = { + { 0 }, +}; + +const block_scheme_t block_script_scheme = { + .name = "script", + .entries = block_script_entries, + .alloc_fn = block_script_alloc, + .clean_fn = block_script_clean, + .validate_fn = block_script_validate, + .resolve_fn = NULL, +}; |
