OSDN Git Service

bfb425dad28f96d43c1381b48721cc2765205126
[spring-ext/ozacc-mail.git] / src / main / java / com / ozacc / mail / fetch / impl / sk_jp / util / StringValues.java
1 /*\r
2  * @(#) $Id: StringValues.java,v 1.1.2.1 2005/01/18 07:20:49 otsuka Exp $\r
3  * $Revision: 1.1.2.1 $\r
4  */\r
5 package com.ozacc.mail.fetch.impl.sk_jp.util;\r
6 \r
7 import java.util.*;\r
8 \r
9 /**\r
10  * StringValues.\r
11  * <p>\r
12  * 複数の文字列をカンマやタブ区切りなどの一つの文字列として管理可能とします。\r
13  * <br>内部的にはListに入れますのでindexによるアクセスも可能ですが、\r
14  * 構築時、及びgetString()時に区切り文字で一本にされた文字列として\r
15  * やりとりすることもできます。\r
16  * エスケープ処理がされないので、デリミタを含むトークンを認識できません。\r
17  * </p>\r
18  * @version $Revision: 1.1.2.1 $ $Date: 2005/01/18 07:20:49 $\r
19  * @author Shin\r
20  */\r
21 public class StringValues {\r
22     private List                src_ = new ArrayList();\r
23     /**\r
24      * 複数文字列管理オブジェクトを生成します。\r
25      */\r
26     public StringValues() {}\r
27     /**\r
28      * 複数文字列管理オブジェクトを生成します。\r
29      * @param str 区切り文字で連結された文字列\r
30      */\r
31     public StringValues(String str) {\r
32         parse(str);\r
33     }\r
34     /**\r
35      * 複数文字列管理オブジェクトを生成します。\r
36      * @param str 区切り文字で連結された文字列\r
37      * @param delim デリミタ\r
38      */\r
39     public StringValues(String str, String delim) {\r
40         parse(str, delim);\r
41     }\r
42     /**\r
43      * 複数文字列管理オブジェクトを生成します。\r
44      * @param strings 文字列の配列\r
45      */\r
46     public StringValues(String[] strings) {\r
47         add(strings);\r
48     }\r
49     /**\r
50      * 複数文字列管理オブジェクトを生成します。\r
51      * @param strings 文字列の配列\r
52      */\r
53     public StringValues(Object[] o) {\r
54         for (int i = 0; i < o.length; i++) {\r
55             add(o[i].toString());\r
56         }\r
57     }\r
58 //////////////////////////////////////////////////////////////////////////////\r
59     /**\r
60      * デリミタで区切られた文字列を分割して追加します。\r
61      * <p>\r
62      * デリミタはStringTokenizerの標準のデリミタ\r
63      * <code>"&#92;t&#92;n&#92;r&#92;f"</code>が使われます。\r
64      * </p>\r
65      * @param str 区切り文字で連結された文字列\r
66      * @param delim デリミタ\r
67      */\r
68     public void parse(String str) {\r
69         StringTokenizer         st = new StringTokenizer(str);\r
70         parse(st);\r
71     }\r
72     /**\r
73      * デリミタで区切られた文字列を分割して追加します。\r
74      * <p>\r
75      * </p>\r
76      * @param str 区切り文字で連結された文字列\r
77      * @param delim デリミタ\r
78      */\r
79     public void parse(String str, String delim) {\r
80         StringTokenizer         st = new StringTokenizer(str, delim);\r
81         parse(st);\r
82     }\r
83     private void parse(StringTokenizer st) {\r
84         while (st.hasMoreTokens()) {\r
85             add(st.nextToken());\r
86         }\r
87     }\r
88     /**\r
89      * 文字列群へのイテレータを返します。\r
90      * @return Iteratorオブジェクト\r
91      */\r
92     public Iterator iterator() {\r
93         return src_.iterator();\r
94     }\r
95 \r
96     /**\r
97      * カンマ区切り文字列を得ます。\r
98      * <p>\r
99      * 区切り文字列は文字列同士の間に単純に挿入されます。\r
100      * </p>\r
101      * @return 文字列化したオブジェクト\r
102      */\r
103     public String getString() {\r
104         return getString(", ");\r
105     }\r
106     /**\r
107      * 指定した区切り文字で連結された文字列を得ます。\r
108      * <p>\r
109      * 区切り文字列は文字列同士の間に単純に挿入されます。\r
110      * </p>\r
111      * @param delim 区切り文字列\r
112      * @return 文字列化したオブジェクト\r
113      */\r
114     public String getString(String delim) {\r
115         StringBuffer            buf = new StringBuffer();\r
116         Iterator                iterator = iterator();\r
117         if (iterator.hasNext()) {\r
118             buf.append(iterator.next());\r
119         }\r
120         while (iterator.hasNext()) {\r
121             buf.append(delim).append(iterator.next());\r
122         }\r
123         return new String(buf);\r
124     }\r
125     public String toString() {\r
126         return getString();\r
127     }\r
128     /**\r
129      * 指定indexの文字列を取得します。\r
130      * @param index 文字列群中の位置\r
131      */\r
132     public String get(int index) {\r
133         return (String)src_.get(index);\r
134     }\r
135     /**\r
136      * 文字列を追加します。\r
137      * @param str 追加する文字列\r
138      */\r
139     public void add(String str) {\r
140         src_.add(str);\r
141     }\r
142     /**\r
143      * 文字列群を追加します。\r
144      * @param str 追加する文字列\r
145      */\r
146     public void add(String[] str) {\r
147         for (int i = 0; i < str.length; i++) {\r
148             src_.add(str[i]);\r
149         }\r
150     }\r
151     /**\r
152      * 管理している文字列を削除します。\r
153      */\r
154     public void clear() {\r
155         src_.clear();\r
156     }\r
157 }\r