summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/modules/extra/m_regex.h10
-rw-r--r--src/modules/extra/m_regex_glob.cpp5
-rw-r--r--src/modules/extra/m_regex_pcre.cpp100
3 files changed, 112 insertions, 3 deletions
diff --git a/src/modules/extra/m_regex.h b/src/modules/extra/m_regex.h
index 361d54831..cffb94cbd 100644
--- a/src/modules/extra/m_regex.h
+++ b/src/modules/extra/m_regex.h
@@ -40,8 +40,10 @@ class RegexFactoryRequest : public Request
{
private:
std::string regex;
-
+
public:
+ Regex* result;
+
RegexFactoryRequest(Module* Me, Module* Target, const std::string& rx) : Request(Me, Target, "REGEX"), regex(rx)
{
}
@@ -50,6 +52,12 @@ public:
{
return regex;
}
+
+ Regex* Create()
+ {
+ Send();
+ return this->result;
+ }
};
class RegexNameRequest : public Request
diff --git a/src/modules/extra/m_regex_glob.cpp b/src/modules/extra/m_regex_glob.cpp
index 8d81b9a03..7977c77f1 100644
--- a/src/modules/extra/m_regex_glob.cpp
+++ b/src/modules/extra/m_regex_glob.cpp
@@ -59,8 +59,9 @@ public:
{
RegexFactoryRequest* rfr = (RegexFactoryRequest*)request;
std::string rx = rfr->GetRegex();
- Regex* rxo = (Regex*)new GlobRegex(rx, ServerInstance); // Cast to base class first, since theoretically the pointer could change by that.
- return (const char*)(rxo);
+ rfr->result = (Regex*)new GlobRegex(rx, ServerInstance);
+ return "OK";
}
+ return NULL;
}
};
diff --git a/src/modules/extra/m_regex_pcre.cpp b/src/modules/extra/m_regex_pcre.cpp
new file mode 100644
index 000000000..aea4cbbb6
--- /dev/null
+++ b/src/modules/extra/m_regex_pcre.cpp
@@ -0,0 +1,100 @@
+/* +------------------------------------+
+ * | Inspire Internet Relay Chat Daemon |
+ * +------------------------------------+
+ *
+ * InspIRCd: (C) 2002-2008 InspIRCd Development Team
+ * See: http://www.inspircd.org/wiki/index.php/Credits
+ *
+ * This program is free but copyrighted software; see
+ * the file COPYING for details.
+ *
+ * ---------------------------------------------------
+ */
+
+#include "inspircd.h"
+#include <pcre.h>
+#include "m_regex.h"
+
+/* $ModDesc: Regex Provider Module for PCRE */
+/* $ModDep: m_regex.h */
+/* $CompileFlags: exec("pcre-config --cflags") */
+/* $LinkerFlags: exec("pcre-config --libs") rpath("pcre-config --libs") -lpcre */
+
+#ifdef WINDOWS
+#pragma comment(lib, "pcre.lib")
+#endif
+
+class PCREException : public ModuleException
+{
+public:
+ PCREException(const std::string& rx, const std::string& error, int erroffset)
+ : ModuleException(std::string("Error in regex ") + rx + " at offset " + ConvToStr(erroffset) + ": " + error)
+ {
+ }
+};
+
+class PCRERegex : public Regex
+{
+private:
+ pcre* regex;
+
+public:
+ PCRERegex(const std::string& rx, InspIRCd* Me) : Regex(rx, Me)
+ {
+ const char* error;
+ int erroffset;
+ regex = pcre_compile(rx.c_str(), 0, &error, &erroffset, NULL);
+ if (!regex)
+ {
+ Me->Logs->Log("REGEX", DEBUG, "pcre_compile failed: /%s/ [%d] %s", rx.c_str(), erroffset, error);
+ throw PCREException(rx, error, erroffset);
+ }
+ }
+
+ virtual ~PCRERegex()
+ {
+ pcre_free(regex);
+ }
+
+ virtual bool Matches(const std::string& text)
+ {
+ if (pcre_exec(regex, NULL, text.c_str(), text.length(), 0, 0, NULL, 0) > -1)
+ {
+ // Bang. :D
+ return true;
+ }
+ return false;
+ }
+};
+
+class ModuleRegexPCRE : public Module
+{
+public:
+ ModuleRegexPCRE(InspIRCd* Me) : Module(Me)
+ {
+ Me->Modules->PublishInterface("RegularExpression", this);
+ Implementation eventlist[] = { I_OnRequest };
+ Me->Modules->Attach(eventlist, this, 1);
+ }
+
+ virtual ~ModuleRegexPCRE()
+ {
+ ServerInstance->Modules->UnpublishInterface("RegularExpression", this);
+ }
+
+ virtual const char* OnRequest(Request* request)
+ {
+ if (strcmp("REGEX-NAME", request->GetId()) == 0)
+ {
+ return "pcre";
+ }
+ else if (strcmp("REGEX", request->GetId()) == 0)
+ {
+ RegexFactoryRequest* rfr = (RegexFactoryRequest*)request;
+ std::string rx = rfr->GetRegex();
+ rfr->result = new PCRERegex(rx, ServerInstance);
+ return "OK";
+ }
+ return NULL;
+ }
+};