e122f2ca8d
in the local tries (and not in the global trie). This required major changes to the trie instructions in order to unify the use of the auxiliary stack organization for the terms in the local tries and in the global trie.
1215 lines
49 KiB
OpenEdge ABL
1215 lines
49 KiB
OpenEdge ABL
/************************************************************************
|
|
** **
|
|
** The YapTab/YapOr/OPTYap systems **
|
|
** **
|
|
** YapTab extends the Yap Prolog engine to support sequential tabling **
|
|
** YapOr extends the Yap Prolog engine to support or-parallelism **
|
|
** OPTYap extends the Yap Prolog engine to support or-parallel tabling **
|
|
** **
|
|
** **
|
|
** Yap Prolog was developed at University of Porto, Portugal **
|
|
** **
|
|
************************************************************************/
|
|
|
|
/************************************************************************
|
|
** Trie instructions: auxiliary stack organization **
|
|
*************************************************************************
|
|
-------------------
|
|
| ha = heap_arity |
|
|
------------------- --
|
|
| heap ptr 1 | |
|
|
------------------- |
|
|
| ... | -- heap_arity (0 if GLOBAL_TRIE)
|
|
------------------- |
|
|
| heap ptr ha | |
|
|
------------------- --
|
|
| va = vars_arity |
|
|
------------------- --
|
|
| var ptr va | |
|
|
------------------- |
|
|
| ... | -- vars_arity
|
|
------------------- |
|
|
| var ptr 1 | |
|
|
------------------- --
|
|
| sa = subs_arity |
|
|
------------------- --
|
|
| subs ptr sa | |
|
|
------------------- |
|
|
| ... | -- subs_arity
|
|
------------------- |
|
|
| subs ptr 1 | |
|
|
------------------- --
|
|
************************************************************************/
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** Trie instructions: macros **
|
|
************************************************************************/
|
|
|
|
#define TOP_STACK YENV
|
|
|
|
#define HEAP_ARITY_ENTRY (0)
|
|
#define VARS_ARITY_ENTRY (1 + heap_arity)
|
|
#define SUBS_ARITY_ENTRY (1 + heap_arity + 1 + vars_arity)
|
|
|
|
/* macros 'HEAP_ENTRY', 'VARS_ENTRY' and 'SUBS_ENTRY' **
|
|
** assume that INDEX starts at 1 (and not at 0 !!!) */
|
|
#define HEAP_ENTRY(INDEX) (HEAP_ARITY_ENTRY + (INDEX))
|
|
#define VARS_ENTRY(INDEX) (VARS_ARITY_ENTRY + 1 + vars_arity - (INDEX))
|
|
#define SUBS_ENTRY(INDEX) (SUBS_ARITY_ENTRY + 1 + subs_arity - (INDEX))
|
|
|
|
#define next_trie_instruction(NODE) \
|
|
PREG = (yamop *) TrNode_child(NODE); \
|
|
PREFETCH_OP(PREG); \
|
|
GONext()
|
|
|
|
#define next_instruction(CONDITION, NODE) \
|
|
if (CONDITION) { \
|
|
PREG = (yamop *) TrNode_child(NODE); \
|
|
} else { /* procceed */ \
|
|
PREG = (yamop *) CPREG; \
|
|
TOP_STACK = ENV; \
|
|
} \
|
|
PREFETCH_OP(PREG); \
|
|
GONext()
|
|
|
|
#define copy_aux_stack() \
|
|
{ int size = 3 + heap_arity + subs_arity + vars_arity; \
|
|
TOP_STACK -= size; \
|
|
memcpy(TOP_STACK, aux_stack, size * sizeof(CELL *)); \
|
|
aux_stack = TOP_STACK; \
|
|
}
|
|
|
|
/* macros 'store_trie_node', 'restore_trie_node' and 'pop_trie_node' **
|
|
** do not include 'set_cut' because trie instructions are cut safe */
|
|
|
|
#define store_trie_node(AP) \
|
|
{ register choiceptr cp; \
|
|
TOP_STACK = (CELL *) (NORM_CP(TOP_STACK) - 1); \
|
|
cp = NORM_CP(TOP_STACK); \
|
|
HBREG = H; \
|
|
store_yaam_reg_cpdepth(cp); \
|
|
cp->cp_tr = TR; \
|
|
cp->cp_h = H; \
|
|
cp->cp_b = B; \
|
|
cp->cp_cp = CPREG; \
|
|
cp->cp_ap = (yamop *) AP; \
|
|
cp->cp_env= ENV; \
|
|
B = cp; \
|
|
YAPOR_SET_LOAD(B); \
|
|
SET_BB(B); \
|
|
TABLING_ERRORS_check_stack; \
|
|
} \
|
|
copy_aux_stack()
|
|
|
|
#define restore_trie_node(AP) \
|
|
H = HBREG = PROTECT_FROZEN_H(B); \
|
|
restore_yaam_reg_cpdepth(B); \
|
|
CPREG = B->cp_cp; \
|
|
ENV = B->cp_env; \
|
|
YAPOR_update_alternative(PREG, (yamop *) AP) \
|
|
B->cp_ap = (yamop *) AP; \
|
|
TOP_STACK = (CELL *) PROTECT_FROZEN_B(B); \
|
|
SET_BB(NORM_CP(TOP_STACK)); \
|
|
copy_aux_stack()
|
|
|
|
#define really_pop_trie_node() \
|
|
TOP_STACK = (CELL *) PROTECT_FROZEN_B((B + 1)); \
|
|
H = PROTECT_FROZEN_H(B); \
|
|
pop_yaam_reg_cpdepth(B); \
|
|
CPREG = B->cp_cp; \
|
|
TABLING_close_alt(B); \
|
|
ENV = B->cp_env; \
|
|
B = B->cp_b; \
|
|
HBREG = PROTECT_FROZEN_H(B); \
|
|
SET_BB(PROTECT_FROZEN_B(B)); \
|
|
if ((choiceptr) TOP_STACK == B_FZ) { \
|
|
copy_aux_stack(); \
|
|
}
|
|
|
|
#ifdef YAPOR
|
|
#define pop_trie_node() \
|
|
if (SCH_top_shared_cp(B)) { \
|
|
restore_trie_node(NULL); \
|
|
} else { \
|
|
really_pop_trie_node(); \
|
|
}
|
|
#else
|
|
#define pop_trie_node() \
|
|
really_pop_trie_node()
|
|
#endif /* YAPOR */
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** aux_stack_null_instr **
|
|
************************************************************************/
|
|
|
|
#define aux_stack_null_instr() \
|
|
next_trie_instruction(node)
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** aux_stack_extension_instr **
|
|
************************************************************************/
|
|
|
|
#define aux_stack_extension_instr() \
|
|
TOP_STACK = &aux_stack[-2]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity + 2; \
|
|
TOP_STACK[HEAP_ENTRY(1)] = TrNode_entry(node); \
|
|
TOP_STACK[HEAP_ENTRY(2)] = 0; /* extension mark */ \
|
|
next_trie_instruction(node)
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** aux_stack_term_(in_pair_)instr **
|
|
************************************************************************/
|
|
|
|
#define aux_stack_term_instr() \
|
|
if (heap_arity) { \
|
|
Bind_Global((CELL *) aux_stack[HEAP_ENTRY(1)], t); \
|
|
TOP_STACK = &aux_stack[1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity - 1; \
|
|
next_instruction(heap_arity - 1 || subs_arity, node); \
|
|
} else { \
|
|
Bind((CELL *) aux_stack[SUBS_ENTRY(1)], t); \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
next_instruction(subs_arity - 1, node); \
|
|
}
|
|
|
|
#define aux_stack_term_in_pair_instr() \
|
|
if (heap_arity) { \
|
|
Bind_Global((CELL *) aux_stack[HEAP_ENTRY(1)], AbsPair(H)); \
|
|
} else { \
|
|
Bind((CELL *) aux_stack[SUBS_ENTRY(1)], AbsPair(H)); \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
TOP_STACK = &aux_stack[-1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = 1; \
|
|
} \
|
|
Bind_Global(H, TrNode_entry(node)); \
|
|
TOP_STACK[HEAP_ENTRY(1)] = (CELL) (H + 1); \
|
|
H += 2; \
|
|
next_trie_instruction(node)
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** aux_stack_(new_)pair_instr **
|
|
************************************************************************/
|
|
|
|
#define aux_stack_new_pair_instr() /* for term 'CompactPairInit' */ \
|
|
if (heap_arity) { \
|
|
Bind_Global((CELL *) aux_stack[HEAP_ENTRY(1)], AbsPair(H)); \
|
|
TOP_STACK = &aux_stack[-1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity + 1; \
|
|
} else { \
|
|
Bind((CELL *) aux_stack[SUBS_ENTRY(1)], AbsPair(H)); \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
TOP_STACK = &aux_stack[-2]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = 2; \
|
|
} \
|
|
TOP_STACK[HEAP_ENTRY(1)] = (CELL) H; \
|
|
TOP_STACK[HEAP_ENTRY(2)] = (CELL) (H + 1); \
|
|
H += 2; \
|
|
next_trie_instruction(node)
|
|
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
#define aux_stack_pair_instr() /* for term 'CompactPairEndList' */ \
|
|
if (heap_arity) { \
|
|
Bind_Global((CELL *) aux_stack[HEAP_ENTRY(1)], AbsPair(H)); \
|
|
} else { \
|
|
Bind((CELL *) aux_stack[SUBS_ENTRY(1)], AbsPair(H)); \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
TOP_STACK = &aux_stack[-1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = 1; \
|
|
} \
|
|
TOP_STACK[HEAP_ENTRY(1)] = (CELL) H; \
|
|
Bind_Global(H + 1, TermNil); \
|
|
H += 2; \
|
|
next_trie_instruction(node)
|
|
#else
|
|
#define aux_stack_pair_instr() \
|
|
aux_stack_new_pair_instr()
|
|
#endif /* TRIE_COMPACT_PAIRS */
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** aux_stack_appl_(in_pair_)instr **
|
|
************************************************************************/
|
|
|
|
#define aux_stack_appl_instr() \
|
|
if (heap_arity) { \
|
|
Bind_Global((CELL *) aux_stack[HEAP_ENTRY(1)], AbsAppl(H)); \
|
|
TOP_STACK = &aux_stack[-func_arity + 1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity + func_arity - 1; \
|
|
} else { \
|
|
Bind((CELL *) aux_stack[SUBS_ENTRY(1)], AbsAppl(H)); \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
TOP_STACK = &aux_stack[-func_arity]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = func_arity; \
|
|
} \
|
|
*H = (CELL) func; \
|
|
{ int i; \
|
|
for (i = 1; i <= func_arity; i++) \
|
|
TOP_STACK[HEAP_ENTRY(i)] = (CELL) (H + i); \
|
|
} \
|
|
H += 1 + func_arity; \
|
|
next_trie_instruction(node)
|
|
|
|
#define aux_stack_appl_in_pair_instr() \
|
|
if (heap_arity) { \
|
|
Bind_Global((CELL *) aux_stack[HEAP_ENTRY(1)], AbsPair(H)); \
|
|
TOP_STACK = &aux_stack[-func_arity]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity + func_arity; \
|
|
} else { \
|
|
Bind((CELL *) aux_stack[SUBS_ENTRY(1)], AbsPair(H)); \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
TOP_STACK = &aux_stack[-func_arity - 1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = func_arity + 1; \
|
|
} \
|
|
TOP_STACK[HEAP_ENTRY(func_arity + 1)] = (CELL) (H + 1); \
|
|
Bind_Global(H, AbsAppl(H + 2)); \
|
|
H += 2; \
|
|
*H = (CELL) func; \
|
|
{ int i; \
|
|
for (i = 1; i <= func_arity; i++) \
|
|
TOP_STACK[HEAP_ENTRY(i)] = (CELL) (H + i); \
|
|
} \
|
|
H += 1 + func_arity; \
|
|
next_trie_instruction(node)
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** aux_stack_var_(in_pair_)instr **
|
|
************************************************************************/
|
|
|
|
#define aux_stack_var_instr() \
|
|
if (heap_arity) { \
|
|
int i; \
|
|
CELL var = aux_stack[HEAP_ENTRY(1)]; \
|
|
RESET_VARIABLE(var); \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity - 1; \
|
|
for (i = 2; i <= heap_arity; i++) \
|
|
TOP_STACK[HEAP_ENTRY(i - 1)] = aux_stack[HEAP_ENTRY(i)]; \
|
|
aux_stack[VARS_ARITY_ENTRY - 1] = vars_arity + 1; \
|
|
aux_stack[VARS_ENTRY(vars_arity + 1)] = var; \
|
|
next_instruction(heap_arity - 1 || subs_arity, node); \
|
|
} else { \
|
|
CELL var = aux_stack[SUBS_ENTRY(1)]; \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
TOP_STACK = &aux_stack[-1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = 0; \
|
|
aux_stack[VARS_ARITY_ENTRY - 1] = vars_arity + 1; \
|
|
aux_stack[VARS_ENTRY(vars_arity + 1)] = var; \
|
|
next_instruction(subs_arity - 1, node); \
|
|
}
|
|
|
|
#define aux_stack_var_in_pair_instr() \
|
|
if (heap_arity) { \
|
|
int i; \
|
|
Bind_Global((CELL *) aux_stack[HEAP_ENTRY(1)], AbsPair(H)); \
|
|
TOP_STACK = &aux_stack[-1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity; \
|
|
TOP_STACK[HEAP_ENTRY(1)] = (CELL) (H + 1); \
|
|
for (i = 2; i <= heap_arity; i++) \
|
|
TOP_STACK[HEAP_ENTRY(i)] = aux_stack[HEAP_ENTRY(i)]; \
|
|
} else { \
|
|
Bind((CELL *) aux_stack[SUBS_ENTRY(1)], AbsPair(H)); \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
TOP_STACK = &aux_stack[-2]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = 1; \
|
|
TOP_STACK[HEAP_ENTRY(1)] = (CELL) (H + 1); \
|
|
} \
|
|
aux_stack[VARS_ARITY_ENTRY - 1] = vars_arity + 1; \
|
|
aux_stack[VARS_ENTRY(vars_arity + 1)] = (CELL) H; \
|
|
RESET_VARIABLE((CELL) H); \
|
|
H += 2; \
|
|
next_trie_instruction(node)
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** aux_stack_val_(in_pair_)instr **
|
|
************************************************************************/
|
|
|
|
#define aux_stack_val_instr() \
|
|
if (heap_arity) { \
|
|
CELL aux_sub, aux_var; \
|
|
aux_sub = aux_stack[HEAP_ENTRY(1)]; \
|
|
aux_var = aux_stack[VARS_ENTRY(var_index + 1)]; \
|
|
if (aux_sub > aux_var) { \
|
|
Bind_Global((CELL *) aux_sub, aux_var); \
|
|
} else { \
|
|
RESET_VARIABLE(aux_sub); \
|
|
Bind_Local((CELL *) aux_var, aux_sub); \
|
|
aux_stack[VARS_ENTRY(var_index + 1)] = aux_sub; \
|
|
} \
|
|
TOP_STACK = &aux_stack[1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity - 1; \
|
|
next_instruction(heap_arity - 1 || subs_arity, node); \
|
|
} else { \
|
|
CELL aux_sub, aux_var; \
|
|
aux_sub = aux_stack[SUBS_ENTRY(1)]; \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
aux_var = aux_stack[VARS_ENTRY(var_index + 1)]; \
|
|
if (aux_sub > aux_var) { \
|
|
if ((CELL *) aux_sub <= H) { \
|
|
Bind_Global((CELL *) aux_sub, aux_var); \
|
|
} else if ((CELL *) aux_var <= H) { \
|
|
Bind_Local((CELL *) aux_sub, aux_var); \
|
|
} else { \
|
|
Bind_Local((CELL *) aux_var, aux_sub); \
|
|
aux_stack[VARS_ENTRY(var_index + 1)] = aux_sub; \
|
|
} \
|
|
} else { \
|
|
if ((CELL *) aux_var <= H) { \
|
|
Bind_Global((CELL *) aux_var, aux_sub); \
|
|
aux_stack[VARS_ENTRY(var_index + 1)] = aux_sub; \
|
|
} else if ((CELL *) aux_sub <= H) { \
|
|
Bind_Local((CELL *) aux_var, aux_sub); \
|
|
aux_stack[VARS_ENTRY(var_index + 1)] = aux_sub; \
|
|
} else { \
|
|
Bind_Local((CELL *) aux_sub, aux_var); \
|
|
} \
|
|
} \
|
|
next_instruction(subs_arity - 1, node); \
|
|
}
|
|
|
|
#define aux_stack_val_in_pair_instr() \
|
|
if (heap_arity) { \
|
|
Bind_Global((CELL *) aux_stack[HEAP_ENTRY(1)], AbsPair(H)); \
|
|
} else { \
|
|
Bind((CELL *) aux_stack[SUBS_ENTRY(1)], AbsPair(H)); \
|
|
aux_stack[SUBS_ARITY_ENTRY] = subs_arity - 1; \
|
|
TOP_STACK = &aux_stack[-1]; \
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = 1; \
|
|
} \
|
|
{ CELL aux_sub, aux_var; \
|
|
aux_sub = (CELL) H; \
|
|
aux_var = aux_stack[VARS_ENTRY(var_index + 1)]; \
|
|
if (aux_sub > aux_var) { \
|
|
Bind_Global((CELL *) aux_sub, aux_var); \
|
|
} else { \
|
|
RESET_VARIABLE(aux_sub); \
|
|
Bind_Local((CELL *) aux_var, aux_sub); \
|
|
aux_stack[VARS_ENTRY(var_index + 1)] = aux_sub; \
|
|
} \
|
|
} \
|
|
TOP_STACK[HEAP_ENTRY(1)] = (CELL) (H + 1); \
|
|
H += 2; \
|
|
next_trie_instruction(node)
|
|
|
|
|
|
|
|
/************************************************************************
|
|
** Trie instructions **
|
|
************************************************************************/
|
|
|
|
PBOp(trie_do_var, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
aux_stack_var_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_var, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
pop_trie_node();
|
|
aux_stack_var_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_var, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_var_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_var, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_var_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_var_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
aux_stack_var_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_do_var_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_var_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
pop_trie_node();
|
|
aux_stack_var_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_trust_var_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_var_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_var_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_try_var_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_var_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_var_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_retry_var_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_val, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
int var_index = VarIndexOfTableTerm(TrNode_entry(node));
|
|
|
|
aux_stack_val_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_val, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
int var_index = VarIndexOfTableTerm(TrNode_entry(node));
|
|
|
|
pop_trie_node();
|
|
aux_stack_val_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_val, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
int var_index = VarIndexOfTableTerm(TrNode_entry(node));
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_val_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_val, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
int var_index = VarIndexOfTableTerm(TrNode_entry(node));
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_val_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_val_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
int var_index = VarIndexOfTableTerm(TrNode_entry(node));
|
|
|
|
aux_stack_val_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_do_val_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_val_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
int var_index = VarIndexOfTableTerm(TrNode_entry(node));
|
|
|
|
pop_trie_node();
|
|
aux_stack_val_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_trust_val_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_val_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
int var_index = VarIndexOfTableTerm(TrNode_entry(node));
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_val_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_try_val_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_val_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
int var_index = VarIndexOfTableTerm(TrNode_entry(node));
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_val_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_retry_val_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_atom, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Term t = TrNode_entry(node);
|
|
|
|
aux_stack_term_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_atom, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Term t = TrNode_entry(node);
|
|
|
|
pop_trie_node();
|
|
aux_stack_term_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_atom, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Term t = TrNode_entry(node);
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_term_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_atom, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Term t = TrNode_entry(node);
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_term_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_atom_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
aux_stack_term_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_do_atom_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_atom_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
pop_trie_node();
|
|
aux_stack_term_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_trust_atom_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_atom_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_term_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_try_atom_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_atom_in_pair, e)
|
|
#if defined(TRIE_COMPACT_PAIRS) && !defined(GLOBAL_TRIE)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_term_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_retry_atom_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_null, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
|
|
aux_stack_null_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_null, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
pop_trie_node();
|
|
aux_stack_null_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_null, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_null_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_null, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_null_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_null_in_pair, e)
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
aux_stack_new_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_do_null_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_null_in_pair, e)
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
pop_trie_node();
|
|
aux_stack_new_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_trust_null_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_null_in_pair, e)
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_new_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_try_null_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_null_in_pair, e)
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_new_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_retry_null_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_pair, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
aux_stack_pair_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_pair, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
pop_trie_node();
|
|
aux_stack_pair_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_pair, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_pair_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_pair, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_pair_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_appl, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Functor func = (Functor) RepAppl(TrNode_entry(node));
|
|
int func_arity = ArityOfFunctor(func);
|
|
|
|
aux_stack_appl_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_appl, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Functor func = (Functor) RepAppl(TrNode_entry(node));
|
|
int func_arity = ArityOfFunctor(func);
|
|
|
|
pop_trie_node();
|
|
aux_stack_appl_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_appl, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Functor func = (Functor) RepAppl(TrNode_entry(node));
|
|
int func_arity = ArityOfFunctor(func);
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_appl_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_appl, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Functor func = (Functor) RepAppl(TrNode_entry(node));
|
|
int func_arity = ArityOfFunctor(func);
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_appl_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_appl_in_pair, e)
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Functor func = (Functor) RepAppl(TrNode_entry(node));
|
|
int func_arity = ArityOfFunctor(func);
|
|
|
|
aux_stack_appl_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_do_appl_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_appl_in_pair, e)
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Functor func = (Functor) RepAppl(TrNode_entry(node));
|
|
int func_arity = ArityOfFunctor(func);
|
|
|
|
pop_trie_node();
|
|
aux_stack_appl_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_trust_appl_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_appl_in_pair, e)
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Functor func = (Functor) RepAppl(TrNode_entry(node));
|
|
int func_arity = ArityOfFunctor(func);
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_appl_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_try_appl_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_appl_in_pair, e)
|
|
#ifdef TRIE_COMPACT_PAIRS
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Functor func = (Functor) RepAppl(TrNode_entry(node));
|
|
int func_arity = ArityOfFunctor(func);
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_appl_in_pair_instr();
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_retry_appl_in_pair: invalid instruction");
|
|
#endif /* TRIE_COMPACT_PAIRS && ! GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_extension, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
|
|
aux_stack_extension_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_extension, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
pop_trie_node();
|
|
aux_stack_extension_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_extension, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
aux_stack_extension_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_extension, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
aux_stack_extension_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_do_double, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
volatile Float dbl;
|
|
volatile Term *t_dbl = (Term *)((void *) &dbl);
|
|
Term t;
|
|
|
|
#if SIZEOF_DOUBLE == 2 * SIZEOF_INT_P
|
|
t_dbl[0] = aux_stack[HEAP_ENTRY(1)];
|
|
t_dbl[1] = aux_stack[HEAP_ENTRY(3)]; /* jump the first extension mark */
|
|
heap_arity -= 4;
|
|
TOP_STACK = aux_stack = &aux_stack[4]; /* jump until the second extension mark */
|
|
#else /* SIZEOF_DOUBLE == SIZEOF_INT_P */
|
|
t_dbl[0] = aux_stack[HEAP_ENTRY(1)];
|
|
heap_arity -= 2;
|
|
TOP_STACK = aux_stack = &aux_stack[2]; /* jump until the extension mark */
|
|
#endif /* SIZEOF_DOUBLE x SIZEOF_INT_P */
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity;
|
|
t = MkFloatTerm(dbl);
|
|
aux_stack_term_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
BOp(trie_trust_double, e)
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_trust_double: invalid instruction");
|
|
ENDBOp();
|
|
|
|
|
|
BOp(trie_try_double, e)
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_try_double: invalid instruction");
|
|
ENDBOp();
|
|
|
|
|
|
BOp(trie_retry_double, e)
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_retry_double: invalid instruction");
|
|
ENDBOp();
|
|
|
|
|
|
PBOp(trie_do_longint, e)
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = aux_stack[HEAP_ARITY_ENTRY];
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
Term t = MkLongIntTerm(aux_stack[HEAP_ENTRY(1)]);
|
|
|
|
heap_arity -= 2;
|
|
TOP_STACK = aux_stack = &aux_stack[2]; /* jump until the extension mark */
|
|
TOP_STACK[HEAP_ARITY_ENTRY] = heap_arity;
|
|
aux_stack_term_instr();
|
|
ENDPBOp();
|
|
|
|
|
|
BOp(trie_trust_longint, e)
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_trust_longint: invalid instruction");
|
|
ENDBOp();
|
|
|
|
|
|
BOp(trie_try_longint, e)
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_try_longint: invalid instruction");
|
|
ENDBOp();
|
|
|
|
|
|
BOp(trie_retry_longint, e)
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_retry_longint: invalid instruction");
|
|
ENDBOp();
|
|
|
|
|
|
PBOp(trie_do_gterm, e)
|
|
#ifdef GLOBAL_TRIE
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = 0;
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
TOP_STACK = exec_substitution((gt_node_ptr)TrNode_entry(node), aux_stack);
|
|
next_instruction(subs_arity - 1 , node);
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_do_gterm: invalid instruction");
|
|
#endif /* GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_trust_gterm, e)
|
|
#ifdef GLOBAL_TRIE
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = 0;
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
pop_trie_node();
|
|
TOP_STACK = exec_substitution((gt_node_ptr)TrNode_entry(node), aux_stack);
|
|
next_instruction(subs_arity - 1 , node);
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_trust_gterm: invalid instruction");
|
|
#endif /* GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_try_gterm, e)
|
|
#ifdef GLOBAL_TRIE
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = TOP_STACK;
|
|
int heap_arity = 0;
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
store_trie_node(TrNode_next(node));
|
|
TOP_STACK = exec_substitution((gt_node_ptr)TrNode_entry(node), aux_stack);
|
|
next_instruction(subs_arity - 1, node);
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_try_gterm: invalid instruction");
|
|
#endif /* GLOBAL_TRIE */
|
|
ENDPBOp();
|
|
|
|
|
|
PBOp(trie_retry_gterm, e)
|
|
#ifdef GLOBAL_TRIE
|
|
register ans_node_ptr node = (ans_node_ptr) PREG;
|
|
register CELL *aux_stack = (CELL *) (B + 1);
|
|
int heap_arity = 0;
|
|
int vars_arity = aux_stack[VARS_ARITY_ENTRY];
|
|
int subs_arity = aux_stack[SUBS_ARITY_ENTRY];
|
|
|
|
restore_trie_node(TrNode_next(node));
|
|
TOP_STACK = exec_substitution((gt_node_ptr)TrNode_entry(node), aux_stack);
|
|
next_instruction(subs_arity - 1, node);
|
|
#else
|
|
Yap_Error(INTERNAL_ERROR, TermNil, "trie_retry_gterm: invalid instruction");
|
|
#endif /* GLOBAL_TRIE */
|
|
ENDPBOp();
|