summaryrefslogtreecommitdiff
path: root/modules/extra/regex_tre.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'modules/extra/regex_tre.cpp')
-rw-r--r--modules/extra/regex_tre.cpp83
1 files changed, 83 insertions, 0 deletions
diff --git a/modules/extra/regex_tre.cpp b/modules/extra/regex_tre.cpp
new file mode 100644
index 000000000..18485507a
--- /dev/null
+++ b/modules/extra/regex_tre.cpp
@@ -0,0 +1,83 @@
+/*
+ *
+ * (C) 2012-2024 Anope Team
+ * Contact us at team@anope.org
+ *
+ * Please read COPYING and README for further details.
+ */
+
+/* RequiredLibraries: tre */
+
+#include "module.h"
+#include <tre/regex.h>
+
+class TRERegex final
+ : public Regex
+{
+ regex_t regbuf;
+
+public:
+ TRERegex(const Anope::string &expr) : Regex(expr)
+ {
+ int err = regcomp(&this->regbuf, expr.c_str(), REG_EXTENDED | REG_NOSUB);
+ if (err)
+ {
+ char buf[BUFSIZE];
+ regerror(err, &this->regbuf, buf, sizeof(buf));
+ regfree(&this->regbuf);
+ throw RegexException("Error in regex " + expr + ": " + buf);
+ }
+ }
+
+ ~TRERegex()
+ {
+ regfree(&this->regbuf);
+ }
+
+ bool Matches(const Anope::string &str)
+ {
+ return regexec(&this->regbuf, str.c_str(), 0, NULL, 0) == 0;
+ }
+};
+
+class TRERegexProvider final
+ : public RegexProvider
+{
+public:
+ TRERegexProvider(Module *creator) : RegexProvider(creator, "regex/tre") { }
+
+ Regex *Compile(const Anope::string &expression) override
+ {
+ return new TRERegex(expression);
+ }
+};
+
+class ModuleRegexTRE final
+ : public Module
+{
+ TRERegexProvider tre_regex_provider;
+
+public:
+ ModuleRegexTRE(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, EXTRA | VENDOR),
+ tre_regex_provider(this)
+ {
+ this->SetPermanent(true);
+ }
+
+ ~ModuleRegexTRE()
+ {
+ for (auto *xlm : XLineManager::XLineManagers)
+ {
+ for (auto *x : xlm->GetList())
+ {
+ if (x->regex && dynamic_cast<TRERegex *>(x->regex))
+ {
+ delete x->regex;
+ x->regex = NULL;
+ }
+ }
+ }
+ }
+};
+
+MODULE_INIT(ModuleRegexTRE)