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 }