Updating to GWT 2.12 SuperDevMode on start: JSwitchStatement cannot be cast to class com.google.gwt.dev.jjs.ast.JExpression

205 views
Skip to first unread message

Oleg Ravun

unread,
Nov 8, 2024, 7:53:40 AM11/8/24
to google-we...@googlegroups.com
Hello,

I have updated from GWT 2.11 to 2.12. SuperDevMode does not start in Intellij IDEA with the following exception. Any idea how to fix this?
com.google.gwt.dev.jjs.InternalCompilerException: Error constructing Java AST
at com.google.gwt.dev.jjs.impl.GwtAstBuilder.translateException(GwtAstBuilder.java:4181)
at com.google.gwt.dev.jjs.impl.GwtAstBuilder$AstVisitor.endVisit(GwtAstBuilder.java:1091)
at org.eclipse.jdt.internal.compiler.ast.IfStatement.traverse(IfStatement.java:335)
at org.eclipse.jdt.internal.compiler.ast.MethodDeclaration.traverse(MethodDeclaration.java:437)
at org.eclipse.jdt.internal.compiler.ast.TypeDeclaration.traverse(TypeDeclaration.java:1699)
at com.google.gwt.dev.jjs.impl.GwtAstBuilder.processImpl(GwtAstBuilder.java:4117)
at com.google.gwt.dev.jjs.impl.GwtAstBuilder.process(GwtAstBuilder.java:4155)
at com.google.gwt.dev.javac.CompilationStateBuilder$CompileMoreLater$UnitProcessorImpl.process(CompilationStateBuilder.java:128)
at com.google.gwt.dev.javac.JdtCompiler$CompilerImpl.process(JdtCompiler.java:322)
at org.eclipse.jdt.internal.compiler.Compiler.processCompiledUnits(Compiler.java:575)
at org.eclipse.jdt.internal.compiler.Compiler.compile(Compiler.java:475)
at org.eclipse.jdt.internal.compiler.Compiler.compile(Compiler.java:426)
at com.google.gwt.dev.javac.JdtCompiler.doCompile(JdtCompiler.java:1021)
at com.google.gwt.dev.javac.CompilationStateBuilder$CompileMoreLater.compile(CompilationStateBuilder.java:322)
at com.google.gwt.dev.javac.CompilationStateBuilder.doBuildFrom(CompilationStateBuilder.java:532)
at com.google.gwt.dev.javac.CompilationStateBuilder.buildFrom(CompilationStateBuilder.java:464)
at com.google.gwt.dev.cfg.ModuleDef.getCompilationState(ModuleDef.java:426)
at com.google.gwt.dev.codeserver.Recompiler.initWithoutPrecompile(Recompiler.java:213)
at com.google.gwt.dev.codeserver.Outbox.maybePrecompile(Outbox.java:89)
at com.google.gwt.dev.codeserver.Outbox.<init>(Outbox.java:61)
at com.google.gwt.dev.codeserver.CodeServer.makeOutboxTable(CodeServer.java:192)
at com.google.gwt.dev.codeserver.CodeServer.start(CodeServer.java:151)
at com.google.gwt.dev.codeserver.CodeServer.main(CodeServer.java:104)
at com.google.gwt.dev.codeserver.CodeServer.main(CodeServer.java:55)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at java.base/jdk.internal.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.base/java.lang.reflect.Method.invoke(Method.java:566)
at com.google.gwt.dev.shell.SuperDevListener.runCodeServer(SuperDevListener.java:118)
at com.google.gwt.dev.shell.SuperDevListener.start(SuperDevListener.java:97)
at com.google.gwt.dev.DevMode.ensureCodeServerListener(DevMode.java:664)
at com.google.gwt.dev.DevModeBase.doStartup(DevModeBase.java:785)
at com.google.gwt.dev.DevMode.doStartup(DevMode.java:549)
at com.google.gwt.dev.DevModeBase.startUp(DevModeBase.java:888)
at com.google.gwt.dev.DevModeBase.run(DevModeBase.java:705)
at com.google.gwt.dev.DevMode.main(DevMode.java:430)
Caused by: java.lang.ClassCastException: class com.google.gwt.dev.jjs.ast.JSwitchStatement cannot be cast to class com.google.gwt.dev.jjs.ast.JExpression (com.google.gwt.dev.jjs.ast.JSwitchStatement and com.google.gwt.dev.jjs.ast.JExpression are in unnamed module of loader 'app')
at com.google.gwt.dev.jjs.impl.GwtAstBuilder$AstVisitor.pop(GwtAstBuilder.java:2816)
at com.google.gwt.dev.jjs.impl.GwtAstBuilder$AstVisitor.endVisit(GwtAstBuilder.java:1087)
... 34 more

Thanks,
Oleg

Colin Alworth

unread,
Nov 8, 2024, 8:08:51 AM11/8/24
to GWT Users
Thanks for the report, looks like you're running into https://github.com/gwtproject/gwt/issues/10024. We have a fix for that merged, you can test the HEAD-SNAPSHOT release from the sonatype snapshots repository (https://oss.sonatype.org/content/repositories/snapshots/), or wait for the 2.12.1 release (see https://github.com/gwtproject/gwt/milestone/24, will likely only contain that fix plus one other long-standing issue that impacts latest jsinterop-base and elemental2).

You can also find the failing code (easier to spot running the compiler) and add the missing "{}"s in the "if" that contains the switch statement, that will work around this bug.

Oleg Ravun

unread,
Nov 8, 2024, 9:06:27 AM11/8/24
to google-we...@googlegroups.com
Thank you Colin.
The compiler gives a different issue though. I have updated to the latest guava but it does not help.

 Caused by: java.lang.NoSuchMethodError: 'void com.google.gwt.thirdparty.guava.common.base.Preconditions.checkState(boolean, java.lang.String, java.lang.Object)'

[INFO] at com.google.gwt.safehtml.rebind.HtmlTemplateParser.getHtmlContextFromParseState(HtmlTemplateParser.java:269)

[INFO] at com.google.gwt.safehtml.rebind.HtmlTemplateParser.parseTemplate(HtmlTemplateParser.java:205)

[INFO] at com.google.gwt.safehtml.rebind.SafeHtmlTemplatesImplMethodCreator.emitMethodBodyFromTemplate(SafeHtmlTemplatesImplMethodCreator.java:220)

[INFO] at com.google.gwt.safehtml.rebind.SafeHtmlTemplatesImplMethodCreator.createMethodFor(SafeHtmlTemplatesImplMethodCreator.java:120)

[INFO] at com.google.gwt.safehtml.rebind.SafeHtmlTemplatesImplCreator.emitMethodBody(SafeHtmlTemplatesImplCreator.java:43)

[INFO] at com.google.gwt.user.rebind.AbstractGeneratorClassCreator.genMethod(AbstractGeneratorClassCreator.java:277)

[INFO] at com.google.gwt.user.rebind.AbstractGeneratorClassCreator.emitMethods(AbstractGeneratorClassCreator.java:239)

[INFO] at com.google.gwt.user.rebind.AbstractGeneratorClassCreator.emitClass(AbstractGeneratorClassCreator.java:118)

[INFO] at com.google.gwt.safehtml.rebind.SafeHtmlTemplatesGenerator.generate(SafeHtmlTemplatesGenerator.java:65)

[INFO] at com.google.gwt.core.ext.IncrementalGenerator.generateNonIncrementally(IncrementalGenerator.java:40)

[INFO] at com.google.gwt.dev.javac.StandardGeneratorContext.runGeneratorIncrementally(StandardGeneratorContext.java:745)

[INFO] at com.google.gwt.dev.cfg.RuleGenerateWith.realize(RuleGenerateWith.java:103)

[INFO] at com.google.gwt.dev.shell.StandardRebindOracle$Rebinder.rebind(StandardRebindOracle.java:78)

[INFO] at com.google.gwt.dev.shell.StandardRebindOracle.rebind(StandardRebindOracle.java:262)

[INFO] at com.google.gwt.dev.shell.StandardRebindOracle.rebind(StandardRebindOracle.java:251)

[INFO] at com.google.gwt.dev.PrecompilationContextCreator$1.getAllPossibleRebindAnswers(PrecompilationContextCreator.java:86)

[INFO] at com.google.gwt.dev.jjs.impl.UnifyAst$UnifyVisitor.createStaticRebindExpression(UnifyAst.java:519)

[INFO] at com.google.gwt.dev.jjs.impl.UnifyAst$UnifyVisitor.createRebindExpression(UnifyAst.java:487)

[INFO] at com.google.gwt.dev.jjs.impl.UnifyAst$UnifyVisitor.maybeHandleMagicMethodCall(UnifyAst.java:415)

[INFO] at com.google.gwt.dev.jjs.impl.UnifyAst$UnifyVisitor.visit(UnifyAst.java:402)

[INFO] at com.google.gwt.dev.jjs.ast.JMethodCall.traverse(JMethodCall.java:265)

[INFO] at com.google.gwt.dev.jjs.ast.JModVisitor.traverse(JModVisitor.java:361)

[INFO] at com.google.gwt.dev.jjs.ast.JModVisitor.accept(JModVisitor.java:273)

[INFO] ... 51 more

[INFO]       [ERROR] at VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.java(21): GWT.create(VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates.class)

[INFO]          com.google.gwt.dev.jjs.ast.JMethodCall

[INFO]       [ERROR] at VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.java(21): (VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates) GWT.create(VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates.class)

[INFO]          com.google.gwt.dev.jjs.ast.JCastOperation

[INFO]       [ERROR] at VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.java(21): ((VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates) GWT.create(VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates.class)).render0(CssFloatLayoutDefaultAppearance_CssFloatLayoutStyle_container_ValueProviderImpl.INSTANCE.getValue(style))

[INFO]          com.google.gwt.dev.jjs.ast.JMethodCall

[INFO]       [ERROR] at VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.java(21): outer = ((VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates) GWT.create(VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates.class)).render0(CssFloatLayoutDefaultAppearance_CssFloatLayoutStyle_container_ValueProviderImpl.INSTANCE.getValue(style))

[INFO]          com.google.gwt.dev.jjs.ast.JBinaryOperation

[INFO]       [ERROR] at VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.java(21): outer = ((VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates) GWT.create(VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates.class)).render0(CssFloatLayoutDefaultAppearance_CssFloatLayoutStyle_container_ValueProviderImpl.INSTANCE.getValue(style))

[INFO]          com.google.gwt.dev.jjs.ast.JExpressionStatement

[INFO]       [ERROR] at VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.java(8): {

[INFO]   SafeHtml outer;

[INFO]   outer = ((VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates) GWT.create(VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates.class)).render0(CssFloatLayoutDefaultAppearance_CssFloatLayoutStyle_container_ValueProviderImpl.INSTANCE.getValue(style));

[INFO]   return outer;

[INFO] }

[INFO]          com.google.gwt.dev.jjs.ast.JBlock

[INFO]       [ERROR] at VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.java(8): {

[INFO]   SafeHtml outer;

[INFO]   outer = ((VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates) GWT.create(VerticalFloatAppearance_VerticalFloatLayoutTemplate_render_SafeHtml__CssFloatLayoutStyle_style___SafeHtmlTemplates.class)).render0(CssFloatLayoutDefaultAppearance_CssFloatLayoutStyle_container_ValueProviderImpl.INSTANCE.getValue(style));

[INFO]   return outer;

[INFO] }

[INFO]          com.google.gwt.dev.jjs.ast.JMethodBody

[INFO]       [ERROR] at VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.java(8): com.company.framework.core.client.ui.component.VerticalFloatAppearance_VerticalFloatLayoutTemplateImpl.render(Lcom/sencha/gxt/theme/base/client/container/CssFloatLayoutDefaultAppearance$CssFloatLayoutStyle;)Lcom/google/gwt/safehtml/shared/SafeHtml;

[INFO]          com.google.gwt.dev.jjs.ast.JMethod


--
You received this message because you are subscribed to the Google Groups "GWT Users" group.
To unsubscribe from this group and stop receiving emails from it, send an email to google-web-tool...@googlegroups.com.
To view this discussion visit https://groups.google.com/d/msgid/google-web-toolkit/374c0074-6ec0-4ced-a70f-ee713141b0d0n%40googlegroups.com.

Colin Alworth

unread,
Nov 8, 2024, 9:22:06 AM11/8/24
to GWT Users
I'm afraid I can't tell a lot from that, except that the line numbers of UnifyAst don't match up with GWT 2.12 - they do however line up with 2.11 (though I didn't test any other versions), so you may additionally have a classpath issue of some kind. That could potentially cause this NoSuchMethodError.

Juan Pablo Gardella

unread,
Nov 8, 2024, 9:58:37 AM11/8/24
to google-we...@googlegroups.com, Colin Alworth
@Colin Alworth what is "will likely only contain that fix plus one other long-standing issue that impacts latest jsinterop-base and elemental2"?

Colin Alworth

unread,
Nov 8, 2024, 10:15:35 AM11/8/24
to GWT Users
Presently the only other ticket in the 2.12.1 milestone (see https://github.com/gwtproject/gwt/milestone/24) is a backported fix for https://github.com/gwtproject/gwt/issues/10020. This was already merged to main, so is available in HEAD-SNAPSHOT.

This bug has been present for a long time, but was apparently only reported by the Guava team inside of Google (see https://github.com/google/jsinterop-base/issues/19#issuecomment-2442674784), and never to the GWT issue tracker. The effect is that some annotations on some elements would fail if their source was missing, and the fix aims to ensure that there will never be a failure no matter where the annotation is located or the kind of annotation (how many fields it has).

Once those are reviewed and approved we can turn around and ship an updated release.

Oleg Ravun

unread,
Nov 8, 2024, 10:24:32 AM11/8/24
to google-we...@googlegroups.com
The UnifyAst stack trace was from running Maven. I use gwt-maven-plugin version 2.10? Could it be the reason for the classpath issue? There is no newer version. And I know that there exists a new maven plugin to run the GWT compiler. I am digging through the maven log trying to figure out what is wrong with the classpath but perhaps GWT 2.12 cannot work with gwt-maven-plugin 2.10. Can it?

Thanks,
Oleg

Colin Alworth

unread,
Nov 8, 2024, 10:30:00 AM11/8/24
to GWT Users
From the homepage for the plugin you're using, https://gwt-maven-plugin.github.io/gwt-maven-plugin/, last updated in 2017 with GWT 2.8.2:
>  NOTICE There is a new plugin (archetypes and eclipse integration), a fresh start that correctly support multi-module projects, it is not version-bounded with GWT, support multiples GWT versions and other fixes, improvements and best practices. This plugin is now considered the legacy GWT maven plugin (aka mojo GWT maven plugin) and the new one is considered the new generation GWT maven plugin (aka tbroyer GWT maven plugin). The legacy maven plugin is still supported but it is strongly encouraged to use the new one for new projects.


GWT 2.12 can work with the old gwt-maven-plugin - be sure to specify <dependencies> _inside_ the plugin tag, and reference gwt-user and gwt-dev there. Otherwise, the plugin will continue to use the version of GWT it was built with. The "new" maven plugin does not have this limitation.

May I ask how you were building with GWT 2.11 with the 2.10 plugin? If you weren't doing this, you potentially weren't using the full GWT 2.10 classpath after all...

Oleg Ravun

unread,
Nov 8, 2024, 10:54:25 AM11/8/24
to google-we...@googlegroups.com
I was using gwt-maven-plugin version 2.10 with GWT 2.11 but there was no dependencies section under the plugin in the pom file. So I guess I was using GWT 2.10 when the project was built using maven. Though I was using GWT 2.11 in Intellij IDEA in SuperDevMode. Let me try to add the dependencies. Thank you so much. 

Oleg Ravun

unread,
Nov 8, 2024, 3:53:05 PM11/8/24
to google-we...@googlegroups.com
Everything (maven and SuperDevMode) works now. I have fixed the "if switch" code. And I have specified the dependencies for the maven plugin. Thank you very much Colin. 

TvT

unread,
Nov 13, 2024, 2:35:46 PM11/13/24
to GWT Users
May I ask what exactly did you fix? I have the exact same error.

"Caused by: java.lang.NoSuchMethodError: 'void com.google.gwt.thirdparty.guava.common.base.Preconditions.checkState(boolean, java.lang.String, java.lang.Object)'"

I will now try to update to the latest plugin...

Colin Alworth

unread,
Nov 13, 2024, 2:37:48 PM11/13/24
to GWT Users
TvT, as above, that seems to happen when you have multiple versions of GWT on your classpath. Please verify that you only have matching versions of gwt-user and gwt-dev, and if using maven/gradle/ivy that you are making use of the org.gwtproject:gwt bom to avoid mixing com.google.gwt artifacts with org.gwtproject ones.

Oleg Ravun

unread,
Nov 13, 2024, 3:52:00 PM11/13/24
to google-we...@googlegroups.com
I added dependencies that specify gwt-dev and gwt-user versions to pluginManagement for the maven GWT plugin.
<properties>
    <gwt.version>2.12.0</gwt.version>
<gwt-maven-plugin.version>2.10.0</gwt-maven-plugin.version>
</properties>
<build>
<pluginManagement>
<plugins>
            <plugin>
    <groupId>org.codehaus.mojo</groupId>
<artifactId>gwt-maven-plugin</artifactId>
<version>${gwt-maven-plugin.version}</version>
<dependencies>
<dependency>
<groupId>org.gwtproject</groupId>
<artifactId>gwt-user</artifactId>
<version>${gwt.version}</version>
</dependency>
<dependency>
<groupId>org.gwtproject</groupId>
<artifactId>gwt-dev</artifactId>
<version>${gwt.version}</version>
</dependency>
</dependencies> Though I don't use GWT bom. I think I don't use it because I have had troubles with specifying different scopes for different GWT dependencies.
 

Colin Alworth

unread,
Nov 13, 2024, 3:58:14 PM11/13/24
to GWT Users
The BOM is not obligatory, but it can be a very helpful way to handle conflicts. You shouldn't have scope issues with using a bom, unless you accidentally put it in dependencies instead of in dependencyManagement/dependencies. Once in dependencyManagement, it would not add dependencies and would not give them scopes - but if a dependency was present (with a scope defined, or the default of "compile") that the bom covered, it would ensure that only the correct version was allowed.
Message has been deleted

Maese

unread,
Dec 5, 2024, 6:59:59 AM12/5/24
to GWT Users
Hi

I had also troubles with the upgrade from GWT 2.10 to 2.12.1. 

[INFO] Caused by: java.lang.NoSuchMethodError: 'void com.google.gwt.thirdparty.guava.common.base.Preconditions.checkState(boolean, java.lang.String, java.lang.Object)'

The problem occurred not in all parts of my software. It seems that the problem depends on other Maven dependencies in our code.

My solution was to download the source code from GitHub (at 2024-12-03) and compile it by myself.
The compilation with Maven was only successful using JDK version 11 and I had to disable some tests in src/it/compile-with-coverage/verify.groovy .

I hope that was useful.

Colin Alworth

unread,
Dec 5, 2024, 8:14:38 AM12/5/24
to GWT Users
GWT 2.12 uses an updated Guava version, but Guava in GWT is shaded into the com.google.gwt.thirdparty package, so it won't be mixing (or confused with) with any other Guava versions on your classpath.

Odds are you have a mix of old and new GWT on your classpath. If you're using maven, I would guess that you accidentally are using both com.google.gwt and org.gwtproject groupIds - make sure you are using the gwt bom in your build to ensure this can't happen. Check that this is present in your dependencyManagement block, and verify with "mvn dependency:tree -Dverbose" for your client project to see what other jars might exist in your dependencies.

src/it/compile-with-coverage/verify.groovy is not part of GWT's own tests, and GWT only can build with ant (not maven), so I think you are building something that isn't GWT itself - perhaps one of the maven plugins?

Maese

unread,
Dec 5, 2024, 12:13:30 PM12/5/24
to GWT Users

Thanks. Yes, I compiled the GWT Maven plugin from https://github.com/gwt-maven-plugin/gwt-maven-plugin

Colin Alworth

unread,
Dec 5, 2024, 12:19:28 PM12/5/24
to GWT Users
The maven plugin doesn't directly invoke the compiler (and so doesnt use Preconditions), but runs it as a forked process. Manage your GWT versions in your own project with a the scope=import bom, and add the gwt-dev and gwt-user dependencies to the plugin block if you continue to use the legacy plugin, or update to the newer plugin - https://tbroyer.github.io/gwt-maven-plugin/ - you can find this linked from the github repo you posted.
Reply all
Reply to author
Forward
0 new messages