From 7890dccf61ba5e92d76e79c121b926ac515d6747 Mon Sep 17 00:00:00 2001 From: Gluzskiy Alexandr Date: Fri, 15 Oct 2010 08:53:21 +0300 Subject: services --- core/main.cpp | 8 +++++++- core/modules.cpp | 13 ++++++++----- core/services.cpp | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 3 files changed, 69 insertions(+), 6 deletions(-) create mode 100644 core/services.cpp (limited to 'core') diff --git a/core/main.cpp b/core/main.cpp index 20b8501..716b7b0 100644 --- a/core/main.cpp +++ b/core/main.cpp @@ -1,8 +1,14 @@ #include "commonheaders.h" +std::list plugins; +std::list services; +void CreateServiceFunction(const char* name, SERVICE svc); +void* CallService(const char *,void*); +int ServiceExists(const char *); -PLUGINLINK pluglink; + +PLUGINLINK pluglink = {&CreateServiceFunction, &CallService, &ServiceExists}; class EvilCore: public wxApp { diff --git a/core/modules.cpp b/core/modules.cpp index b509c6f..09ee63b 100644 --- a/core/modules.cpp +++ b/core/modules.cpp @@ -1,6 +1,6 @@ #include "commonheaders.h" -std::list plugins; +extern std::list plugins; extern PLUGINLINK pluglink; @@ -80,12 +80,15 @@ void load_modules() } void run_plugins() -{ +{ //now for testing only if(!plugins.empty()) - for(std::list::iterator i = plugins.begin(); i != plugins.end(); i++) { - (*i)->get_exported_functions()->Load(&pluglink); - (*i)->get_exported_functions()->OnModulesLoaded(); + std::list::iterator end = plugins.end(); + for(std::list::iterator i = plugins.begin(); i != end; ++i) + { + (*i)->get_exported_functions()->Load(&pluglink); + (*i)->get_exported_functions()->OnModulesLoaded(); + } } } diff --git a/core/services.cpp b/core/services.cpp new file mode 100644 index 0000000..56ee05e --- /dev/null +++ b/core/services.cpp @@ -0,0 +1,54 @@ +#include "commonheaders.h" + +extern std::list services; + +int ServiceExists(const char *name); +void CreateServiceFunction(const char* name, SERVICE svc) +{ + if(!ServiceExists(name)) + services.push_back(new service(name, svc)); +} + +void* CallService(const char *name,void* data) +{ + if(!services.empty()) + { + std::list::iterator end = services.end(); + for(std::list::iterator i = services.begin(); i != end; ++i) + { + if(!strcmp((*i)->getName(), name)) + return (*i)->getService()(data); + } + } + return 0; +} +int ServiceExists(const char *name) +{ + if(!services.empty()) + { + std::list::iterator end = services.end(); + for(std::list::iterator i = services.begin(); i != end; ++i) + if(!strcmp((*i)->getName(), name)) + return 1; + } + return 0; +} + +service::service(const char* name, SERVICE svc) +{ + pService = svc; + szName = strdup(name); +} + +const char* service::getName() +{ + return szName; +} +const SERVICE service::getService() +{ + return pService; +} +service::~service() +{ + free(szName); +} -- cgit v1.2.3