Преглед на файлове

Prettier output from opt scripts (#21707)

Scott Lahteine преди 3 години
родител
ревизия
641bca87bc
No account linked to committer's email address
променени са 3 файла, в които са добавени 19 реда и са изтрити 14 реда
  1. 6
    4
      buildroot/bin/opt_disable
  2. 6
    4
      buildroot/bin/opt_enable
  3. 7
    6
      buildroot/bin/opt_set

+ 6
- 4
buildroot/bin/opt_disable Целия файл

@@ -6,8 +6,10 @@ set -e
6 6
 SED=$(which gsed || which sed)
7 7
 
8 8
 for opt in "$@" ; do
9
-  # Logic for returning nonzero based on answer here: https://stackoverflow.com/a/15966279/104648
10
-  eval "${SED} -i '/\([[:blank:]]*\)\(\/\/\)*\([[:blank:]]*\)\(#define \b${opt}\b\)/{s//\1\3\/\/\4/;h};\${x;/./{x;q0};x;q9}' Marlin/Configuration.h" ||
11
-  eval "${SED} -i '/\([[:blank:]]*\)\(\/\/\)*\([[:blank:]]*\)\(#define \b${opt}\b\)/{s//\1\3\/\/\4/;h};\${x;/./{x;q0};x;q9}' Marlin/Configuration_adv.h" ||
12
-  (echo "ERROR: opt_disable Can't find ${opt}" >&2 && exit 9)
9
+  DID=0 ; FOUND=0
10
+  for FN in Configuration Configuration_adv; do
11
+    "${SED}" -i "/^\(\s*\)\(#define\s\+${opt}\b\s\?\)\(\s\s\)\?/{s//\1\/\/\2/;h};\${x;/./{x;q0};x;q9}" Marlin/$FN.h && DID=1
12
+    ((DID||FOUND)) || { grep -E "^\s*//\s*#define\s+${opt}\b" Marlin/$FN.h >/dev/null && FOUND=1 ; }
13
+  done
14
+  ((DID||FOUND)) || (echo "ERROR: $(basename $0) Can't find ${opt}" >&2 && exit 9)
13 15
 done

+ 6
- 4
buildroot/bin/opt_enable Целия файл

@@ -6,8 +6,10 @@ set -e
6 6
 SED=$(which gsed || which sed)
7 7
 
8 8
 for opt in "$@" ; do
9
-  # Logic for returning nonzero based on answer here: https://stackoverflow.com/a/15966279/104648
10
-  eval "${SED} -i '/^\([[:blank:]]*\/\/\)*[[:blank:]]*\(#define \b${opt}\b\)/{s//\2/;h};\${x;/./{x;q0};x;q9}' Marlin/Configuration.h" ||
11
-  eval "${SED} -i '/^\([[:blank:]]*\/\/\)*[[:blank:]]*\(#define \b${opt}\b\)/{s//\2/;h};\${x;/./{x;q0};x;q9}' Marlin/Configuration_adv.h" ||
12
-  (echo "ERROR: opt_enable Can't find ${opt}" >&2 && exit 9)
9
+  DID=0 ; FOUND=0
10
+  for FN in Configuration Configuration_adv; do
11
+    "${SED}" -i "/^\(\s*\)\/\/\(\s*\)\(#define\s\+${opt}\b\)\( \?\)/{s//\1\2\3\4\4\4/;h};\${x;/./{x;q0};x;q9}" Marlin/$FN.h && DID=1
12
+    ((DID||FOUND)) || { grep -E "^\s*#define\s+${opt}\b" Marlin/$FN.h >/dev/null && FOUND=1 ; }
13
+  done
14
+  ((DID||FOUND)) || (echo "ERROR: $(basename $0) Can't find ${opt}" >&2 && exit 9)
13 15
 done

+ 7
- 6
buildroot/bin/opt_set Целия файл

@@ -5,12 +5,13 @@ set -e
5 5
 
6 6
 SED=$(which gsed || which sed)
7 7
 
8
-ARGC=$#
9 8
 while [[ $# > 1 ]]; do
10
-  # Logic for returning nonzero based on answer here: https://stackoverflow.com/a/15966279/104648
11
-  eval "${SED} -i '/^\([[:blank:]]*\)\(\/\/\)*\([[:blank:]]*\)\(#define\s\+\b${1}\b\).*$/{s//\1\3\4 ${2}/;h};\${x;/./{x;q0};x;q9}' Marlin/Configuration.h" ||
12
-  eval "${SED} -i '/^\([[:blank:]]*\)\(\/\/\)*\([[:blank:]]*\)\(#define\s\+\b${1}\b\).*$/{s//\1\3\4 ${2}/;h};\${x;/./{x;q0};x;q9}' Marlin/Configuration_adv.h" ||
13
-  eval "echo '#define ${1} ${2}' >>Marlin/Configuration.h" ||
14
-  (echo "ERROR: opt_set Can't set or add ${1}" >&2 && exit 9)
9
+  DID=0
10
+  for FN in Configuration Configuration_adv; do
11
+    "${SED}" -i "/^\(\s*\)\/*\s*\(#define\s\+${1}\b\)\(.*\)$/{s//\1\2 ${2} \/\/ \3/;h};\${x;/./{x;q0};x;q9}" Marlin/$FN.h && DID=1
12
+  done
13
+  ((DID)) ||
14
+    eval "echo '#define ${1} ${2}' >>Marlin/Configuration.h" ||
15
+      (echo "ERROR: opt_set Can't set or add ${1}" >&2 && exit 9)
15 16
   shift 2
16 17
 done

Loading…
Отказ
Запис