X-Git-Url: https://git.deb.at/?a=blobdiff_plain;f=filter.c;h=2cb145ce9e9e0965d1d624bdeace1171b296c6f5;hb=b1c882049db5d6d7d5770134cd93e14934ace6c1;hp=eb6e778042f9c63cef421e0306497868e0ef0b80;hpb=44943895d38d31d31e3d948e681b02f3be1cc83c;p=pkg%2Fabook.git diff --git a/filter.c b/filter.c index eb6e778..2cb145c 100644 --- a/filter.c +++ b/filter.c @@ -2562,6 +2562,14 @@ bsdcal_export_database(FILE *out, struct db_enumerator e) return 0; } +/* + * end of BSD calendar export filter + */ + +/* + * custom export filter + */ + static int find_field_enum(char *s) { int i = -1; @@ -2646,8 +2654,7 @@ parse_custom_format(char *s, char *fmt_string, enum field_types *ft) cannotparse: fprintf(stderr, _("%s: invalid format, index %ld\n"), __FUNCTION__, (start - s)); - free(fmt_string); - while(*ft) free(ft--); + free(ft); exit(EXIT_FAILURE); } @@ -2655,10 +2662,12 @@ static int custom_export_item(FILE *out, int item, char *s, enum field_types *ft); -// used to store the format string from --outformatstr when "custom" format is used -// default value overriden in export_file() -extern char *parsed_custom_format; -extern enum field_types *custom_format_fields; +// stores the format string generated from --outformatstr {custom_format} +// (when "custom" output format is requested) +// overrides default value of custom_format set by from abook.c +extern char custom_format[FORMAT_STRING_LEN]; +char parsed_custom_format[FORMAT_STRING_LEN]; +enum field_types *custom_format_fields = 0; /* wrapper for custom_export_item: 1) avoid messing with extern pointer @@ -2716,28 +2725,20 @@ custom_export_item(FILE *out, int item, char *fmt, enum field_types *ft) return 0; } -// used to store the format string from --outformatstr when "custom" format is used -// default value overriden from abook.c -extern char custom_format[FORMAT_STRING_LEN]; - static int custom_export_database(FILE *out, struct db_enumerator e) { - char *format_string = (char *)malloc(FORMAT_STRING_LEN); - enum field_types *ft = (enum field_types *)malloc(FORMAT_STRING_MAX_FIELDS * sizeof(enum field_types)); - parse_custom_format(custom_format, format_string, ft); - + parse_custom_format(custom_format, (char*)&parsed_custom_format, ft); db_enumerate_items(e) { - if(custom_export_item(out, e.item, format_string, ft) == 0) + if(custom_export_item(out, e.item, (char*)&parsed_custom_format, ft) == 0) fprintf(out, "\n"); } return 0; } /* - * end of BSD calendar export filter + * end of custom export filter */ -