summaryrefslogtreecommitdiff
path: root/tools/gnu/classpath/tools/StringToolkit.java
blob: 214dc1b66096baa579492d76f5ac92d98b661249 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
/* gnu.classpath.tools.StringToolkit
   Copyright (C) 2004 Free Software Foundation, Inc.

This file is part of GNU Classpath.

GNU Classpath 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, or (at your option)
any later version.
 
GNU Classpath 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 GNU Classpath; see the file COPYING.  If not, write to the
Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA. */

package gnu.classpath.tools;

/**
 *  Provides various String-related helper methods.
 *
 *  @author Julian Scheid
 */
public class StringToolkit
{
   /**
    *  Prevents instantiation.
    */
   private StringToolkit() {}

   /**
    *  Return <code>haystack</code> with all occurrences of
    *  <code>needle</code> replaced by </code>replacement</code>.
    *
    *  @param haystack the string to replace occurrences of <code>needle</code> in
    *  @param needle the substring to replace
    *  @param replacement the substring to replace <code>needle</code> with
    *
    *  @return <code>haystack</code> with all occurrences of
    *  <code>needle</code> replaced by </code>replacement</code>.
    */
   public static String replace(String haystack, String needle, String replacement)
   {
      int ndx = haystack.indexOf(needle);
      if (ndx < 0) {
         return haystack;
      }
      else {
         StringBuffer result = new StringBuffer();
         result.append(haystack.substring(0, ndx));
         result.append(replacement);
         ndx += needle.length();
         int ndx2;
         while ((ndx2 = haystack.indexOf(needle, ndx)) >= 0) {
            result.append(haystack.substring(ndx, ndx2));
            result.append(replacement);
            ndx = ndx2 + needle.length();
         }
         result.append(haystack.substring(ndx));
         return result.toString();
      }
   }
}