package jp.ac.kobe_u.cs.prolog.builtin;
import jp.ac.kobe_u.cs.prolog.lang.IntegerTerm;
import jp.ac.kobe_u.cs.prolog.lang.Predicate;
import jp.ac.kobe_u.cs.prolog.lang.Prolog;
import jp.ac.kobe_u.cs.prolog.lang.StructureTerm;
import jp.ac.kobe_u.cs.prolog.lang.SymbolTerm;
import jp.ac.kobe_u.cs.prolog.lang.Term;
import jp.ac.kobe_u.cs.prolog.lang.VariableTerm;
/*
This file is generated by Prolog Cafe.
PLEASE DO NOT EDIT!
*/
/**
<code>'$dummy_16_builtins.pl'/1</code> defined in builtins.pl<br>
@author Mutsunori Banbara (banbara@kobe-u.ac.jp)
@author Naoyuki Tamura (tamura@kobe-u.ac.jp)
@version 1.0
*/
class PRED_$dummy_16_builtins$002Epl_1 extends Predicate {
static SymbolTerm s1 = SymbolTerm.makeSymbol("ignore_ops", 1);
static SymbolTerm s2 = SymbolTerm.makeSymbol("true");
static Term[] s3 = {s2};
static StructureTerm s4 = new StructureTerm(s1, s3);
static Predicate _$dummy_16_builtins$002Epl_1_sub_1 = new PRED_$dummy_16_builtins$002Epl_1_sub_1();
static Predicate _$dummy_16_builtins$002Epl_1_1 = new PRED_$dummy_16_builtins$002Epl_1_1();
static Predicate _$dummy_16_builtins$002Epl_1_2 = new PRED_$dummy_16_builtins$002Epl_1_2();
public Term arg1;
public PRED_$dummy_16_builtins$002Epl_1(Term a1, Predicate cont) {
arg1 = a1;
this.cont = cont;
}
public PRED_$dummy_16_builtins$002Epl_1(){}
public void setArgument(Term[] args, Predicate cont) {
arg1 = args[0];
this.cont = cont;
}
public int arity() { return 1; }
public String toString() {
return "$dummy_16_builtins.pl(" + arg1 + ")";
}
public Predicate exec(Prolog engine) {
engine.aregs[1] = arg1;
engine.cont = cont;
engine.setB0();
return engine.jtry(_$dummy_16_builtins$002Epl_1_1, _$dummy_16_builtins$002Epl_1_sub_1);
}
}
class PRED_$dummy_16_builtins$002Epl_1_sub_1 extends PRED_$dummy_16_builtins$002Epl_1 {
public Predicate exec(Prolog engine) {
return engine.trust(_$dummy_16_builtins$002Epl_1_2);
}
}
class PRED_$dummy_16_builtins$002Epl_1_1 extends PRED_$dummy_16_builtins$002Epl_1 {
public Predicate exec(Prolog engine) {
// '$dummy_16_builtins.pl'(A):-'$builtin_member'(ignore_ops(true),A),!,fail
Term a1, a2;
Predicate p1, p2;
Predicate cont;
a1 = engine.aregs[1];
cont = engine.cont;
// '$dummy_16_builtins.pl'(A):-['$get_level'(B),'$builtin_member'(ignore_ops(true),A),'$cut'(B),fail]
a2 = new VariableTerm(engine);
//START inline expansion of $get_level(a(2))
if (! a2.unify(new IntegerTerm(engine.B0), engine.trail)) {
return engine.fail();
}
//END inline expansion
p1 = new PRED_fail_0(cont);
p2 = new PRED_$cut_1(a2, p1);
return new PRED_$builtin_member_2(s4, a1, p2);
}
}
class PRED_$dummy_16_builtins$002Epl_1_2 extends PRED_$dummy_16_builtins$002Epl_1 {
public Predicate exec(Prolog engine) {
// '$dummy_16_builtins.pl'(A):-true
Term a1;
Predicate cont;
a1 = engine.aregs[1];
cont = engine.cont;
// '$dummy_16_builtins.pl'(A):-[]
return cont;
}
}