#
# Authors:
# - Przemysław Iskra <sparky@pld-linux.org>
+# parts based on kernel-config.py, by:
+# - arekm@pld-linux.org
+# - glen@pld-linux.org
#
# TODO:
# - smarter arch split, there could be strings with spaces
# - use as many warnings as possible, we want our configs to be clean
# no:
-# CONFIG_SOMETHING=n -- should warn
-# SOMETHING=n -- should warn
-# CONFIG_SOMETHING all=n -- should warn
+# CONFIG_SOMETHING=n
+# SOMETHING=n
+# CONFIG_SOMETHING all=n
# SOMETHING all=n
-# # CONFIG_SOMETHING is not set -- special case
+# # CONFIG_SOMETHING is not set -- special case
# yes/module/other
# CONFIG_SOMETHING=y
-# SOMETHING=y -- should warn
-# CONFIG_SOMETHING all=y -- should warn
+# SOMETHING=y
+# CONFIG_SOMETHING all=y
# SOMETHING all=y
# return actual file name (without path) and line number
function fileLine() {
f = FILENAME
- gsub( /^.*\//, "", f ) # strip path
+ sub( /^.*\//, "", f ) # strip path
return f " (" FNR ")"
}
# # CONFIG_SOMETHING it not set
# to:
# SOMETHING all=n
-/^# CONFIG_[A-Za-z0-9_-]+ is not set$/ {
- match( $0, /CONFIG_[A-Za-z0-9_-]+/ )
+/^# CONFIG_[A-Za-z0-9_]+ is not set$/ {
+ match( $0, /CONFIG_[A-Za-z0-9_]+/ )
option = substr( $0, RSTART, RLENGTH)
$0 = option " all=n"
}
-# ignore all the comments
+# ignore all the comments and empty lines
/^#/ || /^\s*$/ {
next
}
line = $0
value = ""
if ( option ~ /=/ ) {
- gsub( /=.*$/, "", option )
- gsub( /^[^=]*=/, "", line )
+ sub( /=.*$/, "", option )
+ sub( /^[^=]*=/, "", line )
value = line
} else {
- gsub( "^" option IFS, "", line )
- split( line, archs )
+ sub( "^" option, "", line )
+ sub( /^[ \t]*/, "", line )
+
+ if ( line ~ /"/ ) {
+ # there can be white spaces
+ i = 0
+ while ( match( line, /^[^=]+="[^"]*"/ ) ) {
+ archs[ (++i) ] = substr( line, RSTART, RLENGTH )
+ line = substr( line, RSTART + RLENGTH )
+ sub( /^[ \t]*/, "", line )
+ }
+ } else {
+ split( line, archs )
+ }
for ( i in archs ) {
split( archs[i], opt, "=" );
if ( opt[1] == "all" )
out = option "=" value
if ( value == "y" || value == "m" )
- ;
+ ; # OK
else if ( value ~ /^"[^"]*"$/ )
- ;
+ ; # OK
else if ( value ~ /^-?[0-9]+$/ || value ~ /^0x[0-9A-Fa-f]+$/ )
- ;
+ ; # OK
else {
warn( "ERROR: Incorrect value: " $0 )
dieLater( 1 )