1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
|
/*
* Copyright 2011 Vaadin Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/
package com.vaadin.tools;
import java.lang.reflect.Method;
import java.util.logging.Level;
import java.util.logging.Logger;
import com.vaadin.server.widgetsetutils.WidgetSetBuilder;
/**
* A wrapper for the GWT 1.6 compiler that runs the compiler in a new thread.
*
* This allows circumventing a J2SE 5.0 bug (6316197) that prevents setting the
* stack size for the main thread. Thus, larger widgetsets can be compiled.
*
* This class takes the same command line arguments as the
* com.google.gwt.dev.GWTCompiler class. The old and deprecated compiler is used
* for compatibility with GWT 1.5.
*
* A typical invocation would use e.g. the following arguments
*
* "-out WebContent/VAADIN/widgetsets com.vaadin.terminal.gwt.DefaultWidgetSet"
*
* In addition, larger memory usage settings for the VM should be used, e.g.
*
* "-Xms256M -Xmx512M -Xss8M"
*
* The source directory containing widgetset and related classes must be
* included in the classpath, as well as the gwt-dev-[platform].jar and other
* relevant JARs.
*
* @deprecated with Java 6, can use com.google.gwt.dev.Compiler directly (also
* in Eclipse plug-in etc.)
*/
@Deprecated
public class WidgetsetCompiler {
/**
* @param args
* same arguments as for com.google.gwt.dev.Compiler
*/
public static void main(final String[] args) {
try {
// run the compiler in a different thread to enable using the
// user-set stack size
// on Windows, the default stack size is too small for the main
// thread and cannot be changed in JRE 1.5 (see
// http://bugs.sun.com/bugdatabase/view_bug.do?bug_id=6316197)
Runnable runCompiler = new Runnable() {
@Override
public void run() {
try {
// GWTCompiler.main(args);
// avoid warnings
String wsname = args[args.length - 1];
// TODO expecting this is launched via eclipse WTP
// project
System.out
.println("Updating GWT module description file...");
WidgetSetBuilder.updateWidgetSet(wsname);
System.out.println("Done.");
System.out.println("Starting GWT compiler");
System.setProperty("gwt.nowarn.legacy.tools", "true");
Class<?> compilerClass = Class
.forName("com.google.gwt.dev.GWTCompiler");
Method method = compilerClass.getDeclaredMethod("main",
String[].class);
method.invoke(null, new Object[] { args });
} catch (Throwable thr) {
getLogger().log(Level.SEVERE,
"Widgetset compilation failed", thr);
}
}
};
Thread runThread = new Thread(runCompiler);
runThread.start();
runThread.join();
System.out.println("Widgetset compilation finished");
} catch (Throwable thr) {
getLogger().log(Level.SEVERE, "Widgetset compilation failed", thr);
}
}
private static final Logger getLogger() {
return Logger.getLogger(WidgetsetCompiler.class.getName());
}
}
|