0e97276f709a3b2dbaaebd81f9df71ca2586aa66
[privoxy.git] / actions.h
1 #ifndef ACTIONS_H_INCLUDED
2 #define ACTIONS_H_INCLUDED
3 #define ACTIONS_H_VERSION "$Id: actions.h,v 1.14 2006/07/18 14:48:45 david__schmidt Exp $"
4 /*********************************************************************
5  *
6  * File        :  $Source: /cvsroot/ijbswa/current/actions.h,v $
7  *
8  * Purpose     :  Declares functions to work with actions files
9  *                Functions declared include: FIXME
10  *
11  * Copyright   :  Written by and Copyright (C) 2001-2007 the SourceForge
12  *                Privoxy team. http://www.privoxy.org/
13  *
14  *                Based on the Internet Junkbuster originally written
15  *                by and Copyright (C) 1997 Anonymous Coders and 
16  *                Junkbusters Corporation.  http://www.junkbusters.com
17  *
18  *                This program is free software; you can redistribute it 
19  *                and/or modify it under the terms of the GNU General
20  *                Public License as published by the Free Software
21  *                Foundation; either version 2 of the License, or (at
22  *                your option) any later version.
23  *
24  *                This program is distributed in the hope that it will
25  *                be useful, but WITHOUT ANY WARRANTY; without even the
26  *                implied warranty of MERCHANTABILITY or FITNESS FOR A
27  *                PARTICULAR PURPOSE.  See the GNU General Public
28  *                License for more details.
29  *
30  *                The GNU General Public License should be included with
31  *                this file.  If not, you can view it at
32  *                http://www.gnu.org/copyleft/gpl.html
33  *                or write to the Free Software Foundation, Inc., 59
34  *                Temple Place - Suite 330, Boston, MA  02111-1307, USA.
35  *
36  * Revisions   :
37  *    $Log: actions.h,v $
38  *    Revision 1.14  2006/07/18 14:48:45  david__schmidt
39  *    Reorganizing the repository: swapping out what was HEAD (the old 3.1 branch)
40  *    with what was really the latest development (the v_3_0_branch branch)
41  *
42  *    Revision 1.12  2002/05/06 07:56:50  oes
43  *    Made actions_to_html independent of FEATURE_CGI_EDIT_ACTIONS
44  *
45  *    Revision 1.11  2002/04/30 11:14:52  oes
46  *    Made csp the first parameter in *action_to_html
47  *
48  *    Revision 1.10  2002/04/26 12:53:33  oes
49  *     -  actions_to_html signature change
50  *     -  current_action_to_text: renamed to current_action_to_html
51  *        and signature change
52  *
53  *    Revision 1.9  2002/03/26 22:29:54  swa
54  *    we have a new homepage!
55  *
56  *    Revision 1.8  2002/03/24 13:25:43  swa
57  *    name change related issues
58  *
59  *    Revision 1.7  2002/03/16 23:54:06  jongfoster
60  *    Adding graceful termination feature, to help look for memory leaks.
61  *    If you enable this (which, by design, has to be done by hand
62  *    editing config.h) and then go to http://i.j.b/die, then the program
63  *    will exit cleanly after the *next* request.  It should free all the
64  *    memory that was used.
65  *
66  *    Revision 1.6  2001/10/23 21:30:30  jongfoster
67  *    Adding error-checking to selected functions.
68  *
69  *    Revision 1.5  2001/10/14 21:58:22  jongfoster
70  *    Adding support for the CGI-based editor:
71  *    - Exported get_actions()
72  *    - Added new function free_alias_list()
73  *    - Added support for {{settings}} and {{description}} blocks
74  *      in the actions file.  They are currently ignored.
75  *    - Added restriction to only one {{alias}} block which must appear
76  *      first in the file, to simplify the editor's rewriting rules.
77  *    - Note that load_actions_file() is no longer used by the CGI-based
78  *      editor, but some of the other routines in this file are.
79  *
80  *    Revision 1.4  2001/09/16 15:47:37  jongfoster
81  *    First version of CGI-based edit interface.  This is very much a
82  *    work-in-progress, and you can't actually use it to edit anything
83  *    yet.  You must #define FEATURE_CGI_EDIT_ACTIONS for these changes
84  *    to have any effect.
85  *
86  *    Revision 1.3  2001/09/14 00:17:32  jongfoster
87  *    Tidying up memory allocation. New function init_action().
88  *
89  *    Revision 1.2  2001/07/29 19:01:11  jongfoster
90  *    Changed _FILENAME_H to FILENAME_H_INCLUDED.
91  *    Added forward declarations for needed structures.
92  *
93  *    Revision 1.1  2001/05/31 21:16:46  jongfoster
94  *    Moved functions to process the action list into this new file.
95  *
96  *
97  *********************************************************************/
98 \f
99
100 #ifdef __cplusplus
101 extern "C" {
102 #endif
103
104
105 struct action_spec;
106 struct current_action_spec;
107 struct client_state;
108
109
110
111 /* This structure is used to hold user-defined aliases */
112 struct action_alias
113 {
114    const char * name;
115    struct action_spec action[1];
116    struct action_alias * next;
117 };
118
119
120 extern jb_err get_actions (char *line, 
121                            struct action_alias * alias_list,
122                            struct action_spec *cur_action);
123 extern void free_alias_list(struct action_alias *alias_list);
124
125 extern void init_action(struct action_spec *dest);
126 extern void free_action(struct action_spec *src);
127 extern jb_err merge_actions (struct action_spec *dest, 
128                              const struct action_spec *src);
129 extern int update_action_bits(struct client_state *csp);
130 extern jb_err copy_action (struct action_spec *dest, 
131                            const struct action_spec *src);
132 extern char * actions_to_text     (struct action_spec *action);
133 extern char * actions_to_html     (struct client_state *csp,
134                                    struct action_spec *action);
135 extern void init_current_action     (struct current_action_spec *dest);
136 extern void free_current_action     (struct current_action_spec *src);
137 extern jb_err merge_current_action  (struct current_action_spec *dest, 
138                                      const struct action_spec *src);
139 extern char * current_action_to_html(struct client_state *csp,
140                                      struct current_action_spec *action);
141
142 extern jb_err get_action_token(char **line, char **name, char **value);
143 extern void unload_actions_file(void *file_data);
144 extern int load_actions_file(struct client_state *csp);
145
146 #ifdef FEATURE_GRACEFUL_TERMINATION
147 void unload_current_actions_file(void);
148 #endif
149
150
151 /* Revision control strings from this header and associated .c file */
152 extern const char actions_rcs[];
153 extern const char actions_h_rcs[];
154
155 #ifdef __cplusplus
156 } /* extern "C" */
157 #endif
158
159 #endif /* ndef ACTIONS_H_INCLUDED */
160
161 /*
162   Local Variables:
163   tab-width: 3
164   end:
165 */
166