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    }