mirror of
https://github.com/FirebirdSQL/firebird.git
synced 2025-01-23 22:43:04 +01:00
Make all configuration files case-sensitive
This commit is contained in:
parent
d8938efea2
commit
e344287aa0
@ -32,9 +32,6 @@
|
|||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// config_file works with OS case-sensitivity
|
|
||||||
typedef Firebird::PathName String;
|
|
||||||
|
|
||||||
namespace {
|
namespace {
|
||||||
|
|
||||||
/******************************************************************************
|
/******************************************************************************
|
||||||
@ -222,7 +219,7 @@ void Config::loadValues(const ConfigFile& file)
|
|||||||
for (int i = 0; i < MAX_CONFIG_KEY; i++)
|
for (int i = 0; i < MAX_CONFIG_KEY; i++)
|
||||||
{
|
{
|
||||||
const ConfigEntry& entry = entries[i];
|
const ConfigEntry& entry = entries[i];
|
||||||
const String value = getValue(file, entry.key);
|
const ConfigFile::String value = getValue(file, entry.key);
|
||||||
|
|
||||||
if (value.length())
|
if (value.length())
|
||||||
{
|
{
|
||||||
@ -274,23 +271,23 @@ Config::~Config()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
String Config::getValue(const ConfigFile& file, ConfigName key)
|
ConfigFile::String Config::getValue(const ConfigFile& file, ConfigName key)
|
||||||
{
|
{
|
||||||
const ConfigFile::Parameter* p = file.findParameter(key);
|
const ConfigFile::Parameter* p = file.findParameter(key);
|
||||||
return p ? p->value : "";
|
return p ? p->value : "";
|
||||||
}
|
}
|
||||||
|
|
||||||
int Config::asInteger(const String &value)
|
int Config::asInteger(const ConfigFile::String &value)
|
||||||
{
|
{
|
||||||
return atoi(value.data());
|
return atoi(value.data());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool Config::asBoolean(const String &value)
|
bool Config::asBoolean(const ConfigFile::String &value)
|
||||||
{
|
{
|
||||||
return (atoi(value.data()) != 0);
|
return (atoi(value.data()) != 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* Config::asString(const String &value)
|
const char* Config::asString(const ConfigFile::String &value)
|
||||||
{
|
{
|
||||||
return value.c_str();
|
return value.c_str();
|
||||||
}
|
}
|
||||||
|
@ -26,6 +26,7 @@
|
|||||||
#include "../common/classes/alloc.h"
|
#include "../common/classes/alloc.h"
|
||||||
#include "../common/classes/fb_string.h"
|
#include "../common/classes/fb_string.h"
|
||||||
#include "../common/classes/RefCounted.h"
|
#include "../common/classes/RefCounted.h"
|
||||||
|
#include "../common/config/config_file.h"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Since the original (isc.cpp) code wasn't able to provide powerful and
|
Since the original (isc.cpp) code wasn't able to provide powerful and
|
||||||
@ -74,8 +75,6 @@ extern const char* AmMixed;
|
|||||||
|
|
||||||
enum AmCache {AM_UNKNOWN, AM_DISABLED, AM_ENABLED};
|
enum AmCache {AM_UNKNOWN, AM_DISABLED, AM_ENABLED};
|
||||||
|
|
||||||
class ConfigFile;
|
|
||||||
|
|
||||||
class Config : public Firebird::RefCounted, public Firebird::GlobalStorage
|
class Config : public Firebird::RefCounted, public Firebird::GlobalStorage
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -150,11 +149,11 @@ private:
|
|||||||
ConfigValue default_value;
|
ConfigValue default_value;
|
||||||
};
|
};
|
||||||
|
|
||||||
static Firebird::PathName getValue(const ConfigFile&, ConfigName);
|
static ConfigFile::String getValue(const ConfigFile&, ConfigName);
|
||||||
|
|
||||||
static int asInteger(const Firebird::PathName&);
|
static int asInteger(const ConfigFile::String&);
|
||||||
static bool asBoolean(const Firebird::PathName&);
|
static bool asBoolean(const ConfigFile::String&);
|
||||||
static const char* asString(const Firebird::PathName&);
|
static const char* asString(const ConfigFile::String&);
|
||||||
|
|
||||||
void loadValues(const ConfigFile& file);
|
void loadValues(const ConfigFile& file);
|
||||||
|
|
||||||
|
@ -166,7 +166,7 @@ private:
|
|||||||
} // anonymous namespace
|
} // anonymous namespace
|
||||||
|
|
||||||
|
|
||||||
ConfigFile::ConfigFile(const ConfigFile::String& file, USHORT fl)
|
ConfigFile::ConfigFile(const Firebird::PathName& file, USHORT fl)
|
||||||
: AutoStorage(), configFile(getPool(), file), parameters(getPool()), flags(fl)
|
: AutoStorage(), configFile(getPool(), file), parameters(getPool()), flags(fl)
|
||||||
{
|
{
|
||||||
MainStream s(configFile.c_str(), flags & EXCEPTION_ON_ERROR);
|
MainStream s(configFile.c_str(), flags & EXCEPTION_ON_ERROR);
|
||||||
@ -334,8 +334,9 @@ bool ConfigFile::translate(const String& from, String& to)
|
|||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
PathName file;
|
PathName path, file;
|
||||||
PathUtils::splitLastComponent(to, file, configFile);
|
PathUtils::splitLastComponent(path, file, configFile.ToPathName());
|
||||||
|
to = path.ToString();
|
||||||
}
|
}
|
||||||
/* else if (!substituteOneOfStandardFirebirdDirs(from, to))
|
/* else if (!substituteOneOfStandardFirebirdDirs(from, to))
|
||||||
{
|
{
|
||||||
|
@ -57,8 +57,8 @@ public:
|
|||||||
// enum to distinguish ctors
|
// enum to distinguish ctors
|
||||||
enum UseText {USE_TEXT};
|
enum UseText {USE_TEXT};
|
||||||
|
|
||||||
// config_file works with OS case-sensitivity
|
// config_file is always OS case sensitive
|
||||||
typedef Firebird::PathName String;
|
typedef Firebird::string String;
|
||||||
|
|
||||||
class Stream
|
class Stream
|
||||||
{
|
{
|
||||||
@ -91,7 +91,7 @@ public:
|
|||||||
typedef Firebird::SortedObjectsArray<Parameter, Firebird::InlineStorage<Parameter*, 100>,
|
typedef Firebird::SortedObjectsArray<Parameter, Firebird::InlineStorage<Parameter*, 100>,
|
||||||
String, Parameter> Parameters;
|
String, Parameter> Parameters;
|
||||||
|
|
||||||
ConfigFile(const String& file, USHORT fl);
|
ConfigFile(const Firebird::PathName& file, USHORT fl);
|
||||||
ConfigFile(const char* file, USHORT fl);
|
ConfigFile(const char* file, USHORT fl);
|
||||||
ConfigFile(UseText, const char* configText, USHORT fl);
|
ConfigFile(UseText, const char* configText, USHORT fl);
|
||||||
|
|
||||||
|
@ -363,7 +363,7 @@ void* FB_CALL ExtEngineManager::ExternalContextImpl::setInfo(int code, void* val
|
|||||||
//---------------------
|
//---------------------
|
||||||
|
|
||||||
|
|
||||||
static InitInstance<GenericMap<Pair<Full<MetaName, PathName> > > > enginesModules;
|
static InitInstance<GenericMap<Pair<Full<MetaName, ConfigFile::String> > > > enginesModules;
|
||||||
|
|
||||||
|
|
||||||
//---------------------
|
//---------------------
|
||||||
@ -888,7 +888,7 @@ ExternalEngine* ExtEngineManager::getEngine(thread_db* tdbb, const MetaName& nam
|
|||||||
|
|
||||||
if (!engines.get(name, engine))
|
if (!engines.get(name, engine))
|
||||||
{
|
{
|
||||||
PathName pluginName;
|
ConfigFile::String pluginName;
|
||||||
if (enginesModules().get(name, pluginName))
|
if (enginesModules().get(name, pluginName))
|
||||||
{
|
{
|
||||||
PluginImpl* plugin = PluginManager::getPlugin(pluginName);
|
PluginImpl* plugin = PluginManager::getPlugin(pluginName);
|
||||||
|
@ -468,7 +468,7 @@ bool IntlManager::initialize()
|
|||||||
{
|
{
|
||||||
fatal_exception::raiseFmt("Missing parameter 'filename' for intl_module %s\n", module->value.c_str());
|
fatal_exception::raiseFmt("Missing parameter 'filename' for intl_module %s\n", module->value.c_str());
|
||||||
}
|
}
|
||||||
filename = fname->value;
|
filename = fname->value.ToPathName();
|
||||||
configInfo = getConfigInfo(objModule);
|
configInfo = getConfigInfo(objModule);
|
||||||
|
|
||||||
if (!modules->exist(filename))
|
if (!modules->exist(filename))
|
||||||
|
@ -43,11 +43,11 @@ namespace Jrd {
|
|||||||
|
|
||||||
namespace
|
namespace
|
||||||
{
|
{
|
||||||
class PluginsMap : public GenericMap<Pair<Left<PathName, PluginImpl*> > >
|
class PluginsMap : public GenericMap<Pair<Left<ConfigFile::String, PluginImpl*> > >
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
explicit PluginsMap(MemoryPool& p)
|
explicit PluginsMap(MemoryPool& p)
|
||||||
: GenericMap<Pair<Left<PathName, PluginImpl*> > >(p)
|
: GenericMap<Pair<Left<ConfigFile::String, PluginImpl*> > >(p)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -127,7 +127,7 @@ void PluginManager::initialize()
|
|||||||
plugin->name.c_str());
|
plugin->name.c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
plugin->filename = par->value;
|
plugin->filename = par->value.ToPathName();
|
||||||
|
|
||||||
par = pm->sub->findParameter("plugin_config");
|
par = pm->sub->findParameter("plugin_config");
|
||||||
if (par)
|
if (par)
|
||||||
@ -172,7 +172,7 @@ PathName PluginManager::getPluginsDirectory()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
PluginImpl* PluginManager::getPlugin(const PathName& name)
|
PluginImpl* PluginManager::getPlugin(const ConfigFile::String& name)
|
||||||
{
|
{
|
||||||
PluginImpl* plugin;
|
PluginImpl* plugin;
|
||||||
|
|
||||||
|
@ -33,11 +33,12 @@
|
|||||||
#include "../common/classes/MetaName.h"
|
#include "../common/classes/MetaName.h"
|
||||||
#include "../common/classes/objects_array.h"
|
#include "../common/classes/objects_array.h"
|
||||||
#include "../common/classes/rwlock.h"
|
#include "../common/classes/rwlock.h"
|
||||||
|
#include "../common/config/config_file.h"
|
||||||
|
|
||||||
namespace Jrd {
|
namespace Jrd {
|
||||||
|
|
||||||
|
|
||||||
typedef Firebird::Pair<Firebird::Full<Firebird::PathName, Firebird::PathName> > ConfigEntry;
|
typedef Firebird::Pair<Firebird::Full<ConfigFile::String, ConfigFile::String> > ConfigEntry;
|
||||||
|
|
||||||
class PluginImpl : public Firebird::Plugin, public Firebird::GlobalStorage
|
class PluginImpl : public Firebird::Plugin, public Firebird::GlobalStorage
|
||||||
{
|
{
|
||||||
@ -66,12 +67,12 @@ public:
|
|||||||
Firebird::ExternalEngineFactory* getExternalEngineFactory();
|
Firebird::ExternalEngineFactory* getExternalEngineFactory();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
Firebird::PathName name;
|
ConfigFile::String name;
|
||||||
Firebird::PathName filename;
|
Firebird::PathName filename;
|
||||||
Firebird::SortedObjectsArray<
|
Firebird::SortedObjectsArray<
|
||||||
ConfigEntry,
|
ConfigEntry,
|
||||||
Firebird::EmptyStorage<ConfigEntry*>,
|
Firebird::EmptyStorage<ConfigEntry*>,
|
||||||
Firebird::PathName, Firebird::FirstPointerKey<ConfigEntry>
|
ConfigFile::String, Firebird::FirstPointerKey<ConfigEntry>
|
||||||
> configInfo;
|
> configInfo;
|
||||||
Firebird::AutoPtr<ModuleLoader::Module> module;
|
Firebird::AutoPtr<ModuleLoader::Module> module;
|
||||||
Firebird::ExternalEngineFactory* externalEngineFactory;
|
Firebird::ExternalEngineFactory* externalEngineFactory;
|
||||||
@ -83,7 +84,7 @@ class PluginManager
|
|||||||
public:
|
public:
|
||||||
static void initialize();
|
static void initialize();
|
||||||
static Firebird::PathName getPluginsDirectory();
|
static Firebird::PathName getPluginsDirectory();
|
||||||
static PluginImpl* getPlugin(const Firebird::PathName& name);
|
static PluginImpl* getPlugin(const ConfigFile::String& name);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
@ -84,7 +84,8 @@ namespace
|
|||||||
|
|
||||||
static void upcpy(size_t* toPar, const char* from, size_t length)
|
static void upcpy(size_t* toPar, const char* from, size_t length)
|
||||||
{
|
{
|
||||||
char* to = reinterpret_cast<char*>(toPar);
|
memcpy(toPar, from, length);
|
||||||
|
/* char* to = reinterpret_cast<char*>(toPar);
|
||||||
while (length--)
|
while (length--)
|
||||||
{
|
{
|
||||||
if (CASE_SENSITIVITY)
|
if (CASE_SENSITIVITY)
|
||||||
@ -96,6 +97,7 @@ namespace
|
|||||||
*to++ = toupper(*from++);
|
*to++ = toupper(*from++);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
*/
|
||||||
}
|
}
|
||||||
|
|
||||||
static size_t hash(const char* value, size_t length, size_t hashSize)
|
static size_t hash(const char* value, size_t length, size_t hashSize)
|
||||||
@ -205,7 +207,7 @@ namespace
|
|||||||
{
|
{
|
||||||
const ConfigFile::Parameter* par = ¶ms[n];
|
const ConfigFile::Parameter* par = ¶ms[n];
|
||||||
|
|
||||||
PathName file(par->value);
|
PathName file(par->value.ToPathName());
|
||||||
replace_dir_sep(file);
|
replace_dir_sep(file);
|
||||||
if (PathUtils::isRelative(file))
|
if (PathUtils::isRelative(file))
|
||||||
{
|
{
|
||||||
@ -236,7 +238,7 @@ namespace
|
|||||||
db->config = new Config(*par->sub, *Config::getDefaultConfig());
|
db->config = new Config(*par->sub, *Config::getDefaultConfig());
|
||||||
}
|
}
|
||||||
|
|
||||||
PathName correctedAlias(par->name);
|
PathName correctedAlias(par->name.ToPathName());
|
||||||
AliasName* alias = aliasHash.lookup(correctedAlias);
|
AliasName* alias = aliasHash.lookup(correctedAlias);
|
||||||
if (alias)
|
if (alias)
|
||||||
{
|
{
|
||||||
|
@ -47,7 +47,7 @@ void TraceCfgReader::readTraceConfiguration(const char* text,
|
|||||||
|
|
||||||
#define PATH_PARAMETER(NAME, VALUE) \
|
#define PATH_PARAMETER(NAME, VALUE) \
|
||||||
if (!found && el->name == #NAME) { \
|
if (!found && el->name == #NAME) { \
|
||||||
ConfigFile::String temp; \
|
Firebird::PathName temp; \
|
||||||
expandPattern(el, temp); \
|
expandPattern(el, temp); \
|
||||||
m_config.NAME = temp.c_str(); \
|
m_config.NAME = temp.c_str(); \
|
||||||
found = true; \
|
found = true; \
|
||||||
@ -273,10 +273,10 @@ ULONG TraceCfgReader::parseUInteger(const ConfigFile::Parameter* el) const
|
|||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TraceCfgReader::expandPattern(const ConfigFile::Parameter* el, ConfigFile::String& valueToExpand)
|
void TraceCfgReader::expandPattern(const ConfigFile::Parameter* el, PathName& valueToExpand)
|
||||||
{
|
{
|
||||||
valueToExpand = el->value;
|
valueToExpand = el->value.ToPathName();
|
||||||
string::size_type pos = 0;
|
PathName::size_type pos = 0;
|
||||||
while (pos < valueToExpand.length())
|
while (pos < valueToExpand.length())
|
||||||
{
|
{
|
||||||
string::char_type c = valueToExpand[pos];
|
string::char_type c = valueToExpand[pos];
|
||||||
|
@ -28,7 +28,8 @@
|
|||||||
#ifndef TRACEPLUGINCONFIG_H
|
#ifndef TRACEPLUGINCONFIG_H
|
||||||
#define TRACEPLUGINCONFIG_H
|
#define TRACEPLUGINCONFIG_H
|
||||||
|
|
||||||
#include "../../common/classes/fb_string.h"
|
#include "../common/classes/fb_string.h"
|
||||||
|
#include "../common/config/config_file.h"
|
||||||
|
|
||||||
//enum LogFormat { lfText = 0, lfBinary = 1 };
|
//enum LogFormat { lfText = 0, lfBinary = 1 };
|
||||||
|
|
||||||
@ -38,7 +39,7 @@ struct TracePluginConfig
|
|||||||
#define SERVICE_PARAMS
|
#define SERVICE_PARAMS
|
||||||
|
|
||||||
#define PATH_PARAMETER(NAME, VALUE) Firebird::PathName NAME;
|
#define PATH_PARAMETER(NAME, VALUE) Firebird::PathName NAME;
|
||||||
#define STR_PARAMETER(NAME, VALUE) Firebird::PathName NAME;
|
#define STR_PARAMETER(NAME, VALUE) ConfigFile::String NAME;
|
||||||
#define BOOL_PARAMETER(NAME, VALUE) bool NAME;
|
#define BOOL_PARAMETER(NAME, VALUE) bool NAME;
|
||||||
#define UINT_PARAMETER(NAME, VALUE) ULONG NAME;
|
#define UINT_PARAMETER(NAME, VALUE) ULONG NAME;
|
||||||
#include "paramtable.h"
|
#include "paramtable.h"
|
||||||
|
Loading…
Reference in New Issue
Block a user