001 /*
002 * Copyright (c) 2009 The openGion Project.
003 *
004 * Licensed under the Apache License, Version 2.0 (the "License");
005 * you may not use this file except in compliance with the License.
006 * You may obtain a copy of the License at
007 *
008 * http://www.apache.org/licenses/LICENSE-2.0
009 *
010 * Unless required by applicable law or agreed to in writing, software
011 * distributed under the License is distributed on an "AS IS" BASIS,
012 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
013 * either express or implied. See the License for the specific language
014 * governing permissions and limitations under the License.
015 */
016 package org.opengion.fukurou.process;
017
018 import org.opengion.fukurou.model.DataModel;
019 import org.opengion.fukurou.model.NativeType;
020 import org.opengion.fukurou.util.StringUtil;
021
022 import java.util.Arrays;
023
024 /**
025 * LineModel は、データの?行?を管?る為の TableModel と類似の実?ラスです?
026 *
027 * ??タの?行??LineModel に割り当てます?
028 * カラ?号は? から始まります?カラ?よりカラ?号を求める?合に?
029 * 存在しな??合??1 を返します?
030 * カラ?号?-1 の場合?、??行いません?
031 *
032 * 注意:このクラスは、同期??れて?せん?
033 *
034 * @version 4.0
035 * @author Kazuhiko Hasegawa
036 * @since JDK5.0,
037 */
038 public class LineModel implements DataModel<Object> { // 4.3.3.6 (2008/11/15) Generics警告対?
039 /** タブセパレータ */
040 private static final String TAB = "\t"; // タブ区???
041
042 /** リターンコー? System.getProperty("line.separator") */
043 private static final String CR = System.getProperty("line.separator");
044
045 private String[] names = null;
046 private Object[] data = null;
047 private int dtSize = 0;
048 private int rowNo = -1;
049
050 /**
051 * こ?オブジェクトを初期化します?
052 * ??引数???配?を作?します?
053 *
054 * @param columnCount カラ?
055 */
056 public void init( final int columnCount ) {
057 if( columnCount <= 0 ) {
058 String errMsg = "?配?の数量が 0か??す?count=[" + columnCount + "]";
059 throw new RuntimeException( errMsg );
060 }
061 dtSize = columnCount;
062 names = new String[dtSize];
063 data = new Object[dtSize];
064 }
065
066 /**
067 * カラ?配?を指定して、このオブジェクトを初期化します?
068 *
069 * @param clmNms カラ?配?
070 */
071 public void init( final String[] clmNms ) {
072 if( clmNms == null ) {
073 String errMsg = "カラ?配?が? null です?";
074 throw new RuntimeException( errMsg );
075 }
076 dtSize = clmNms.length;
077 names = new String[dtSize];
078 System.arraycopy( clmNms,0,names,0,dtSize );
079 data = new Object[dtSize];
080 }
081
082 /**
083 * 名前をセ?します?
084 * ??カラ?号が?-1 の場合?、なにもしません?
085 *
086 * @param clm 値が変更されるカラ?号
087 * @param key 新しい名前
088 *
089 */
090 public void setName( final int clm,final String key ) {
091 if( clm >= 0 ) { names[clm] = key; }
092 }
093
094 /**
095 * カラ?号に対するカラ?を取得します?
096 * ??カラ?号が?-1 の場合?、null を返します?
097 *
098 * @param clm ??のカラ?号は 0?番目のカラ?号は 1、などとする?
099 *
100 * @return カラ?
101 *
102 */
103 public String getName( final int clm ) {
104 return ( clm >= 0 ) ? names[clm] : null ;
105 }
106
107 /**
108 * カラ?配?を返します?
109 * 配?オブジェクト?、clone されたコピ?を返します?で?
110 * ?を書き換えた??合?、setName() メソ?を使用してください?
111 *
112 * @return カラ?配?
113 */
114 public String[] getNames() {
115 return names.clone();
116 }
117
118 /**
119 * column に対応し?値を登録します?
120 * ??カラ?号が?-1 の場合?、なにもしません?
121 *
122 * @param clm 値が変更されるカラ?号
123 * @param value 新しい値。null も可
124 *
125 */
126 public void setValue( final int clm,final Object value ) {
127 if( clm >= 0 ) { data[clm] = value; }
128 }
129
130 /**
131 * column にあるセルの属?値をObjectに変換して返します?
132 * ??カラ?号が?-1 の場合?、null を返します?
133 *
134 * @param clm 値が参照されるカラ?号
135 *
136 * @return ?されたセルの値 Object
137 *
138 */
139 public Object getValue( final int clm ) {
140 return ( clm >= 0 ) ? data[clm] : null ;
141 }
142
143 /**
144 * row および clm にあるセルの属?値をStringに変換して返します?
145 *
146 * @param row 値が参照される?
147 * @param clm 値が参照される?
148 *
149 * @return ?されたセルの値
150 *
151 */
152 public String getValue( final int row, final int clm) {
153 String errMsg = "こ?クラスでは実?れて?せん?;
154 throw new UnsupportedOperationException( errMsg );
155 }
156
157 /**
158 * 属?値配?をセ?します?
159 * こ?メソ?では、カラ?配?は更新しません。?列数が異なる?合や?
160 * 属?値配??null の場合?設定できません?
161 * 設定???列オブジェクト?コピ?をセ?します?で、登録??配?オブジェクトを
162 * 書き換えた場合でも?こ?オブジェクト??値は変更されませんので?
163 * 副作用を期?たコー?ングは、行わな?下さ??
164 * 注意:?オブジェクト?列?身はコピ?しますが、???オブジェクトそのも?は?
165 * arraycopy して??です?個?のオブジェクト?状態変化に対しては?
166 * ?ライアント?で対応が?です?
167 *
168 * @param values セ?する値配?
169 * @param rno 処?の行番号
170 */
171 public void setValues( final Object[] values, final int rno ) {
172 if( values == null ) {
173 String errMsg = "値配?が? null です?row=[" + rno + "]";
174 throw new RuntimeException( errMsg );
175 }
176 else if( names.length != values.length ) {
177 String errMsg = "カラ?配?と異なる要??属?値配?は登録できません? + CR
178 + " names.length=[" + names.length + "],"
179 + " values.length[" + values.length + "],"
180 + " row=[" + rno + "]" + CR
181 + " names=" + StringUtil.array2csv( names )
182 + " values=" + Arrays.toString( values ) ; // 5.1.8.0 (2010/07/01) errMsg 修正
183 throw new RuntimeException( errMsg );
184 }
185
186 rowNo = rno;
187 System.arraycopy( values,0,data,0,values.length );
188 }
189
190 /**
191 * 属?値を?列で返します?
192 * 配?オブジェクト?、clone されたコピ?を返します?で?
193 * ?を書き換えた??合?、setValue() メソ?を使用してください?
194 *
195 * @return ?されたセルの属?値
196 */
197 public Object[] getValues() {
198 return data.clone();
199 }
200
201 /**
202 * row にあるセルの属?値を?列で返します?
203 *
204 * @param row 値が参照される?
205 *
206 * @return ?されたセルの属?値
207 */
208 public String[] getValues( final int row ) {
209 String errMsg = "こ?クラスでは実?れて?せん?;
210 throw new UnsupportedOperationException( errMsg );
211 }
212
213 /**
214 * 行データモ?属?に、??の行番号??を設定します?
215 * ?に、setValue( int clm, Object value ) との併用時に使用します?
216 *
217 * @param rno 処?の行番号
218 */
219 public void setRowNo( final int rno ) {
220 rowNo = rno;
221 }
222
223 /**
224 * 行データモ?属?の、??の行番号??を返します?
225 *
226 * @return 処?の行番号
227 *
228 */
229 public int getRowNo() {
230 return rowNo;
231 }
232
233 /**
234 * columnName 名称に対応す?カラ?号を返します?存在しな??合??1 を返します?
235 *
236 * @param columnName 値が参照されるカラ?号
237 *
238 * @return ?されたセルのカラ?号(存在しな??合??1)
239 *
240 */
241 public int getColumnNo( final String columnName ) {
242 int clmNo = -1;
243 if( columnName != null ) {
244 for( int i=0; i<dtSize; i++ ) {
245 if( columnName.equalsIgnoreCase( names[i] ) ) {
246 clmNo = i;
247 break;
248 }
249 }
250 }
251
252 return clmNo;
253 }
254
255 /**
256 * ??タ??ブル??列?数を返します?
257 *
258 * @return モ?の列数
259 *
260 */
261 public int size() {
262 return dtSize ;
263 }
264
265 /**
266 * こ????タの名前配?を?結した文字?で、?力します?
267 *
268 * @return ???タの名前配?を?結した文字?
269 */
270 public String nameLine() {
271 String rtn = "No Data";
272
273 if( dtSize > 0 ) {
274 StringBuilder buf = new StringBuilder();
275 buf.append( "#Name" );
276 for( int clm=0; clm<dtSize; clm++ ) {
277 buf.append( TAB );
278 buf.append( names[clm] );
279 }
280 rtn = buf.toString() ;
281 }
282 return rtn ;
283 }
284
285 /**
286 * こ????タの名前配?を?結した文字?で、?力します?
287 *
288 * @return 名前配?を?結した文字?
289 */
290 public String dataLine() {
291 String rtn = "No Data";
292
293 if( dtSize > 0 ) {
294 StringBuilder buf = new StringBuilder();
295 buf.append( rowNo );
296 for( int clm=0; clm<dtSize; clm++ ) {
297 buf.append( TAB );
298 buf.append( data[clm] );
299 }
300 rtn = buf.toString() ;
301 }
302 return rtn ;
303 }
304
305 /**
306 * こ????タを見える形で出力します?
307 *
308 * @return ???タを見える形
309 */
310 @Override
311 public String toString() {
312 return nameLine() + CR + dataLine() ;
313 }
314
315 /**
316 * clm のNativeタイプを返します?
317 * Nativeタイプ?org.opengion.fukurou.model.NativeTypeで定義されて?す?
318 *
319 * @og.rev 4.1.1.2 (2008/02/28) 新規追?
320 * @og.rev 5.1.8.0 (2010/07/01) NativeType#getType(String) のメソ?を使用するように変更?
321 *
322 * @param clm 値が参照される?
323 *
324 * @return Nativeタイ?
325 * @see org.opengion.fukurou.model.NativeType
326 */
327 public NativeType getNativeType( final int clm ) {
328 // return StringUtil.getNativeType( data[clm].toString() );
329 return NativeType.getType( data[clm].toString() );
330 }
331 }