Не удается запустить консоль Groovy

Я только что сделал новую установку Groovy 2.4.3 в OSX 10.10.3 с помощью инструмента GVM. Я также установил с помощью GVM связанные библиотеки и инструменты, такие как groovyserv, grails и gradle. Я использую версию Java 1.8.0_25.

Все выглядит нормально, за исключением того, что я не могу запустить консоль Groovy с помощью команды groovyConsole, так как я продолжаю получать это исключение:

java.lang.reflect.InvocationTargetException
    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:483)
    at org.codehaus.groovy.tools.GroovyStarter.rootLoader(GroovyStarter.java:106)
    at org.codehaus.groovy.tools.GroovyStarter.main(GroovyStarter.java:128)
Caused by: javax.xml.parsers.FactoryConfigurationError: Provider for javax.xml.parsers.SAXParserFactory cannot be found
    at javax.xml.parsers.SAXParserFactory.newInstance(Unknown Source)
    at org.apache.ivy.core.settings.XmlSettingsParser.doParse(XmlSettingsParser.java:160)
    at org.apache.ivy.core.settings.XmlSettingsParser.parse(XmlSettingsParser.java:150)
    at org.apache.ivy.core.settings.IvySettings.load(IvySettings.java:417)
    at org.apache.ivy.core.settings.IvySettings$load.call(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:45)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:110)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:122)
    at groovy.grape.GrapeIvy.<init>(GrapeIvy.groovy:96)
    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:408)
    at java.lang.Class.newInstance(Class.java:438)
    at groovy.grape.Grape.getInstance(Grape.java:117)
    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:483)
    at org.codehaus.groovy.reflection.CachedMethod.invoke(CachedMethod.java:90)
    at groovy.lang.MetaMethod.doMethodInvoke(MetaMethod.java:324)
    at groovy.lang.MetaClassImpl.getProperty(MetaClassImpl.java:1844)
    at groovy.lang.MetaClassImpl.getProperty(MetaClassImpl.java:3734)
    at org.codehaus.groovy.runtime.callsite.ClassMetaClassGetPropertySite.getProperty(ClassMetaClassGetPropertySite.java:48)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callGetProperty(AbstractCallSite.java:293)
    at groovy.ui.ConsoleIvyPlugin.addListener(ConsoleIvyPlugin.groovy:41)
    at groovy.ui.ConsoleIvyPlugin$addListener.call(Unknown Source)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCall(CallSiteArray.java:45)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:110)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.call(AbstractCallSite.java:122)
    at groovy.ui.Console.<init>(Console.groovy:239)
    at groovy.ui.Console.<init>(Console.groovy:221)
    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:408)
    at org.codehaus.groovy.reflection.CachedConstructor.invoke(CachedConstructor.java:77)
    at org.codehaus.groovy.runtime.callsite.ConstructorSite$ConstructorSiteNoUnwrapNoCoerce.callConstructor(ConstructorSite.java:102)
    at org.codehaus.groovy.runtime.callsite.CallSiteArray.defaultCallConstructor(CallSiteArray.java:57)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callConstructor(AbstractCallSite.java:232)
    at org.codehaus.groovy.runtime.callsite.AbstractCallSite.callConstructor(AbstractCallSite.java:244)
    at groovy.ui.Console.main(Console.groovy:206)
    ... 6 more

Каков наилучший способ исправить это?


person Sergio    schedule 25.05.2015    source источник
comment
Просто дикая догадка: это может иметь какое-то отношение к .ivy2 или .java/.userPrefs/groovy/prefs.xml. Попробуйте mv .ivy2 .ivy2.backup && .java/.userPrefs/groovy/prefs.xml .java/.userPrefs/groovy/prefs.xml.backup и посмотрите, решит ли это проблему.   -  person BahmanM    schedule 25.05.2015
comment
Ну, я даже не устанавливал Ivy, поэтому не думаю, что это может быть причиной.   -  person Sergio    schedule 25.05.2015
comment
Я не уверен, но я предполагаю, что часть Groovy (возможно, Grapes) использует Ivy. Кто-нибудь может это подтвердить?   -  person BahmanM    schedule 25.05.2015
comment
Это известная ошибка: github.com/grails/grails-gradle-plugin/ вопросы/95   -  person christopher    schedule 25.05.2015
comment
У вас есть какой-нибудь странный путь к классам, настроенный в вашей среде? У вас есть что-нибудь, указывающее на старую версию groovy? Что-то вроде Java_home указывает на странные места?   -  person tim_yates    schedule 25.05.2015
comment
Привет @Тим. Проблема действительно заключалась в том, что в моем CLASSPATH что-то указывало на банку, включающую пакет «javax.xml.parsers» по какой-то причине. Пожалуйста, добавьте свой комментарий в качестве ответа, чтобы я мог принять его.   -  person Sergio    schedule 25.05.2015
comment
@Серджио рад, что мы разобрались и сделали :-)   -  person tim_yates    schedule 25.05.2015


Ответы (1)


У меня было это раньше, и это было связано с тем, что переменная пути к классам среды была установлена ​​​​указывающей на недопустимую банку.

person tim_yates    schedule 25.05.2015