/* This file was generated automatically by "yap -L misc/buildops" please do not update */ while (TRUE) { op_numbers op; op = Yap_op_from_opcode(pc->opc); /* C-code, maybe indexing */ switch (op) { /* instructions type Ills */ case _enter_lu_pred: return walk_got_lu_block(pc->u.Ills.I, startp, endp); /* instructions type L */ case _alloc_for_logical_pred: return walk_got_lu_clause(pc->u.L.ClBase, startp, endp); /* instructions type Osblp */ case _either: case _or_else: clause_code = TRUE; pp = pc->u.Osblp.p0; pc = NEXTOP(pc,Osblp); break; /* instructions type Osbmp */ case _p_execute: pc = NEXTOP(pc,Osbmp); break; /* instructions type Osbpp */ case _p_execute2: case _p_execute_tail: return found_meta_call(startp, endp); case _call: case _call_cpred: case _call_usercpred: case _fcall: clause_code = TRUE; pp = pc->u.Osbpp.p0; pc = NEXTOP(pc,Osbpp); break; /* instructions type OtILl */ case _count_trust_logical: case _profiled_trust_logical: case _trust_logical: return walk_got_lu_block(pc->u.OtILl.block, startp, endp); /* instructions type OtaLl */ case _count_retry_logical: case _profiled_retry_logical: case _retry_logical: case _try_logical: pc = pc->u.OtaLl.n; /* instructions type OtapFs */ #ifdef CUT_C case _cut_c: #endif #ifdef CUT_C case _cut_userc: #endif case _retry_c: case _retry_userc: case _try_c: case _try_userc: clause_code = TRUE; pp = pc->u.OtapFs.p; pc = NEXTOP(pc,OtapFs); break; /* instructions type Otapl */ case _count_retry_and_mark: case _count_retry_me: case _count_trust_me: case _profiled_retry_and_mark: case _profiled_retry_me: case _profiled_trust_me: case _retry: case _retry_and_mark: case _retry_me: case _spy_or_trymark: case _trust: case _trust_me: case _try_and_mark: case _try_clause: case _try_me: clause_code = TRUE; pp = pc->u.Otapl.p; pc = NEXTOP(pc,Otapl); break; /* instructions type c */ case _write_atom: pc = NEXTOP(pc,c); break; /* instructions type cc */ case _get_2atoms: pc = NEXTOP(pc,cc); break; /* instructions type ccc */ case _get_3atoms: pc = NEXTOP(pc,ccc); break; /* instructions type cccc */ case _get_4atoms: pc = NEXTOP(pc,cccc); break; /* instructions type ccccc */ case _get_5atoms: pc = NEXTOP(pc,ccccc); break; /* instructions type cccccc */ case _get_6atoms: pc = NEXTOP(pc,cccccc); break; /* instructions type clll */ case _if_not_then: pc = NEXTOP(pc,clll); break; /* instructions type d */ case _write_float: pc = NEXTOP(pc,d); break; /* instructions type e */ case _Nstop: return NULL; case _copy_idb_term: return found_idb_clause(pc, startp, endp); case _expand_index: case _index_pred: return found_owner_op(pc, startp, endp); case _lock_pred: return found_owner_op(pc, startp, endp); case _op_fail: if (codeptr == FAILCODE) return found_fail(pc, startp, endp); pc = NEXTOP(pc,e); break; case _spy_pred: return found_owner_op(pc, startp, endp); case _trust_fail: if (codeptr == TRUSTFAILCODE) return found_fail(pc, startp, endp); pc = NEXTOP(pc,e); break; case _undef_p: return found_owner_op(pc, startp, endp); case _unify_idb_term: return found_idb_clause(pc, startp, endp); case _allocate: case _count_a_call: case _cut: case _cut_e: case _cut_t: case _enter_a_profiling: case _index_blob: case _index_dbref: case _index_long: case _p_equal: case _p_functor: case _pop: #ifdef BEAM case _retry_eam: #endif #ifdef THREADS case _thread_local: #endif case _unlock_lu: case _write_l_list: case _write_list: case _write_void: pc = NEXTOP(pc,e); break; /* instructions type fa */ case _write_l_struc: case _write_struct: pc = NEXTOP(pc,fa); break; /* instructions type i */ case _write_longint: pc = NEXTOP(pc,i); break; /* instructions type l */ case _Ystop: return found_ystop(pc, clause_code, startp, endp, pp); case _jump: case _jump_if_var: case _move_back: case _p_dif: case _p_eq: case _retry2: case _retry3: case _retry4: case _skip: case _try_clause2: case _try_clause3: case _try_clause4: case _try_in: pc = NEXTOP(pc,l); break; /* instructions type llll */ case _switch_on_type: pc = NEXTOP(pc,llll); break; /* instructions type lp */ case _user_switch: pc = NEXTOP(pc,lp); break; /* instructions type o */ case _unify_l_list: case _unify_l_list_write: case _unify_l_void: case _unify_l_void_write: case _unify_list: case _unify_list_write: case _unify_void: case _unify_void_write: pc = NEXTOP(pc,o); break; /* instructions type oc */ case _unify_atom: case _unify_atom_write: case _unify_bigint: case _unify_dbterm: case _unify_l_atom: case _unify_l_atom_write: case _unify_l_bigint: case _unify_l_dbterm: pc = NEXTOP(pc,oc); break; /* instructions type od */ case _unify_float: case _unify_float_write: case _unify_l_float: case _unify_l_float_write: pc = NEXTOP(pc,od); break; /* instructions type ofa */ case _unify_l_struc: case _unify_l_struc_write: case _unify_struct: case _unify_struct_write: pc = NEXTOP(pc,ofa); break; /* instructions type oi */ case _unify_l_longint: case _unify_l_longint_write: case _unify_longint: case _unify_longint_write: pc = NEXTOP(pc,oi); break; /* instructions type ollll */ case _switch_list_nl: pc = NEXTOP(pc,ollll); break; /* instructions type os */ #ifdef BEAM case _run_eam: #endif case _unify_l_n_voids: case _unify_l_n_voids_write: case _unify_n_voids: case _unify_n_voids_write: pc = NEXTOP(pc,os); break; /* instructions type osc */ case _unify_n_atoms: case _unify_n_atoms_write: pc = NEXTOP(pc,osc); break; /* instructions type ox */ case _save_appl_x: case _save_appl_x_write: case _save_pair_x: case _save_pair_x_write: case _unify_l_x_loc: case _unify_l_x_loc_write: case _unify_l_x_val: case _unify_l_x_val_write: case _unify_l_x_var: case _unify_l_x_var_write: case _unify_x_loc: case _unify_x_loc_write: case _unify_x_val: case _unify_x_val_write: case _unify_x_var: case _unify_x_var_write: pc = NEXTOP(pc,ox); break; /* instructions type oxx */ case _unify_l_x_var2: case _unify_l_x_var2_write: case _unify_x_var2: case _unify_x_var2_write: pc = NEXTOP(pc,oxx); break; /* instructions type oy */ case _save_appl_y: case _save_appl_y_write: case _save_pair_y: case _save_pair_y_write: case _unify_l_y_loc: case _unify_l_y_loc_write: case _unify_l_y_val: case _unify_l_y_val_write: case _unify_l_y_var: case _unify_l_y_var_write: case _unify_y_loc: case _unify_y_loc_write: case _unify_y_val: case _unify_y_val_write: case _unify_y_var: case _unify_y_var_write: pc = NEXTOP(pc,oy); break; /* instructions type p */ case _lock_lu: case _procceed: pp = pc->u.p.p; if (pp->PredFlags & MegaClausePredFlag) return found_mega_clause(pp, startp, endp); clause_code = TRUE; pc = NEXTOP(pc,p); break; case _count_call: case _count_retry: case _deallocate: case _enter_profiling: case _retry_profiled: pc = NEXTOP(pc,p); break; /* instructions type plxxs */ case _call_bfunc_xx: pc = NEXTOP(pc,plxxs); break; /* instructions type plxys */ case _call_bfunc_xy: case _call_bfunc_yx: pc = NEXTOP(pc,plxys); break; /* instructions type plyys */ case _call_bfunc_yy: pc = NEXTOP(pc,plyys); break; /* instructions type pp */ case _dexecute: case _execute: case _execute_cpred: clause_code = TRUE; pp = pc->u.pp.p0; pc = NEXTOP(pc,pp); break; /* instructions type s */ case _pop_n: case _write_n_voids: pc = NEXTOP(pc,s); break; /* instructions type sc */ case _write_n_atoms: pc = NEXTOP(pc,sc); break; /* instructions type sdll */ case _a_eqc_float: case _gtc_float: case _ltc_float: pc = NEXTOP(pc,sdll); break; /* instructions type sllll */ case _switch_on_sub_arg_type: pc = NEXTOP(pc,sllll); break; /* instructions type slp */ case _call_c_wfail: pc = NEXTOP(pc,slp); break; /* instructions type snll */ case _a_eqc_int: case _gtc_int: case _ltc_int: pc = NEXTOP(pc,snll); break; /* instructions type ssd */ case _add_float_c: case _fdiv_c1: case _fdiv_c2: case _mul_float_c: case _sub_float_c: pc = NEXTOP(pc,ssd); break; /* instructions type ssll */ case _a_eq: case _lt: pc = NEXTOP(pc,ssll); break; /* instructions type ssn */ case _a_and_c: case _a_or_c: case _add_int_c: case _idiv_c1: case _idiv_c2: case _mod_c1: case _mod_c2: case _mul_int_c: case _rem_c1: case _rem_c2: case _sl_c1: case _sl_c2: case _sr_c1: case _sr_c2: case _sub_int_c: case _xor_c: pc = NEXTOP(pc,ssn); break; /* instructions type sss */ case _a_and: case _a_or: case _add: case _fdiv: case _idiv: case _mod: case _mul: case _rem: case _sl: case _sr: case _sub: case _uminus: case _xor: pc = NEXTOP(pc,sss); break; /* instructions type sssl */ case _go_on_cons: case _go_on_func: case _if_cons: case _if_func: case _switch_on_cons: case _switch_on_func: pc = NEXTOP(pc,sssl); break; /* instructions type sssllp */ case _expand_clauses: return found_expand_index(pc, startp, endp, codeptr); pc = NEXTOP(pc,sssllp); break; /* instructions type sxl */ case _get_f_x: case _get_fi_x: case _get_i_x: case _put_f_var_x: case _put_fi_var_x: case _put_i_var_x: pc = NEXTOP(pc,sxl); break; /* instructions type sxll */ case _put_f_val_x: case _put_fi_val_x: case _put_i_val_x: pc = NEXTOP(pc,sxll); break; /* instructions type syl */ case _get_f_y: case _get_fi_y: case _get_i_y: case _put_f_var_y: case _put_fi_var_y: case _put_i_var_y: pc = NEXTOP(pc,syl); break; /* instructions type syll */ case _put_f_val_y: case _put_fi_val_y: case _put_i_val_y: pc = NEXTOP(pc,syll); break; /* instructions type x */ case _get_list: case _put_list: case _save_b_x: case _write_x_loc: case _write_x_val: case _write_x_var: pc = NEXTOP(pc,x); break; /* instructions type xc */ case _get_atom: case _get_bigint: case _get_dbterm: case _put_atom: pc = NEXTOP(pc,xc); break; /* instructions type xd */ case _get_float: case _put_float: pc = NEXTOP(pc,xd); break; /* instructions type xfa */ case _get_struct: case _put_struct: pc = NEXTOP(pc,xfa); break; /* instructions type xi */ case _get_longint: case _put_longint: pc = NEXTOP(pc,xi); break; /* instructions type xl */ case _p_atom_x: case _p_atomic_x: case _p_compound_x: case _p_cut_by_x: case _p_db_ref_x: case _p_float_x: case _p_integer_x: case _p_nonvar_x: case _p_number_x: case _p_primitive_x: case _p_var_x: pc = NEXTOP(pc,xl); break; /* instructions type xll */ case _jump_if_nonvar: pc = NEXTOP(pc,xll); break; /* instructions type xllll */ case _switch_on_arg_type: pc = NEXTOP(pc,xllll); break; /* instructions type xp */ case _commit_b_x: pc = NEXTOP(pc,xp); break; /* instructions type xx */ case _get_x_val: case _get_x_var: case _gl_void_valx: case _gl_void_varx: case _glist_valx: case _put_x_val: case _put_x_var: pc = NEXTOP(pc,xx); break; /* instructions type xxn */ case _p_and_vc: case _p_arg_cv: case _p_div_cv: case _p_div_vc: case _p_func2s_cv: case _p_func2s_vc: case _p_minus_cv: case _p_or_vc: case _p_plus_vc: case _p_sll_cv: case _p_sll_vc: case _p_slr_cv: case _p_slr_vc: case _p_times_vc: pc = NEXTOP(pc,xxn); break; /* instructions type xxx */ case _p_and_vv: case _p_arg_vv: case _p_div_vv: case _p_func2f_xx: case _p_func2s_vv: case _p_minus_vv: case _p_or_vv: case _p_plus_vv: case _p_sll_vv: case _p_slr_vv: case _p_times_vv: pc = NEXTOP(pc,xxx); break; /* instructions type xxxx */ case _put_xx_val: pc = NEXTOP(pc,xxxx); break; /* instructions type xxy */ case _p_func2f_xy: pc = NEXTOP(pc,xxy); break; /* instructions type xy */ case _gl_void_valy: case _gl_void_vary: case _glist_valy: pc = NEXTOP(pc,xy); break; /* instructions type y */ case _save_b_y: case _write_y_loc: case _write_y_val: case _write_y_var: pc = NEXTOP(pc,y); break; /* instructions type yl */ case _p_atom_y: case _p_atomic_y: case _p_compound_y: case _p_cut_by_y: case _p_db_ref_y: case _p_float_y: case _p_integer_y: case _p_nonvar_y: case _p_number_y: case _p_primitive_y: case _p_var_y: pc = NEXTOP(pc,yl); break; /* instructions type yp */ case _commit_b_y: pc = NEXTOP(pc,yp); break; /* instructions type yx */ case _get_y_val: case _get_y_var: case _put_unsafe: case _put_y_val: case _put_y_var: pc = NEXTOP(pc,yx); break; /* instructions type yxn */ case _p_and_y_vc: case _p_arg_y_cv: case _p_div_y_cv: case _p_div_y_vc: case _p_func2s_y_cv: case _p_func2s_y_vc: case _p_minus_y_cv: case _p_or_y_vc: case _p_plus_y_vc: case _p_sll_y_cv: case _p_sll_y_vc: case _p_slr_y_cv: case _p_slr_y_vc: case _p_times_y_vc: pc = NEXTOP(pc,yxn); break; /* instructions type yxx */ case _p_and_y_vv: case _p_arg_y_vv: case _p_div_y_vv: case _p_func2f_yx: case _p_func2s_y_vv: case _p_minus_y_vv: case _p_or_y_vv: case _p_plus_y_vv: case _p_sll_y_vv: case _p_slr_y_vv: case _p_times_y_vv: pc = NEXTOP(pc,yxx); break; /* instructions type yyx */ case _p_func2f_yy: pc = NEXTOP(pc,yyx); break; #ifdef YAPOR /* instructions type Otapl */ case _getwork: case _getwork_seq: case _sync: clause_code = TRUE; pp = pc->u.Otapl.p; pc = NEXTOP(pc,Otapl); break; /* instructions type e */ case _getwork_first_time: pc = NEXTOP(pc,e); break; #endif #ifdef TABLING /* instructions type Otapl */ case _table_answer_resolution: case _table_completion: case _table_load_answer: case _table_retry: case _table_retry_me: case _table_trust: case _table_trust_me: case _table_try: case _table_try_answer: case _table_try_me: case _table_try_single: clause_code = TRUE; pp = pc->u.Otapl.p; pc = NEXTOP(pc,Otapl); break; /* instructions type e */ #ifdef TABLING_INNER_CUTS case _clause_with_cut: #endif pc = NEXTOP(pc,e); break; /* instructions type s */ case _table_new_answer: pc = NEXTOP(pc,s); break; /* instructions type e */ case _trie_do_atom: case _trie_do_extension: case _trie_do_float: case _trie_do_list: case _trie_do_long: case _trie_do_null: case _trie_do_struct: case _trie_do_val: case _trie_do_var: case _trie_retry_atom: case _trie_retry_extension: case _trie_retry_float: case _trie_retry_list: case _trie_retry_long: case _trie_retry_null: case _trie_retry_struct: case _trie_retry_val: case _trie_retry_var: case _trie_trust_atom: case _trie_trust_extension: case _trie_trust_float: case _trie_trust_list: case _trie_trust_long: case _trie_trust_null: case _trie_trust_struct: case _trie_trust_val: case _trie_trust_var: case _trie_try_atom: case _trie_try_extension: case _trie_try_float: case _trie_try_list: case _trie_try_long: case _trie_try_null: case _trie_try_struct: case _trie_try_val: case _trie_try_var: pc = NEXTOP(pc,e); break; #endif /* this instruction is hardwired */ case _or_last: #ifdef YAPOR pp = pc->u.Osblp.p; if (pp->PredFlags & MegaClausePredFlag) return found_mega_clause(pp, startp, endp); clause_code = TRUE; pc = NEXTOP(pc,Osblp); #else pp = pc->u.p.p; if (pp->PredFlags & MegaClausePredFlag) return found_mega_clause(pp, startp, endp); clause_code = TRUE; pc = NEXTOP(pc,p); #endif } }