diff options
author | Stephan Bergmann <sbergman@redhat.com> | 2012-03-15 09:34:56 +0100 |
---|---|---|
committer | Stephan Bergmann <sbergman@redhat.com> | 2012-03-15 09:47:29 +0100 |
commit | 84ecea9655267afc266b79059baa4512a285b1f2 (patch) | |
tree | b040fbc785524665226ea4537403e9462b02cd2e /configmgr | |
parent | 32dc82b9d456ed92ba946611239349ab0e424e2a (diff) |
fdo#42961 Don't let env vars interfere with internal bootstrap vars
Diffstat (limited to 'configmgr')
-rw-r--r-- | configmgr/source/components.cxx | 40 |
1 files changed, 31 insertions, 9 deletions
diff --git a/configmgr/source/components.cxx b/configmgr/source/components.cxx index 0e1c7e4571f2..6f1850897c7c 100644 --- a/configmgr/source/components.cxx +++ b/configmgr/source/components.cxx @@ -53,6 +53,7 @@ #include "rtl/oustringostreaminserter.hxx" #include "rtl/ref.hxx" #include "rtl/string.h" +#include "rtl/ustrbuf.hxx" #include "rtl/ustring.h" #include "rtl/ustring.hxx" #include "rtl/instance.hxx" @@ -827,17 +828,38 @@ void Components::parseXcsXcuLayer(int layer, rtl::OUString const & url) { void Components::parseXcsXcuIniLayer( int layer, rtl::OUString const & url, bool recordAdditions) { - //TODO: rtl::Bootstrap::getFrom "first trie[s] to retrieve the value via the - // global function" + // Check if ini file exists (otherwise .override would still read global + // SCHEMA/DATA variables, which could interfere with unrelated environment + // variables): rtl::Bootstrap ini(url); - rtl::OUString urls; - if (ini.getFrom(rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("SCHEMA")), urls)) + if (ini.getHandle() != 0) { - parseFileList(layer, &parseXcsFile, urls, ini, false); - } - if (ini.getFrom(rtl::OUString(RTL_CONSTASCII_USTRINGPARAM("DATA")), urls)) - { - parseFileList(layer + 1, &parseXcuFile, urls, ini, recordAdditions); + rtl::OUStringBuffer prefix("${.override:"); + for (sal_Int32 i = 0; i != url.getLength(); ++i) { + sal_Unicode c = url[i]; + switch (c) { + case '$': + case ':': + case '\\': + prefix.append('\\'); + // fall through + default: + prefix.append(c); + } + } + prefix.append(':'); + rtl::OUString urls(prefix.toString() + rtl::OUString("SCHEMA}")); + rtl::Bootstrap::expandMacros(urls); + if (!urls.isEmpty()) + { + parseFileList(layer, &parseXcsFile, urls, ini, false); + } + urls = prefix.makeStringAndClear() + rtl::OUString("DATA}"); + rtl::Bootstrap::expandMacros(urls); + if (!urls.isEmpty()) + { + parseFileList(layer + 1, &parseXcuFile, urls, ini, recordAdditions); + } } } |