diff options
author | sean <seanlkml@sympatico.ca> | 2006-05-05 09:49:15 -0400 |
---|---|---|
committer | Junio C Hamano <junkio@cox.net> | 2006-05-05 14:33:58 -0700 |
commit | 93ddef3e2dd5f7f3238fad9d52e974d03c7844f2 (patch) | |
tree | 7afb0223c5ca77620f9073c7246ba78362784a7b | |
parent | 7abd7117ec57b8c3c2a469db62c7811fdac5c655 (diff) | |
download | git-93ddef3e2dd5f7f3238fad9d52e974d03c7844f2.tar.gz git-93ddef3e2dd5f7f3238fad9d52e974d03c7844f2.tar.xz |
Fix for config file section parsing.
Currently, if the target key has a section that matches
the initial substring of another section we mistakenly
believe we've found the correct section. To avoid this
problem, ensure that the section lengths are identical
before comparison.
Signed-off-by: Sean Estabrooks <seanlkml@sympatico.ca>
Signed-off-by: Junio C Hamano <junkio@cox.net>
-rw-r--r-- | config.c | 5 |
1 files changed, 3 insertions, 2 deletions
@@ -335,8 +335,9 @@ static int store_aux(const char* key, const char* value) store.offset[store.seen] = ftell(config_file); store.state = KEY_SEEN; store.seen++; - } else if(!strncmp(key, store.key, store.baselen)) - store.state = SECTION_SEEN; + } else if (strrchr(key, '.') - key == store.baselen && + !strncmp(key, store.key, store.baselen)) + store.state = SECTION_SEEN; } return 0; } |