|
@@ -4,18 +4,18 @@
|
|
|
|
|
|
import { TempNode } from '../core/TempNode.js';
|
|
|
|
|
|
-function CondNode( a, b, ifNode, elseNode, op ) {
|
|
|
+function CondNode( a, b, op, ifNode, elseNode ) {
|
|
|
|
|
|
TempNode.call( this );
|
|
|
|
|
|
this.a = a;
|
|
|
this.b = b;
|
|
|
|
|
|
+ this.op = op;
|
|
|
+
|
|
|
this.ifNode = ifNode;
|
|
|
this.elseNode = elseNode;
|
|
|
|
|
|
- this.op = op;
|
|
|
-
|
|
|
}
|
|
|
|
|
|
CondNode.EQUAL = '==';
|
|
@@ -31,13 +31,22 @@ CondNode.prototype.nodeType = "Cond";
|
|
|
|
|
|
CondNode.prototype.getType = function ( builder ) {
|
|
|
|
|
|
- if ( builder.getTypeLength( this.elseNode.getType( builder ) ) > builder.getTypeLength( this.ifNode.getType( builder ) ) ) {
|
|
|
+ if (this.ifNode) {
|
|
|
+
|
|
|
+ var ifType = this.ifNode.getType( builder );
|
|
|
+ var elseType = this.elseNode.getType( builder );
|
|
|
+
|
|
|
+ if ( builder.getTypeLength( elseType ) > builder.getTypeLength( ifType ) ) {
|
|
|
|
|
|
- return this.elseNode.getType( builder );
|
|
|
+ return elseType;
|
|
|
|
|
|
- }
|
|
|
+ }
|
|
|
|
|
|
- return this.ifNode.getType( builder );
|
|
|
+ return ifType;
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ return 'b';
|
|
|
|
|
|
};
|
|
|
|
|
@@ -59,10 +68,20 @@ CondNode.prototype.generate = function ( builder, output ) {
|
|
|
condType = this.getCondType( builder ),
|
|
|
a = this.a.build( builder, condType ),
|
|
|
b = this.b.build( builder, condType ),
|
|
|
- ifNode = this.ifNode.build( builder, type ),
|
|
|
- elseNode = this.elseNode.build( builder, type );
|
|
|
-
|
|
|
- var code = '( ' + [ a, this.op, b, '?', ifNode, ':', elseNode ].join( ' ' ) + ' )';
|
|
|
+ code;
|
|
|
+
|
|
|
+ if (this.ifNode) {
|
|
|
+
|
|
|
+ var ifCode = this.ifNode.build( builder, type ),
|
|
|
+ elseCode = this.elseNode.build( builder, type );
|
|
|
+
|
|
|
+ code = '( ' + [ a, this.op, b, '?', ifCode, ':', elseCode ].join( ' ' ) + ' )';
|
|
|
+
|
|
|
+ } else {
|
|
|
+
|
|
|
+ code = '( ' + a + ' ' + this.op + ' ' + b + ' )';
|
|
|
+
|
|
|
+ }
|
|
|
|
|
|
return builder.format( code, this.getType( builder ), output );
|
|
|
|
|
@@ -75,11 +94,11 @@ CondNode.prototype.copy = function ( source ) {
|
|
|
this.a = source.a;
|
|
|
this.b = source.b;
|
|
|
|
|
|
+ this.op = source.op;
|
|
|
+
|
|
|
this.ifNode = source.ifNode;
|
|
|
this.elseNode = source.elseNode;
|
|
|
|
|
|
- this.op = source.op;
|
|
|
-
|
|
|
};
|
|
|
|
|
|
CondNode.prototype.toJSON = function ( meta ) {
|
|
@@ -93,11 +112,11 @@ CondNode.prototype.toJSON = function ( meta ) {
|
|
|
data.a = this.a.toJSON( meta ).uuid;
|
|
|
data.b = this.b.toJSON( meta ).uuid;
|
|
|
|
|
|
- data.ifNode = this.ifNode.toJSON( meta ).uuid;
|
|
|
- data.elseNode = this.elseNode.toJSON( meta ).uuid;
|
|
|
-
|
|
|
data.op = this.op;
|
|
|
|
|
|
+ if ( data.ifNode ) data.ifNode = this.ifNode.toJSON( meta ).uuid;
|
|
|
+ if ( data.elseNode ) data.elseNode = this.elseNode.toJSON( meta ).uuid;
|
|
|
+
|
|
|
}
|
|
|
|
|
|
return data;
|