NullPointerException в com.sun.tools.jxc.SchemaGenTask - PullRequest
4 голосов
/ 07 апреля 2010

Данный скрипт муравья:

<?xml version="1.0" encoding="UTF-8"?>
<project name="projectname" default="generate-schema" basedir=".">

    <taskdef name="schemagen" classname="com.sun.tools.jxc.SchemaGenTask">
        <classpath>
            <fileset dir="../BuildJars/lib" includes="*.jar" />
        </classpath>
    </taskdef>

    <target name="generate-schema">
        <schemagen srcdir="src/gb/informaticasystems/messages" destdir="schema">
            <schema namespace="http://www.informatica-systems.co.uk/aquarius/messages/1.0" file="messages-1.0.xsd" />
        </schemagen>
    </target>

</project>

Я получаю эту ошибку:

Buildfile: C:\Users\davidcollie\workspace\aquarius-feature\AquariusServerLibrary\schemagen.xml
generate-schema:
[schemagen] Generating schema from 4 source files
[schemagen] Problem encountered during annotation processing; 
[schemagen] see stacktrace below for more information.
[schemagen] java.lang.NullPointerException
[schemagen]     at com.sun.tools.jxc.model.nav.APTNavigator$2.onDeclaredType(APTNavigator.java:428)
[schemagen]     at com.sun.tools.jxc.model.nav.APTNavigator$2.onClassType(APTNavigator.java:402)
[schemagen]     at com.sun.tools.jxc.model.nav.APTNavigator$2.onClassType(APTNavigator.java:456)
[schemagen]     at com.sun.istack.tools.APTTypeVisitor.apply(APTTypeVisitor.java:27)
[schemagen]     at com.sun.tools.jxc.model.nav.APTNavigator.getBaseClass(APTNavigator.java:109)
[schemagen]     at com.sun.tools.jxc.model.nav.APTNavigator.getBaseClass(APTNavigator.java:85)
[schemagen]     at com.sun.xml.bind.v2.model.impl.PropertyInfoImpl.getIndividualType(PropertyInfoImpl.java:190)
[schemagen]     at com.sun.xml.bind.v2.model.impl.PropertyInfoImpl.<init>(PropertyInfoImpl.java:132)
[schemagen]     at com.sun.xml.bind.v2.model.impl.MapPropertyInfoImpl.<init>(MapPropertyInfoImpl.java:67)
[schemagen]     at com.sun.xml.bind.v2.model.impl.ClassInfoImpl.createMapProperty(ClassInfoImpl.java:917)
[schemagen]     at com.sun.xml.bind.v2.model.impl.ClassInfoImpl.addProperty(ClassInfoImpl.java:874)
[schemagen]     at com.sun.xml.bind.v2.model.impl.ClassInfoImpl.findGetterSetterProperties(ClassInfoImpl.java:993)
[schemagen]     at com.sun.xml.bind.v2.model.impl.ClassInfoImpl.getProperties(ClassInfoImpl.java:303)
[schemagen]     at com.sun.xml.bind.v2.model.impl.ModelBuilder.getClassInfo(ModelBuilder.java:243)
[schemagen]     at com.sun.xml.bind.v2.model.impl.ModelBuilder.getClassInfo(ModelBuilder.java:209)
[schemagen]     at com.sun.xml.bind.v2.model.impl.ModelBuilder.getTypeInfo(ModelBuilder.java:315)
[schemagen]     at com.sun.xml.bind.v2.model.impl.ModelBuilder.getTypeInfo(ModelBuilder.java:330)
[schemagen]     at com.sun.tools.xjc.api.impl.j2s.JavaCompilerImpl.bind(JavaCompilerImpl.java:90)
[schemagen]     at com.sun.tools.jxc.apt.SchemaGenerator$1.process(SchemaGenerator.java:115)
[schemagen]     at com.sun.mirror.apt.AnnotationProcessors$CompositeAnnotationProcessor.process(AnnotationProcessors.java:60)
[schemagen]     at com.sun.tools.apt.comp.Apt.main(Apt.java:454)
[schemagen]     at com.sun.tools.apt.main.JavaCompiler.compile(JavaCompiler.java:258)
[schemagen]     at com.sun.tools.apt.main.Main.compile(Main.java:1102)
[schemagen]     at com.sun.tools.apt.main.Main.compile(Main.java:964)
[schemagen]     at com.sun.tools.apt.Main.processing(Main.java:95)
[schemagen]     at com.sun.tools.apt.Main.process(Main.java:85)
[schemagen]     at com.sun.tools.apt.Main.process(Main.java:67)
[schemagen]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[schemagen]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
[schemagen]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
[schemagen]     at java.lang.reflect.Method.invoke(Method.java:597)
[schemagen]     at com.sun.tools.jxc.AptBasedTask$InternalAptAdapter.execute(AptBasedTask.java:97)
[schemagen]     at com.sun.tools.jxc.AptBasedTask.compile(AptBasedTask.java:144)
[schemagen]     at org.apache.tools.ant.taskdefs.Javac.execute(Javac.java:820)
[schemagen]     at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:288)
[schemagen]     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
[schemagen]     at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
[schemagen]     at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
[schemagen]     at java.lang.reflect.Method.invoke(Method.java:597)
[schemagen]     at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:105)
[schemagen]     at org.apache.tools.ant.Task.perform(Task.java:348)
[schemagen]     at org.apache.tools.ant.Target.execute(Target.java:357)
[schemagen]     at org.apache.tools.ant.Target.performTasks(Target.java:385)
[schemagen]     at org.apache.tools.ant.Project.executeSortedTargets(Project.java:1329)
[schemagen]     at org.apache.tools.ant.Project.executeTarget(Project.java:1298)
[schemagen]     at org.apache.tools.ant.helper.DefaultExecutor.executeTargets(DefaultExecutor.java:41)
[schemagen]     at org.eclipse.ant.internal.ui.antsupport.EclipseDefaultExecutor.executeTargets(EclipseDefaultExecutor.java:32)
[schemagen]     at org.apache.tools.ant.Project.executeTargets(Project.java:1181)
[schemagen]     at org.eclipse.ant.internal.ui.antsupport.InternalAntRunner.run(InternalAntRunner.java:423)
[schemagen]     at org.eclipse.ant.internal.ui.antsupport.InternalAntRunner.main(InternalAntRunner.java:137)

BUILD FAILED
C:\Users\davidcollie\workspace\aquarius-feature\AquariusServerLibrary\schemagen.xml:11: schema generation failed

Total time: 1 second

Есть идеи?

Ответы [ 4 ]

3 голосов
/ 07 июля 2010

У меня была эта проблема, потому что мой srcdir был установлен в папку пакета, которая содержала файлы java.

Лучше изменить это на исходную папку верхнего уровня, но тогда schemagen захотел создать схему для всех файлов .java в моем исходном пути (на самом деле только 20% были классами jaxb).

Мой последний муравейник выглядит так:

<property name="event.package" value="my/organisation/events"/>
<schemagen srcdir="${src.main.java.dir}" 
    destdir="META-INF/event-schema" 
    classpathref="build.classpath">
    <include name="${event.package}/Event1.java"/>
    <include name="${event.package}/Event2.java"/>
</schemagen>
0 голосов
/ 05 ноября 2014

Причиной этой ошибки очень вероятно, что отсутствуют некоторые классы, которые используются в классах, из которых вы хотите создать схему.В моем случае мне пришлось включить несколько пропущенных классов, которых не было в моем первом наборе подходящих подстановочных знаков.Я использовал Maven, и мне пришлось переключиться с jaxb2-maven-plugin версии 1.6 на 1.5, которая показывает некоторые ошибки, когда verbose установлен в true.Позже я переключился на самую последнюю версию.

                 <execution>
                    <phase>generate-resources</phase>
                    <id>rest-webservice-schemagen</id>
                    <goals>
                        <goal>schemagen</goal>
                    </goals>
                    <configuration>
                        <includes>
                            <include>**/*DTO.java</include>
                            <include>**/*Type.java</include>
                            <include>**/*Status.java</include>
                        </includes>
                        <verbose>true</verbose>
                    </configuration>
                </execution>
0 голосов
/ 24 мая 2010

Я перешел с запуска скрипта ant с 1.6 на 1.5, который затем вызвал правильные трассировки стека, и оттуда я исправил проблему.

0 голосов
/ 07 апреля 2010

Задача <schemagen> должна включать путь к классу, вероятно, эквивалентный тому, что находится в задаче <javac>, которая, несомненно, находится где-то еще в вашем скрипте Ant. Я также подвергаю сомнению значение атрибута srcdir. Он должен указывать на верхнюю часть вашего исходного дерева, а не на какие-либо пакеты. Мне кажется, что «gb.informaticasystems.messages» может быть пакетом в вашем проекте. Если это так, вы должны изменить атрибут на srcdir="src". Итак, это должно выглядеть примерно так (вам нужно указать classpath):

<target name="generate-schema">
    <schemagen srcdir="src" destdir="schema">
        <schema namespace="http://www.informatica-systems.co.uk/aquarius/messages/1.0" file="messages-1.0.xsd" />
        <classpath>
           <!-- Classpath definition goes here -->
        </classpath>
    </schemagen>
</target>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...