rebuilding head
[mir.git] / source / mircoders / localizer / basic / MirBasicUtilityFunctions.java
diff --git a/source/mircoders/localizer/basic/MirBasicUtilityFunctions.java b/source/mircoders/localizer/basic/MirBasicUtilityFunctions.java
new file mode 100755 (executable)
index 0000000..363b997
--- /dev/null
@@ -0,0 +1,159 @@
+/*\r
+ * Copyright (C) 2001, 2002 The Mir-coders group\r
+ *\r
+ * This file is part of Mir.\r
+ *\r
+ * Mir is free software; you can redistribute it and/or modify\r
+ * it under the terms of the GNU General Public License as published by\r
+ * the Free Software Foundation; either version 2 of the License, or\r
+ * (at your option) any later version.\r
+ *\r
+ * Mir is distributed in the hope that it will be useful,\r
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of\r
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the\r
+ * GNU General Public License for more details.\r
+ *\r
+ * You should have received a copy of the GNU General Public License\r
+ * along with Mir; if not, write to the Free Software\r
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA\r
+ *\r
+ * In addition, as a special exception, The Mir-coders gives permission to link\r
+ * the code of this program with  any library licensed under the Apache Software License,\r
+ * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library\r
+ * (or with modified versions of the above that use the same license as the above),\r
+ * and distribute linked combinations including the two.  You must obey the\r
+ * GNU General Public License in all respects for all of the code used other than\r
+ * the above mentioned libraries.  If you modify this file, you may extend this\r
+ * exception to your version of the file, but you are not obligated to do so.\r
+ * If you do not wish to do so, delete this exception statement from your version.\r
+ */\r
+package mircoders.localizer.basic;\r
+\r
+import mir.util.*;\r
+import mir.config.MirPropertiesConfiguration;\r
+\r
+import java.util.Collections;\r
+import java.util.List;\r
+\r
+public class MirBasicUtilityFunctions {\r
+  public String encodeXML(Object anObject) throws Exception {\r
+    return HTMLRoutines.encodeXML(StringRoutines.interpretAsString(anObject));\r
+  }\r
+\r
+  public String encodeHTML(Object aString) throws Exception {\r
+    return HTMLRoutines.encodeHTML(StringRoutines.interpretAsString(aString));\r
+  }\r
+\r
+  public String prettyEncodeHTML(Object aString) throws Exception {\r
+    return HTMLRoutines.prettyEncodeHTML(StringRoutines.interpretAsString(aString));\r
+  }\r
+\r
+  public String encodeURI(Object aString) throws Exception {\r
+    return HTMLRoutines.encodeURL(StringRoutines.interpretAsString(aString));\r
+  }\r
+\r
+  public String encodeURI(Object aString, Object anEncoding) throws Exception {\r
+    return HTMLRoutines.encodeURL(\r
+        StringRoutines.interpretAsString(aString),\r
+        StringRoutines.interpretAsString(anEncoding));\r
+  }\r
+\r
+  public String subString(Object aString, Object aFrom) throws Exception {\r
+    return StringRoutines.interpretAsString(aString).substring(StringRoutines.interpretAsInteger(aFrom));\r
+  }\r
+\r
+  public String subString(Object aString, Object aFrom, Object aLength) throws Exception {\r
+    int length = StringRoutines.interpretAsInteger(aLength);\r
+    String target = StringRoutines.interpretAsString(aString);\r
+    if (length<0 || length>target.length()) {\r
+      length=target.length();\r
+    }\r
+\r
+    return target.substring(StringRoutines.interpretAsInteger(aFrom), length);\r
+  }\r
+\r
+  public String escapeJDBCString(Object aString) throws Exception {\r
+    return JDBCStringRoutines.escapeStringLiteral(StringRoutines.interpretAsString(aString));\r
+  }\r
+\r
+  public String constructString(Object aString) throws Exception {\r
+    if (aString==null)\r
+      return StructuredContentParser.constructStringLiteral("");\r
+    else\r
+      return StructuredContentParser.constructStringLiteral(StringRoutines.interpretAsString(aString));\r
+  }\r
+\r
+  public Object parseStructuredString(Object aString) throws Exception {\r
+    if (aString==null)\r
+      return null;\r
+    else\r
+      return StructuredContentParser.parse(StringRoutines.interpretAsString(aString));\r
+  }\r
+\r
+  public boolean isOdd(Object anInteger) throws Exception {\r
+    return (StringRoutines.interpretAsInteger(anInteger) & 1) == 1;\r
+  }\r
+\r
+  public int increment(Object anInteger) throws Exception {\r
+    final Integer ONE = new Integer(1);\r
+\r
+    return increment(anInteger, ONE);\r
+  }\r
+\r
+  public int increment(Object anInteger, Object anIncrement) throws Exception {\r
+    return StringRoutines.interpretAsInteger(anInteger) +\r
+           StringRoutines.interpretAsInteger(anIncrement);\r
+  }\r
+\r
+  public Object subList(Object aList, Object aSkip) throws Exception {\r
+    return subList(aList, aSkip, new Integer(-1));\r
+  }\r
+\r
+  public Object subList(Object aList, Object aSkip, Object aMaxSize) throws Exception {\r
+    int skip = StringRoutines.interpretAsInteger(aSkip);\r
+    int maxSize = StringRoutines.interpretAsInteger(aMaxSize);\r
+\r
+    if (aList instanceof RewindableIterator)\r
+      return new SubsetIterator((RewindableIterator) aList, skip, maxSize);\r
+    else {\r
+      List list = (List) aList;\r
+\r
+      if (skip>=list.size())\r
+        return Collections.EMPTY_LIST;\r
+      if (maxSize<0 || (skip+maxSize)>=list.size())\r
+        return list.subList(skip, list.size());\r
+      else\r
+        return list.subList(skip, skip+maxSize);\r
+    }\r
+  }\r
+\r
+  public int listSize(RewindableIterator anIterator) {\r
+    anIterator.rewind();\r
+    int result=0;\r
+\r
+    while (anIterator.hasNext()) {\r
+      result++;\r
+      anIterator.next();\r
+    }\r
+\r
+    anIterator.rewind();\r
+\r
+    return result;\r
+  }\r
+\r
+  public int listSize(List aList) {\r
+    return aList.size();\r
+  }\r
+\r
+  public Object evaluate(Object aTarget, String anExpression) throws Exception {\r
+    return ParameterExpander.expandExpression(aTarget, anExpression);\r
+  }\r
+\r
+  public String regexpreplace(String aString, String anExpression, String aReplacement) {\r
+    return StringRoutines.performRegularExpressionReplacement(aString, anExpression, aReplacement);\r
+  }\r
+\r
+  public boolean regexpmatch(String aString, String anExpression) {\r
+    return StringRoutines.performRegularExpressionSearch(aString, anExpression);\r
+  }\r
+}\r