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.xml;
017
018 import org.opengion.fukurou.util.Closer ;
019 import org.opengion.fukurou.util.HybsEntry ;
020 import org.opengion.fukurou.util.FileUtil ;
021 import org.opengion.fukurou.util.StringUtil ;
022 import org.opengion.fukurou.util.LogWriter;
023 import org.opengion.fukurou.util.HybsDateUtil ;
024
025 import java.io.Reader;
026 import java.io.Writer;
027 import java.io.File;
028 import java.io.IOException;
029 import java.io.StringReader;
030 // import java.text.DateFormat;
031 // import java.text.SimpleDateFormat;
032 // import java.util.Date;
033 // import java.util.Locale;
034
035 import javax.xml.transform.TransformerException;
036 import javax.xml.transform.TransformerConfigurationException;
037 import javax.xml.transform.TransformerFactory;
038 import javax.xml.transform.Transformer;
039 import javax.xml.transform.stream.StreamSource;
040 import javax.xml.transform.stream.StreamResult;
041
042 /**
043 * XML 入力ファイルに、XSL 入力ファイルを適用して?XSLT変換を行います?
044 * 結果は、XML 出力ファイルにセーブします?
045 * ?ァイルの代わりに、Writer,Reader を設定することも可能です?
046 *
047 * こ?パ?サーでは、?部で実行中の入力ファイル???パラメータとして設定できます?
048 * useFileInfo( true ) とセ?すると、以下???目が?部?セ?されます?
049 * ただし?こ?設定が可能なのは、XML 入力ファイルに、Reader ではなく?ファイル名を
050 * 渡した場合?みです?ストリー??場合?、各種??は取れません?
051 *
052 * 入力ファイル(inXMLのフルパス) : FILEPATH (? G:\webapps\gf\jsp\DOC10\query.jsp)
053 * 入力親フォル?inXMLの親フォル? : ADDRESS (? DOC10)
054 * 入力ファイル(inXMLのファイル? : FILENAME (? query.jsp)
055 * 入力ファイル(inXMLの更新日? ) : MODIFIED (? yyyyMMddHHmmss形?
056 *
057 * xsl ファイルでは、パラメータ は、xsl:param で宣?、xsl:value-of で取り出します?
058 * <xsl:param name="ADDRESS" select="" /> と宣?ておき、?な?で
059 * <xsl:value-of select="$ADDRESS" /> とすれば、取得できます?
060 *
061 * String inXSTL = "inXSLfile.xsl" ; // 入力X??ファイル
062 * String outFile = "outXMLfile.xml" ; // 出力X??ファイル
063 * String inXML = "inXMLfile.xml" ; // 入力X??ファイル
064 *
065 * XSLT xslt = new XSLT();
066 * xslt.setXslFile( inXSTL );
067 * xslt.setOutFile( outFile,false );
068 *
069 * xslt.transform( inXML );
070 *
071 * @version 4.0
072 * @author Kazuhiko Hasegawa
073 * @since JDK5.0,
074 */
075 public class XSLT {
076 private static final String CR = System.getProperty("line.separator") ;
077 /** 初期 ENCODE ?{@value} */
078 public static final String ENCODE = "UTF-8" ;
079
080 private Transformer transformer = null;
081
082 private String encode = ENCODE;
083 private String xmlFile = null;
084 private String xslFile = null;
085 private String outFile = null;
086 private Reader xslReader = null;
087 private Writer outWriter = null;
088 private HybsEntry[] paramEntry = null;
089 private boolean isFileInfo = false;
090 private boolean isErrClose = true;
091 private boolean isErrXmlIn = false; // useErrXmlIn ?isErrXmlIn 変更
092 private boolean isInclude = true; // 4.2.3.0 (2008/05/26)
093 private StreamResult result = null;
094
095 // private DateFormat formatter = null; // HybsDateUtil を利用
096
097 // private String jspIncludeData = null; // 5.6.7.1 (2013/08/09) ローカル変数?
098 private String debugMsg = null; // 5.6.7.1 (2013/08/09) ??用
099
100 /**
101 * 入力XSLファイルを??します?
102 *
103 * @param file 入力XSLファイル
104 * @see #setXslFile( Reader )
105 */
106 public void setXslFile( final String file ) {
107 xslFile = file;
108 setXslFile( FileUtil.getBufferedReader( new File( xslFile ),encode ) );
109 }
110
111 /**
112 * 入力XSLリー??を??します?
113 *
114 * @param reader 入力XSLリー??
115 * @see #setXslFile( String )
116 */
117 public void setXslFile( final Reader reader ) {
118 transformer = null;
119 xslReader = reader;
120 }
121
122 /**
123 * 結果XML ファイル名と、そのオープン方法を?します?
124 * 結果XML ファイルを?追記す?append=true)か新規作?する(append=false)か指定します?
125 * なお?結果XML ファイル(outFile) を指定しな?=null)か?特別な名称 "System.out"
126 * ??を渡すと、標準?力に 結果を?力します?
127 *
128 * @param file 出力ファイル?null また??System.out" ??時?、標準??
129 * @param append [true]追記す?false:新規作?する]
130 */
131 public void setOutFile( final String file,final boolean append ) {
132 outFile = file ;
133 setOutFile( FileUtil.getPrintWriter( new File( outFile ),encode,append ) );
134 }
135
136 /**
137 * 結果XML ??タを?力する?Writer を指定します?
138 * ファイル、標準?力?JSPWriter など、?に応じて Writer を作?してください?
139 * 標準??System.out)の場合?、NonClosePrintWriter クラスなどの非close()処?を?
140 * JSPWriterの場合?、NonFlushPrintWriter クラスなどの非flush()、close()処?を?
141 * 使用してください?
142 *
143 * @param writer 出力するWriter
144 */
145 public void setOutFile( final Writer writer ) {
146 Closer.ioClose( outWriter );
147 outWriter = writer ;
148 result = new StreamResult( outWriter );
149 }
150
151 /**
152 * 結果XML ライターに、指定???タを書き?します?
153 *
154 * @param outData 書き?すデータ
155 */
156 public void setOutData( final String outData ) {
157 if( outData != null && outData.length() > 0 ) {
158 try {
159 outWriter.write( outData );
160 outWriter.write( CR );
161 }
162 catch( IOException ex ) {
163 String errMsg = "ライターに??タ登録を失敗しました? + CR
164 + ex.getMessage() ;
165 close();
166 throw new RuntimeException( errMsg,ex );
167 }
168 }
169 }
170
171 /**
172 * XML ファイルをXSLT変換します?
173 * XML 入力ファイルに、XSL 入力ファイルを適用して?XSLT変換を行います?
174 * 結果は、XML ファイルにセーブします?
175 * 拡張子が?jsp』?場合?jsp:directive.include 処?行います?
176 *
177 * @og.rev 4.0.0.2 (2007/12/10) 拡張子が?jsp』?場合?jsp:directive.include 処?行います?
178 *
179 * @param file 入力XMLファイル
180 * @see #transform( Reader )
181 */
182 public void transform( final String file ) {
183 transform( file, isInclude );
184 }
185
186 /**
187 * XML ファイルをXSLT変換します?
188 * XML 入力ファイルに、XSL 入力ファイルを適用して?XSLT変換を行います?
189 * 結果は、XML ファイルにセーブします?
190 * 引数の isJspInclude によって、jsp:directive.include 処?行うかど?判断します?
191 *
192 * @og.rev 4.2.3.0 (2008/05/26) jsp:directive.include 処??実施可否を引数?します?
193 * @og.rev 5.2.1.0 (2010/10/01) JspIncludeReader#getString の第?引数を?
194 * @og.rev 5.6.7.1 (2013/08/09) ??用に、ファイルリストを取得しておきます?
195 *
196 * @param file 入力XMLファイル
197 * @param isJspInclude jsp:directive.include 処?行うかど??
198 * @see #transform( Reader )
199 */
200 public void transform( final String file, final boolean isJspInclude ) {
201 xmlFile = file;
202
203 if( xmlFile.endsWith( ".jsp" ) && isJspInclude ) {
204 // if( xmlFile.endsWith( ".jsp" ) ) {
205 // transform( new JspIncludeReader().getReader( new File( xmlFile ),encode ) );
206 // jspIncludeData = new JspIncludeReader().getString( new File( xmlFile ),encode,false );
207 // jspIncludeData = new JspIncludeReader().getString( new File( xmlFile ),encode ); // 5.2.1.0 (2010/10/01)
208
209 // 5.6.7.1 (2013/08/09) ??用に、ファイルリストを取得しておきます?
210 JspIncludeReader jspIncReader = new JspIncludeReader();
211 debugMsg = jspIncReader.getIncludeFiles();
212
213 String jspIncludeData = jspIncReader.getString( new File( xmlFile ),encode ); // 5.2.1.0 (2010/10/01)
214 transform( new StringReader( jspIncludeData ) );
215 }
216 else {
217 transform( FileUtil.getBufferedReader( new File( xmlFile ),encode ) );
218 }
219 }
220
221 /**
222 * XML ファイルをXSLT変換します?
223 * XML 入力リー??に、XSL 入力リー??を適用して?XSLT変換を行います?
224 * 結果は、XML ライターに書き?します?
225 * こ?処??終?に、?力XML リー?? は、close() されます?
226 *
227 * @og.rev 5.6.5.2 (2013/06/21) エラーメ?ージが判りにくいので、追記します?
228 * @og.rev 5.6.7.1 (2013/08/09) ??用に、ファイルリストを出力します?
229 *
230 * @param xmlReader 入力XML リー??
231 * @see #transform( String )
232 */
233 public void transform( final Reader xmlReader ) {
234 HybsEntry[] entry = null;
235
236 try {
237 if( transformer == null ) {
238 init();
239 }
240 else {
241 transformer.reset();
242 }
243
244 // 入力XMLファイルのファイル??を設定します?
245 if( isFileInfo && xmlFile != null ) {
246 entry = getXmlParameter( xmlFile );
247 parameterSet( transformer,entry );
248 }
249 xmlFile = null ;
250
251 // 入力XMLリー??からStreamSourceを作る
252 StreamSource data = new StreamSource( xmlReader );
253
254 transformer.transform( data,result );
255 }
256 catch( TransformerException ex ) {
257 String errMsg = "XML-XSLT 変換に失敗しました? + CR
258 + ex.getMessage() ;
259
260 // 5.6.5.2 (2013/06/21) エラーメ?ージが判りにくいので、追記します?
261 if( errMsg.indexOf( "プロローグにはコン???できません" ) >= 0 ) {
262 errMsg = errMsg + CR + "(UTF-8変換時に、BOMが付くとこ?エラーが?ます?BOMを外してみてください?" ;
263 }
264
265 // 5.6.7.1 (2013/08/09) ??用に、ファイルリストを出力します?
266 if( errMsg.indexOf( "で終?る?がありま? ) >= 0 && debugMsg != null && debugMsg.length() > 0 ) {
267 errMsg = errMsg + CR + "不整合?、includeファイルの可能性があります?" + debugMsg;
268 }
269
270 if( isErrXmlIn ) { setOutData( toXmlRow( entry, ex ) ); }
271
272 if( isErrClose ) { close(); }
273 throw new RuntimeException( errMsg,ex );
274 }
275 finally {
276 Closer.ioClose( xmlReader );
277 }
278 }
279
280 /**
281 * Transformer オブジェクトに対して、Parameter を設定します?
282 *
283 * ?されたパラメーターキーは、xsl ファイルでは、xsl:param で宣??
284 * xsl:value-of で取り出します?
285 * <xsl:param name="ADDRESS" select="" /> と宣?ておき、?な?で
286 * <xsl:value-of select="$ADDRESS" /> とすれば、取得できます?
287 *
288 * @param entry HybsEntry配?
289 */
290 public void setParamEntry( final HybsEntry[] entry ) {
291 if( entry != null && entry.length > 0 ) {
292 paramEntry = new HybsEntry[entry.length];
293 System.arraycopy( entry,0,paramEntry,0,entry.length );
294 }
295 }
296
297 /**
298 * transform 処?にエラーが発生した?合に、?力ファイルを閉じるかど?を指定します?
299 *
300 * 処??中でエラーが発生した?合に、そこで処?中断するか?それとも?
301 * 無視して、さらに処?進めるかを?することが可能です?
302 * 継続して処?進めた??合?、?力ファイルを閉じな?め?false ?
303 * 設定します?ただし?エラー時には、RuntimeException は throw されます?
304 * 初期値は、true(閉じ?です?
305 *
306 * @param flag エラー時クローズ [true:閉じ?false:閉じない]
307 */
308 public void errClose( final boolean flag ) {
309 isErrClose = flag ;
310 }
311
312 /**
313 * transform 処?エラーを?出力ファイルに、XML形式でエラーを追記するかど?を指定します?
314 *
315 * 処??中でエラーが発生した?合に、ログ?ではなく?結果XMLファイルに?
316 * エラー???エラーファイルなどを埋め込?、XMLファイルとしてDB登録??
317 * そ?他集計等に使えます?
318 * 今?、GE70 スキーマ形式?ファイルしか作?できません?
319 * これは?errClose( boolean ) メソ?と共に使用すると効果的です?
320 * つまり?errClose = false; にして、エラー時でも?力ファイルを閉じずに?
321 * 処?続ける事で、エラーメ?ージもXMLファイルとして?できます?
322 * 初期値は、false(使用しな?です?
323 *
324 * @param flag エラー時XML形?[false:使用しな?true:使用する]
325 */
326 public void useErrXmlIn( final boolean flag ) {
327 isErrXmlIn = flag ;
328 }
329
330 /**
331 * jsp:directive.include 発見時に、そのファイル?INCLUDE するかを?するかど?を指定しま?初期値:true:使用する)
332 *
333 * 引数の処?象ファイル(transformの引数ファイル)が??jsp』?場合?
334 * jsp:directive.include 発見時に、そのファイル?INCLUDE するかを?するか
335 * ど?を指定します?
336 * インクルードされたファイルとあわせて、正規?XML にならな?、パーサー
337 * エラーが発生します?
338 * JSPソース解析を行うには、INCLUDE ファイルも?慮しな?正確な結果?
339 * 得られませんが?INCLUDE 先?ファイルまで合わせる?があるため?
340 * 場合によっては、INCLUDEファイルを無視しなければならな?ースがあります?
341 * 初期値は、true(使用する)です?
342 *
343 * @param flag エラー時XML形?[false:使用しな?true:使用する]
344 */
345 public void jspInclude( final boolean flag ) {
346 isInclude = flag ;
347 }
348
349 /**
350 * 入力XSLファイルのストリー?閉じます?
351 *
352 * @og.rev 5.6.7.1 (2013/08/09) includeしたファイルのキャ?ュをクリアします?
353 */
354 public void close() {
355 Closer.ioClose( outWriter );
356
357 // 5.6.7.1 (2013/08/09) includeしたファイルのキャ?ュをクリア
358 JspIncludeReader.cacheClear();
359 }
360
361 /**
362 * XML ファイルをXSLT変換します?
363 * XML 入力ファイルに、XSL 入力ファイルを適用して?XSLT変換を行います?
364 * 結果は、XML ファイルにセーブします?
365 * なお?結果XML ファイル(outFile) に、特別な名称 "System.out" ??を渡すと?
366 * 標準?力に 結果を?力します?
367 *
368 * @og.rev 5.6.7.1 (2013/08/09) includeしたファイルのキャ?ュをクリアします?
369 */
370 private void init() {
371 try {
372 // xsl属?からStreamSourceを作る
373 StreamSource style = new StreamSource( xslReader );
374
375 // Transformerを作り、XMLを変換する
376 TransformerFactory tFactory = TransformerFactory.newInstance();
377 transformer = tFactory.newTransformer( style );
378
379 parameterSet( transformer,paramEntry );
380
381 // 5.6.7.1 (2013/08/09) includeしたファイルのキャ?ュをクリア
382 JspIncludeReader.cacheClear();
383 }
384 catch( TransformerConfigurationException ex ) {
385 String errMsg = xslFile + "ファイルの XSLT 解析に失敗しました? + CR
386 + ex.getMessage() ;
387 throw new RuntimeException( errMsg,ex );
388 }
389 finally {
390 Closer.ioClose( xslReader );
391 xslReader = null;
392 }
393 }
394
395 /**
396 * 実行中の入力ファイル名などの属????パラメータとして設定するかど?を指定します?
397 *
398 * こ?パ?サーでは、?部で実行中の入力ファイル???パラメータとして設定できます?
399 * useFileInfo( true ) とセ?すると、以下???目が?部?セ?されます?
400 *
401 * 入力ファイル(inXMLのフルパス) : FILEPATH (? G:\webapps\gf\jsp\DOC10\query.jsp)
402 * 入力親フォル?inXMLの親フォル? : ADDRESS (? DOC10)
403 * 入力ファイル(inXMLのファイル? : FILENAME (? query.jsp)
404 * 入力ファイル(inXMLの更新日? ) : MODIFIED (? yyyyMMddHHmmss形?
405 *
406 * @og.rev 4.0.0.0 (2007/09/25) ParameterMetaData を使用したパラメータ設定追??
407 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用するように修正します?
408 *
409 * xsl ファイルでは、xsl:param で宣?、xsl:value-of で取り出します?
410 * <xsl:param name="ADDRESS" select="" /> と宣?ておき、?な?で
411 * <xsl:value-of select="$ADDRESS" /> とすれば、取得できます?
412 *
413 * 初期値は、false(セ?しな? です?
414 *
415 * @param flag セ?する:true/セ?しな?false
416 */
417 public void useFileInfo( final boolean flag ) {
418 isFileInfo = flag;
419 // if( isFileInfo ) {
420 // formatter = new SimpleDateFormat( "yyyyMMddHHmmss",Locale.JAPAN );
421 // }
422 }
423
424 /**
425 * ファイル名指定で XML,XSL,OUTファイルを指定する?合?エンコードを?します?
426 *
427 * 初期値は、UTF-8 です?
428 *
429 * @param encode エンコー?
430 */
431 public void useEncode( final String encode ) {
432 this.encode = encode;
433 }
434
435 /**
436 * 実行中の入力ファイル名などの属????パラメータとして取得します?
437 *
438 * 入力ファイル(inXMLのフルパス) : FILEPATH (? G:\webapps\gf\jsp\DOC10\query.jsp)
439 * 入力ファイル(inXMLのファイル? : FILENAME (? query.jsp)
440 * 入力親フォル?inXMLの親フォル? : ADDRESS (? DOC10)
441 * 入力ファイル(inXMLの更新日? ) : MODIFIED (? yyyyMMddHHmmss形?
442 *
443 * @og.rev 5.5.7.2 (2012/10/09) HybsDateUtil を利用するように修正します?
444 *
445 * @param xmlIn XML入力ファイル
446 *
447 * @return HybsEntry配?
448 */
449 private HybsEntry[] getXmlParameter( final String xmlIn ) {
450 HybsEntry[] entry = new HybsEntry[4] ;
451
452 entry[0] = new HybsEntry( "FILEPATH" , xmlIn) ;
453
454 File xmlFile = new File( xmlIn );
455 entry[1] = new HybsEntry( "FILENAME" , xmlFile.getName()) ;
456
457 File parentFile = xmlFile.getParentFile() ;
458 if( parentFile != null ) {
459 entry[2] = new HybsEntry( "ADDRESS" , parentFile.getName()) ;
460 }
461 else {
462 entry[2] = new HybsEntry( "ADDRESS" , "" ) ;
463 }
464
465 // String lastDate = formatter.format( new Date( xmlFile.lastModified() ) ) ;
466 String lastDate = HybsDateUtil.getDate( xmlFile.lastModified() , "yyyyMMddHHmmss" ) ; // 5.5.7.2 (2012/10/09) HybsDateUtil を利用
467 entry[3] = new HybsEntry( "MODIFIED" , lastDate ) ;
468
469 return entry ;
470 }
471
472 /**
473 * Transformer オブジェク?に、パラメータを設定します?
474 *
475 * ?されたパラメーターキーは、xsl ファイルでは、xsl:param で宣??
476 * xsl:value-of で取り出します?
477 * <xsl:param name="ADDRESS" select="" /> と宣?ておき、?な?で
478 * <xsl:value-of select="$ADDRESS" /> とすれば、取得できます?
479 *
480 * @param former Transformerオブジェク?
481 * @param entry パラメータ配?
482 */
483 private void parameterSet( final Transformer former,final HybsEntry[] entry ) {
484 if( entry != null ) {
485 int size = entry.length;
486 for( int i=0; i<size; i++ ) {
487 String key = entry[i].getKey() ;
488 String val = entry[i].getValue();
489 former.setParameter( key , val );
490 }
491 }
492 }
493
494 /**
495 * こ?オブジェクト????表現を返します?
496 *
497 * 接続URL + "," + 接続ユーザー + " (" + 作?日?+ ")" です?
498 *
499 * @return ???表現
500 */
501 @Override
502 public String toString() {
503 StringBuilder buf = new StringBuilder();
504
505 buf.append( "XSL File:" ).append( xslFile ).append( CR );
506 buf.append( "XML File:" ).append( xmlFile ).append( CR );
507 buf.append( "OUT File:" ).append( outFile ).append( CR );
508
509 return buf.toString() ;
510 }
511
512 /**
513 * エラー??の?XML??表現を返します?
514 *
515 * エラー時???も?XML化して保存する為の簡易???
516 * ここでは、XMLスキーマ?、固定で、GF70 の形式になります?
517 *
518 * @og.rev 4.2.3.0 (2008/05/26) エラー発生時のXMLファイルを追?ます?
519 * @og.rev 5.2.1.0 (2010/10/01) XML形式を変更します?(TEXT⇒TEXT_DATA)
520 *
521 * @param entry HybsEntry配?
522 * @param ex エラー??
523 *
524 * @return XMLの部?字?
525 */
526 private String toXmlRow( final HybsEntry[] entry,final TransformerException ex ) {
527 StringBuilder buf = new StringBuilder();
528
529 buf.append( "<ROW>" ).append( CR );
530 if( paramEntry != null ) {
531 for( int i=0; i<paramEntry.length; i++ ) {
532 String key = paramEntry[i].getKey() ;
533 String val = paramEntry[i].getValue();
534 buf.append( " <" ).append( key ).append( ">" );
535 buf.append( val );
536 buf.append( "</" ).append( key ).append( ">" );
537 buf.append( CR );
538 }
539 }
540
541 if( entry != null ) {
542 for( int i=0; i<entry.length; i++ ) {
543 String key = entry[i].getKey() ;
544 String val = entry[i].getValue();
545 buf.append( " <" ).append( key ).append( ">" );
546 buf.append( val );
547 buf.append( "</" ).append( key ).append( ">" );
548 buf.append( CR );
549 }
550 }
551
552 buf.append( " <TAGNAME />" ).append( CR );
553 buf.append( " <MSGCD>XML_ERROR</MSGCD>" ).append( CR );
554 buf.append( " <MSGTXT>XML-XSLT 変換に失敗しました?/MSGTXT>" ).append( CR );
555
556 String errMsg = StringUtil.htmlFilter( ex.getMessage() );
557 int indx = errMsg.lastIndexOf( "Exception:" );
558 if( indx >= 0 ) {
559 errMsg = errMsg.substring( indx + "Exception:".length() );
560 }
561 buf.append( " <TEXT_DATA>" ).append( errMsg ).append( CR ); // 5.2.1.0 (2010/10/01)
562 buf.append( " Location:" ).append( ex.getLocationAsString() ).append( CR );
563
564 // 4.2.3.0 (2008/05/26)
565 // if( jspIncludeData != null ) {
566 // buf.append( StringUtil.htmlFilter( jspIncludeData ) );
567 // }
568
569 buf.append( "</TEXT_DATA>" ).append( CR ); // 5.2.1.0 (2010/10/01)
570 buf.append( "</ROW>" ).append( CR );
571
572 return buf.toString() ;
573
574 /*
575 <ROW>
576 <SYSTEM_ID> </SYSTEM_ID>
577 <ADDRESS > </ADDRESS>
578 <FILENAME > </FILENAME>
579 <FILEPATH > </FILEPATH>
580 <MODIFIED > </MODIFIED>
581 <TAGNAME > </TAGNAME>
582 <MSGCD > </MSGCD>
583 <MSGTXT > </MSGTXT>
584 <TEXT_DATA> </TEXT_DATA>
585 </ROW>
586 */
587 }
588
589 /**
590 * ?ト用のメインメソ?
591 *
592 * java XSLT in_xml in_xsl out_xml
593 *
594 * @param args コマンド引数配?
595 */
596 public static void main( final String[] args ) throws IOException {
597 if( args.length != 3 ) {
598 LogWriter.log( "Usage: java XSLT in_xml in_xsl out_xml" );
599 LogWriter.log( " XML 入力ファイルに、XSL 入力ファイルを適用して? );
600 LogWriter.log( " XSLT変換を行います?" );
601 LogWriter.log( " 結果は、XML ファイルにセーブします?" );
602 LogWriter.log( " out_xml に System.out を指定すると標準?力に出力します?" );
603 return ;
604 }
605
606 XSLT xslt = new XSLT();
607 xslt.setXslFile( args[1] );
608 xslt.setOutFile( args[2],false );
609 xslt.transform( args[0] );
610 xslt.close();
611 }
612 }