X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Fdict.h;h=84b6e48686a00ff583572f26dee9b962d7366d85;hb=3eb26862c3e82f9332c75c9c560f1044f80bc778;hp=2b78d2df3b4871eaa22ae2f23af4123d453026f3;hpb=d07818ca27f4e0efc9683148cb5d9891d34b9495;p=idzebra-moved-to-github.git diff --git a/include/dict.h b/include/dict.h index 2b78d2d..84b6e48 100644 --- a/include/dict.h +++ b/include/dict.h @@ -4,7 +4,18 @@ * Sebastian Hammer, Adam Dickmeiss * * $Log: dict.h,v $ - * Revision 1.18 1996-02-01 20:41:06 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. + * + * Revision 1.18 1996/02/01 20:41:06 adam * Bug fix: insert didn't work on 8-bit characters due to unsigned char * compares in dict_strcmp (strcmp) and signed Dict_char. Dict_char is * unsigned now. @@ -110,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" @@ -127,23 +138,25 @@ int dict_bf_close (Dict_BFile dbf); Dict dict_open (const char *name, int cache, int rw); int dict_close (Dict dict); -int dict_insert (Dict dict, const Dict_char *p, int userlen, - void *userinfo); -int dict_delete (Dict dict, const Dict_char *p); -char *dict_lookup (Dict dict, const Dict_char *p); -int dict_lookup_ec (Dict dict, Dict_char *p, int range, - int (*f)(Dict_char *name)); -int dict_lookup_grep (Dict dict, Dict_char *p, int range, void *client, - int *max_pos, - int (*f)(Dict_char *name, const char *info, +int dict_insert (Dict dict, const char *p, int userlen, void *userinfo); +int dict_delete (Dict dict, const char *p); +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 init_pos, + int (*f)(char *name, const char *info, void *client)); int dict_strcmp (const Dict_char *s1, const Dict_char *s2); int dict_strlen (const Dict_char *s); -int dict_scan (Dict dict, Dict_char *str, +int dict_scan (Dict dict, char *str, int *before, int *after, void *client, - int (*f)(Dict_char *name, const char *info, int pos, + 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]