SBT 0.10 plugin to compile XML Schema with XJC. Mirror, official repository is now https://github.com/sbt/sbt-xjc
Pull request Compare This branch is 1 commit ahead, 51 commits behind sbt:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Failed to load latest commit information.
.idea
.idea_modules
notes
project
src
.gitignore
README.md

README.md

sbt-xjc An SBT 0.11 Plugin to compile XML Schemata to JAXB Java sources with XJC

Mirror, official repository is now https://github.com/sbt/sbt-xjc

Usage

Depend on the plugin: ./project/plugins/build.sbt. Requires SBT 0.11.2 or higher.

resolvers += Resolver.url(
  "sbt-plugin-releases", 
  new URL("http://scalasbt.artifactoryonline.com/scalasbt/sbt-plugin-releases/")
)(Resolver.ivyStylePatterns)

addSbtPlugin("com.github.retronym" % "sbt-xjc" % "0.5") 

Introduce Settings

Include the settings from com.github.retronym.sbtxjc.SbtXjcPlugin.xjcSettings.

Configure

By default, all XSDs found under unmanagedResourceDirectories will be compiled. This is repeated in the Compile and Test scopes. The table below show the configuration for the Compile scope; replace with Test to configure that scope.

KeyTypeDefaultDescriptionExample
xjcLibsSeq[ModuleId]jaxb-api 2.1, jaxb-impl and jaxb-xjc 2.1.9 The artifacts to download to run XJC
xjcPluginsSeq[ModuleId]The artifacts to download containing XJC plugins
xjcCommandLineSeq[String]Additional command line, e.g. -verbose -Xfluent-api
sources in (Compile, xjc)Seq[File]${unmanagedResourceDirectories} ** "*.xsd"Input XSD Files sources in (Compile, xjc) <<= sourceDirectory map (_ / "main" / "schema" ** "*.xsd" get)
sourceManaged in (Compile, xjc)File${sourceManaged}/compile/xjc Target for generated files. Should not be shared with other generated files

See the Tests for example builds.

As a convenience, the fluent API settings are provided in SbtXjcPlugin.fluentApiSettings

Use

The timestamps of the source XSD files is compared with the generated files, and if newer these are compiled. This occurs automatically before compilation.

Problems

You can troubleshoot problems by inspecting debug logs with > last xjc.

Please use the Issue Tracker here if you find a bug. Do not raise bugs for problems with your schema or with usage of XJC itself.