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             * &lt;xsl:param name="ADDRESS" select="" /&gt; と宣?ておき、?な?で
411             * &lt;xsl:value-of select="$ADDRESS"     /&gt; とすれば、取得できます?
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    }