diff --git a/C/qly.c b/C/qly.c index 929c2a6c8..3d95eaa1d 100644 --- a/C/qly.c +++ b/C/qly.c @@ -252,6 +252,7 @@ static size_t save_static_clause(IOSTREAM *stream, StaticClause *cl) { CHECK(save_tag(stream, QLF_START_CLAUSE)); if (!(cl->ClFlags & FactMask)) { + Yap_DebugPlWrite(cl->usc.ClSource->Entry);fprintf(stderr,"\n"); CHECK(save_term(stream, cl->usc.ClSource->Entry)); return save_code(stream, cl->ClCode, (yamop *)(cl->usc.ClSource)); } else { @@ -323,12 +324,38 @@ save_pred(IOSTREAM *stream, PredEntry *ap) { return save_clauses(stream, ap); } -size_t +static size_t save_module(IOSTREAM *stream, Term mod) { PredEntry *ap = Yap_ModulePred(mod); while (ap) { CHECK(save_pred(stream, ap)); ap = ap->NextPredOfModule; } + return 1; +} + +static Int +p_save_module_preds( USES_REGS1 ) +{ + IOSTREAM *stream; + Term tmod = Deref(ARG2); + + if (!Yap_getOutputStream(Yap_InitSlot(Deref(ARG1) PASS_REGS), &stream)) { + return FALSE; + } + if (IsVarTerm(tmod)) { + Yap_Error(INSTANTIATION_ERROR,tmod,"save_module/2"); + return FALSE; + } + if (!IsAtomTerm(tmod)) { + Yap_Error(TYPE_ERROR_ATOM,tmod,"save_module/2"); + return FALSE; + } + return save_module(stream, tmod) != 0; +} + +void Yap_InitQLY(void) +{ + Yap_InitCPred("$save_module_preds", 2, p_save_module_preds, SyncPredFlag|HiddenPredFlag|UserCPredFlag); } diff --git a/C/stdpreds.c b/C/stdpreds.c index 853a8e7e9..4c249587c 100755 --- a/C/stdpreds.c +++ b/C/stdpreds.c @@ -4481,6 +4481,7 @@ Yap_InitCPreds(void) Yap_InitSavePreds(); Yap_InitSysPreds(); Yap_InitUnify(); + Yap_InitQLY(); #if defined CUT_C && defined MYDDAS_MYSQL Yap_InitMYDDAS_MySQLPreds(); #endif diff --git a/H/Yapproto.h b/H/Yapproto.h index 5ea86f51a..49fe4695f 100755 --- a/H/Yapproto.h +++ b/H/Yapproto.h @@ -307,6 +307,9 @@ Term STD_PROTO(Yap_Parse,(void)); /* readutil.c */ void STD_PROTO(Yap_InitReadUtil,(void)); +/* qly.c */ +void STD_PROTO(Yap_InitQLY,(void)); + /* save.c */ int STD_PROTO(Yap_SavedInfo,(char *,char *,CELL *,CELL *,CELL *)); int STD_PROTO(Yap_Restore,(char *, char *)); @@ -487,3 +490,9 @@ gc_P(yamop *p, yamop *cp) { return (p->opc == Yap_opcode(_execute_cpred) ? cp : p); } + +#ifdef _PL_STREAM_H +extern int Yap_getInputStream(Int t, IOSTREAM **s); +extern int Yap_getOutputStream(Int t, IOSTREAM **s); +#endif + diff --git a/H/saveclause.h b/H/saveclause.h new file mode 100644 index 000000000..4a49f7126 --- /dev/null +++ b/H/saveclause.h @@ -0,0 +1,938 @@ + + /* This file was generated automatically by "yap -L misc/buildops" + please do not update */ + + + while (TRUE) { + op_numbers op; + if (max && pc >= max) return 1; + op = Yap_op_from_opcode(pc->opc); + save_Opcode(stream, op); + + /* C-code, maybe indexing */ + switch (op) { + /* instructions type D */ + case _write_dbterm: + CHECK(save_DBGroundTerm(stream, pc->u.D.D)); + pc = NEXTOP(pc,D); + break; + /* instructions type Illss */ + case _enter_lu_pred: + CHECK(save_PtoLUIndex(stream, pc->u.Illss.I)); + CHECK(save_PtoOp(stream, pc->u.Illss.l1)); + CHECK(save_PtoOp(stream, pc->u.Illss.l2)); + CHECK(save_Constant(stream, pc->u.Illss.s)); + CHECK(save_Constant(stream, pc->u.Illss.e)); + pc = NEXTOP(pc,Illss); + break; + /* instructions type L */ + case _alloc_for_logical_pred: + CHECK(save_PtoLUClause(stream, pc->u.L.ClBase)); + pc = NEXTOP(pc,L); + break; + /* instructions type N */ + case _write_bigint: + CHECK(save_BlobTermInCode(stream, pc->u.N.b)); + pc = NEXTOP(pc,N); + break; + /* instructions type Osblp */ + case _either: + case _or_else: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.Osblp.or_arg)); +#endif + CHECK(save_Constant(stream, pc->u.Osblp.s)); + CHECK(save_CellPtoHeap(stream, pc->u.Osblp.bmap)); + CHECK(save_PtoOp(stream, pc->u.Osblp.l)); + CHECK(save_PtoPred(stream, pc->u.Osblp.p0)); + pc = NEXTOP(pc,Osblp); + break; + /* instructions type Osbmp */ + case _p_execute: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.Osbmp.or_arg)); +#endif + CHECK(save_Constant(stream, pc->u.Osbmp.s)); + CHECK(save_CellPtoHeap(stream, pc->u.Osbmp.bmap)); + CHECK(save_Module(stream, pc->u.Osbmp.mod)); + CHECK(save_PtoPred(stream, pc->u.Osbmp.p0)); + pc = NEXTOP(pc,Osbmp); + break; + /* instructions type Osbpa */ + case _ensure_space: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.Osbpa.or_arg)); +#endif + CHECK(save_Constant(stream, pc->u.Osbpa.s)); + CHECK(save_CellPtoHeap(stream, pc->u.Osbpa.bmap)); + CHECK(save_PtoPred(stream, pc->u.Osbpa.p)); + CHECK(save_Arity(stream, pc->u.Osbpa.i)); + pc = NEXTOP(pc,Osbpa); + break; + /* instructions type Osbpp */ + case _call: + case _call_cpred: + case _call_usercpred: + case _fcall: + case _p_execute2: + case _p_execute_tail: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.Osbpp.or_arg)); +#endif + CHECK(save_Constant(stream, pc->u.Osbpp.s)); + CHECK(save_CellPtoHeap(stream, pc->u.Osbpp.bmap)); + CHECK(save_PtoPred(stream, pc->u.Osbpp.p)); + CHECK(save_PtoPred(stream, pc->u.Osbpp.p0)); + pc = NEXTOP(pc,Osbpp); + break; + /* instructions type OtILl */ + case _count_trust_logical: + case _profiled_trust_logical: + case _trust_logical: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.OtILl.or_arg)); +#endif +#ifdef TABLING + CHECK(save_TabEntry(stream, pc->u.OtILl.te)); +#endif + CHECK(save_PtoLUIndex(stream, pc->u.OtILl.block)); + CHECK(save_PtoLUClause(stream, pc->u.OtILl.d)); + CHECK(save_PtoOp(stream, pc->u.OtILl.n)); + pc = NEXTOP(pc,OtILl); + break; + /* instructions type OtaLl */ + case _count_retry_logical: + case _profiled_retry_logical: + case _retry_logical: + case _try_logical: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.OtaLl.or_arg)); +#endif +#ifdef TABLING + CHECK(save_TabEntry(stream, pc->u.OtaLl.te)); +#endif + CHECK(save_Arity(stream, pc->u.OtaLl.s)); + CHECK(save_PtoLUClause(stream, pc->u.OtaLl.d)); + CHECK(save_PtoOp(stream, pc->u.OtaLl.n)); + pc = NEXTOP(pc,OtaLl); + break; + /* 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: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.OtapFs.or_arg)); +#endif +#ifdef TABLING + CHECK(save_TabEntry(stream, pc->u.OtapFs.te)); +#endif + CHECK(save_Arity(stream, pc->u.OtapFs.s)); + CHECK(save_PtoPred(stream, pc->u.OtapFs.p)); + CHECK(save_ExternalFunction(stream, pc->u.OtapFs.f)); + CHECK(save_Constant(stream, pc->u.OtapFs.extra)); + 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: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.Otapl.or_arg)); +#endif +#ifdef TABLING + CHECK(save_TabEntry(stream, pc->u.Otapl.te)); +#endif + CHECK(save_Arity(stream, pc->u.Otapl.s)); + CHECK(save_PtoPred(stream, pc->u.Otapl.p)); + CHECK(save_PtoOp(stream, pc->u.Otapl.d)); + pc = NEXTOP(pc,Otapl); + break; + /* instructions type aFlp */ + case _native_me: + CHECK(save_Arity(stream, pc->u.aFlp.n)); + CHECK(save_ExternalFunction(stream, pc->u.aFlp.native)); + CHECK(save_PtoOp(stream, pc->u.aFlp.native_next)); + CHECK(save_PtoPred(stream, pc->u.aFlp.p)); + pc = NEXTOP(pc,aFlp); + break; + /* instructions type c */ + case _write_atom: + CHECK(save_ConstantTerm(stream, pc->u.c.c)); + pc = NEXTOP(pc,c); + break; + /* instructions type cc */ + case _get_2atoms: + CHECK(save_ConstantTerm(stream, pc->u.cc.c1)); + CHECK(save_ConstantTerm(stream, pc->u.cc.c2)); + pc = NEXTOP(pc,cc); + break; + /* instructions type ccc */ + case _get_3atoms: + CHECK(save_ConstantTerm(stream, pc->u.ccc.c1)); + CHECK(save_ConstantTerm(stream, pc->u.ccc.c2)); + CHECK(save_ConstantTerm(stream, pc->u.ccc.c3)); + pc = NEXTOP(pc,ccc); + break; + /* instructions type cccc */ + case _get_4atoms: + CHECK(save_ConstantTerm(stream, pc->u.cccc.c1)); + CHECK(save_ConstantTerm(stream, pc->u.cccc.c2)); + CHECK(save_ConstantTerm(stream, pc->u.cccc.c3)); + CHECK(save_ConstantTerm(stream, pc->u.cccc.c4)); + pc = NEXTOP(pc,cccc); + break; + /* instructions type ccccc */ + case _get_5atoms: + CHECK(save_ConstantTerm(stream, pc->u.ccccc.c1)); + CHECK(save_ConstantTerm(stream, pc->u.ccccc.c2)); + CHECK(save_ConstantTerm(stream, pc->u.ccccc.c3)); + CHECK(save_ConstantTerm(stream, pc->u.ccccc.c4)); + CHECK(save_ConstantTerm(stream, pc->u.ccccc.c5)); + pc = NEXTOP(pc,ccccc); + break; + /* instructions type cccccc */ + case _get_6atoms: + CHECK(save_ConstantTerm(stream, pc->u.cccccc.c1)); + CHECK(save_ConstantTerm(stream, pc->u.cccccc.c2)); + CHECK(save_ConstantTerm(stream, pc->u.cccccc.c3)); + CHECK(save_ConstantTerm(stream, pc->u.cccccc.c4)); + CHECK(save_ConstantTerm(stream, pc->u.cccccc.c5)); + CHECK(save_ConstantTerm(stream, pc->u.cccccc.c6)); + pc = NEXTOP(pc,cccccc); + break; + /* instructions type clll */ + case _if_not_then: + CHECK(save_ConstantTerm(stream, pc->u.clll.c)); + CHECK(save_PtoOp(stream, pc->u.clll.l1)); + CHECK(save_PtoOp(stream, pc->u.clll.l2)); + CHECK(save_PtoOp(stream, pc->u.clll.l3)); + pc = NEXTOP(pc,clll); + break; + /* instructions type d */ + case _write_float: + CHECK(save_DoubleInCode(stream, pc->u.d.d)); + pc = NEXTOP(pc,d); + break; + /* instructions type e */ + case _Nstop: + case _allocate: + case _copy_idb_term: + case _expand_index: + case _index_blob: + case _index_dbref: + case _index_long: + case _index_pred: + case _lock_pred: + case _op_fail: + case _p_equal: + case _p_functor: + case _pop: +#ifdef BEAM + case _retry_eam: +#endif + case _spy_pred: +#ifdef THREADS + case _thread_local: +#endif + case _trust_fail: + case _undef_p: + case _unify_idb_term: + case _unlock_lu: + case _write_l_list: + case _write_list: + case _write_void: + if (op == _Nstop || op == _copy_idb_term || op == _unify_idb_term) return 1; + pc = NEXTOP(pc,e); + break; + /* instructions type fa */ + case _write_l_struc: + case _write_struct: + CHECK(save_Func(stream, pc->u.fa.f)); + CHECK(save_Arity(stream, pc->u.fa.a)); + pc = NEXTOP(pc,fa); + break; + /* instructions type i */ + case _write_longint: + CHECK(save_IntegerInCode(stream, pc->u.i.i)); + pc = NEXTOP(pc,i); + break; + /* instructions type l */ + case _Ystop: + 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: + CHECK(save_PtoOp(stream, pc->u.l.l)); + pc = NEXTOP(pc,l); + break; + /* instructions type llll */ + case _switch_on_type: + CHECK(save_PtoOp(stream, pc->u.llll.l1)); + CHECK(save_PtoOp(stream, pc->u.llll.l2)); + CHECK(save_PtoOp(stream, pc->u.llll.l3)); + CHECK(save_PtoOp(stream, pc->u.llll.l4)); + pc = NEXTOP(pc,llll); + break; + /* instructions type lp */ + case _user_switch: + CHECK(save_PtoOp(stream, pc->u.lp.l)); + CHECK(save_PtoPred(stream, pc->u.lp.p)); + 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: + CHECK(save_Opcode(stream, pc->u.o.opcw)); + pc = NEXTOP(pc,o); + break; + /* instructions type oD */ + case _unify_dbterm: + case _unify_l_dbterm: + CHECK(save_Opcode(stream, pc->u.oD.opcw)); + CHECK(save_DBGroundTerm(stream, pc->u.oD.D)); + pc = NEXTOP(pc,oD); + break; + /* instructions type oN */ + case _unify_bigint: + case _unify_l_bigint: + CHECK(save_Opcode(stream, pc->u.oN.opcw)); + CHECK(save_BlobTermInCode(stream, pc->u.oN.b)); + pc = NEXTOP(pc,oN); + break; + /* instructions type oc */ + case _unify_atom: + case _unify_atom_write: + case _unify_l_atom: + case _unify_l_atom_write: + CHECK(save_Opcode(stream, pc->u.oc.opcw)); + CHECK(save_ConstantTerm(stream, pc->u.oc.c)); + pc = NEXTOP(pc,oc); + break; + /* instructions type od */ + case _unify_float: + case _unify_float_write: + case _unify_l_float: + case _unify_l_float_write: + CHECK(save_Opcode(stream, pc->u.od.opcw)); + CHECK(save_DoubleInCode(stream, pc->u.od.d)); + pc = NEXTOP(pc,od); + break; + /* instructions type ofa */ + case _unify_l_struc: + case _unify_l_struc_write: + case _unify_struct: + case _unify_struct_write: + CHECK(save_Opcode(stream, pc->u.ofa.opcw)); + CHECK(save_Func(stream, pc->u.ofa.f)); + CHECK(save_Arity(stream, pc->u.ofa.a)); + pc = NEXTOP(pc,ofa); + break; + /* instructions type oi */ + case _unify_l_longint: + case _unify_l_longint_write: + case _unify_longint: + case _unify_longint_write: + CHECK(save_Opcode(stream, pc->u.oi.opcw)); + CHECK(save_IntegerInCode(stream, pc->u.oi.i)); + pc = NEXTOP(pc,oi); + break; + /* instructions type ollll */ + case _switch_list_nl: + CHECK(save_Opcode(stream, pc->u.ollll.pop)); + CHECK(save_PtoOp(stream, pc->u.ollll.l1)); + CHECK(save_PtoOp(stream, pc->u.ollll.l2)); + CHECK(save_PtoOp(stream, pc->u.ollll.l3)); + CHECK(save_PtoOp(stream, pc->u.ollll.l4)); + 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: + CHECK(save_Opcode(stream, pc->u.os.opcw)); + CHECK(save_Constant(stream, pc->u.os.s)); + pc = NEXTOP(pc,os); + break; + /* instructions type osc */ + case _unify_n_atoms: + case _unify_n_atoms_write: + CHECK(save_Opcode(stream, pc->u.osc.opcw)); + CHECK(save_Constant(stream, pc->u.osc.s)); + CHECK(save_ConstantTerm(stream, pc->u.osc.c)); + 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: + CHECK(save_Opcode(stream, pc->u.ox.opcw)); + CHECK(save_X(stream, pc->u.ox.x)); + 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: + CHECK(save_Opcode(stream, pc->u.oxx.opcw)); + CHECK(save_X(stream, pc->u.oxx.xl)); + CHECK(save_X(stream, pc->u.oxx.xr)); + 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: + CHECK(save_Opcode(stream, pc->u.oy.opcw)); + CHECK(save_Y(stream, pc->u.oy.y)); + pc = NEXTOP(pc,oy); + break; + /* instructions type p */ + case _count_call: + case _count_retry: + case _deallocate: + case _enter_profiling: + case _lock_lu: + case _procceed: + case _retry_profiled: + CHECK(save_PtoPred(stream, pc->u.p.p)); + pc = NEXTOP(pc,p); + break; + /* instructions type plxxs */ + case _call_bfunc_xx: + CHECK(save_PtoPred(stream, pc->u.plxxs.p)); + CHECK(save_PtoOp(stream, pc->u.plxxs.f)); + CHECK(save_X(stream, pc->u.plxxs.x1)); + CHECK(save_X(stream, pc->u.plxxs.x2)); + CHECK(save_Constant(stream, pc->u.plxxs.flags)); + pc = NEXTOP(pc,plxxs); + break; + /* instructions type plxys */ + case _call_bfunc_xy: + case _call_bfunc_yx: + CHECK(save_PtoPred(stream, pc->u.plxys.p)); + CHECK(save_PtoOp(stream, pc->u.plxys.f)); + CHECK(save_X(stream, pc->u.plxys.x)); + CHECK(save_Y(stream, pc->u.plxys.y)); + CHECK(save_Constant(stream, pc->u.plxys.flags)); + pc = NEXTOP(pc,plxys); + break; + /* instructions type plyys */ + case _call_bfunc_yy: + CHECK(save_PtoPred(stream, pc->u.plyys.p)); + CHECK(save_PtoOp(stream, pc->u.plyys.f)); + CHECK(save_Y(stream, pc->u.plyys.y1)); + CHECK(save_Y(stream, pc->u.plyys.y2)); + CHECK(save_Constant(stream, pc->u.plyys.flags)); + pc = NEXTOP(pc,plyys); + break; + /* instructions type pp */ + case _dexecute: + case _execute: + case _execute_cpred: + CHECK(save_PtoPred(stream, pc->u.pp.p)); + CHECK(save_PtoPred(stream, pc->u.pp.p0)); + pc = NEXTOP(pc,pp); + break; + /* instructions type s */ + case _cut: + case _cut_e: + case _cut_t: + case _pop_n: + case _write_n_voids: + CHECK(save_Constant(stream, pc->u.s.s)); + pc = NEXTOP(pc,s); + break; + /* instructions type sc */ + case _write_n_atoms: + CHECK(save_Constant(stream, pc->u.sc.s)); + CHECK(save_ConstantTerm(stream, pc->u.sc.c)); + pc = NEXTOP(pc,sc); + break; + /* instructions type sllll */ + case _switch_on_sub_arg_type: + CHECK(save_Constant(stream, pc->u.sllll.s)); + CHECK(save_PtoOp(stream, pc->u.sllll.l1)); + CHECK(save_PtoOp(stream, pc->u.sllll.l2)); + CHECK(save_PtoOp(stream, pc->u.sllll.l3)); + CHECK(save_PtoOp(stream, pc->u.sllll.l4)); + pc = NEXTOP(pc,sllll); + break; + /* instructions type slp */ + case _call_c_wfail: + CHECK(save_Constant(stream, pc->u.slp.s)); + CHECK(save_PtoOp(stream, pc->u.slp.l)); + CHECK(save_PtoPred(stream, pc->u.slp.p)); + pc = NEXTOP(pc,slp); + 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: + CHECK(save_Constant(stream, pc->u.sssl.s)); + CHECK(save_Constant(stream, pc->u.sssl.e)); + CHECK(save_Constant(stream, pc->u.sssl.w)); + CHECK(save_PtoOp(stream, pc->u.sssl.l)); + pc = NEXTOP(pc,sssl); + break; + /* instructions type sssllp */ + case _expand_clauses: + CHECK(save_Constant(stream, pc->u.sssllp.s1)); + CHECK(save_Constant(stream, pc->u.sssllp.s2)); + CHECK(save_Constant(stream, pc->u.sssllp.s3)); + CHECK(save_PtoOp(stream, pc->u.sssllp.sprev)); + CHECK(save_PtoOp(stream, pc->u.sssllp.snext)); + CHECK(save_PtoPred(stream, pc->u.sssllp.p)); + pc = NEXTOP(pc,sssllp); + 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: + CHECK(save_X(stream, pc->u.x.x)); + pc = NEXTOP(pc,x); + break; + /* instructions type xD */ + case _get_dbterm: + case _put_dbterm: + CHECK(save_X(stream, pc->u.xD.x)); + CHECK(save_DBGroundTerm(stream, pc->u.xD.D)); + pc = NEXTOP(pc,xD); + break; + /* instructions type xN */ + case _get_bigint: + case _put_bigint: + CHECK(save_X(stream, pc->u.xN.x)); + CHECK(save_BlobTermInCode(stream, pc->u.xN.b)); + pc = NEXTOP(pc,xN); + break; + /* instructions type xc */ + case _get_atom: + case _put_atom: + CHECK(save_X(stream, pc->u.xc.x)); + CHECK(save_ConstantTerm(stream, pc->u.xc.c)); + pc = NEXTOP(pc,xc); + break; + /* instructions type xd */ + case _get_float: + case _put_float: + CHECK(save_X(stream, pc->u.xd.x)); + CHECK(save_DoubleInCode(stream, pc->u.xd.d)); + pc = NEXTOP(pc,xd); + break; + /* instructions type xfa */ + case _get_struct: + case _put_struct: + CHECK(save_X(stream, pc->u.xfa.x)); + CHECK(save_Func(stream, pc->u.xfa.f)); + CHECK(save_Arity(stream, pc->u.xfa.a)); + pc = NEXTOP(pc,xfa); + break; + /* instructions type xi */ + case _get_longint: + case _put_longint: + CHECK(save_X(stream, pc->u.xi.x)); + CHECK(save_IntegerInCode(stream, pc->u.xi.i)); + pc = NEXTOP(pc,xi); + break; + /* instructions type xl */ + case _p_atom_x: + case _p_atomic_x: + case _p_compound_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: + CHECK(save_X(stream, pc->u.xl.x)); + CHECK(save_PtoOp(stream, pc->u.xl.F)); + pc = NEXTOP(pc,xl); + break; + /* instructions type xll */ + case _jump_if_nonvar: + CHECK(save_X(stream, pc->u.xll.x)); + CHECK(save_PtoOp(stream, pc->u.xll.l1)); + CHECK(save_PtoOp(stream, pc->u.xll.l2)); + pc = NEXTOP(pc,xll); + break; + /* instructions type xllll */ + case _switch_on_arg_type: + CHECK(save_X(stream, pc->u.xllll.x)); + CHECK(save_PtoOp(stream, pc->u.xllll.l1)); + CHECK(save_PtoOp(stream, pc->u.xllll.l2)); + CHECK(save_PtoOp(stream, pc->u.xllll.l3)); + CHECK(save_PtoOp(stream, pc->u.xllll.l4)); + pc = NEXTOP(pc,xllll); + break; + /* instructions type xps */ + case _commit_b_x: + CHECK(save_X(stream, pc->u.xps.x)); + CHECK(save_PtoPred(stream, pc->u.xps.p0)); + CHECK(save_Constant(stream, pc->u.xps.s)); + pc = NEXTOP(pc,xps); + 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: + CHECK(save_X(stream, pc->u.xx.xl)); + CHECK(save_X(stream, pc->u.xx.xr)); + pc = NEXTOP(pc,xx); + break; + /* instructions type xxc */ + case _p_func2s_cv: + CHECK(save_X(stream, pc->u.xxc.x)); + CHECK(save_X(stream, pc->u.xxc.xi)); + CHECK(save_ConstantTerm(stream, pc->u.xxc.c)); + pc = NEXTOP(pc,xxc); + break; + /* instructions type xxn */ + case _p_and_vc: + case _p_arg_cv: + case _p_div_cv: + case _p_div_vc: + 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: + CHECK(save_X(stream, pc->u.xxn.x)); + CHECK(save_X(stream, pc->u.xxn.xi)); + CHECK(save_Integer(stream, pc->u.xxn.c)); + 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: + CHECK(save_X(stream, pc->u.xxx.x)); + CHECK(save_X(stream, pc->u.xxx.x1)); + CHECK(save_X(stream, pc->u.xxx.x2)); + pc = NEXTOP(pc,xxx); + break; + /* instructions type xxxx */ + case _put_xx_val: + CHECK(save_X(stream, pc->u.xxxx.xl1)); + CHECK(save_X(stream, pc->u.xxxx.xl2)); + CHECK(save_X(stream, pc->u.xxxx.xr1)); + CHECK(save_X(stream, pc->u.xxxx.xr2)); + pc = NEXTOP(pc,xxxx); + break; + /* instructions type xxy */ + case _p_func2f_xy: + CHECK(save_X(stream, pc->u.xxy.x)); + CHECK(save_X(stream, pc->u.xxy.x1)); + CHECK(save_Y(stream, pc->u.xxy.y2)); + pc = NEXTOP(pc,xxy); + break; + /* instructions type y */ + case _save_b_y: + case _write_y_loc: + case _write_y_val: + case _write_y_var: + CHECK(save_Y(stream, pc->u.y.y)); + pc = NEXTOP(pc,y); + break; + /* instructions type yl */ + case _p_atom_y: + case _p_atomic_y: + case _p_compound_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: + CHECK(save_Y(stream, pc->u.yl.y)); + CHECK(save_PtoOp(stream, pc->u.yl.F)); + pc = NEXTOP(pc,yl); + break; + /* instructions type yps */ + case _commit_b_y: + CHECK(save_Y(stream, pc->u.yps.y)); + CHECK(save_PtoPred(stream, pc->u.yps.p0)); + CHECK(save_Constant(stream, pc->u.yps.s)); + pc = NEXTOP(pc,yps); + break; + /* instructions type yx */ + case _get_y_val: + case _get_y_var: + case _gl_void_valy: + case _gl_void_vary: + case _glist_valy: + case _put_unsafe: + case _put_y_val: + case _put_y_var: + CHECK(save_Y(stream, pc->u.yx.y)); + CHECK(save_X(stream, pc->u.yx.x)); + 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: + CHECK(save_Y(stream, pc->u.yxn.y)); + CHECK(save_X(stream, pc->u.yxn.xi)); + CHECK(save_Integer(stream, pc->u.yxn.c)); + 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: + CHECK(save_Y(stream, pc->u.yxx.y)); + CHECK(save_X(stream, pc->u.yxx.x1)); + CHECK(save_X(stream, pc->u.yxx.x2)); + pc = NEXTOP(pc,yxx); + break; + /* instructions type yyx */ + case _p_func2f_yy: + CHECK(save_Y(stream, pc->u.yyx.y1)); + CHECK(save_Y(stream, pc->u.yyx.y2)); + CHECK(save_X(stream, pc->u.yyx.x)); + pc = NEXTOP(pc,yyx); + break; + /* instructions type yyxx */ + case _get_yy_var: + case _put_y_vals: + CHECK(save_Y(stream, pc->u.yyxx.y1)); + CHECK(save_Y(stream, pc->u.yyxx.y2)); + CHECK(save_X(stream, pc->u.yyxx.x1)); + CHECK(save_X(stream, pc->u.yyxx.x2)); + pc = NEXTOP(pc,yyxx); + break; +#ifdef YAPOR + /* instructions type Otapl */ + case _getwork: + case _getwork_seq: + case _sync: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.Otapl.or_arg)); +#endif +#ifdef TABLING + CHECK(save_TabEntry(stream, pc->u.Otapl.te)); +#endif + CHECK(save_Arity(stream, pc->u.Otapl.s)); + CHECK(save_PtoPred(stream, pc->u.Otapl.p)); + CHECK(save_PtoOp(stream, pc->u.Otapl.d)); + pc = NEXTOP(pc,Otapl); + break; + /* instructions type e */ + case _getwork_first_time: + if (op == _Nstop || op == _copy_idb_term || op == _unify_idb_term) return 1; + 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: +#ifdef YAPOR + CHECK(save_OrArg(stream, pc->u.Otapl.or_arg)); +#endif +#ifdef TABLING + CHECK(save_TabEntry(stream, pc->u.Otapl.te)); +#endif + CHECK(save_Arity(stream, pc->u.Otapl.s)); + CHECK(save_PtoPred(stream, pc->u.Otapl.p)); + CHECK(save_PtoOp(stream, pc->u.Otapl.d)); + pc = NEXTOP(pc,Otapl); + break; + /* instructions type e */ +#ifdef TABLING_INNER_CUTS + case _clause_with_cut: +#endif + if (op == _Nstop || op == _copy_idb_term || op == _unify_idb_term) return 1; + pc = NEXTOP(pc,e); + break; + /* instructions type s */ + case _table_new_answer: + CHECK(save_Constant(stream, pc->u.s.s)); + pc = NEXTOP(pc,s); + break; + /* instructions type e */ + case _trie_do_appl: + case _trie_do_appl_in_pair: + case _trie_do_atom: + case _trie_do_atom_in_pair: + case _trie_do_double: + case _trie_do_extension: + case _trie_do_gterm: + case _trie_do_longint: + case _trie_do_null: + case _trie_do_null_in_pair: + case _trie_do_pair: + case _trie_do_val: + case _trie_do_val_in_pair: + case _trie_do_var: + case _trie_do_var_in_pair: + case _trie_retry_appl: + case _trie_retry_appl_in_pair: + case _trie_retry_atom: + case _trie_retry_atom_in_pair: + case _trie_retry_double: + case _trie_retry_extension: + case _trie_retry_gterm: + case _trie_retry_longint: + case _trie_retry_null: + case _trie_retry_null_in_pair: + case _trie_retry_pair: + case _trie_retry_val: + case _trie_retry_val_in_pair: + case _trie_retry_var: + case _trie_retry_var_in_pair: + case _trie_trust_appl: + case _trie_trust_appl_in_pair: + case _trie_trust_atom: + case _trie_trust_atom_in_pair: + case _trie_trust_double: + case _trie_trust_extension: + case _trie_trust_gterm: + case _trie_trust_longint: + case _trie_trust_null: + case _trie_trust_null_in_pair: + case _trie_trust_pair: + case _trie_trust_val: + case _trie_trust_val_in_pair: + case _trie_trust_var: + case _trie_trust_var_in_pair: + case _trie_try_appl: + case _trie_try_appl_in_pair: + case _trie_try_atom: + case _trie_try_atom_in_pair: + case _trie_try_double: + case _trie_try_extension: + case _trie_try_gterm: + case _trie_try_longint: + case _trie_try_null: + case _trie_try_null_in_pair: + case _trie_try_pair: + case _trie_try_val: + case _trie_try_val_in_pair: + case _trie_try_var: + case _trie_try_var_in_pair: + if (op == _Nstop || op == _copy_idb_term || op == _unify_idb_term) return 1; + pc = NEXTOP(pc,e); + break; +#endif +default: + return -1; + } + } diff --git a/Makefile.in b/Makefile.in index 9b812480f..04a9559ba 100755 --- a/Makefile.in +++ b/Makefile.in @@ -316,6 +316,7 @@ PL_SOURCES= \ $(srcdir)/pl/modules.yap $(srcdir)/pl/preds.yap \ $(srcdir)/pl/profile.yap \ $(srcdir)/pl/protect.yap \ + $(srcdir)/pl/qly.yap \ $(srcdir)/pl/save.yap \ $(srcdir)/pl/setof.yap \ $(srcdir)/pl/signals.yap \ diff --git a/packages/PLStream/pl-yap.c b/packages/PLStream/pl-yap.c index 24f517fae..8f0d11357 100755 --- a/packages/PLStream/pl-yap.c +++ b/packages/PLStream/pl-yap.c @@ -993,6 +993,14 @@ int Yap_getInputStream(term_t t, IOSTREAM **s) return getInputStream(t, s); } +extern int Yap_getOutputStream(term_t t, IOSTREAM **s); + +int Yap_getOutputStream(term_t t, IOSTREAM **s) +{ + GET_LD + return getOutputStream(t, s); +} + #ifdef _WIN32 #include