9aa6fa1997-05-19Fredrik Hübinette (Hubbe) /*\ ||| This file a part of Pike, and is copyright by Fredrik Hubinette ||| Pike is distributed as GPL (General Public License) ||| See the files COPYING and DISCLAIMER for more information. \*/
24ddc71998-03-28Henrik Grubbström (Grubba)  /*
4218011999-01-31Fredrik Hübinette (Hubbe)  * $Id: pike_memory.h,v 1.8 1999/01/31 09:01:59 hubbe Exp $
24ddc71998-03-28Henrik Grubbström (Grubba)  */
9aa6fa1997-05-19Fredrik Hübinette (Hubbe) #ifndef MEMORY_H #define MEMORY_H #include "global.h"
3e625c1998-10-11Fredrik Hübinette (Hubbe) #include "stralloc.h"
9aa6fa1997-05-19Fredrik Hübinette (Hubbe)  #define MEMSEARCH_LINKS 512 struct link { struct link *next; INT32 key, offset; }; enum methods { no_search, use_memchr, memchr_and_memcmp,
db4a401998-10-09Fredrik Hübinette (Hubbe)  hubbe_search, boyer_moore
9aa6fa1997-05-19Fredrik Hübinette (Hubbe) }; struct mem_searcher { enum methods method; char *needle; SIZE_T needlelen; unsigned INT32 hsize, max; struct link links[MEMSEARCH_LINKS]; struct link *set[MEMSEARCH_LINKS]; };
db4a401998-10-09Fredrik Hübinette (Hubbe) struct generic_mem_searcher { char needle_shift; char haystack_shift; union data_u { struct mem_searcher eightbit; struct other_search_s { enum methods method; void *needle; SIZE_T needlelen; int first_char; } other; } data; };
4218011999-01-31Fredrik Hübinette (Hubbe) #include "block_alloc_h.h"
db4a401998-10-09Fredrik Hübinette (Hubbe) #define MEMCHR0 MEMCHR
9aa6fa1997-05-19Fredrik Hübinette (Hubbe) /* Prototypes begin here */
db4a401998-10-09Fredrik Hübinette (Hubbe) INLINE p_wchar1 *MEMCHR1(p_wchar1 *p,p_wchar1 c,INT32 e); INLINE p_wchar2 *MEMCHR2(p_wchar2 *p,p_wchar2 c,INT32 e);
9aa6fa1997-05-19Fredrik Hübinette (Hubbe) void swap(char *a, char *b, INT32 size); void reverse(char *memory, INT32 nitems, INT32 size); void reorder(char *memory, INT32 nitems, INT32 size,INT32 *order); unsigned INT32 hashmem(const unsigned char *a,INT32 len,INT32 mlen); unsigned INT32 hashstr(const unsigned char *str,INT32 maxn); void init_memsearch(struct mem_searcher *s, char *needle, SIZE_T needlelen, SIZE_T max_haystacklen); char *memory_search(struct mem_searcher *s, char *haystack, SIZE_T haystacklen);
db4a401998-10-09Fredrik Hübinette (Hubbe) void init_generic_memsearcher(struct generic_mem_searcher *s, void *needle, SIZE_T needlelen, char needle_shift, SIZE_T estimated_haystack, char haystack_shift); void *generic_memory_search(struct generic_mem_searcher *s, void *haystack, SIZE_T haystacklen, char haystack_shift);
9aa6fa1997-05-19Fredrik Hübinette (Hubbe) char *my_memmem(char *needle, SIZE_T needlelen, char *haystack, SIZE_T haystacklen); void memfill(char *to, INT32 tolen, char *from, INT32 fromlen, INT32 offset); /* Prototypes end here */
db4a401998-10-09Fredrik Hübinette (Hubbe) #undef BLOCK_ALLOC
9aa6fa1997-05-19Fredrik Hübinette (Hubbe) #endif