Started implementing ability to load custom config files (currently unstable).
Feel free to help out with this if you like :)
This commit is contained in:
parent
f4de000646
commit
61059e66ec
2
init.lua
2
init.lua
|
@ -28,7 +28,7 @@ g_resources.setupUserWriteDir(g_app.getCompactName())
|
||||||
g_resources.searchAndAddPackages('/', '.otpkg', true)
|
g_resources.searchAndAddPackages('/', '.otpkg', true)
|
||||||
|
|
||||||
-- load configurations
|
-- load configurations
|
||||||
g_configs.load("/config.otml")
|
g_configs.loadSettings("/config.otml")
|
||||||
|
|
||||||
g_modules.discoverModules()
|
g_modules.discoverModules()
|
||||||
|
|
||||||
|
|
|
@ -91,9 +91,9 @@ function init()
|
||||||
g_keyboard.bindKeyDown('Ctrl+Shift+R', reloadScripts)
|
g_keyboard.bindKeyDown('Ctrl+Shift+R', reloadScripts)
|
||||||
|
|
||||||
-- generate machine uuid, this is a security measure for storing passwords
|
-- generate machine uuid, this is a security measure for storing passwords
|
||||||
if not g_crypt.setMachineUUID(g_configs.get('uuid')) then
|
if not g_crypt.setMachineUUID(g_settings.get('uuid')) then
|
||||||
g_configs.set('uuid', g_crypt.getMachineUUID())
|
g_settings.set('uuid', g_crypt.getMachineUUID())
|
||||||
g_configs.save()
|
g_settings.save()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,8 @@ function init()
|
||||||
g_keyboard.bindKeyPress('Up', function() moduleList:focusPreviousChild(KeyboardFocusReason) end, moduleManagerWindow)
|
g_keyboard.bindKeyPress('Up', function() moduleList:focusPreviousChild(KeyboardFocusReason) end, moduleManagerWindow)
|
||||||
g_keyboard.bindKeyPress('Down', function() moduleList:focusNextChild(KeyboardFocusReason) end, moduleManagerWindow)
|
g_keyboard.bindKeyPress('Down', function() moduleList:focusNextChild(KeyboardFocusReason) end, moduleManagerWindow)
|
||||||
|
|
||||||
moduleManagerButton = modules.client_topmenu.addLeftButton('moduleManagerButton', tr('Module Manager'), '/images/topbuttons/modulemanager', toggle)
|
moduleManagerButton = modules.client_topmenu.addLeftButton('moduleManagerButton',
|
||||||
|
tr('Module Manager'), '/images/topbuttons/modulemanager', toggle)
|
||||||
|
|
||||||
-- refresh modules only after all modules are loaded
|
-- refresh modules only after all modules are loaded
|
||||||
addEvent(listModules)
|
addEvent(listModules)
|
||||||
|
|
|
@ -1,14 +1,5 @@
|
||||||
-- @docclass
|
-- @docclass
|
||||||
g_settings = {}
|
g_settings = g_configs.getSettings()
|
||||||
|
|
||||||
g_settings.exists = g_configs.exists
|
|
||||||
g_settings.setNode = g_configs.setNode
|
|
||||||
g_settings.mergeNode = g_configs.mergeNode
|
|
||||||
g_settings.getNode = g_configs.getNode
|
|
||||||
g_settings.remove = g_configs.remove
|
|
||||||
g_settings.setList = g_configs.setList
|
|
||||||
g_settings.getList = g_configs.getList
|
|
||||||
g_settings.save = g_configs.save
|
|
||||||
|
|
||||||
local function convertSettingValue(value)
|
local function convertSettingValue(value)
|
||||||
if type(value) == 'table' then
|
if type(value) == 'table' then
|
||||||
|
@ -31,7 +22,7 @@ local function convertSettingValue(value)
|
||||||
end
|
end
|
||||||
|
|
||||||
function g_settings.set(key, value)
|
function g_settings.set(key, value)
|
||||||
g_configs.set(key, convertSettingValue(value))
|
g_settings.set(key, convertSettingValue(value))
|
||||||
end
|
end
|
||||||
|
|
||||||
function g_settings.setDefault(key, value)
|
function g_settings.setDefault(key, value)
|
||||||
|
@ -41,10 +32,11 @@ function g_settings.setDefault(key, value)
|
||||||
end
|
end
|
||||||
|
|
||||||
function g_settings.get(key, default)
|
function g_settings.get(key, default)
|
||||||
|
print(g_settings.exists)
|
||||||
if not g_settings.exists(key) and default ~= nil then
|
if not g_settings.exists(key) and default ~= nil then
|
||||||
g_settings.set(key, default)
|
g_settings.set(key, default)
|
||||||
end
|
end
|
||||||
return g_configs.get(key)
|
return g_settings.get(key)
|
||||||
end
|
end
|
||||||
|
|
||||||
function g_settings.getString(key, default)
|
function g_settings.getString(key, default)
|
||||||
|
|
|
@ -284,6 +284,10 @@ function numbertoboolean(number)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function postostring(pos)
|
||||||
|
return pos.x .. " " .. pos.y .. " " .. pos.z
|
||||||
|
end
|
||||||
|
|
||||||
function signalcall(param, ...)
|
function signalcall(param, ...)
|
||||||
if type(param) == 'function' then
|
if type(param) == 'function' then
|
||||||
local status, ret = pcall(param, ...)
|
local status, ret = pcall(param, ...)
|
||||||
|
|
|
@ -71,6 +71,8 @@ set(framework_SOURCES ${framework_SOURCES}
|
||||||
${CMAKE_CURRENT_LIST_DIR}/core/binarytree.h
|
${CMAKE_CURRENT_LIST_DIR}/core/binarytree.h
|
||||||
${CMAKE_CURRENT_LIST_DIR}/core/clock.cpp
|
${CMAKE_CURRENT_LIST_DIR}/core/clock.cpp
|
||||||
${CMAKE_CURRENT_LIST_DIR}/core/clock.h
|
${CMAKE_CURRENT_LIST_DIR}/core/clock.h
|
||||||
|
${CMAKE_CURRENT_LIST_DIR}/core/config.cpp
|
||||||
|
${CMAKE_CURRENT_LIST_DIR}/core/config.h
|
||||||
${CMAKE_CURRENT_LIST_DIR}/core/configmanager.cpp
|
${CMAKE_CURRENT_LIST_DIR}/core/configmanager.cpp
|
||||||
${CMAKE_CURRENT_LIST_DIR}/core/configmanager.h
|
${CMAKE_CURRENT_LIST_DIR}/core/configmanager.h
|
||||||
${CMAKE_CURRENT_LIST_DIR}/core/declarations.h
|
${CMAKE_CURRENT_LIST_DIR}/core/declarations.h
|
||||||
|
|
|
@ -126,7 +126,10 @@ void Application::terminate()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// save configurations
|
// save configurations
|
||||||
g_configs.save();
|
ConfigPtr settings = g_configs.getSettings();
|
||||||
|
if(settings) {
|
||||||
|
settings->save();
|
||||||
|
}
|
||||||
|
|
||||||
// release resources
|
// release resources
|
||||||
g_resources.terminate();
|
g_resources.terminate();
|
||||||
|
|
|
@ -0,0 +1,156 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2010-2013 OTClient <https://github.com/edubart/otclient>
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
* THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "config.h"
|
||||||
|
#include "resourcemanager.h"
|
||||||
|
|
||||||
|
#include <framework/otml/otml.h>
|
||||||
|
|
||||||
|
Config::Config()
|
||||||
|
{
|
||||||
|
m_confsDoc = OTMLDocument::create();
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Config::load(const std::string& file)
|
||||||
|
{
|
||||||
|
m_fileName = file;
|
||||||
|
|
||||||
|
if(!g_resources.fileExists(file))
|
||||||
|
return false;
|
||||||
|
|
||||||
|
try {
|
||||||
|
OTMLDocumentPtr confsDoc = OTMLDocument::parse(file);
|
||||||
|
if(confsDoc)
|
||||||
|
m_confsDoc = confsDoc;
|
||||||
|
return true;
|
||||||
|
} catch(stdext::exception& e) {
|
||||||
|
g_logger.error(stdext::format("Unable to parse configuration file '%s': ", e.what()));
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Config::unload()
|
||||||
|
{
|
||||||
|
if(isLoaded()) {
|
||||||
|
m_confsDoc = nullptr;
|
||||||
|
m_fileName = "";
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Config::save()
|
||||||
|
{
|
||||||
|
if(m_fileName.length() == 0)
|
||||||
|
return false;
|
||||||
|
return m_confsDoc->save(m_fileName);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Config::clear()
|
||||||
|
{
|
||||||
|
m_confsDoc->clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
void Config::set(const std::string& key, const std::string& value)
|
||||||
|
{
|
||||||
|
if(key == "") {
|
||||||
|
remove(key);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
OTMLNodePtr child = OTMLNode::create(key, value);
|
||||||
|
m_confsDoc->addChild(child);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Config::setList(const std::string& key, const std::vector<std::string>& list)
|
||||||
|
{
|
||||||
|
remove(key);
|
||||||
|
|
||||||
|
if(list.size() == 0)
|
||||||
|
return;
|
||||||
|
|
||||||
|
OTMLNodePtr child = OTMLNode::create(key, true);
|
||||||
|
for(const std::string& value : list)
|
||||||
|
child->writeIn(value);
|
||||||
|
m_confsDoc->addChild(child);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Config::exists(const std::string key)
|
||||||
|
{
|
||||||
|
return m_confsDoc->hasChildAt(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string Config::get(const std::string& key)
|
||||||
|
{
|
||||||
|
OTMLNodePtr child = m_confsDoc->get(key);
|
||||||
|
if(child)
|
||||||
|
return child->value();
|
||||||
|
else
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
std::vector<std::string> Config::getList(const std::string& key)
|
||||||
|
{
|
||||||
|
std::vector<std::string> list;
|
||||||
|
OTMLNodePtr child = m_confsDoc->get(key);
|
||||||
|
if(child) {
|
||||||
|
for(const OTMLNodePtr& subchild : child->children())
|
||||||
|
list.push_back(subchild->value());
|
||||||
|
}
|
||||||
|
return list;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Config::remove(const std::string& key)
|
||||||
|
{
|
||||||
|
OTMLNodePtr child = m_confsDoc->get(key);
|
||||||
|
if(child)
|
||||||
|
m_confsDoc->removeChild(child);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Config::setNode(const std::string& key, const OTMLNodePtr& node)
|
||||||
|
{
|
||||||
|
remove(key);
|
||||||
|
mergeNode(key, node);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Config::mergeNode(const std::string& key, const OTMLNodePtr& node)
|
||||||
|
{
|
||||||
|
OTMLNodePtr clone = node->clone();
|
||||||
|
node->setTag(key);
|
||||||
|
node->setUnique(true);
|
||||||
|
m_confsDoc->addChild(node);
|
||||||
|
}
|
||||||
|
|
||||||
|
OTMLNodePtr Config::getNode(const std::string& key)
|
||||||
|
{
|
||||||
|
return m_confsDoc->get(key);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Config::isLoaded()
|
||||||
|
{
|
||||||
|
return !m_fileName.empty();
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string Config::getFileName()
|
||||||
|
{
|
||||||
|
return m_fileName;
|
||||||
|
}
|
|
@ -0,0 +1,65 @@
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2010-2013 OTClient <https://github.com/edubart/otclient>
|
||||||
|
*
|
||||||
|
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
|
* of this software and associated documentation files (the "Software"), to deal
|
||||||
|
* in the Software without restriction, including without limitation the rights
|
||||||
|
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
||||||
|
* copies of the Software, and to permit persons to whom the Software is
|
||||||
|
* furnished to do so, subject to the following conditions:
|
||||||
|
*
|
||||||
|
* The above copyright notice and this permission notice shall be included in
|
||||||
|
* all copies or substantial portions of the Software.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
||||||
|
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
||||||
|
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
||||||
|
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
||||||
|
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
||||||
|
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
|
* THE SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef CONFIG_H
|
||||||
|
#define CONFIG_H
|
||||||
|
|
||||||
|
#include "declarations.h"
|
||||||
|
|
||||||
|
#include <framework/luaengine/luaobject.h>
|
||||||
|
#include <framework/otml/declarations.h>
|
||||||
|
|
||||||
|
// @bindclass
|
||||||
|
class Config : public LuaObject
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
Config();
|
||||||
|
|
||||||
|
bool load(const std::string& file);
|
||||||
|
bool unload();
|
||||||
|
bool save();
|
||||||
|
void clear();
|
||||||
|
|
||||||
|
void set(const std::string& key, const std::string& value);
|
||||||
|
void setList(const std::string& key, const std::vector<std::string>& list);
|
||||||
|
std::string get(const std::string& key);
|
||||||
|
std::vector<std::string> getList(const std::string& key);
|
||||||
|
|
||||||
|
void setNode(const std::string& key, const OTMLNodePtr& node);
|
||||||
|
void mergeNode(const std::string& key, const OTMLNodePtr& node);
|
||||||
|
OTMLNodePtr getNode(const std::string& key);
|
||||||
|
|
||||||
|
bool exists(const std::string key);
|
||||||
|
void remove(const std::string& key);
|
||||||
|
|
||||||
|
std::string getFileName();
|
||||||
|
bool isLoaded();
|
||||||
|
|
||||||
|
// @dontbind
|
||||||
|
ConfigPtr asConfig() { return static_self_cast<Config>(); }
|
||||||
|
|
||||||
|
private:
|
||||||
|
std::string m_fileName = "";
|
||||||
|
OTMLDocumentPtr m_confsDoc;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
|
@ -21,118 +21,65 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "configmanager.h"
|
#include "configmanager.h"
|
||||||
#include "resourcemanager.h"
|
|
||||||
|
|
||||||
#include <framework/otml/otml.h>
|
|
||||||
|
|
||||||
ConfigManager g_configs;
|
ConfigManager g_configs;
|
||||||
|
|
||||||
ConfigManager::ConfigManager()
|
ConfigManager::ConfigManager()
|
||||||
{
|
{
|
||||||
m_confsDoc = OTMLDocument::create();
|
m_settings = ConfigPtr(new Config());
|
||||||
}
|
}
|
||||||
|
|
||||||
bool ConfigManager::load(const std::string& file)
|
ConfigPtr ConfigManager::getSettings()
|
||||||
{
|
{
|
||||||
m_fileName = file;
|
return m_settings;
|
||||||
|
}
|
||||||
|
|
||||||
if(!g_resources.fileExists(file))
|
ConfigPtr ConfigManager::get(const std::string& file)
|
||||||
return false;
|
{
|
||||||
|
for(const ConfigPtr config : m_configs) {
|
||||||
|
if(config->getFileName() == file) {
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
g_logger.error(stdext::format("Unable to find configuration for '%s' ", file));
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
try {
|
ConfigPtr ConfigManager::loadSettings(const std::string file)
|
||||||
OTMLDocumentPtr confsDoc = OTMLDocument::parse(file);
|
{
|
||||||
if(confsDoc)
|
if(file.empty()) {
|
||||||
m_confsDoc = confsDoc;
|
g_logger.error("Must provide a configuration file to load.");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
if(m_settings->load(file)) {
|
||||||
|
return m_settings;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
ConfigPtr ConfigManager::load(const std::string& file)
|
||||||
|
{
|
||||||
|
if(file.empty()) {
|
||||||
|
g_logger.error("Must provide a configuration file to load.");
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
ConfigPtr config = ConfigPtr(new Config());
|
||||||
|
if(config->load(file)) {
|
||||||
|
m_configs.push_back(config);
|
||||||
|
return config;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool ConfigManager::unload(const std::string& file)
|
||||||
|
{
|
||||||
|
ConfigPtr config = get(file);
|
||||||
|
if(config) {
|
||||||
|
config->unload();
|
||||||
|
m_configs.remove(config);
|
||||||
return true;
|
return true;
|
||||||
} catch(stdext::exception& e) {
|
}
|
||||||
g_logger.error(stdext::format("Unable to parse configuration file '%s': ", e.what()));
|
|
||||||
return false;
|
return false;
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ConfigManager::save()
|
|
||||||
{
|
|
||||||
if(m_fileName.length() == 0)
|
|
||||||
return false;
|
|
||||||
return m_confsDoc->save(m_fileName);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConfigManager::clear()
|
|
||||||
{
|
|
||||||
m_confsDoc->clear();
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConfigManager::set(const std::string& key, const std::string& value)
|
|
||||||
{
|
|
||||||
if(key == "") {
|
|
||||||
remove(key);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
OTMLNodePtr child = OTMLNode::create(key, value);
|
|
||||||
m_confsDoc->addChild(child);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConfigManager::setList(const std::string& key, const std::vector<std::string>& list)
|
|
||||||
{
|
|
||||||
remove(key);
|
|
||||||
|
|
||||||
if(list.size() == 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
OTMLNodePtr child = OTMLNode::create(key, true);
|
|
||||||
for(const std::string& value : list)
|
|
||||||
child->writeIn(value);
|
|
||||||
m_confsDoc->addChild(child);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool ConfigManager::exists(const std::string& key)
|
|
||||||
{
|
|
||||||
return m_confsDoc->hasChildAt(key);
|
|
||||||
}
|
|
||||||
|
|
||||||
std::string ConfigManager::get(const std::string& key)
|
|
||||||
{
|
|
||||||
OTMLNodePtr child = m_confsDoc->get(key);
|
|
||||||
if(child)
|
|
||||||
return child->value();
|
|
||||||
else
|
|
||||||
return "";
|
|
||||||
}
|
|
||||||
|
|
||||||
std::vector<std::string> ConfigManager::getList(const std::string& key)
|
|
||||||
{
|
|
||||||
std::vector<std::string> list;
|
|
||||||
OTMLNodePtr child = m_confsDoc->get(key);
|
|
||||||
if(child) {
|
|
||||||
for(const OTMLNodePtr& subchild : child->children())
|
|
||||||
list.push_back(subchild->value());
|
|
||||||
}
|
|
||||||
return list;
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConfigManager::remove(const std::string& key)
|
|
||||||
{
|
|
||||||
OTMLNodePtr child = m_confsDoc->get(key);
|
|
||||||
if(child)
|
|
||||||
m_confsDoc->removeChild(child);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConfigManager::setNode(const std::string& key, const OTMLNodePtr& node)
|
|
||||||
{
|
|
||||||
remove(key);
|
|
||||||
mergeNode(key, node);
|
|
||||||
}
|
|
||||||
|
|
||||||
void ConfigManager::mergeNode(const std::string& key, const OTMLNodePtr& node)
|
|
||||||
{
|
|
||||||
OTMLNodePtr clone = node->clone();
|
|
||||||
node->setTag(key);
|
|
||||||
node->setUnique(true);
|
|
||||||
m_confsDoc->addChild(node);
|
|
||||||
}
|
|
||||||
|
|
||||||
OTMLNodePtr ConfigManager::getNode(const std::string& key)
|
|
||||||
{
|
|
||||||
return m_confsDoc->get(key);
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,8 +23,7 @@
|
||||||
#ifndef CONFIGMANAGER_H
|
#ifndef CONFIGMANAGER_H
|
||||||
#define CONFIGMANAGER_H
|
#define CONFIGMANAGER_H
|
||||||
|
|
||||||
#include "declarations.h"
|
#include "config.h"
|
||||||
#include <framework/otml/declarations.h>
|
|
||||||
|
|
||||||
// @bindsingleton g_configs
|
// @bindsingleton g_configs
|
||||||
class ConfigManager
|
class ConfigManager
|
||||||
|
@ -32,25 +31,18 @@ class ConfigManager
|
||||||
public:
|
public:
|
||||||
ConfigManager();
|
ConfigManager();
|
||||||
|
|
||||||
bool load(const std::string& file);
|
ConfigPtr getSettings();
|
||||||
bool save();
|
ConfigPtr get(const std::string& file);
|
||||||
void clear();
|
|
||||||
|
|
||||||
void set(const std::string& key, const std::string& value);
|
ConfigPtr loadSettings(const std::string file);
|
||||||
void setList(const std::string& key, const std::vector<std::string>& list);
|
ConfigPtr load(const std::string& file);
|
||||||
std::string get(const std::string& key);
|
bool unload(const std::string& file);
|
||||||
std::vector<std::string> getList(const std::string& key);
|
|
||||||
|
|
||||||
void setNode(const std::string& key, const OTMLNodePtr& node);
|
protected:
|
||||||
void mergeNode(const std::string& key, const OTMLNodePtr& node);
|
ConfigPtr m_settings;
|
||||||
OTMLNodePtr getNode(const std::string& key);
|
|
||||||
|
|
||||||
bool exists(const std::string& key);
|
|
||||||
void remove(const std::string& key);
|
|
||||||
|
|
||||||
private:
|
private:
|
||||||
std::string m_fileName;
|
std::list<ConfigPtr> m_configs;
|
||||||
OTMLDocumentPtr m_confsDoc;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern ConfigManager g_configs;
|
extern ConfigManager g_configs;
|
||||||
|
|
|
@ -25,9 +25,11 @@
|
||||||
|
|
||||||
#include <framework/global.h>
|
#include <framework/global.h>
|
||||||
|
|
||||||
|
class ConfigManager;
|
||||||
class ModuleManager;
|
class ModuleManager;
|
||||||
class ResourceManager;
|
class ResourceManager;
|
||||||
class Module;
|
class Module;
|
||||||
|
class Config;
|
||||||
class Event;
|
class Event;
|
||||||
class ScheduledEvent;
|
class ScheduledEvent;
|
||||||
class FileStream;
|
class FileStream;
|
||||||
|
@ -35,6 +37,7 @@ class BinaryTree;
|
||||||
class OutputBinaryTree;
|
class OutputBinaryTree;
|
||||||
|
|
||||||
typedef stdext::shared_object_ptr<Module> ModulePtr;
|
typedef stdext::shared_object_ptr<Module> ModulePtr;
|
||||||
|
typedef stdext::shared_object_ptr<Config> ConfigPtr;
|
||||||
typedef stdext::shared_object_ptr<Event> EventPtr;
|
typedef stdext::shared_object_ptr<Event> EventPtr;
|
||||||
typedef stdext::shared_object_ptr<ScheduledEvent> ScheduledEventPtr;
|
typedef stdext::shared_object_ptr<ScheduledEvent> ScheduledEventPtr;
|
||||||
typedef stdext::shared_object_ptr<FileStream> FileStreamPtr;
|
typedef stdext::shared_object_ptr<FileStream> FileStreamPtr;
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include <framework/luaengine/luainterface.h>
|
#include <framework/luaengine/luainterface.h>
|
||||||
#include <framework/core/eventdispatcher.h>
|
#include <framework/core/eventdispatcher.h>
|
||||||
#include <framework/core/configmanager.h>
|
#include <framework/core/configmanager.h>
|
||||||
|
#include <framework/core/config.h>
|
||||||
#include <framework/otml/otml.h>
|
#include <framework/otml/otml.h>
|
||||||
#include <framework/core/modulemanager.h>
|
#include <framework/core/modulemanager.h>
|
||||||
#include <framework/core/module.h>
|
#include <framework/core/module.h>
|
||||||
|
@ -135,17 +136,11 @@ void Application::registerLuaFunctions()
|
||||||
|
|
||||||
// ConfigManager
|
// ConfigManager
|
||||||
g_lua.registerSingletonClass("g_configs");
|
g_lua.registerSingletonClass("g_configs");
|
||||||
g_lua.bindSingletonFunction("g_configs", "load", &ConfigManager::load, &g_configs);
|
g_lua.bindSingletonFunction("g_configs", "getSettings", &ConfigManager::getSettings, &g_configs);
|
||||||
g_lua.bindSingletonFunction("g_configs", "save", &ConfigManager::save, &g_configs);
|
|
||||||
g_lua.bindSingletonFunction("g_configs", "set", &ConfigManager::set, &g_configs);
|
|
||||||
g_lua.bindSingletonFunction("g_configs", "setList", &ConfigManager::setList, &g_configs);
|
|
||||||
g_lua.bindSingletonFunction("g_configs", "get", &ConfigManager::get, &g_configs);
|
g_lua.bindSingletonFunction("g_configs", "get", &ConfigManager::get, &g_configs);
|
||||||
g_lua.bindSingletonFunction("g_configs", "getList", &ConfigManager::getList, &g_configs);
|
g_lua.bindSingletonFunction("g_configs", "loadSettings", &ConfigManager::loadSettings, &g_configs);
|
||||||
g_lua.bindSingletonFunction("g_configs", "exists", &ConfigManager::exists, &g_configs);
|
g_lua.bindSingletonFunction("g_configs", "load", &ConfigManager::load, &g_configs);
|
||||||
g_lua.bindSingletonFunction("g_configs", "remove", &ConfigManager::remove, &g_configs);
|
g_lua.bindSingletonFunction("g_configs", "unload", &ConfigManager::unload, &g_configs);
|
||||||
g_lua.bindSingletonFunction("g_configs", "setNode", &ConfigManager::setNode, &g_configs);
|
|
||||||
g_lua.bindSingletonFunction("g_configs", "mergeNode", &ConfigManager::mergeNode, &g_configs);
|
|
||||||
g_lua.bindSingletonFunction("g_configs", "getNode", &ConfigManager::getNode, &g_configs);
|
|
||||||
|
|
||||||
// Logger
|
// Logger
|
||||||
g_lua.registerSingletonClass("g_logger");
|
g_lua.registerSingletonClass("g_logger");
|
||||||
|
@ -195,6 +190,19 @@ void Application::registerLuaFunctions()
|
||||||
g_lua.bindSingletonFunction("g_resources", "isFileType", &ResourceManager::isFileType, &g_resources);
|
g_lua.bindSingletonFunction("g_resources", "isFileType", &ResourceManager::isFileType, &g_resources);
|
||||||
g_lua.bindSingletonFunction("g_resources", "getFileTime", &ResourceManager::getFileTime, &g_resources);
|
g_lua.bindSingletonFunction("g_resources", "getFileTime", &ResourceManager::getFileTime, &g_resources);
|
||||||
|
|
||||||
|
// Config
|
||||||
|
g_lua.registerClass<Config>();
|
||||||
|
g_lua.bindClassMemberFunction<Config>("save", &Config::save);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("set", &Config::set);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("setList", &Config::setList);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("get", &Config::get);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("getList", &Config::getList);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("exists", &Config::exists);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("remove", &Config::remove);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("setNode", &Config::setNode);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("getNode", &Config::getNode);
|
||||||
|
g_lua.bindClassMemberFunction<Config>("mergeNode", &Config::mergeNode);
|
||||||
|
|
||||||
// Module
|
// Module
|
||||||
g_lua.registerClass<Module>();
|
g_lua.registerClass<Module>();
|
||||||
g_lua.bindClassMemberFunction<Module>("load", &Module::load);
|
g_lua.bindClassMemberFunction<Module>("load", &Module::load);
|
||||||
|
|
Loading…
Reference in New Issue