]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/extra/m_regex_tre.cpp
Use ServiceProvider for inter-module dependencies
[user/henk/code/inspircd.git] / src / modules / extra / m_regex_tre.cpp
index 01c6ebf4aa33ba624a6d7a060918769933debf55..5a208ec8ac0e05ba1eb4ce76e0f02610c2c7b89b 100644 (file)
@@ -73,35 +73,30 @@ public:
        }
 };
 
+class TREFactory : public RegexFactory {
+ public:
+       TREFactory(Module* m) : RegexFactory(m, "regex/tre") {}
+       Regex* Create(const std::string& expr)
+       {
+               return new TRERegex(expr);
+       }
+};
+
 class ModuleRegexTRE : public Module
 {
+       TREFactory trf;
 public:
-       ModuleRegexTRE()        {
-               ServerInstance->Modules->PublishInterface("RegularExpression", this);
+       ModuleRegexTRE() : trf(this) {
+               ServerInstance->Modules->AddService(trf);
        }
 
-       virtual Version GetVersion()
+       Version GetVersion()
        {
                return Version("Regex Provider Module for TRE Regular Expressions", VF_COMMON | VF_VENDOR);
        }
 
-       virtual ~ModuleRegexTRE()
+       ~ModuleRegexTRE()
        {
-               ServerInstance->Modules->UnpublishInterface("RegularExpression", this);
-       }
-
-       void OnRequest(Request& request)
-       {
-               if (strcmp("REGEX-NAME", request.id) == 0)
-               {
-                       static_cast<RegexNameRequest&>(request).result = "tre";
-               }
-               else if (strcmp("REGEX", request.id) == 0)
-               {
-                       RegexFactoryRequest& rfr = (RegexFactoryRequest&)request;
-                       std::string rx = rfr.GetRegex();
-                       rfr.result = new TRERegex(rx);
-               }
        }
 };