e25df1400c7372ea6a786272056f856479158fe8
[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   public static String interpretAsString(Object aValue) throws Exception {
59     if (aValue instanceof String)
60       return (String) aValue;
61
62     if (aValue instanceof Integer)
63       return ((Integer) aValue).toString();
64
65     if (aValue == null)
66       return "";
67
68     throw new Exception("String expected, "+aValue+" found");
69   }
70
71   public static int interpretAsInteger(Object aValue) throws Exception {
72     if (aValue instanceof Integer)
73       return ((Integer) aValue).intValue();
74
75     if (aValue instanceof String)
76       try {
77         return Integer.parseInt((String) aValue);
78       }
79       catch (Throwable t) {
80         throw new Exception("Integer expected, "+aValue+" found");
81       }
82
83     throw new Exception("Integer expected, "+aValue+" found");
84   }
85
86   public static String performRegularExpressionReplacement(String aSource,
87       String aSearchExpression, String aReplacement) throws Exception {
88
89     RE regularExpression;
90
91     regularExpression = new RE(aSearchExpression);
92
93     return regularExpression.substituteAll(aSource, aReplacement);
94   }
95
96   public static boolean performRegularExpressionSearch(String aSource,
97       String aSearchExpression) throws REException {
98     RE regularExpression;
99
100     regularExpression = new RE(aSearchExpression);
101
102     return regularExpression.isMatch(aSource);
103   }
104
105   public static List splitString(String aString, String aSeparator) {
106     List result= new Vector();
107     int previousPosition = 0;
108     int position;
109     int endOfNamePosition;
110
111     while ((position = aString.indexOf(aSeparator, previousPosition))>=0) {
112       result.add(aString.substring(previousPosition, position));
113       previousPosition = position + aSeparator.length();
114     }
115
116     result.add(aString.substring(previousPosition, aString.length()));
117
118     return result;
119   }
120 }