X-Git-Url: http://juplo.de/gitweb/?p=hibernate4-maven-plugin;a=blobdiff_plain;f=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fplugins%2Fhibernate%2FCreateMojo.java;fp=src%2Fmain%2Fjava%2Fde%2Fjuplo%2Fplugins%2Fhibernate%2FCreateMojo.java;h=a6c2ba42b4b9140125d685085fd6b8649cd55348;hp=cdba7a432ca1bcd6222554bd8277f00860e8a9d6;hb=505d13bdca776dd80f661a52797789b87e97b200;hpb=4ab00d5dbf8f4263d867726607ce84d4107ef1c6 diff --git a/src/main/java/de/juplo/plugins/hibernate/CreateMojo.java b/src/main/java/de/juplo/plugins/hibernate/CreateMojo.java index cdba7a43..a6c2ba42 100644 --- a/src/main/java/de/juplo/plugins/hibernate/CreateMojo.java +++ b/src/main/java/de/juplo/plugins/hibernate/CreateMojo.java @@ -16,16 +16,23 @@ package de.juplo.plugins.hibernate; * limitations under the License. */ +import static de.juplo.plugins.hibernate.AbstractSchemaMojo.EXECUTE; +import java.io.File; +import java.util.EnumSet; import java.util.Map; import org.apache.maven.plugin.MojoExecutionException; import org.apache.maven.plugin.MojoFailureException; import org.hibernate.boot.spi.MetadataImplementor; +import org.hibernate.cfg.AvailableSettings; +import org.hibernate.engine.config.spi.ConfigurationService; import org.hibernate.service.ServiceRegistry; -import org.hibernate.tool.schema.SourceType; +import org.hibernate.tool.schema.TargetType; +import org.hibernate.tool.schema.internal.ExceptionHandlerCollectingImpl; +import org.hibernate.tool.schema.internal.exec.ScriptTargetOutputToFile; import org.hibernate.tool.schema.spi.ExecutionOptions; import org.hibernate.tool.schema.spi.SchemaManagementTool; -import org.hibernate.tool.schema.spi.ScriptSourceInput; -import org.hibernate.tool.schema.spi.SourceDescriptor; +import org.hibernate.tool.schema.spi.SchemaManagementToolCoordinator; +import org.hibernate.tool.schema.spi.ScriptTargetOutput; import org.hibernate.tool.schema.spi.TargetDescriptor; @@ -64,35 +71,56 @@ public class CreateMojo extends AbstractSchemaMojo @Override - void build( - MetadataImplementor metadata, - ExecutionOptions options, - TargetDescriptor target + ExceptionHandlerCollectingImpl build( + final MetadataImplementor metadata, + final File output ) throws MojoExecutionException, MojoFailureException { - ServiceRegistry service = + final ServiceRegistry registry = metadata.getMetadataBuildingOptions().getServiceRegistry(); - SchemaManagementTool tool = service.getService(SchemaManagementTool.class); + final Map settings = + registry.getService(ConfigurationService.class).getSettings(); + SchemaManagementTool tool = registry.getService(SchemaManagementTool.class); - Map config = options.getConfigurationValues(); - SourceDescriptor source = new SourceDescriptor() + final EnumSet targetTypes = EnumSet.of(TargetType.SCRIPT); + if ((Boolean)settings.get(EXECUTE)) + targetTypes.add(TargetType.DATABASE); + + TargetDescriptor target = new TargetDescriptor() { - @Override - public SourceType getSourceType() + @Override + public EnumSet getTargetTypes() { - return SourceType.METADATA; + return targetTypes; } @Override - public ScriptSourceInput getScriptSourceInput() + public ScriptTargetOutput getScriptTargetOutput() { - return null; + String charset = + (String)settings.get(AvailableSettings.HBM2DDL_CHARSET_NAME); + return new ScriptTargetOutputToFile(output, charset); } }; - tool.getSchemaCreator(config).doCreation(metadata, options, source, target); + ExceptionHandlerCollectingImpl handler = + new ExceptionHandlerCollectingImpl(); + + ExecutionOptions options = + SchemaManagementToolCoordinator.buildExecutionOptions( + registry + .getService(ConfigurationService.class) + .getSettings(), + handler + ); + + Map config = options.getConfigurationValues(); + + tool.getSchemaMigrator(config).doMigration(metadata, options, target); + + return handler; } }