Intellij Groovy编译器抛出错误抓取葡萄(下载失败)

时间:2016-02-12 14:00:26

标签: java intellij-idea groovy compiler-errors

当我尝试在Mac OSX 10.10.5上的Intellij IDEA 15.0.3中编译 groovy 项目时,我当前收到以下错误。 (Windows机器上的同一项目不会出现此问题)

  

信息:Groovyc:java.lang.RuntimeException:抓取Grapes时出错 - [下载失败:   com.google.code.gson#GSON;!2.2.4 gson.jar]

JAR存在于repo.maven.orgjcenter.bintray.com中。

我可以使用compile "com.google.code.gson:gson:2.2.4"明确地下载并将其包含在我的项目中 - 我仍然看到这个编译器问题。

我看不出下载失败的原因,我正在使用out-of-the-box ~/.gradle/grapeConfig.xml

我尝试删除我的grape cache目录并重新下载依赖项 - 适用于我所有明确定义的依赖项。

我在家庭网络上 - 没有代理。

我想要enable advanced logging,以便我可以看到Grapes下载失败的确切原因。我已经尝试将groovy.grape.report.downloads=true系统属性添加到终端(并在~/.bashrc中),但无济于事。我在Intellij“Groovy编译器”设置页面中找不到任何设置这些属性的方法。 (如果我可以启用Grapes日志记录,我相信我能够看到根本原因)

Intellij项目是从gradle cleanIdea idea设置的。当项目是从命令行构建的时候 - gradle clean build(在Mac和Windows上),应用程序编译时没有错误 - 只有问题出现在Mac上的Intellij中。

gson.jar / @Grab注释中实际上未引用此@Grape,我没有检查过,但我猜它是传递依赖。

非常感谢任何帮助!

完整堆栈跟踪

Information:Using javac 1.8.0_60 to compile java sources
Information:Groovyc: Groovyc stub generation failed
Information:Groovyc: java.lang.RuntimeException: Error grabbing Grapes -- [download failed: com.google.code.gson#gson;2.2.4!gson.jar]
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)
    at java.lang.reflect.Constructor.newInstance(Constructor.java:422)
    at org.codehaus.groovy.reflection.CachedConstructor.invoke(CachedConstructor.java:80)
    at org.codehaus.groovy.reflection.CachedConstructor.doConstructorInvoke(CachedConstructor.java:74)
    at org.codehaus.groovy.runtime.callsite.ConstructorSite$ConstructorSiteNoUnwrap.callConstructor(ConstructorSite.java:84)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallConstructor(CallSiteArray.java:60)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callConstructor(AbstractCallSite.java:235)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callConstructor(AbstractCallSite.java:247)
    at groovy.grape.GrapeIvy.getDependencies(GrapeIvy.groovy:421)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:497)
    at org.codehaus.groovy.runtime.callsite.PogoMetaMethodSite$PogoCachedMethodSite.invoke(PogoMetaMethodSite.java:169)
    at org.codehaus.groovy.runtime.callsite.PogoMetaMethodSite.callCurrent(PogoMetaMethodSite.java:59)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallCurrent(CallSiteArray.java:52)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:154)
    at groovy.grape.GrapeIvy.resolve(GrapeIvy.groovy:566)
    at groovy.grape.GrapeIvy$resolve$1.callCurrent(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallCurrent(CallSiteArray.java:52)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:154)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:190)
    at groovy.grape.GrapeIvy.resolve(GrapeIvy.groovy:535)
    at groovy.grape.GrapeIvy$resolve$0.callCurrent(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallCurrent(CallSiteArray.java:52)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:154)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callCurrent(AbstractCallSite.java:182)
    at groovy.grape.GrapeIvy.grab(GrapeIvy.groovy:257)
    at groovy.grape.Grape.grab(Grape.java:166)
    at groovy.grape.GrabAnnotationTransformation.visit(GrabAnnotationTransformation.java:360)
    at org.codehaus.groovy.transform.ASTTransformationVisitor$3.call(ASTTransformationVisitor.java:321)
    at org.codehaus.groovy.control.CompilationUnit.applyToSourceUnits(CompilationUnit.java:931)
    at org.codehaus.groovy.control.CompilationUnit.doPhaseOperation(CompilationUnit.java:593)
    at org.codehaus.groovy.control.CompilationUnit.processPhaseOperations(CompilationUnit.java:569)
    at org.codehaus.groovy.control.CompilationUnit.compile(CompilationUnit.java:546)
    at org.jetbrains.groovy.compiler.rt.GroovyCompilerWrapper.compile(GroovyCompilerWrapper.java:62)
    at org.jetbrains.groovy.compiler.rt.DependentGroovycRunner.runGroovyc(DependentGroovycRunner.java:115)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:497)
    at org.jetbrains.groovy.compiler.rt.GroovycRunner.intMain2(GroovycRunner.java:134)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
    at java.lang.reflect.Method.invoke(Method.java:497)
    at org.jetbrains.jps.incremental.groovy.InProcessGroovyc.runGroovycInThisProcess(InProcessGroovyc.java:156)
    at org.jetbrains.jps.incremental.groovy.InProcessGroovyc.access$000(InProcessGroovyc.java:51)
    at org.jetbrains.jps.incremental.groovy.InProcessGroovyc$1.call(InProcessGroovyc.java:85)
    at org.jetbrains.jps.incremental.groovy.InProcessGroovyc$1.call(InProcessGroovyc.java:82)
    at java.util.concurrent.FutureTask.run(FutureTask.java:266)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1142)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:617)
    at java.lang.Thread.run(Thread.java:745)
Information:java: Errors occurred while compiling module 'server'
Information:12/02/2016 6:45 PM - Compilation completed with 3 errors and 0 warnings in 9s 266ms
/<myproject>/WebConfigurer.java
Error:(10, 37) java: cannot find symbol
  symbol:   class HtmlHttpMessageConverter
  location: package mypackage.mediaType
Error:(113, 16) java: cannot find symbol
  symbol:   class HtmlHttpMessageConverter
  location: class mypackage.WebConfigurer
/<myproject>/SirenConverters.java
Error:(14, 38) java: package mypackage.controller does not exist

相关(?)

Groovy - Grab - download failed

更新14/02/16 - 仍然没有运气

  1. 将grapeConfig.xml移至正确的目录 - ~/.groovy/grapeConfig.xml

  2. 在Intellij中启用调试日志记录:

    ... &LT;根&GT;   &lt; priority value =“DEBUG”/&gt;   &lt; appender-ref ref =“DIALOG”/&gt;   &lt; appender-ref ref =“CONSOLE-DEBUG”/&gt;   &lt; appender-ref ref =“FILE”/&gt; &LT; /根&GT; ...

  3. ~/Library/Logs/IdeaIC15/idea.log

    中找不到有关例外的详细信息
    1. 将记录标记添加到/Applications/IntelliJ\ IDEA\ 15\ CE.app/Contents/bin/idea.vmoptions

      -Dgroovy.grape.report.downloads =真 -Xms128m -Xmx750m -XX:MaxPermSize参数=350米 -XX:ReservedCodeCacheSize =240米 -XX:+ UseCompressedOops

    2. 日志或控制台没有可观察到的变化。

      1. -Dgroovy.grape.report.downloads=true添加到Intellij偏好设置&gt;编译器&gt;共享构建过程VM选项:
      2. 日志或控制台没有可观察到的变化。

2 个答案:

答案 0 :(得分:5)

我遇到了同样的问题,对我而言,maven缓存是问题所在。

我找到了解决方案on this page

rm -rf ~/.m2/repository ~/.groovy/grapes

我之前尝试删除~/.groovy/grapes缓存,但这并没有解决问题。删除~/.m2/repository实际上是为我做的。

答案 1 :(得分:1)

我在IntelliJ中使用此脚本没有问题:

@Grab(group = 'com.google.code.gson', module = 'gson', version = '2.2.4')
import com.google.gson.Gson

println Gson

我做的第一件事是写@Grab声明......右键单击它,选择“Grab artifacts”......

编辑:实际上,我认为将光标放在@Grab上,然后按Alt + Enter(这是我通常从IntelliJ获取建议的方法)。

IntelliJ失败并告诉我我需要将Ivy添加到类路径中...所以我打开了Project Structure,在模块依赖项中添加了Ivy,再次尝试......它有效。

再次运行脚本,它会打印出预期的消息。

希望以某种方式帮助...