]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_opermodes.cpp
AMD64 warning 'fix' which tested fine when I added it seems to now...stop things...
[user/henk/code/inspircd.git] / src / modules / m_opermodes.cpp
index 628f0a40d14193961b65affc1cf980543bc9b9d4..d99a7ad8ae19c35e80764589292747b7da4f71ca 100644 (file)
@@ -2,7 +2,7 @@
  *       | Inspire Internet Relay Chat Daemon |
  *       +------------------------------------+
  *
- *  Inspire is copyright (C) 2002-2004 ChatSpike-Dev.
+ *  InspIRCd is copyright (C) 2002-2006 ChatSpike-Dev.
  *                       E-mail:
  *                <brain@chatspike.net>
  *               <Craig@chatspike.net>
@@ -40,7 +40,13 @@ class ModuleModesOnOper : public Module
 
        void Implements(char* List)
        {
-               List[I_OnOper] = 1;
+               List[I_OnPostOper] = List[I_OnRehash] = 1;
+       }
+
+       virtual void OnRehash(const std::string &parameter)
+       {
+               delete Conf;
+               Conf = new ConfigReader;
        }
        
        virtual ~ModuleModesOnOper()
@@ -53,7 +59,7 @@ class ModuleModesOnOper : public Module
                return Version(1,0,0,1,VF_VENDOR);
        }
        
-       virtual void OnOper(userrec* user, std::string opertype)
+       virtual void OnPostOper(userrec* user, const std::string &opertype)
        {
                // whenever a user opers, go through the oper types, find their <type:modes>,
                // and if they have one apply their modes. The mode string can contain +modes
@@ -64,6 +70,9 @@ class ModuleModesOnOper : public Module
                         if (!strcmp(typen.c_str(),user->oper))
                         {
                                 std::string ThisOpersModes = Conf->ReadValue("type","modes",j);
+                               char first = *(ThisOpersModes.c_str());
+                               if ((first != '+') && (first != '-'))
+                                       ThisOpersModes = "+" + ThisOpersModes;
                                if (ThisOpersModes != "")
                                {
                                        char* modes[2];