1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53
|
/*
* IRC - Internet Relay Chat, include/ircd_handler.h
* Copyright (C) 1990 Jarkko Oikarinen and
* University of Oulu, Computing Center
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2, or (at your option)
* any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
*/
/** @file
* @brief Message handler types and definitions.
* @version $Id: ircd_handler.h,v 1.2 2004/10/05 04:11:36 entrope Exp $
*/
#ifndef INCLUDED_ircd_handler_h
#define INCLUDED_ircd_handler_h
struct Client;
/*
* MessageHandler
*/
/** Enumerated type for client message handlers. */
typedef enum HandlerType {
UNREGISTERED_HANDLER, /**< Used for unregistered clients. */
CLIENT_HANDLER, /**< Used for local users. */
SERVER_HANDLER, /**< Used for server conections. */
OPER_HANDLER, /**< Used for IRC operators. */
SERVICE_HANDLER, /**< Used for services connections. */
LAST_HANDLER_TYPE /**< NUmber of handler types. */
} HandlerType;
/**
* MessageHandler function.
* @param[in] cptr Client that sent us the message.
* @param[in] sptr Original source of message.
* @param[in] parc Number of arguments.
* @param[in] parv Argument vector.
*/
typedef int (*MessageHandler)(struct Client* cptr, struct Client* sptr, int parc, char*parv[]);
#endif /* INCLUDED_ircd_handler_h */
|