aboutsummaryrefslogtreecommitdiffstats
path: root/package/base-files/files/bin/config_generate
diff options
context:
space:
mode:
authorJo-Philipp Wich <jo@mein.io>2016-05-31 14:47:30 +0200
committerJo-Philipp Wich <jo@mein.io>2016-06-08 00:34:02 +0200
commitb98f78b1c15f1593b508c58fc9a34f90b1e58081 (patch)
treea72ca575dab6a2c6398063589bdf872ab1d19e0d /package/base-files/files/bin/config_generate
parent82768561c4709bab4c278c426fdf5ded14f4d5e8 (diff)
downloadupstream-b98f78b1c15f1593b508c58fc9a34f90b1e58081.tar.gz
upstream-b98f78b1c15f1593b508c58fc9a34f90b1e58081.tar.bz2
upstream-b98f78b1c15f1593b508c58fc9a34f90b1e58081.zip
base-files: rework config generation logic
Now that config_generate is able to generate the entire /etc/config/system from scratch we can apply the same logic as used for /etc/config/network; when the configuration file exists already then do not do anything, else generate it from the values provided by /etc/board.json . In order to facilitate that move the file existance checking inside /bin/config_generate and call it unconditionally from /bin/board_detect. Signed-off-by: Jo-Philipp Wich <jo@mein.io>
Diffstat (limited to 'package/base-files/files/bin/config_generate')
-rwxr-xr-xpackage/base-files/files/bin/config_generate32
1 files changed, 18 insertions, 14 deletions
diff --git a/package/base-files/files/bin/config_generate b/package/base-files/files/bin/config_generate
index 428c6bd9de..fe5fa85c87 100755
--- a/package/base-files/files/bin/config_generate
+++ b/package/base-files/files/bin/config_generate
@@ -5,6 +5,7 @@ CFG=/etc/board.json
. /usr/share/libubox/jshn.sh
[ -f $CFG ] || exit 1
+[ -f /etc/config/network -a -f /etc/config/system ] && exit 0
generate_static_network() {
uci -q batch <<-EOF
@@ -398,24 +399,27 @@ generate_gpioswitch() {
json_init
json_load "$(cat ${CFG})"
-generate_static_network
+if [ ! -f /etc/config/network ]; then
+ touch /etc/config/network
+ generate_static_network
-json_get_keys keys network
-for key in $keys; do generate_network $key; done
+ json_get_keys keys network
+ for key in $keys; do generate_network $key; done
-json_get_keys keys switch
-for key in $keys; do generate_switch $key; done
+ json_get_keys keys switch
+ for key in $keys; do generate_switch $key; done
+fi
+if [ ! -f /etc/config/system ]; then
+ touch /etc/config/system
+ generate_static_system
-generate_static_system
+ json_get_keys keys rssimon
+ for key in $keys; do generate_rssimon $key; done
-json_get_keys keys rssimon
-for key in $keys; do generate_rssimon $key; done
-
-json_get_keys keys gpioswitch
-for key in $keys; do generate_gpioswitch $key; done
-
-json_get_keys keys led
-for key in $keys; do generate_led $key; done
+ json_get_keys keys gpioswitch
+ for key in $keys; do generate_gpioswitch $key; done
+ json_get_keys keys led
+ for key in $keys; do generate_led $key; done
uci commit