]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/extra/m_regex_posix.cpp
Make a ./configure --system to support system-wide installation of inspircd
[user/henk/code/inspircd.git] / src / modules / extra / m_regex_posix.cpp
index 62b44e0e4dae4497c53b1ee9fce605d88b976d65..dc8af3c7110ac5077b4c71637bd598de7e16fa98 100644 (file)
@@ -2,7 +2,7 @@
  *       | Inspire Internet Relay Chat Daemon |
  *       +------------------------------------+
  *
- *  InspIRCd: (C) 2002-2009 InspIRCd Development Team
+ *  InspIRCd: (C) 2002-2010 InspIRCd Development Team
  * See: http://wiki.inspircd.org/Credits
  *
  * This program is free but copyrighted software; see
@@ -71,46 +71,37 @@ public:
        }
 };
 
-class ModuleRegexPOSIX : public Module
+class PosixFactory : public RegexFactory
 {
-private:
+ public:
        bool extended;
+       PosixFactory(Module* m) : RegexFactory(m, "regex/posix") {}
+       Regex* Create(const std::string& expr)
+       {
+               return new POSIXRegex(expr, extended);
+       }
+};
+
+class ModuleRegexPOSIX : public Module
+{
+       PosixFactory ref;
 public:
-       ModuleRegexPOSIX()      {
-               ServerInstance->Modules->PublishInterface("RegularExpression", this);
+       ModuleRegexPOSIX() : ref(this) {
+               ServerInstance->Modules->AddService(ref);
                Implementation eventlist[] = { I_OnRehash };
                ServerInstance->Modules->Attach(eventlist, this, 1);
                OnRehash(NULL);
        }
 
-       virtual Version GetVersion()
-       {
-               return Version("Regex Provider Module for POSIX Regular Expressions", VF_COMMON | VF_VENDOR | VF_SERVICEPROVIDER, API_VERSION);
-       }
-
-       virtual ~ModuleRegexPOSIX()
+       Version GetVersion()
        {
-               ServerInstance->Modules->UnpublishInterface("RegularExpression", this);
+               return Version("Regex Provider Module for POSIX Regular Expressions", VF_VENDOR);
        }
 
-       virtual void OnRehash(User* u)
+       void OnRehash(User* u)
        {
                ConfigReader Conf;
-               extended = Conf.ReadFlag("posix", "extended", 0);
-       }
-
-       void OnRequest(Request& request)
-       {
-               if (strcmp("REGEX-NAME", request.id) == 0)
-               {
-                       static_cast<RegexNameRequest&>(request).result = "posix";
-               }
-               else if (strcmp("REGEX", request.id) == 0)
-               {
-                       RegexFactoryRequest& rfr = (RegexFactoryRequest&)request;
-                       std::string rx = rfr.GetRegex();
-                       rfr.result = new POSIXRegex(rx, extended);
-               }
+               ref.extended = Conf.ReadFlag("posix", "extended", 0);
        }
 };