X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Fdict.h;h=84b6e48686a00ff583572f26dee9b962d7366d85;hb=3eb26862c3e82f9332c75c9c560f1044f80bc778;hp=2323ac7a252045a311db7f694ea91e13976342dd;hpb=b31a8654c5b7a597dd4a351f452ac91e5ef60798;p=idzebra-moved-to-github.git diff --git a/include/dict.h b/include/dict.h index 2323ac7..84b6e48 100644 --- a/include/dict.h +++ b/include/dict.h @@ -4,7 +4,14 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: dict.h,v $ - * Revision 1.19 1996-02-02 13:43:54 adam + * Revision 1.21 1996-05-24 14:46:07 adam + * Added dict_grep_cmap function to define user-mapping in grep lookups. + * + * Revision 1.20 1996/03/20 09:35:23 adam + * Function dict_lookup_grep got extra parameter, init_pos, which marks + * from which position in pattern approximate pattern matching should occur. + * + * Revision 1.19 1996/02/02 13:43:54 adam * The public functions simply use char instead of Dict_char to represent * search strings. Dict_char is used internally only. * @@ -114,9 +121,9 @@ typedef struct Dict_file_struct typedef struct Dict_struct { int rw; Dict_BFile dbf; + char **(*grep_cmap)(const char **from); struct Dict_head head; -} -*Dict; +} *Dict; #define DICT_MAGIC "dict00" @@ -137,7 +144,7 @@ char *dict_lookup (Dict dict, const char *p); int dict_lookup_ec (Dict dict, char *p, int range, int (*f)(char *name)); int dict_lookup_grep (Dict dict, const char *p, int range, void *client, - int *max_pos, + int *max_pos, int init_pos, int (*f)(char *name, const char *info, void *client)); int dict_strcmp (const Dict_char *s1, const Dict_char *s2); @@ -147,6 +154,9 @@ int dict_scan (Dict dict, char *str, int (*f)(char *name, const char *info, int pos, void *client)); +void dict_grep_cmap (Dict dict, char **(*cmap)(const char **from)); + + #define DICT_EOS 0 #define DICT_type(x) 0[(Dict_ptr*) x] #define DICT_backptr(x) 1[(Dict_ptr*) x]