X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=source%2Fmir%2Futil%2FStringRoutines.java;h=55d5edfd807441bb0447bd2d0fe2d0c90942c36a;hb=c26251faa299ed62d0e47c32636f440c554610ec;hp=16e98465403457253165ad7b5f5b533b74cee267;hpb=84123438aa8c1df395f64f65b613d863c6d86e37;p=mir.git diff --git a/source/mir/util/StringRoutines.java b/source/mir/util/StringRoutines.java index 16e98465..55d5edfd 100755 --- a/source/mir/util/StringRoutines.java +++ b/source/mir/util/StringRoutines.java @@ -1,363 +1,319 @@ -/* - * Copyright (C) 2001, 2002 The Mir-coders group - * - * This file is part of Mir. - * - * Mir is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2 of the License, or - * (at your option) any later version. - * - * Mir is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with Mir; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA - * - * In addition, as a special exception, The Mir-coders gives permission to link - * the code of this program with any library licensed under the Apache Software License, - * The Sun (tm) Java Advanced Imaging library (JAI), The Sun JIMI library - * (or with modified versions of the above that use the same license as the above), - * and distribute linked combinations including the two. You must obey the - * GNU General Public License in all respects for all of the code used other than - * the above mentioned libraries. If you modify this file, you may extend this - * exception to your version of the file, but you are not obligated to do so. - * If you do not wish to do so, delete this exception statement from your version. - */ -package mir.util; - -import gnu.regexp.RE; -import gnu.regexp.REException; - -import java.util.List; -import java.util.Vector; - -public class StringRoutines { - - private StringRoutines() { - } - - public static int indexOfCharacters(String aString, char[] aCharacters, int aFrom) { - int i; - int result=-1; - int position; - - for (i=0; iseperateString("a:b:c", ":"); will lead to - * a List with 3 Strings: "a", "b" and "c" - * - * @param aString The string to split - * @param aSeparator - * @return - */ - - public static List splitString(String aString, String aSeparator) { - List result= new Vector(); - int previousPosition = 0; - int position; - int endOfNamePosition; - - if (aString!=null) { - while ( (position = aString.indexOf(aSeparator, previousPosition)) >= 0) { - result.add(aString.substring(previousPosition, position)); - previousPosition = position + aSeparator.length(); - } - result.add(aString.substring(previousPosition, aString.length())); - } - - return result; - } - - /** - * Separates a String into at most 2 parts based on a separator: - * - * - * - * @param aString - * @param aSeparator - * @return - */ - public static List separateString(String aString, String aSeparator) { - List result= new Vector(); - int previousPosition = 0; - int position; - - if((position = aString.indexOf(aSeparator, previousPosition))>=0) { - result.add(aString.substring(previousPosition, position)); - previousPosition = position + aSeparator.length(); - } - - result.add(aString.substring(previousPosition, aString.length())); - - return result; - } - - public static List splitStringWithEscape(String aString, char aSeparator, char anEscape) { - List result= new Vector(); - int previousPosition = 0; - int position; - int endOfNamePosition; - StringBuffer currentItem = new StringBuffer(); - - if (aString!=null) { - while ((position = indexOfCharacters(aString, new char[] {aSeparator, anEscape}, previousPosition))>=0) { - currentItem.append(aString.substring(previousPosition, position)); - - if (aString.charAt(position)==aSeparator) { - result.add(currentItem.toString()); - currentItem.delete(0, currentItem.length()); - } - else { - currentItem.append(aString.charAt(position)); - if (aString.length()>position+1) { - position=position+1; - currentItem.append(aString.charAt(position)); - } - } - previousPosition = position + 1; - } - currentItem.append(aString.substring(previousPosition, aString.length())); - result.add(currentItem.toString()); - } - - return result; - } - - public static String replicateString(String aString, int aCount) { - StringBuffer result = new StringBuffer(); - - for (int i=0; i=0; digit--) { - int value = (int) (aData >> (digit*4)) & 0xf; - result.append(HEX_CHARACTERS[value]); - } - - return result.toString(); - } - - public static String convertToHex(byte[] aData) { - StringBuffer result = new StringBuffer(); - - for (int i = 0; iseperateString("a:b:c", ":"); will lead to + * a List with 3 Strings: "a", "b" and "c" + * + * @param aString The string to split + * @param aSeparator + * @return + */ + + public static List splitString(String aString, String aSeparator) { + List result= new ArrayList(); + int previousPosition = 0; + int position; + + if (aString!=null) { + while ( (position = aString.indexOf(aSeparator, previousPosition)) >= 0) { + result.add(aString.substring(previousPosition, position)); + previousPosition = position + aSeparator.length(); + } + result.add(aString.substring(previousPosition, aString.length())); + } + + return result; + } + + /** + * Separates a String into at most 2 parts based on a separator: + *
    + *
  • + * seperateString("a:b:c", ":"); will lead to + * a List with 2 Strings: "a" and "b:c" + *
  • + * seperateString("abc", ":"); will lead to + * a List with a single String: "abc" + *
+ * + * + * @param aString + * @param aSeparator + * @return + */ + public static List separateString(String aString, String aSeparator) { + List result= new ArrayList(); + int previousPosition = 0; + int position; + + if((position = aString.indexOf(aSeparator, previousPosition))>=0) { + result.add(aString.substring(previousPosition, position)); + previousPosition = position + aSeparator.length(); + } + + result.add(aString.substring(previousPosition, aString.length())); + + return result; + } + + /** + * Separates a string based on a separator, taking into account an escape character: + * seperateString("a:/::b", ":", "/"); will lead to + * a List with 3 Strings: "a", ":" and "b" + * + * @param aString The string to split + * @param aSeparator + * @return + */ + + public static List splitStringWithEscape(String aString, char aSeparator, char anEscape) { + List result= new ArrayList(); + int previousPosition = 0; + int position; + + StringBuffer currentItem = new StringBuffer(); + + if (aString!=null && aString.length()>0) { + while ((position = indexOfCharacters(aString, new char[] {aSeparator, anEscape}, previousPosition))>=0) { + currentItem.append(aString.substring(previousPosition, position)); + + if (aString.charAt(position)==aSeparator) { + result.add(currentItem.toString()); + currentItem.delete(0, currentItem.length()); + } + else { + if (aString.length()>position+1) { + position=position+1; + currentItem.append(aString.charAt(position)); + } + else { + currentItem.append(aString.charAt(position)); + } + } + previousPosition = position + 1; + } + currentItem.append(aString.substring(previousPosition, aString.length())); + result.add(currentItem.toString()); + } + + return result; + } + + public static String replicateString(String aString, int aCount) { + StringBuffer result = new StringBuffer(); + + for (int i=0; i=0; digit--) { + int value = (int) (aData >> (digit*4)) & 0xf; + result.append(HEX_CHARACTERS[value]); + } + + return result.toString(); + } + + public static String convertToHex(byte[] aData) { + StringBuffer result = new StringBuffer(); + + for (int i = 0; i