magicvar: Add support for dynamically added magicvars
Add support to add a new magicvar using the magicvar command. This is useful for magicvars assigned and used only in the environment. Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
This commit is contained in:
parent
70e718baa1
commit
fe39e8aadc
|
@ -3,34 +3,118 @@
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
#include <environment.h>
|
#include <environment.h>
|
||||||
#include <magicvar.h>
|
#include <magicvar.h>
|
||||||
|
#include <malloc.h>
|
||||||
|
|
||||||
|
static LIST_HEAD(magicvars);
|
||||||
|
|
||||||
|
struct magicvar_dyn {
|
||||||
|
char *name;
|
||||||
|
char *description;
|
||||||
|
struct list_head list;
|
||||||
|
};
|
||||||
|
|
||||||
|
static void magicvar_print_one(struct magicvar_dyn *md, int verbose)
|
||||||
|
{
|
||||||
|
printf("%-32s %s\n", md->name, md->description);
|
||||||
|
|
||||||
|
if (verbose) {
|
||||||
|
const char *val = getenv(md->name);
|
||||||
|
if (val && strlen(val))
|
||||||
|
printf(" %s\n", val);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
struct magicvar_dyn *magicvar_find(const char *name)
|
||||||
|
{
|
||||||
|
struct magicvar_dyn *md;
|
||||||
|
|
||||||
|
list_for_each_entry(md, &magicvars, list)
|
||||||
|
if (!strcmp(md->name, name))
|
||||||
|
return md;
|
||||||
|
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void magicvar_remove(struct magicvar_dyn *md)
|
||||||
|
{
|
||||||
|
free(md->name);
|
||||||
|
free(md->description);
|
||||||
|
list_del(&md->list);
|
||||||
|
free(md);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int compare(struct list_head *a, struct list_head *b)
|
||||||
|
{
|
||||||
|
char *na = (char*)list_entry(a, struct magicvar_dyn, list)->name;
|
||||||
|
char *nb = (char*)list_entry(b, struct magicvar_dyn, list)->name;
|
||||||
|
|
||||||
|
return strcmp(na, nb);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int magicvar_add(const char *name, const char *description)
|
||||||
|
{
|
||||||
|
struct magicvar_dyn *md;
|
||||||
|
|
||||||
|
md = magicvar_find(name);
|
||||||
|
if (md)
|
||||||
|
magicvar_remove(md);
|
||||||
|
|
||||||
|
md = xzalloc(sizeof(*md));
|
||||||
|
md->name = xstrdup(name);
|
||||||
|
md->description = xstrdup(description);
|
||||||
|
|
||||||
|
list_add_sort(&md->list, &magicvars, compare);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void magicvar_build(void)
|
||||||
|
{
|
||||||
|
static int first = 1;
|
||||||
|
struct magicvar *m;
|
||||||
|
|
||||||
|
if (!first)
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (m = &__barebox_magicvar_start;
|
||||||
|
m != &__barebox_magicvar_end;
|
||||||
|
m++)
|
||||||
|
magicvar_add(m->name, m->description);
|
||||||
|
|
||||||
|
first = 0;
|
||||||
|
}
|
||||||
|
|
||||||
static int do_magicvar(int argc, char *argv[])
|
static int do_magicvar(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
struct magicvar *m;
|
struct magicvar_dyn *md;
|
||||||
int opt;
|
int opt;
|
||||||
int verbose = 0;
|
int verbose = 0, add = 0;
|
||||||
|
|
||||||
while ((opt = getopt(argc, argv, "v")) > 0) {
|
magicvar_build();
|
||||||
|
|
||||||
|
while ((opt = getopt(argc, argv, "va")) > 0) {
|
||||||
switch (opt) {
|
switch (opt) {
|
||||||
case 'v':
|
case 'v':
|
||||||
verbose = 1;
|
verbose = 1;
|
||||||
break;
|
break;
|
||||||
|
case 'a':
|
||||||
|
add = 1;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
return COMMAND_ERROR_USAGE;
|
return COMMAND_ERROR_USAGE;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
for (m = &__barebox_magicvar_start;
|
if (add) {
|
||||||
m != &__barebox_magicvar_end;
|
if (optind + 2 != argc)
|
||||||
m++) {
|
return COMMAND_ERROR_USAGE;
|
||||||
printf("%-32s %s\n", m->name, m->description);
|
|
||||||
if (verbose) {
|
return magicvar_add(argv[optind], argv[optind + 1]);
|
||||||
const char *val = getenv(m->name);
|
|
||||||
if (val && strlen(val))
|
|
||||||
printf(" %s\n", val);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
list_for_each_entry(md, &magicvars, list)
|
||||||
|
magicvar_print_one(md, verbose);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -38,12 +122,13 @@ static int do_magicvar(int argc, char *argv[])
|
||||||
BAREBOX_CMD_HELP_START(magicvar)
|
BAREBOX_CMD_HELP_START(magicvar)
|
||||||
BAREBOX_CMD_HELP_TEXT("Options:")
|
BAREBOX_CMD_HELP_TEXT("Options:")
|
||||||
BAREBOX_CMD_HELP_OPT ("-v", "verbose (list all value if there is one)")
|
BAREBOX_CMD_HELP_OPT ("-v", "verbose (list all value if there is one)")
|
||||||
|
BAREBOX_CMD_HELP_OPT ("-a <NAME> <DESC>", "Add a new magicvar")
|
||||||
BAREBOX_CMD_HELP_END
|
BAREBOX_CMD_HELP_END
|
||||||
|
|
||||||
BAREBOX_CMD_START(magicvar)
|
BAREBOX_CMD_START(magicvar)
|
||||||
.cmd = do_magicvar,
|
.cmd = do_magicvar,
|
||||||
BAREBOX_CMD_DESC("list information about magic variables")
|
BAREBOX_CMD_DESC("list information about magic variables")
|
||||||
BAREBOX_CMD_OPTS("[-v]")
|
BAREBOX_CMD_OPTS("[-va]")
|
||||||
BAREBOX_CMD_HELP(cmd_magicvar_help)
|
BAREBOX_CMD_HELP(cmd_magicvar_help)
|
||||||
BAREBOX_CMD_GROUP(CMD_GRP_ENV)
|
BAREBOX_CMD_GROUP(CMD_GRP_ENV)
|
||||||
BAREBOX_CMD_END
|
BAREBOX_CMD_END
|
||||||
|
|
Loading…
Reference in New Issue