From 1ec7cb9f7b8ecd7647f21c5fd749ab868697e226 Mon Sep 17 00:00:00 2001 From: Iain Sproat Date: Thu, 18 Nov 2010 23:53:07 +0000 Subject: [PATCH] PI constant added to GREL git-svn-id: http://google-refine.googlecode.com/svn/trunk@1904 7d457c2a-affb-35e4-300a-418c747d4874 --- .../google/refine/expr/ExpressionUtils.java | 57 ++++++++++--------- 1 file changed, 29 insertions(+), 28 deletions(-) diff --git a/main/src/com/google/refine/expr/ExpressionUtils.java b/main/src/com/google/refine/expr/ExpressionUtils.java index f4039fbc2..65dd75416 100644 --- a/main/src/com/google/refine/expr/ExpressionUtils.java +++ b/main/src/com/google/refine/expr/ExpressionUtils.java @@ -23,8 +23,8 @@ LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT -LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, -DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY +LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, +DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. @@ -51,37 +51,38 @@ import com.google.refine.model.Row; public class ExpressionUtils { static protected Set s_binders = new HashSet(); - + static public void registerBinder(Binder binder) { s_binders.add(binder); } - + static public Properties createBindings(Project project) { Properties bindings = new Properties(); - + bindings.put("true", true); bindings.put("false", false); - + bindings.put("PI", Math.PI); + bindings.put("project", project); - + for (Binder binder : s_binders) { binder.initializeBindings(bindings, project); } return bindings; } - + static public void bind(Properties bindings, Row row, int rowIndex, String columnName, Cell cell) { Project project = (Project) bindings.get("project"); - + bindings.put("rowIndex", rowIndex); bindings.put("row", new WrappedRow(project, rowIndex, row)); bindings.put("cells", new CellTuple(project, row)); - + if (columnName != null) { bindings.put("columnName", columnName); } - + if (cell == null) { bindings.remove("cell"); bindings.remove("value"); @@ -93,12 +94,12 @@ public class ExpressionUtils { bindings.put("value", cell.value); } } - + for (Binder binder : s_binders) { binder.bind(bindings, row, rowIndex, columnName, cell); } } - + static public boolean isError(Object o) { return o != null && o instanceof EvalError; } @@ -108,19 +109,19 @@ public class ExpressionUtils { } */ static public boolean isNonBlankData(Object o) { - return - o != null && + return + o != null && !(o instanceof EvalError) && (!(o instanceof String) || ((String) o).length() > 0); } static public boolean isTrue(Object o) { - return o != null && - (o instanceof Boolean ? - ((Boolean) o).booleanValue() : + return o != null && + (o instanceof Boolean ? + ((Boolean) o).booleanValue() : Boolean.parseBoolean(o.toString())); } - + static public boolean sameValue(Object v1, Object v2) { if (v1 == null) { return (v2 == null) @@ -132,7 +133,7 @@ public class ExpressionUtils { return v1.equals(v2); } } - + static public boolean isStorable(Object v) { return v == null || v instanceof Number || @@ -142,36 +143,36 @@ public class ExpressionUtils { v instanceof Calendar || v instanceof EvalError; } - + static public Serializable wrapStorable(Object v) { if (v instanceof JSONArray) { return ((JSONArray) v).toString(); } else if (v instanceof JSONObject) { return ((JSONObject) v).toString(); } else { - return isStorable(v) ? - (Serializable) v : + return isStorable(v) ? + (Serializable) v : new EvalError(v.getClass().getSimpleName() + " value not storable"); } } - + static public boolean isArray(Object v) { return v != null && v.getClass().isArray(); } - + static public boolean isArrayOrCollection(Object v) { return v != null && (v.getClass().isArray() || v instanceof Collection); } - + static public boolean isArrayOrList(Object v) { return v != null && (v.getClass().isArray() || v instanceof List); } - + @SuppressWarnings("unchecked") static public List toObjectList(Object v) { return (List) v; } - + @SuppressWarnings("unchecked") static public Collection toObjectCollection(Object v) { return (Collection) v;