* | Inspire Internet Relay Chat Daemon |
* +------------------------------------+
*
- * InspIRCd: (C) 2002-2007 InspIRCd Development Team
+ * InspIRCd: (C) 2002-2008 InspIRCd Development Team
* See: http://www.inspircd.org/wiki/index.php/Credits
*
* This program is free but copyrighted software; see
#ifndef __MODE_H
#define __MODE_H
-/* include the common header files */
-#include <string>
-#include <deque>
-#include <vector>
-#include "users.h"
-#include "channels.h"
-#include "ctables.h"
-
-class InspIRCd;
-
/**
* Holds the values for different type of modes
* that can exist, USER or CHANNEL type.
*/
unsigned int count;
+ /** The prefix char needed on channel to use this mode,
+ * only checked for channel modes
+ */
+ char prefixneeded;
+
public:
/**
* The constructor for ModeHandler initalizes the mode handler.
* and the rank values OP_VALUE, HALFOP_VALUE and VOICE_VALUE respectively. Any prefixes you define should have unique values proportional
* to these three defaults or proportional to another mode in a module you depend on. See src/cmode_o.cpp as an example.
*/
- ModeHandler(InspIRCd* Instance, char modeletter, int parameters_on, int parameters_off, bool listmode, ModeType type, bool operonly, char mprefix = 0);
+ ModeHandler(InspIRCd* Instance, char modeletter, int parameters_on, int parameters_off, bool listmode, ModeType type, bool operonly, char mprefix = 0, char prefixrequired = '%');
/**
* The default destructor does nothing
*/
* @param channel The channel which the server wants to remove your mode from
*/
virtual void RemoveMode(Channel* channel);
+
+ char GetNeededPrefix();
+
+ void SetNeededPrefix(char needsprefix);
};
/**
* @return Last parsed string, as seen by users.
*/
const std::string& GetLastParse();
- /** Add a mode to the mode parser. The modeletter parameter
- * is purely to save on doing a lookup in the function, as
- * strictly it could be obtained via ModeHandler::GetModeChar().
+ /** Add a mode to the mode parser.
* @return True if the mode was successfully added.
*/
- bool AddMode(ModeHandler* mh, unsigned const char modeletter);
+ bool AddMode(ModeHandler* mh);
/** Delete a mode from the mode parser.
* When a mode is deleted, the mode handler will be called
* for every user (if it is a user mode) or for every channel