You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@commons.apache.org by at...@apache.org on 2015/12/28 21:45:37 UTC

[1/2] commons-scxml git commit: Support Javascript (Nashorn) based arrays for foreach

Repository: commons-scxml
Updated Branches:
  refs/heads/master 2a9e83027 -> 4f0841e04


Support Javascript (Nashorn) based arrays for foreach


Project: http://git-wip-us.apache.org/repos/asf/commons-scxml/repo
Commit: http://git-wip-us.apache.org/repos/asf/commons-scxml/commit/b24e7f33
Tree: http://git-wip-us.apache.org/repos/asf/commons-scxml/tree/b24e7f33
Diff: http://git-wip-us.apache.org/repos/asf/commons-scxml/diff/b24e7f33

Branch: refs/heads/master
Commit: b24e7f33aa4c19352a5aca076dc3880b3924ed61
Parents: 2a9e830
Author: Ate Douma <at...@apache.org>
Authored: Mon Dec 28 21:43:26 2015 +0100
Committer: Ate Douma <at...@apache.org>
Committed: Mon Dec 28 21:43:26 2015 +0100

----------------------------------------------------------------------
 .../java/org/apache/commons/scxml2/model/Foreach.java  | 13 +++++++++----
 1 file changed, 9 insertions(+), 4 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/commons-scxml/blob/b24e7f33/src/main/java/org/apache/commons/scxml2/model/Foreach.java
----------------------------------------------------------------------
diff --git a/src/main/java/org/apache/commons/scxml2/model/Foreach.java b/src/main/java/org/apache/commons/scxml2/model/Foreach.java
index 0be121e..1325f79 100644
--- a/src/main/java/org/apache/commons/scxml2/model/Foreach.java
+++ b/src/main/java/org/apache/commons/scxml2/model/Foreach.java
@@ -19,6 +19,7 @@ package org.apache.commons.scxml2.model;
 import java.lang.reflect.Array;
 import java.util.ArrayList;
 import java.util.List;
+import java.util.Map;
 
 import org.apache.commons.scxml2.ActionExecutionContext;
 import org.apache.commons.scxml2.Context;
@@ -49,7 +50,7 @@ public class Foreach extends Action implements ActionsContainer {
 
     public Foreach() {
         super();
-        this.actions = new ArrayList<Action>();
+        this.actions = new ArrayList<>();
     }
 
     @Override
@@ -103,7 +104,7 @@ public class Foreach extends Action implements ActionsContainer {
         ctx.setLocal(getNamespacesKey(), getNamespaces());
         try {
             Object arrayObject = eval.eval(ctx,array);
-            if (arrayObject != null && (arrayObject instanceof Iterable || arrayObject.getClass().isArray())) {
+            if (arrayObject != null && (arrayObject.getClass().isArray() || arrayObject instanceof Iterable || arrayObject instanceof Map)) {
                 if (arrayObject.getClass().isArray()) {
                     for (int currentIndex = 0, size = Array.getLength(arrayObject); currentIndex < size; currentIndex++) {
                         ctx.setLocal(item, Array.get(arrayObject, currentIndex));
@@ -117,12 +118,16 @@ public class Foreach extends Action implements ActionsContainer {
                     }
                 }
                 else {
+                    // In case of Javascript based arrays, the (Nashorn) engine returns a ScriptObjectMirror
+                    // which (also) implements Map<String, Object), so then we can/must use the map values as Iterable
+                    Iterable iterable = arrayObject instanceof Iterable ? (Iterable)arrayObject : ((Map)arrayObject).values();
+
                     // Spec requires to iterate over a shallow copy of underlying array in a way that modifications to
                     // the collection during the execution of <foreach> must not affect the iteration behavior.
                     // For array objects (see above) this isn't needed, but for Iterables we don't have that guarantee
                     // so we make a copy first
-                    ArrayList<Object> arrayList = new ArrayList<Object>();
-                    for (Object value: (Iterable)arrayObject) {
+                    ArrayList<Object> arrayList = new ArrayList<>();
+                    for (Object value: iterable) {
                         arrayList.add(value);
                     }
                     int currentIndex = 0;


[2/2] commons-scxml git commit: Javascript conditional expressions must be evaluated as (converted to) effective boolean expression

Posted by at...@apache.org.
Javascript conditional expressions must be evaluated as (converted to) effective boolean expression


Project: http://git-wip-us.apache.org/repos/asf/commons-scxml/repo
Commit: http://git-wip-us.apache.org/repos/asf/commons-scxml/commit/4f0841e0
Tree: http://git-wip-us.apache.org/repos/asf/commons-scxml/tree/4f0841e0
Diff: http://git-wip-us.apache.org/repos/asf/commons-scxml/diff/4f0841e0

Branch: refs/heads/master
Commit: 4f0841e04d88db62129618493ff85b87efec7712
Parents: b24e7f3
Author: Ate Douma <at...@apache.org>
Authored: Mon Dec 28 21:45:01 2015 +0100
Committer: Ate Douma <at...@apache.org>
Committed: Mon Dec 28 21:45:01 2015 +0100

----------------------------------------------------------------------
 .../commons/scxml2/env/javascript/JSEvaluator.java      | 12 +-----------
 1 file changed, 1 insertion(+), 11 deletions(-)
----------------------------------------------------------------------


http://git-wip-us.apache.org/repos/asf/commons-scxml/blob/4f0841e0/src/main/java/org/apache/commons/scxml2/env/javascript/JSEvaluator.java
----------------------------------------------------------------------
diff --git a/src/main/java/org/apache/commons/scxml2/env/javascript/JSEvaluator.java b/src/main/java/org/apache/commons/scxml2/env/javascript/JSEvaluator.java
index aa0a744..a901136 100644
--- a/src/main/java/org/apache/commons/scxml2/env/javascript/JSEvaluator.java
+++ b/src/main/java/org/apache/commons/scxml2/env/javascript/JSEvaluator.java
@@ -188,17 +188,7 @@ public class JSEvaluator extends AbstractBaseEvaluator {
      */
     @Override
     public Boolean evalCond(Context context, String expression) throws SCXMLExpressionException {
-        final Object result = eval(context, expression);
-
-        if (result == null) {
-            return Boolean.FALSE;
-        }
-
-        if (result instanceof Boolean) {
-            return (Boolean)result;
-        }
-
-        throw new SCXMLExpressionException("Invalid boolean expression: " + expression);
+        return (Boolean)eval(context, "Boolean("+expression+")");
     }
 
     /**