afa44238f2e98a0338013c37a253adf4786c4417
[privoxy.git] / list.h
1 #ifndef LIST_H_INCLUDED
2 #define LIST_H_INCLUDED
3 #define LIST_H_VERSION "$Id: list.h,v 1.11 2002/03/24 13:25:43 swa Exp $"
4 /*********************************************************************
5  *
6  * File        :  $Source: /cvsroot/ijbswa/current/list.h,v $
7  *
8  * Purpose     :  Declares functions to handle lists.
9  *                Functions declared include:
10  *                   `destroy_list', `enlist' and `list_to_text'
11  *
12  * Copyright   :  Written by and Copyright (C) 2001 the SourceForge
13  *                Privoxy team. http://www.privoxy.org/
14  *
15  *                Based on the Internet Junkbuster originally written
16  *                by and Copyright (C) 1997 Anonymous Coders and 
17  *                Junkbusters Corporation.  http://www.junkbusters.com
18  *
19  *                This program is free software; you can redistribute it 
20  *                and/or modify it under the terms of the GNU General
21  *                Public License as published by the Free Software
22  *                Foundation; either version 2 of the License, or (at
23  *                your option) any later version.
24  *
25  *                This program is distributed in the hope that it will
26  *                be useful, but WITHOUT ANY WARRANTY; without even the
27  *                implied warranty of MERCHANTABILITY or FITNESS FOR A
28  *                PARTICULAR PURPOSE.  See the GNU General Public
29  *                License for more details.
30  *
31  *                The GNU General Public License should be included with
32  *                this file.  If not, you can view it at
33  *                http://www.gnu.org/copyleft/gpl.html
34  *                or write to the Free Software Foundation, Inc., 59
35  *                Temple Place - Suite 330, Boston, MA  02111-1307, USA.
36  *
37  * Revisions   :
38  *    $Log: list.h,v $
39  *    Revision 1.11  2002/03/24 13:25:43  swa
40  *    name change related issues
41  *
42  *    Revision 1.10  2002/03/07 03:46:17  oes
43  *    Fixed compiler warnings
44  *
45  *    Revision 1.9  2001/10/23 21:21:03  jongfoster
46  *    New error handling - error codes are now jb_errs, not ints.
47  *    Changed the way map() handles out-of-memory, to dramatically
48  *    reduce the amount of error-checking clutter needed.
49  *
50  *    Revision 1.8  2001/09/16 17:30:24  jongfoster
51  *    Fixing a compiler warning.
52  *
53  *    Revision 1.7  2001/09/16 13:20:29  jongfoster
54  *    Rewrite of list library.  Now has seperate header and list_entry
55  *    structures.  Also added a large sprinking of assert()s to the list
56  *    code.
57  *
58  *    Revision 1.6  2001/08/05 16:06:20  jongfoster
59  *    Modifiying "struct map" so that there are now separate header and
60  *    "map_entry" structures.  This means that functions which modify a
61  *    map no longer need to return a pointer to the modified map.
62  *    Also, it no longer reverses the order of the entries (which may be
63  *    important with some advanced template substitutions).
64  *
65  *    Revision 1.5  2001/07/29 18:43:08  jongfoster
66  *    Changing #ifdef _FILENAME_H to FILENAME_H_INCLUDED, to conform to
67  *    ANSI C rules.
68  *
69  *    Revision 1.4  2001/06/29 13:30:37  oes
70  *    - Introduced enlist_unique_header()
71  *    - Removed logentry from cancelled commit
72  *
73  *    Revision 1.3  2001/06/03 11:03:48  oes
74  *    introduced functions for new list type "map": map(), lookup(),
75  *    free_map(), and extended enlist_unique
76  *
77  *    Revision 1.2  2001/06/01 18:49:17  jongfoster
78  *    Replaced "list_share" with "list" - the tiny memory gain was not
79  *    worth the extra complexity.
80  *
81  *    Revision 1.1  2001/05/31 21:11:53  jongfoster
82  *    - Moved linked list support to new "list.c" file.
83  *      Structure definitions are still in project.h,
84  *      function prototypes are now in "list.h".
85  *    - Added support for "struct list_share", which is identical
86  *      to "struct list" except it saves memory by not duplicating
87  *      the strings.  Obviously, this only works if there is some
88  *      other way of managing the memory used by the strings.
89  *      (These list_share lists are used for lists which last
90  *      for only 1 request, and where all the list entries are
91  *      just coming directly from entries in the actionsfile.)
92  *      Note that you still need to destroy list_share lists
93  *      properly to free the nodes - it's only the strings
94  *      which are shared.
95  *
96  *
97  *********************************************************************/
98 \f
99
100 #include "project.h"
101
102 #ifdef __cplusplus
103 extern "C" {
104 #endif
105
106
107 /*
108  * struct list
109  *
110  * A linked list class.
111  */
112
113 extern void init_list    (struct list *the_list);
114 extern void destroy_list (struct list *the_list);
115
116 extern jb_err enlist                 (struct list *the_list, const char *str);
117 extern jb_err enlist_unique          (struct list *the_list, const char *str, size_t num_significant_chars);
118 extern jb_err enlist_unique_header   (struct list *the_list, const char *name, const char *value);
119 extern jb_err enlist_first           (struct list *the_list, const char *str);
120 extern jb_err list_append_list_unique(struct list *dest,     const struct list *src);
121 extern jb_err list_duplicate         (struct list *dest,     const struct list *src);
122
123 extern int    list_remove_item(struct list *the_list, const char *str);
124 extern int    list_remove_list(struct list *dest,     const struct list *src);
125 extern void   list_remove_all (struct list *the_list);
126
127 extern int    list_is_empty(const struct list *the_list);
128
129 extern char * list_to_text(const struct list *the_list);
130
131
132 /*
133  * struct map
134  *
135  * A class which maps names to values.
136  *
137  * Note: You must allocate this through new_map() and free it
138  * through free_map().
139  */
140
141 extern struct map * new_map  (void);
142 extern void         free_map (struct map * the_map);
143
144 extern int          map      (struct map * the_map,
145                               const char * name, int name_needs_copying,
146                               const char * value, int value_needs_copying);
147 extern const char * lookup   (const struct map * the_map, const char * name);
148
149
150 /* Revision control strings from this header and associated .c file */
151 extern const char list_rcs[];
152 extern const char list_h_rcs[];
153
154 #ifdef __cplusplus
155 } /* extern "C" */
156 #endif
157
158 #endif /* ndef LIST_H_INCLUDED */
159
160 /*
161   Local Variables:
162   tab-width: 3
163   end:
164 */