Bene, c'è il Maven Hibernate3 Plugin se non si vuole mescolare Ant e Maven (che è una buona idea qui IMO). Ha un obiettivo hbm2java
che è associato per impostazione predefinita alla fase generate-sources
. Fare riferimento al sito web del Mojo per maggiori dettagli, ma la messa a punto della potenza plug-in si presenta come qualcosa di simile a questo:
<plugin>
<groupId>org.codehaus.mojo</groupId>
<artifactId>hibernate3-maven-plugin</artifactId>
<version>2.2</version>
<executions>
<execution>
<phase>generate-sources</phase>
<goals>
<goal>hbm2java</goal>
</goals>
</execution>
</executions>
<configuration>
<components>
<component>
<name>hbm2java</name>
<implementation>configuration</implementation>
<outputDirectory>target/generated-sources/hibernate3</outputDirectory>
</component>
</components>
<componentProperties>
<drop>true</drop>
<jdk5>true</jdk5>
<configurationfile>/src/main/resources/hibernate.cfg.xml</configurationfile>
</componentProperties>
</configuration>
</plugin>
EDIT: Il plugin sembra in realtà per .hbm.xml
in target/classes
per generare i file sorgente Java. Quindi, se inserisci i file di mappatura in src/main/resources
, verranno copiati in target/classes
durante la fase process-resources
che viene richiamata dal plug-in e le cose funzioneranno. Ho appena provato questo con il seguente progetto di esempio:
maven-hibernate3-testcase
|-- pom.xml
`-- src
|-- main
| |-- java
| `-- resources
| |-- Person.hbm.xml
| `-- hibernate.cfg.xml
`-- test
`-- java
Il pom.xml
è quasi vuoto, contiene solo la configurazione del plugin visto sopra e una dipendenza JUnit. Il hibernate.cfg.xml
contiene:
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD//EN"
"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- Database connection settings -->
<property name="connection.driver_class">org.apache.derby.jdbc.ClientDriver</property>
<property name="connection.url">jdbc:derby://localhost:1527/mydatabase</property>
<property name="connection.username">app</property>
<property name="connection.password">app</property>
<!-- JDBC connection pool (use the built-in) -->
<property name="connection.pool_size">1</property>
<!-- SQL dialect -->
<property name="dialect">org.hibernate.dialect.DerbyDialect</property>
<!-- Echo all executed SQL to stdout -->
<property name="show_sql">false</property>
<!-- Mapping files -->
<mapping resource="Person.hbm.xml" />
</session-factory>
</hibernate-configuration>
E Person.hbm.xml
appare come segue:
<?xml version='1.0' encoding='utf-8'?>
<!DOCTYPE hibernate-mapping
PUBLIC "-//Hibernate/Hibernate Mapping DTD//EN"
"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="Person" table="person">
<id name="id" type="int">
<generator class="increment" />
</id>
<property name="name" column="cname" type="string" />
</class>
</hibernate-mapping>
Con questa configurazione, esecuzione mvn install
genera Person.java
come illustrato di seguito:
$ cat target/generated-sources/hibernate3/Person.java
// default package
// Generated Dec 14, 2009 2:19:22 PM by Hibernate Tools 3.2.2.GA
/**
* Person generated by hbm2java
*/
public class Person implements java.io.Serializable {
private int id;
private String name;
public Person() {
}
public Person(String name) {
this.name = name;
}
public int getId() {
return this.id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return this.name;
}
public void setName(String name) {
this.name = name;
}
}
Tutto funziona come descritto.
La nuova convenzione maven3 sembra essere $ {} project.build.directory/generata/Hibernate3/main/java piuttosto che $ { project.build.directory}/generated/hibernate3 Ho difficoltà a trovare la documentazione per supportare questo. Il nuovo plugin m2Eclipse sembra utilizzare questa nuova convenzione. Ciò è particolarmente evidente quando si utilizza la funzione "Aggiorna configurazione progetto". –