Mercurial > ~dholland > hg > ag > index.cgi
view anagram/agcore/dict.h @ 15:f5acaf0c8a29
Don't cast through "volatile int". Causes a gcc warning nowadays.
XXX: should put something else back here to frighten the optimizer
author | David A. Holland |
---|---|
date | Tue, 31 May 2022 01:00:55 -0400 |
parents | 13d2b8934445 |
children |
line wrap: on
line source
/* * AnaGram, A System for Syntax Directed Programming * Copyright 1993 Parsifal Software. All Rights Reserved. * See the file COPYING for license and usage terms. * * dict.h - old dictionary module */ #ifndef DICT_H #define DICT_H struct string_dict { unsigned *ndx; /* index array */ unsigned nsx; /* number of strings */ unsigned nxs; /* number of indices allocated */ char *text; /* text */ unsigned ntc; /* number of text characters */ unsigned nts; /* length of test storage */ //unsigned short *ht; /* pointer to hash table */ unsigned *ht; /* pointer to hash table */ unsigned nhs; /* number of hash table slots */ unsigned *st; /* sort table */ unsigned nss; /* number of entries sorted */ unsigned *pt; /* permutation table */ unsigned ignore_case : 1; /* ignore case flag */ }; struct list_dict { unsigned *ndx; /* index array */ unsigned nsx; /* number of lists */ unsigned nxs; /* number of indices allocated */ int *text; /* text */ unsigned ntc; /* number of text characters */ unsigned nts; /* length of test storage */ //unsigned short *ht; /* pointer to hash table */ unsigned *ht; /* pointer to hash table */ unsigned nhs; /* number of hash table slots */ unsigned *st; /* sort table */ unsigned nss; /* number of entries sorted */ unsigned *pt; /* permutation table */ }; struct tuple_dict { unsigned *ndx; /* index array */ unsigned nsx; /* number of lists */ unsigned nxs; /* number of indices allocated */ int *text; /* text */ unsigned ntc; /* number of text characters */ unsigned nts; /* length of test storage */ //unsigned short *ht; /* pointer to hash table */ unsigned *ht; /* pointer to hash table */ unsigned nhs; /* number of hash table slots */ unsigned *st; /* sort table */ unsigned nss; /* number of entries sorted */ unsigned *pt; /* permutation table */ unsigned tw; /* tuple width */ }; #define dict_str(d,n) ((d)->text+(d)->ndx[n]) int add_list_dict(const int *s, int n, list_dict *d); int add_string_dict(const char *s, string_dict *d); int add_tuple_dict_new(tuple_dict *d, ...); list_dict *delete_list_dict(list_dict *da); string_dict *delete_string_dict(string_dict *da); tuple_dict *delete_tuple_dict(tuple_dict *da); void empty_tuple_dict(tuple_dict *); void extract_tuple_dict(tuple_dict *d, unsigned k, ...); int identify_string(const char *, string_dict *d); int insert_tuple_dict(tuple_dict *d, ...); int list_in_dict(int*, int, list_dict *); list_dict *reset_list_dict(list_dict *d); tuple_dict *reset_tuple_dict(tuple_dict *d); list_dict *null_list_dict(void); string_dict *null_str_dict(void); tuple_dict *null_tuple_dict(int tw); //string_dict *restore_string_dict(char *text, int ntc, int ne, int ic, // int byte_swap_required); //void sort_string_dict(string_dict *d); #endif /* DICT_H */