author | tonyp |
Wed, 19 Aug 2009 12:53:25 -0400 | |
changeset 3691 | c84b8483cd2c |
parent 2678 | 57cf2a1c1a05 |
permissions | -rw-r--r-- |
8 | 1 |
/* |
2678
57cf2a1c1a05
6831313: update jaxws in OpenJDK7 to 2.1 plus bug fixes from OpenJDK 6
tbell
parents:
8
diff
changeset
|
2 |
* Copyright 2005-2006 Sun Microsystems, Inc. All Rights Reserved. |
8 | 3 |
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. |
4 |
* |
|
5 |
* This code is free software; you can redistribute it and/or modify it |
|
6 |
* under the terms of the GNU General Public License version 2 only, as |
|
7 |
* published by the Free Software Foundation. Sun designates this |
|
8 |
* particular file as subject to the "Classpath" exception as provided |
|
9 |
* by Sun in the LICENSE file that accompanied this code. |
|
10 |
* |
|
11 |
* This code is distributed in the hope that it will be useful, but WITHOUT |
|
12 |
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
|
13 |
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License |
|
14 |
* version 2 for more details (a copy is included in the LICENSE file that |
|
15 |
* accompanied this code). |
|
16 |
* |
|
17 |
* You should have received a copy of the GNU General Public License version |
|
18 |
* 2 along with this work; if not, write to the Free Software Foundation, |
|
19 |
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA. |
|
20 |
* |
|
21 |
* Please contact Sun Microsystems, Inc., 4150 Network Circle, Santa Clara, |
|
22 |
* CA 95054 USA or visit www.sun.com if you need additional information or |
|
23 |
* have any questions. |
|
24 |
*/ |
|
25 |
package com.sun.codemodel.internal.writer; |
|
26 |
||
27 |
import java.io.IOException; |
|
28 |
import java.io.PrintWriter; |
|
29 |
import java.io.Writer; |
|
30 |
||
31 |
import com.sun.codemodel.internal.CodeWriter; |
|
32 |
import com.sun.codemodel.internal.JPackage; |
|
33 |
||
34 |
/** |
|
35 |
* Writes all the source files under the specified file folder and |
|
36 |
* inserts a file prolog comment in each java source file. |
|
37 |
* |
|
38 |
* @author |
|
39 |
* Kohsuke Kawaguchi (kohsuke.kawaguchi@sun.com) |
|
40 |
*/ |
|
41 |
public class PrologCodeWriter extends FilterCodeWriter { |
|
42 |
||
43 |
/** prolog comment */ |
|
44 |
private final String prolog; |
|
45 |
||
46 |
/** |
|
47 |
* @param core |
|
48 |
* This CodeWriter will be used to actually create a storage for files. |
|
49 |
* PrologCodeWriter simply decorates this underlying CodeWriter by |
|
50 |
* adding prolog comments. |
|
51 |
* @param prolog |
|
52 |
* Strings that will be added as comments. |
|
53 |
* This string may contain newlines to produce multi-line comments. |
|
54 |
* '//' will be inserted at the beginning of each line to make it |
|
55 |
* a valid Java comment, so the caller can just pass strings like |
|
56 |
* "abc\ndef" |
|
57 |
*/ |
|
58 |
public PrologCodeWriter( CodeWriter core, String prolog ) { |
|
59 |
super(core); |
|
60 |
this.prolog = prolog; |
|
61 |
} |
|
62 |
||
63 |
||
64 |
public Writer openSource(JPackage pkg, String fileName) throws IOException { |
|
65 |
Writer w = super.openSource(pkg,fileName); |
|
66 |
||
67 |
PrintWriter out = new PrintWriter(w); |
|
68 |
||
69 |
// write prolog if this is a java source file |
|
70 |
if( prolog != null ) { |
|
71 |
out.println( "//" ); |
|
72 |
||
73 |
String s = prolog; |
|
74 |
int idx; |
|
75 |
while( (idx=s.indexOf('\n'))!=-1 ) { |
|
76 |
out.println("// "+ s.substring(0,idx) ); |
|
77 |
s = s.substring(idx+1); |
|
78 |
} |
|
79 |
out.println("//"); |
|
80 |
out.println(); |
|
81 |
} |
|
82 |
out.flush(); // we can't close the stream for that would close the undelying stream. |
|
83 |
||
84 |
return w; |
|
85 |
} |
|
86 |
} |