From 10021c40317d0b445e60aa9582bbe337ef0a04a1 Mon Sep 17 00:00:00 2001 From: nyamatongwe Date: Sat, 6 Aug 2005 06:16:59 +0000 Subject: Allow properties to differentiate between different case file names on GTK+ so that .C can be treated as c++ and .c as C. --- src/PropSet.cxx | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/PropSet.cxx b/src/PropSet.cxx index 287934980..b4011a04c 100644 --- a/src/PropSet.cxx +++ b/src/PropSet.cxx @@ -329,6 +329,8 @@ char *SContainer::StringAllocate(const char *s, lenpos_t len) { // End SString functions +bool PropSet::caseSensitiveFilenames = false; + PropSet::PropSet() { superPS = 0; for (int root = 0; root < hashRoots; root++) @@ -536,16 +538,23 @@ bool isprefix(const char *target, const char *prefix) { return true; } -static bool IsSuffixCaseInsensitive(const char *target, const char *suffix) { +static bool IsSuffix(const char *target, const char *suffix, bool caseSensitive) { size_t lentarget = strlen(target); size_t lensuffix = strlen(suffix); if (lensuffix > lentarget) return false; + if (caseSensitive) { + for (int i = static_cast(lensuffix) - 1; i >= 0; i--) { + if (target[i + lentarget - lensuffix] != suffix[i]) + return false; + } + } else { for (int i = static_cast(lensuffix) - 1; i >= 0; i--) { if (MakeUpperCase(target[i + lentarget - lensuffix]) != MakeUpperCase(suffix[i])) return false; } + } return true; } @@ -577,7 +586,7 @@ SString PropSet::GetWild(const char *keybase, const char *filename) { char delchr = *del; *del = '\0'; if (*keyfile == '*') { - if (IsSuffixCaseInsensitive(filename, keyfile + 1)) { + if (IsSuffix(filename, keyfile + 1, caseSensitiveFilenames)) { *del = delchr; delete []keyptr; return p->val; -- cgit v1.2.3