1

JAXB の schemagen ツールは JDK 11 の一部ではなくなったため、使用可能な ant タスクを介して schemagen ツールの機能を提供する gradle を使用してプロジェクトをセットアップしたいと考えました。ただし、ant タスクを実行しても期待どおりに動作しません。特に、作成されたスキーマはソース コードの注釈と一致しません。

さらに、私が解決できなかった例外が常にスローされます。

bashシェルを備えたWindows 10マシンでバージョン2.3.2のJDK 11、Gradle 5.4.1、およびJAXBを使用しています。

プロジェクトは次のようになります (A gradle Java プロジェクト):

Movie.java内側src/main/java/movie

package movie;

import javax.xml.bind.annotation.XmlAttribute;
import javax.xml.bind.annotation.XmlElement;
import javax.xml.bind.annotation.XmlRootElement;

@XmlRootElement
public class Movie {

    @XmlElement
    public String name;

    @XmlAttribute
    public String genre;

}

build.gradle:

plugins {
    id 'java'
    id 'application'
}

repositories {
    jcenter()
}

configurations {
    schemagen
}

dependencies {
    implementation group: 'org.glassfish.jaxb', name: 'jaxb-runtime', version: '2.3.2'
    schemagen group: 'org.glassfish.jaxb', name: 'jaxb-jxc', version: '2.3.2'
}

def srcDir = file("src/main/java/movie")
def schemaDir = file("$buildDir/schema")

task schemagen {
    doLast {
        ant.taskdef(name: 'schemagen', classname: 'com.sun.tools.jxc.SchemaGenTask', classpath: configurations.schemagen.asPath)
        schemaDir.mkdirs()
        ant.schemagen(
            srcdir: srcDir,
            destdir: schemaDir,
            includeAntRuntime: false,
            debug: true,
            verbose: true)
    }
}

を実行するgradle schemagen --stacktraceと、次の出力がコンソールに表示されます。

> Task :schemagen FAILED
[ant:schemagen] anomalous package-info.java path: package-info.java
[ant:schemagen] [parsing started SimpleFileObject[...\src\main\java\movie\Movie.java]]
[ant:schemagen] [parsing completed 0ms]
[ant:schemagen] [parsing started SimpleFileObject[...\src\main\java\movie\package-info.java]]
[ant:schemagen] [parsing completed 0ms]
[ant:schemagen] [loading /modules/jdk.jconsole/module-info.class]
...many more
[ant:schemagen] [search path for source files: ...\src\main\java\movie]
[ant:schemagen] [search path for class files: C:\Program Files\Amazon Corretto\jdk11.0.3_7\lib\modules,...\build\schema]
[ant:schemagen] [loading /modules/java.base/java/lang/Object.class]
[ant:schemagen] [loading /modules/java.base/java/lang/String.class]
[ant:schemagen] [loading /modules/java.base/java/lang/Deprecated.class]
[ant:schemagen] [loading /modules/java.base/java/lang/annotation/Retention.class]
[ant:schemagen] [loading /modules/java.base/java/lang/annotation/RetentionPolicy.class]
[ant:schemagen] [loading /modules/java.base/java/lang/annotation/Target.class]
[ant:schemagen] [loading /modules/java.base/java/lang/annotation/ElementType.class]
[ant:schemagen] Round 1:
[ant:schemagen]         input files: {movie.Movie}
[ant:schemagen]         annotations: [XmlRootElement, XmlElement, XmlAttribute]
[ant:schemagen]         last round: false
[ant:schemagen] [loading /modules/java.base/java/lang/Character.class]
...many more
[ant:schemagen] [loading /modules/java.base/java/util/Collection.class]
[ant:schemagen] Processor com.sun.tools.jxc.ap.SchemaGenerator matches [XmlRootElement, XmlAttribute, XmlElement] and returns false.
[ant:schemagen] Round 2:
[ant:schemagen]         input files: {}
[ant:schemagen]         annotations: []
[ant:schemagen]         last round: true
[ant:schemagen] [total 297ms]

FAILURE: Build failed with an exception.

* Where:
Build file '...\build.gradle' line: 26

* What went wrong:
Execution failed for task ':schemagen'.
> schema generation failed

* Try:
Run with --info or --debug option to get more log output. Run with --scan to get full insights.

* Exception is:
org.gradle.api.tasks.TaskExecutionException: Execution failed for task ':schemagen'.
        at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$3.accept(ExecuteActionsTaskExecuter.java:151)
        at org.gradle.api.internal.tasks.execution.ExecuteActionsTaskExecuter$3.accept(ExecuteActionsTaskExecuter.java:148)
        at org.gradle.internal.Try$Failure.ifSuccessfulOrElse(Try.java:191)
        ...many more
Caused by: : schema generation failed
        at com.sun.tools.jxc.ApBasedTask.compile(ApBasedTask.java:142)
        at com.sun.tools.jxc.SchemaGenBase.compile(SchemaGenBase.java:228)
        at org.apache.tools.ant.taskdefs.Javac.execute(Javac.java:1130)
        at org.apache.tools.ant.UnknownElement.execute(UnknownElement.java:293)
        at jdk.internal.reflect.GeneratedMethodAccessor314.invoke(Unknown Source)
        at java.base/jdk.internal.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
        at org.apache.tools.ant.dispatch.DispatchUtils.execute(DispatchUtils.java:106)
        ...many more

(ファイルシステムのパスと不要な情報を考慮して出力を短くしました)

タスクは失敗しますが、スキーマが作成されますschema1.xsd:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<xs:schema version="1.0" xmlns:xs="http://www.w3.org/2001/XMLSchema">

  <xs:complexType name="movie">
    <xs:sequence>
      <xs:element name="name" type="xs:string" minOccurs="0"/>
      <xs:element name="genre" type="xs:string" minOccurs="0"/>
    </xs:sequence>
  </xs:complexType>
</xs:schema>

そして、ここでは@XmlAttribute-Annotation は無視され、ジャンルは単純に要素として含まれています。

私は次のようなものを期待していたでしょう:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<xs:schema version="1.0" xmlns:xs="http://www.w3.org/2001/XMLSchema">

  <xs:complexType name="movie">
    <xs:sequence>
      <xs:element name="name" type="xs:string" minOccurs="0"/>
    </xs:sequence>
    <xs:extension base="xs:string">
        <xs:attribute name="genre" type="xs:boolean" use="required"/>
    </xs:extension>
  </xs:complexType>
</xs:schema>

このようなプロジェクトのセットアップに成功し、schemagen ant タスクから有効なスキーマを取得した人はいますか?

4

1 に答える 1