protected PCondIsRatnumLSQ(PrimitiveIsRatnumL predicate, SCode consequent, Quotation alternative) : base(predicate, consequent, alternative) { this.alternativeValue = alternative.Quoted; }
public static SCode Make(PrimitiveIsRatnumL predicate, SCode consequent, Quotation alternative) { return new PCondIsRatnumLSQ (predicate, consequent, alternative); }
protected PCondIsRatnumLSL(PrimitiveIsRatnumL predicate, SCode consequent, LexicalVariable alternative) : base(predicate, consequent, alternative) { }
public static SCode Make(PrimitiveIsRatnumL predicate, SCode consequent, LexicalVariable alternative) { return new PCondIsRatnumLSL (predicate, consequent, alternative); }
protected PCondIsRatnumLQQ(PrimitiveIsRatnumL predicate, Quotation consequent, Quotation alternative) : base(predicate, consequent, alternative) { }
public static SCode Make(PrimitiveIsRatnumL predicate, Quotation consequent, Quotation alternative) { if (consequent.Quoted == alternative.Quoted) { Debug.WriteLine ("; Optimize (if <expr> <literal> <literal>) => (begin <expr> <literal>)"); return Sequence2.Make (predicate, consequent); } else if (Configuration.EnableTrueUnspecific && consequent.Quoted == Constant.Unspecific) { Debug.WriteLine ("; Optimize (if <expr> <unspecific> <literal>) => (begin <expr> <literal>)"); return Sequence2.Make (predicate, alternative); } else if (Configuration.EnableTrueUnspecific && alternative.Quoted == Constant.Unspecific) { Debug.WriteLine ("; Optimize (if <expr> <literal> <unspecific>) => (begin <expr> <literal>)"); return Sequence2.Make (predicate, consequent); } return new PCondIsRatnumLQQ (predicate, consequent, alternative); }
protected PCondIsRatnumLQL(PrimitiveIsRatnumL predicate, Quotation consequent, LexicalVariable alternative) : base(predicate, consequent, alternative) { }
public static SCode Make(PrimitiveIsRatnumL predicate, Quotation consequent, SCode alternative) { return (alternative is LexicalVariable) ? PCondIsRatnumLQL.Make (predicate, consequent, (LexicalVariable) alternative) : (alternative is Quotation) ? PCondIsRatnumLQQ.Make (predicate, consequent, (Quotation) alternative) : new PCondIsRatnumLQ (predicate, consequent, alternative); }
protected PCondIsRatnumLQ(PrimitiveIsRatnumL predicate, Quotation consequent, SCode alternative) : base(predicate, consequent, alternative) { this.consequentValue = consequent.Quoted; }
public static SCode Make(PrimitiveIsRatnumL predicate, SCode consequent, SCode alternative) { return (predicate is PrimitiveIsRatnumA) ? PCondIsRatnumA.Make ((PrimitiveIsRatnumA) predicate, consequent, alternative) : (predicate is PrimitiveIsRatnumL1) ? PCondIsRatnumL1.Make ((PrimitiveIsRatnumL1) predicate, consequent, alternative) : (consequent is LexicalVariable) ? PCondIsRatnumLL.Make (predicate, (LexicalVariable) consequent, alternative) : (consequent is Quotation) ? PCondIsRatnumLQ.Make (predicate, (Quotation) consequent, alternative) : (alternative is LexicalVariable) ? PCondIsRatnumLSL.Make (predicate, consequent, (LexicalVariable) alternative) : (alternative is Quotation) ? PCondIsRatnumLSQ.Make (predicate, consequent, (Quotation) alternative) : new PCondIsRatnumL (predicate, consequent, alternative); }
protected PCondIsRatnumL(PrimitiveIsRatnumL predicate, SCode consequent, SCode alternative) : base(predicate, consequent, alternative) { this.predicateName = ((LexicalVariable) predicate.Operand).Name; this.predicateDepth = ((LexicalVariable) predicate.Operand).Depth; this.predicateOffset = ((LexicalVariable) predicate.Operand).Offset; }