예제 #1
0
 internal static SCode Make(PrimitiveIsFixnumA0 predicate, SCode consequent, LexicalVariable alternative)
 {
     return
         (alternative is Argument) ? PCondIsFixnumA0SA.Make (predicate, consequent, (Argument) alternative) :
         (alternative is LexicalVariable1) ? Unimplemented() :
         new PCondIsFixnumA0SL (predicate, consequent, alternative);
 }
예제 #2
0
 internal static SCode Make(PrimitiveIsFixnumA0 predicate, SCode consequent, Argument0 alternative)
 {
     return
         new PCondIsFixnumA0SA0 (predicate, consequent, alternative);
 }
예제 #3
0
 protected PCondIsFixnumA0SL(PrimitiveIsFixnumA0 predicate, SCode consequent, LexicalVariable alternative)
     : base(predicate, consequent, alternative)
 {
     this.alternativeName = alternative.Name;
     this.alternativeDepth = alternative.Depth;
     this.alternativeOffset = alternative.Offset;
 }
예제 #4
0
 internal static SCode Make(PrimitiveIsFixnumA0 predicate, SCode consequent, Argument alternative)
 {
     return
         (alternative is Argument0) ? PCondIsFixnumA0SA0.Make (predicate, consequent, (Argument0) alternative) :
         (alternative is Argument1) ? Unimplemented () :
         new PCondIsFixnumA0SA (predicate, consequent, alternative);
 }
예제 #5
0
 PCondIsFixnumA0SA0(PrimitiveIsFixnumA0 predicate, SCode consequent, Argument0 alternative)
     : base(predicate, consequent, alternative)
 {
 }
예제 #6
0
 internal static SCode Make(PrimitiveIsFixnumA0 predicate, Argument0 consequent, SCode alternative)
 {
     return
         (alternative is LexicalVariable) ? Unimplemented () :
         (alternative is Quotation) ? Unimplemented () :
         new PCondIsFixnumA0A0 (predicate, consequent, alternative);
 }
예제 #7
0
 internal static SCode Make(PrimitiveIsFixnumA0 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 PCondIsFixnumA0QQ (predicate, consequent, alternative);
 }
예제 #8
0
 protected PCondIsFixnumA0QL(PrimitiveIsFixnumA0 predicate, Quotation consequent, LexicalVariable alternative)
     : base(predicate, consequent, alternative)
 {
 }
예제 #9
0
 internal static SCode Make(PrimitiveIsFixnumA0 predicate, Quotation consequent, LexicalVariable alternative)
 {
     return new PCondIsFixnumA0QL (predicate, consequent, alternative);
 }
예제 #10
0
 protected PCondIsFixnumA0Q(PrimitiveIsFixnumA0 predicate, Quotation consequent, SCode alternative)
     : base(predicate, consequent, alternative)
 {
     this.consequentValue = consequent.Quoted;
 }
예제 #11
0
 internal static SCode Make(PrimitiveIsFixnumA0 predicate, Quotation consequent, SCode alternative)
 {
     return
     (alternative is LexicalVariable) ? PCondIsFixnumA0QL.Make (predicate, consequent, (LexicalVariable) alternative)
     : (alternative is Quotation) ? PCondIsFixnumA0QQ.Make (predicate, consequent, (Quotation) alternative)
     : new PCondIsFixnumA0Q (predicate, consequent, alternative);
 }
예제 #12
0
 protected PCondIsFixnumA0LQ(PrimitiveIsFixnumA0 predicate, LexicalVariable consequent, Quotation alternative)
     : base(predicate, consequent, alternative)
 {
     this.alternativeValue = alternative.Quoted;
 }
예제 #13
0
 internal static SCode Make(PrimitiveIsFixnumA0 predicate, LexicalVariable consequent, SCode alternative)
 {
     return
         (consequent is Argument) ? PCondIsFixnumA0A.Make (predicate, (Argument) consequent, alternative) :
         (consequent is LexicalVariable1) ? Unimplemented():
         (alternative is LexicalVariable) ? PCondIsFixnumA0LL.Make (predicate, consequent, (LexicalVariable) alternative):
         (alternative is Quotation) ? PCondIsFixnumA0LQ.Make (predicate, consequent, (Quotation) alternative):
         new PCondIsFixnumA0L (predicate, consequent, alternative);
 }
예제 #14
0
 protected PCondIsFixnumA0L(PrimitiveIsFixnumA0 predicate, LexicalVariable consequent, SCode alternative)
     : base(predicate, consequent, alternative)
 {
     this.consequentName = consequent.Name;
     this.consequentDepth = consequent.Depth;
     this.consequentOffset = consequent.Offset;
 }
예제 #15
0
 protected PCondIsFixnumA0SQ(PrimitiveIsFixnumA0 predicate, SCode consequent, Quotation alternative)
     : base(predicate, consequent, alternative)
 {
     this.alternativeValue = alternative.Quoted;
 }
예제 #16
0
 protected PCondIsFixnumA0QQ(PrimitiveIsFixnumA0 predicate, Quotation consequent, Quotation alternative)
     : base(predicate, consequent, alternative)
 {
 }
예제 #17
0
 internal static SCode Make(PrimitiveIsFixnumA0 predicate, SCode consequent, Quotation alternative)
 {
     return new PCondIsFixnumA0SQ (predicate, consequent, alternative);
 }
예제 #18
0
 protected PCondIsFixnumA0A0(PrimitiveIsFixnumA0 predicate, Argument0 consequent, SCode alternative)
     : base(predicate, consequent, alternative)
 {
 }