X-Git-Url: http://www.privoxy.org/gitweb/?p=privoxy.git;a=blobdiff_plain;f=actions.c;h=a1c00f980299e539cf5b6352a8786af426596bc2;hp=8e731387414201baf8e4247bbd147cf928dc8c37;hb=2af67a6ef60b2a0b05c51f2e0899200028116863;hpb=cd25f2f3e6faf2b5f46e01bf670d16364ed49d8f diff --git a/actions.c b/actions.c index 8e731387..a1c00f98 100644 --- a/actions.c +++ b/actions.c @@ -1,12 +1,11 @@ -const char actions_rcs[] = "$Id: actions.c,v 1.93 2015/08/12 10:33:13 fabiankeil Exp $"; /********************************************************************* * * File : $Source: /cvsroot/ijbswa/current/actions.c,v $ * * Purpose : Declares functions to work with actions files * - * Copyright : Written by and Copyright (C) 2001-2011 the - * Privoxy team. http://www.privoxy.org/ + * Copyright : Written by and Copyright (C) 2001-2016 the + * Privoxy team. https://www.privoxy.org/ * * Based on the Internet Junkbuster originally written * by and Copyright (C) 1997 Anonymous Coders and @@ -57,9 +56,6 @@ const char actions_rcs[] = "$Id: actions.c,v 1.93 2015/08/12 10:33:13 fabiankeil #include "ssplit.h" #include "filters.h" -const char actions_h_rcs[] = ACTIONS_H_VERSION; - - /* * We need the main list of options. * @@ -124,7 +120,10 @@ static const struct action_name action_names[] = }; -static int load_one_actions_file(struct client_state *csp, int fileid); +#ifndef FUZZ +static +#endif +int load_one_actions_file(struct client_state *csp, int fileid); /********************************************************************* @@ -1080,6 +1079,44 @@ int load_action_files(struct client_state *csp) } +/********************************************************************* + * + * Function : filter_type_to_string + * + * Description : Converts a filter type enum into a string. + * + * Parameters : + * 1 : filter_type = filter_type as enum + * + * Returns : Pointer to static string. + * + *********************************************************************/ +static const char *filter_type_to_string(enum filter_type filter_type) +{ + switch (filter_type) + { + case FT_CONTENT_FILTER: + return "content filter"; + case FT_CLIENT_HEADER_FILTER: + return "client-header filter"; + case FT_SERVER_HEADER_FILTER: + return "server-header filter"; + case FT_CLIENT_HEADER_TAGGER: + return "client-header tagger"; + case FT_SERVER_HEADER_TAGGER: + return "server-header tagger"; +#ifdef FEATURE_EXTERNAL_FILTERS + case FT_EXTERNAL_CONTENT_FILTER: + return "external content filter"; +#endif + case FT_INVALID_FILTER: + return "invalid filter type"; + } + + return "unknown filter type"; + +} + /********************************************************************* * * Function : referenced_filters_are_missing @@ -1106,7 +1143,8 @@ static int referenced_filters_are_missing(const struct client_state *csp, { if (NULL == get_filter(csp, filtername->str, filter_type)) { - log_error(LOG_LEVEL_ERROR, "Missing filter '%s'", filtername->str); + log_error(LOG_LEVEL_ERROR, "Missing %s '%s'", + filter_type_to_string(filter_type), filtername->str); return 1; } } @@ -1171,7 +1209,10 @@ static int action_spec_is_valid(struct client_state *csp, const struct action_sp * Returns : 0 => Ok, everything else is an error. * *********************************************************************/ -static int load_one_actions_file(struct client_state *csp, int fileid) +#ifndef FUZZ +static +#endif +int load_one_actions_file(struct client_state *csp, int fileid) { /* @@ -1212,13 +1253,7 @@ static int load_one_actions_file(struct client_state *csp, int fileid) return 1; /* never get here */ } - fs->f = last_perm = (struct url_actions *)zalloc(sizeof(*last_perm)); - if (last_perm == NULL) - { - log_error(LOG_LEVEL_FATAL, "can't load actions file '%s': out of memory!", - csp->config->actions_file[fileid]); - return 1; /* never get here */ - } + fs->f = last_perm = zalloc_or_die(sizeof(*last_perm)); if ((fp = fopen(csp->config->actions_file[fileid], "r")) == NULL) { @@ -1362,15 +1397,7 @@ static int load_one_actions_file(struct client_state *csp, int fileid) cur_action = NULL; } cur_action_used = 0; - cur_action = (struct action_spec *)zalloc(sizeof(*cur_action)); - if (cur_action == NULL) - { - fclose(fp); - log_error(LOG_LEVEL_FATAL, - "can't load actions file '%s': out of memory", - csp->config->actions_file[fileid]); - return 1; /* never get here */ - } + cur_action = zalloc_or_die(sizeof(*cur_action)); init_action(cur_action); /* @@ -1486,14 +1513,7 @@ static int load_one_actions_file(struct client_state *csp, int fileid) return 1; /* never get here */ } - if ((new_alias = zalloc(sizeof(*new_alias))) == NULL) - { - fclose(fp); - log_error(LOG_LEVEL_FATAL, - "can't load actions file '%s': out of memory!", - csp->config->actions_file[fileid]); - return 1; /* never get here */ - } + new_alias = zalloc_or_die(sizeof(*new_alias)); /* Eat any the whitespace before the '=' */ end--; @@ -1544,14 +1564,7 @@ static int load_one_actions_file(struct client_state *csp, int fileid) /* it's an URL pattern */ /* allocate a new node */ - if ((perm = zalloc(sizeof(*perm))) == NULL) - { - fclose(fp); - log_error(LOG_LEVEL_FATAL, - "can't load actions file '%s': out of memory!", - csp->config->actions_file[fileid]); - return 1; /* never get here */ - } + perm = zalloc_or_die(sizeof(*perm)); perm->action = cur_action; cur_action_used = 1;