- circumvented the JDBC ?-bug
[mir.git] / source / mir / util / StringRoutines.java
1 /*
2  * Copyright (C) 2001, 2002  The Mir-coders group
3  *
4  * This file is part of Mir.
5  *
6  * Mir is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * Mir is distributed in the hope that it will be useful,
12  * but WITHOUT ANY WARRANTY; without even the implied warranty of
13  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14  * GNU General Public License for more details.
15  *
16  * You should have received a copy of the GNU General Public License
17  * along with Mir; if not, write to the Free Software
18  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19  *
20  * In addition, as a special exception, The Mir-coders gives permission to link
21  * the code of this program with the com.oreilly.servlet library, any library
22  * licensed under the Apache Software License, The Sun (tm) Java Advanced
23  * Imaging library (JAI), The Sun JIMI library (or with modified versions of
24  * the above that use the same license as the above), and distribute linked
25  * combinations including the two.  You must obey the GNU General Public
26  * License in all respects for all of the code used other than the above
27  * mentioned libraries.  If you modify this file, you may extend this exception
28  * to your version of the file, but you are not obligated to do so.  If you do
29  * not wish to do so, delete this exception statement from your version.
30  */
31
32 package mir.util;
33
34 import java.util.*;
35 import gnu.regexp.*;
36
37 public class StringRoutines {
38
39   private StringRoutines() {
40   }
41
42   static int indexOfCharacters(String aString, char[] aCharacters, int aFrom) {
43     int i;
44     int result=-1;
45     int position;
46
47     for (i=0; i<aCharacters.length ; i++) {
48       position = aString.indexOf(aCharacters[i], aFrom);
49
50       if (position != -1 && ( result == -1 || position < result )) {
51         result = position;
52       }
53     }
54
55     return result;
56   }
57
58   static String replaceStringCharacters(String aText, char[] aCharactersToReplace, String[] aStringsToSubstitute) {
59     int position, nextPosition;
60     int i;
61     StringBuffer result = new StringBuffer();
62
63     position=0;
64
65     do {
66       nextPosition = StringRoutines.indexOfCharacters(aText, aCharactersToReplace, position);
67
68       if (nextPosition<0)
69         nextPosition = aText.length();
70
71       result.append(aText.substring(position, nextPosition));
72
73       if (nextPosition<aText.length())
74         for (i=0; i<aCharactersToReplace.length; i++) {
75           if (aCharactersToReplace[i] == aText.charAt(nextPosition)) {
76             result.append(aStringsToSubstitute[i]);
77             break;
78           }
79         }
80       position=nextPosition+1;
81     }
82     while (nextPosition<aText.length()) ;
83
84     return result.toString();
85   }
86
87
88   public static String interpretAsString(Object aValue) throws Exception {
89     if (aValue instanceof String)
90       return (String) aValue;
91
92     if (aValue instanceof Integer)
93       return ((Integer) aValue).toString();
94
95     if (aValue == null)
96       return "";
97
98     throw new Exception("String expected, "+aValue+" found");
99   }
100
101   public static int interpretAsInteger(Object aValue) throws Exception {
102     if (aValue instanceof Integer)
103       return ((Integer) aValue).intValue();
104
105     if (aValue instanceof String)
106       try {
107         return Integer.parseInt((String) aValue);
108       }
109       catch (Throwable t) {
110         throw new Exception("Integer expected, "+aValue+" found");
111       }
112
113     throw new Exception("Integer expected, "+aValue+" found");
114   }
115
116   public static String performRegularExpressionReplacement(String aSource,
117       String aSearchExpression, String aReplacement) throws Exception {
118
119     RE regularExpression;
120
121     regularExpression = new RE(aSearchExpression);
122
123     return regularExpression.substituteAll(aSource, aReplacement);
124   }
125
126   public static boolean performRegularExpressionSearch(String aSource,
127       String aSearchExpression) throws REException {
128     RE regularExpression;
129
130     regularExpression = new RE(aSearchExpression);
131
132     return regularExpression.isMatch(aSource);
133   }
134
135   public static List splitString(String aString, String aSeparator) {
136     List result= new Vector();
137     int previousPosition = 0;
138     int position;
139     int endOfNamePosition;
140
141     while ((position = aString.indexOf(aSeparator, previousPosition))>=0) {
142       result.add(aString.substring(previousPosition, position));
143       previousPosition = position + aSeparator.length();
144     }
145
146     result.add(aString.substring(previousPosition, aString.length()));
147
148     return result;
149   }
150 }