From 84bf9af758c84da7d9ff2929bce06bf2b2f239b8 Mon Sep 17 00:00:00 2001 From: Dima Zavin Date: Tue, 20 Dec 2011 13:44:41 -0800 Subject: [PATCH] init: use init's property expansion code for setprop/write Change-Id: I3c284860cc8d5106ac2b086e62baeb6263873935 Signed-off-by: Dima Zavin --- init/builtins.c | 44 ++++++++++++++++---------------------------- init/init_parser.c | 2 +- init/init_parser.h | 1 + 3 files changed, 18 insertions(+), 29 deletions(-) diff --git a/init/builtins.c b/init/builtins.c index eccda3f8d..3781dcdc8 100644 --- a/init/builtins.c +++ b/init/builtins.c @@ -31,6 +31,7 @@ #include #include #include +#include #include "init.h" #include "keywords.h" @@ -448,22 +449,15 @@ int do_setprop(int nargs, char **args) { const char *name = args[1]; const char *value = args[2]; + char prop_val[PROP_VALUE_MAX]; + int ret; - if (value[0] == '$') { - /* Use the value of a system property if value starts with '$' */ - value++; - if (value[0] != '$') { - value = property_get(value); - if (!value) { - ERROR("property %s has no value for assigning to %s\n", value, name); - return -EINVAL; - } - } /* else fall through to support double '$' prefix for setting properties - * to string literals that start with '$' - */ + ret = expand_props(prop_val, value, sizeof(prop_val)); + if (ret) { + ERROR("cannot expand '%s' while assigning to '%s'\n", value, name); + return -EINVAL; } - - property_set(name, value); + property_set(name, prop_val); return 0; } @@ -547,21 +541,15 @@ int do_write(int nargs, char **args) { const char *path = args[1]; const char *value = args[2]; - if (value[0] == '$') { - /* Write the value of a system property if value starts with '$' */ - value++; - if (value[0] != '$') { - value = property_get(value); - if (!value) { - ERROR("property %s has no value for writing to %s\n", value, path); - return -EINVAL; - } - } /* else fall through to support double '$' prefix for writing - * string literals that start with '$' - */ - } + char prop_val[PROP_VALUE_MAX]; + int ret; - return write_file(path, value); + ret = expand_props(prop_val, value, sizeof(prop_val)); + if (ret) { + ERROR("cannot expand '%s' while writing to '%s'\n", value, path); + return -EINVAL; + } + return write_file(path, prop_val); } int do_copy(int nargs, char **args) diff --git a/init/init_parser.c b/init/init_parser.c index 311aaeaec..d255db969 100644 --- a/init/init_parser.c +++ b/init/init_parser.c @@ -176,7 +176,7 @@ static int push_chars(char **dst, int *len, const char *chars, int cnt) return 0; } -static int expand_props(char *dst, const char *src, int dst_size) +int expand_props(char *dst, const char *src, int dst_size) { int cnt = 0; char *dst_ptr = dst; diff --git a/init/init_parser.h b/init/init_parser.h index ff13b04f2..b078cadbf 100644 --- a/init/init_parser.h +++ b/init/init_parser.h @@ -31,5 +31,6 @@ void queue_all_property_triggers(); void queue_builtin_action(int (*func)(int nargs, char **args), char *name); int init_parse_config_file(const char *fn); +int expand_props(char *dst, const char *src, int len); #endif