diff options
author | danieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7> | 2009-11-16 17:59:06 +0000 |
---|---|---|
committer | danieldg <danieldg@e03df62e-2008-0410-955e-edbf42e46eb7> | 2009-11-16 17:59:06 +0000 |
commit | 54fb0cd5aa7d090d5c3da5ab54988c86ba8a2e8e (patch) | |
tree | bc20ce6dca41b2d16349ae4c8212861c10e3685e /src/modules/extra/m_regex_pcre.cpp | |
parent | 3bfd0db65ff01c026e968af4de074cc1155a4061 (diff) |
Use ServiceProvider for inter-module dependencies
This will stop dependency chains from preventing module reloads when
it is not actually needed; however, it removes some failsafes that will
need to be reimplemented in order to avoid unmapped vtables.
This deprecates Request as an inter-module signaling mechanism, although
SQL still uses it.
git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@12140 e03df62e-2008-0410-955e-edbf42e46eb7
Diffstat (limited to 'src/modules/extra/m_regex_pcre.cpp')
-rw-r--r-- | src/modules/extra/m_regex_pcre.cpp | 36 |
1 files changed, 14 insertions, 22 deletions
diff --git a/src/modules/extra/m_regex_pcre.cpp b/src/modules/extra/m_regex_pcre.cpp index 9e8aff159..c286162e8 100644 --- a/src/modules/extra/m_regex_pcre.cpp +++ b/src/modules/extra/m_regex_pcre.cpp @@ -67,35 +67,27 @@ public: } }; -class ModuleRegexPCRE : public Module +class PCREFactory : public RegexFactory { -public: - ModuleRegexPCRE() { - ServerInstance->Modules->PublishInterface("RegularExpression", this); - } - - virtual Version GetVersion() + public: + PCREFactory(Module* m) : RegexFactory(m, "regex/pcre") {} + Regex* Create(const std::string& expr) { - return Version("Regex Provider Module for PCRE", VF_COMMON | VF_VENDOR); + return new PCRERegex(expr); } +}; - virtual ~ModuleRegexPCRE() - { - ServerInstance->Modules->UnpublishInterface("RegularExpression", this); +class ModuleRegexPCRE : public Module +{ +public: + PCREFactory ref; + ModuleRegexPCRE() : ref(this) { + ServerInstance->Modules->AddService(ref); } - void OnRequest(Request& request) + Version GetVersion() { - if (strcmp("REGEX-NAME", request.id) == 0) - { - static_cast<RegexNameRequest&>(request).result = "pcre"; - } - else if (strcmp("REGEX", request.id) == 0) - { - RegexFactoryRequest& rfr = (RegexFactoryRequest&)request; - std::string rx = rfr.GetRegex(); - rfr.result = new PCRERegex(rx); - } + return Version("Regex Provider Module for PCRE", VF_OPTCOMMON | VF_VENDOR); } }; |