X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=util%2Fzebramap.c;h=e05bdcefdde6c78f46ae9ad826209eedc3664001;hb=83533000f9456dcab2fc171abafd84d6104d4087;hp=629d842fdbf5d5bfb4e8f8f943348ffb15fb8980;hpb=87142cb2b4f17d37fd5111576668d90e2a3aec3d;p=idzebra-moved-to-github.git diff --git a/util/zebramap.c b/util/zebramap.c index 629d842..e05bdce 100644 --- a/util/zebramap.c +++ b/util/zebramap.c @@ -4,7 +4,16 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: zebramap.c,v $ - * Revision 1.17 1999-09-08 12:13:21 adam + * Revision 1.20 2000-03-02 14:35:19 adam + * Added structure year and date. + * + * Revision 1.19 1999/11/30 13:48:04 adam + * Improved installation. Updated for inclusion of YAZ header files. + * + * Revision 1.18 1999/10/15 08:27:46 adam + * Fixed replace handler. 8-bit fix. + * + * Revision 1.17 1999/09/08 12:13:21 adam * Fixed minor bug "replace"-mappings. Removed some logging messages. * * Revision 1.16 1999/09/07 07:19:21 adam @@ -66,7 +75,7 @@ #include #include -#include +#include #include #include @@ -195,6 +204,9 @@ static void zebra_map_read (ZebraMaps zms, const char *name) struct zm_token *token = nmem_malloc (zms->nmem, sizeof(*token)); token->next = (*zm)->replace_tokens; (*zm)->replace_tokens = token; +#if 0 + logf (LOG_LOG, "replace %s", argv[1]); +#endif token->token_from = 0; if (argc >= 2) { @@ -213,7 +225,12 @@ static void zebra_map_read (ZebraMaps zms, const char *name) cp++; } else + { *dp++ = zebra_prim(&cp); +#if 0 + logf (LOG_LOG, " char %2X %c", dp[-1], dp[-1]); +#endif + } *dp = '\0'; } if (argc >= 3) @@ -292,7 +309,7 @@ chrmaptab zebra_charmap_get (ZebraMaps zms, unsigned reg_id) logf (LOG_WARN, "Unknown register type: %c", reg_id); zm->reg_id = reg_id; - zm->maptab_name = NULL; + zm->maptab_name = nmem_strdup (zms->nmem, "@"); zm->maptab = NULL; zm->type = ZEBRA_MAP_TYPE_INDEX; zm->completeness = 0; @@ -558,6 +575,14 @@ int zebra_maps_attr (ZebraMaps zms, Z_AttributesPlusTerm *zapt, *reg_id = '0'; *search_type = "phrase"; break; + case 4: /* year */ + *reg_id = 'y'; + *search_type = "phrase"; + break; + case 5: /* date */ + *reg_id = 'd'; + *search_type = "phrase"; + break; default: return -1; } @@ -574,10 +599,10 @@ WRBUF zebra_replace(ZebraMaps zms, unsigned reg_id, const char *ex_list, wrbuf_rewind(zms->wrbuf_1); wrbuf_write(zms->wrbuf_1, input_str, input_len); - if (!zm->replace_tokens) + if (!zm || !zm->replace_tokens) return zms->wrbuf_1; -#if 0 +#if 0 logf (LOG_LOG, "in:%.*s:", wrbuf_len(zms->wrbuf_1), wrbuf_buf(zms->wrbuf_1)); #endif @@ -627,7 +652,7 @@ int zebra_replace_sub(ZebraMaps zms, unsigned reg_id, const char *ex_list, if (i+j < 0 || j+i >= input_len) c = ' '; else - c = tolower(input_str[j+i]); + c = input_str[j+i] & 255; if (token->token_from[j] == ZEBRA_REPLACE_ANY) { if (c == ' ') @@ -637,7 +662,9 @@ int zebra_replace_sub(ZebraMaps zms, unsigned reg_id, const char *ex_list, else { if (c != token->token_from[j]) + { break; + } if (!replace_done) { const char *cp = token->token_to;