ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/svn/ircd-hybrid/trunk/include/whowas.h
Revision: 2865
Committed: Sun Jan 19 14:35:22 2014 UTC (11 years, 7 months ago) by michael
Content type: text/x-chdr
File size: 2587 byte(s)
Log Message:
- Clean up all files in include/ (fixed indentation, removed whitespaces/tabs)
- Fixed copyright years

File Contents

# Content
1 /*
2 * ircd-hybrid: an advanced, lightweight Internet Relay Chat Daemon (ircd)
3 *
4 * Copyright (c) 1997-2014 ircd-hybrid development team
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 * GNU General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with this program; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307
19 * USA
20 */
21
22 /*! \file whowas.h
23 * \brief A header for the whowas functions.
24 * \version $Id$
25 */
26
27 #ifndef INCLUDED_whowas_h
28 #define INCLUDED_whowas_h
29
30 #include "ircd_defs.h"
31 #include "client.h"
32 #include "config.h"
33
34
35 struct Whowas
36 {
37 int hashv;
38 int shide;
39 time_t logoff;
40 char name[NICKLEN + 1];
41 char username[USERLEN + 1];
42 char hostname[HOSTLEN + 1];
43 char realname[REALLEN + 1];
44 char servername[HOSTLEN + 1];
45 struct Client *online; /* Pointer to new nickname for chasing or NULL */
46 dlink_node tnode; /* for hash table... */
47 dlink_node cnode; /* for client struct linked list */
48 };
49
50 /*
51 ** initwhowas
52 */
53 extern void whowas_init(void);
54
55 /*
56 ** whowas_add_history
57 ** Add the currently defined name of the client to history.
58 ** usually called before changing to a new name (nick).
59 ** Client must be a fully registered user.
60 */
61 extern void whowas_add_history(struct Client *, const int);
62
63 /*
64 ** whowas_off_history
65 ** This must be called when the client structure is about to
66 ** be released. History mechanism keeps pointers to client
67 ** structures and it must know when they cease to exist. This
68 ** also implicitly calls AddHistory.
69 */
70 extern void whowas_off_history(struct Client *);
71
72 /*
73 ** whowas_get_history
74 ** Return the current client that was using the given
75 ** nickname within the timelimit. Returns NULL, if no
76 ** one found...
77 */
78 extern struct Client *whowas_get_history(const char *, time_t);
79
80 /*
81 ** for debugging...counts related structures stored in whowas array.
82 */
83 extern void whowas_count_memory(unsigned int *const, uint64_t *const);
84 extern dlink_list WHOWASHASH[];
85 #endif /* INCLUDED_whowas_h */

Properties

Name Value
svn:eol-style native
svn:keywords Id Revision