summaryrefslogtreecommitdiff
path: root/src/modules/m_alias.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/modules/m_alias.cpp')
-rw-r--r--src/modules/m_alias.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/src/modules/m_alias.cpp b/src/modules/m_alias.cpp
index ffa6c1e46..e8fe736c4 100644
--- a/src/modules/m_alias.cpp
+++ b/src/modules/m_alias.cpp
@@ -15,6 +15,7 @@
#include "channels.h"
#include "modules.h"
#include "inspircd.h"
+#include "wildcard.h"
#include <vector>
/* $ModDesc: Provides aliases of commands. */
@@ -34,6 +35,8 @@ class Alias : public classbase
bool uline;
/** Requires oper? */
bool operonly;
+ /* is case sensitive params */
+ bool case_sensitive;
/** Format that must be matched for use */
std::string format;
};
@@ -63,6 +66,7 @@ class ModuleAlias : public Module
a.uline = MyConf.ReadFlag("alias", "uline", i);
a.operonly = MyConf.ReadFlag("alias", "operonly", i);
a.format = MyConf.ReadValue("alias", "format", i);
+ a.case_sensitive = MyConf.ReadFlag("alias", "matchcase", i);
Aliases.push_back(a);
AliasMap[txt] = 1;
}
@@ -162,9 +166,10 @@ class ModuleAlias : public Module
if (Aliases[i].text == c)
{
/* Does it match the pattern? */
- if ((!Aliases[i].format.empty()) && (!ServerInstance->MatchText(compare, Aliases[i].format)))
+ if (!Aliases[i].format.empty())
{
- continue;
+ if (!match(Aliases[i].case_sensitive, compare.c_str(), Aliases[i].format.c_str()))
+ continue;
}
if ((Aliases[i].operonly) && (!*user->oper))