#include "config.h" #include "udi.h" #include "utarray.h" #include "uthash.h" /* Argument Indexing */ struct udi_p_args { int arg; //indexed arg void *idxstr; //user indexing structure UdiControlBlock control; //user indexing structure functions }; typedef struct udi_p_args *UdiPArg; UT_icd arg_icd = {sizeof(struct udi_p_args), NULL, NULL, NULL }; /* clauselist */ UT_icd cl_icd = {sizeof(yamop *), NULL, NULL, NULL }; /* * All the info we need to enter user indexed code * stored in a uthash */ struct udi_info { PredEntry *p; //predicate (need to identify asserts) UT_array *clauselist; //clause list used on returns UT_array *args; //indexed args UT_hash_handle hh; //uthash handle }; typedef struct udi_info *UdiInfo; /* to ease code for a UdiInfo hash table*/ #define HASH_FIND_UdiInfo(head,find,out) \ HASH_FIND(hh,head,find,sizeof(PredEntry),out) #define HASH_ADD_UdiInfo(head,p,add) \ HASH_ADD_KEYPTR(hh,head,p,sizeof(PredEntry *),add) /* used during init */ static YAP_Int p_new_udi( USES_REGS1 ); static YAP_Int p_udi_args_init(Term spec, int arity, UdiInfo blk); /* * Indexing Search and intersection Helpers */ /* single indexing helpers (no intersection needed just create clauselist) */ #include "clause_list.h" struct si_callback_h { clause_list_t cl; UT_array *clauselist; void * pred; }; typedef struct si_callback_h * si_callback_h_t; static inline int si_callback(void *key, void *data, void *arg) { si_callback_h_t c = (si_callback_h_t) arg; yamop **cl = (yamop **) utarray_eltptr(c->clauselist, ((YAP_Int) data) - 1); return Yap_ClauseListExtend(c->cl, *cl, c->pred); } #ifdef USE_JUDY #include <Judy.h> /* Judy1 integer sparse set intersection */ static inline int j1_callback(void *key, void *data, void *arg) { int r; Pvoid_t *array = (Pvoid_t *) arg; J1S(r, *array, (int) data); if (r == JERR) return FALSE; return TRUE; } #endif