Hi, Am Freitag, dem 31.05.2024 um 10:56 +0100 schrieb Michael Tremer: > > > > On 20 May 2024, at 10:06, Jonatan Schlag > > wrote: > > > > A line without a = is clearly invalid. > > > > Signed-off-by: Jonatan Schlag > > --- > > src/initscripts/system/functions                            | 6 > > ++++++ > > tests/src/initscripts/system/functions/data/2               | 1 + > > tests/src/initscripts/system/functions/data/2_output_stderr | 1 + > > 3 files changed, 8 insertions(+) > > > > diff --git a/src/initscripts/system/functions > > b/src/initscripts/system/functions > > index bbcfab95d..38a1316a8 100644 > > --- a/src/initscripts/system/functions > > +++ b/src/initscripts/system/functions > > @@ -911,6 +911,12 @@ readhash() { > > continue > > fi > > > > + # Skip lines without a = > > + if ! [[ ${line} =~ [^=]*=[^=]*$ ]]; then > > + echo "Invalid line '${line}'" >&2 > > + continue > > + fi > > + > > local key="${line%=*}" > > local val="${line#*=}" > > You can simply check if key and value have content. That should be a > lot easier than whatever this is. Hi, Unfortunately not. A line like Line_without_a_equal_sign_is_also_invalid result in an entry like this: Key = Line_without_a_equal_sign_is_also_invalid Value = Line_without_a_equal_sign_is_also_invalid We simply do not split without an equal sign, so key and value are equal. And maybe are also valid keys and values. Jonatan > > > > > diff --git a/tests/src/initscripts/system/functions/data/2 > > b/tests/src/initscripts/system/functions/data/2 > > index 3e1a7028b..d1c4d327d 100644 > > --- a/tests/src/initscripts/system/functions/data/2 > > +++ b/tests/src/initscripts/system/functions/data/2 > > @@ -15,6 +15,7 @@ RED_ADDRESS=0.0.0.0 > > RED_NETMASK=0.0.0.0 > > RED_TYPE=PPPOE > > RED_NETADDRESS=0.0.0.0 > > +Line_without_a_equal_sign_is_also_invalid > > > > # Comment for testing  > >     # Comment for testing Comments with spaces before > > diff --git > > a/tests/src/initscripts/system/functions/data/2_output_stderr > > b/tests/src/initscripts/system/functions/data/2_output_stderr > > index dfcf2154b..cccd19af6 100644 > > --- a/tests/src/initscripts/system/functions/data/2_output_stderr > > +++ b/tests/src/initscripts/system/functions/data/2_output_stderr > > @@ -2,3 +2,4 @@ Invalid key '-RED_DEV' > > Invalid key 'RE??D_MACADDR' > > Invalid key 'RED&&_DRIVER' > > Invalid key '0BLUE_DEV' > > +Invalid line 'Line_without_a_equal_sign_is_also_invalid' > > -- > > 2.39.2 > > >