mraible:
  Hi~Thanks for your repondence.
  I am using the latest AppFuse2.0.1 version and maven2.0.7.
  I don't know whether it's just the AMP or whether there's something
inherently wrong with my entity structure.
  

mraible wrote:
> 
> What version of AppFuse/AMP are you using?
> 
> Matt
> 
> On 12/19/07, JinBinWang <[EMAIL PROTECTED]> wrote:
>>
>> This seems as though it would be a common problem but I haven't found
>> much
>> information on the forum.
>> I create two entitys like this:
>> SUPERCLASS:
>> @Entity
>> @Table(name="emp_table")
>> @Inheritance(strategy=InheritanceType.JOINED)
>> public class Employee implements Serializable {
>>         private static final long serialVersionUID = 48L;
>>
>>         private Long id;
>>
>>         private String name;
>>
>>         private String pass;
>>
>>         private double salary;
>>
>>         private Manager manager;
>>
>>         private Set<Attend> attends = new HashSet<Attend>();
>>
>>         private Set<Payment> payments = new HashSet<Payment>();
>>
>>         @OneToMany(mappedBy="id")
>>         public Set<Attend> getAttends() {
>>                 return attends;
>>         }
>>
>>         public void setAttends(Set<Attend> attends) {
>>                 this.attends = attends;
>>         }
>>
>>         @Id @GeneratedValue(strategy=GenerationType.AUTO)
>>         @Column(name="emp_id")
>>         public Long getId() {
>>                 return id;
>>         }
>>
>>         public void setId(Long id) {
>>                 this.id = id;
>>         }
>>
>>         @ManyToOne(cascade = { CascadeType.PERSIST, CascadeType.MERGE
>> },fetch=FetchType.EAGER)
>>         @JoinColumn(name = "mgr_id")
>>         public Manager getManager() {
>>                 return manager;
>>         }
>>
>>         public void setManager(Manager manager) {
>>                 this.manager = manager;
>>         }
>>
>>         @Column(name="emp_name")
>>         public String getName() {
>>                 return name;
>>         }
>>
>>         public void setName(String name) {
>>                 this.name = name;
>>         }
>>
>>         @Column(name="emp_pass")
>>         public String getPass() {
>>                 return pass;
>>         }
>>
>>         public void setPass(String pass) {
>>                 this.pass = pass;
>>         }
>>
>>         @OneToMany(mappedBy="id")
>>         public Set<Payment> getPayments() {
>>                 return payments;
>>         }
>>
>>         public void setPayments(Set<Payment> payments) {
>>                 this.payments = payments;
>>         }
>>
>>         @Column(name="emp_salary")
>>         public double getSalary() {
>>                 return salary;
>>         }
>>
>>         public void setSalary(double salary) {
>>                 this.salary = salary;
>>         }
>>
>>         public Employee() {
>>         }
>>
>>         public Employee(Long id, String name, String pass, double salary,
>>                         Manager manager) {
>>                 this.id = id;
>>                 this.name = name;
>>                 this.pass = pass;
>>                 this.salary = salary;
>>                 this.manager = manager;
>>         }
>>
>>         public boolean equals (Object obj)
>>     {
>>                 if (null == obj) return false;
>>                 if (!(obj instanceof Employee))
>>         {
>>             return false;
>>         }
>>                 else
>>         {
>>                         Employee employee = (Employee) obj;
>>                         if (null == this.getName() || null ==
>> employee.getName() )
>>             {
>>                 return false;
>>             }
>>                         else
>>             {
>>                 return (this.getName().equals(employee.getName()));
>>             }
>>                 }
>>         }
>>
>>         public int hashCode ()
>>     {
>>                 return name.hashCode();
>>         }
>>
>>         public String toString () {
>>                 return super.toString();
>>         }
>> }
>> SUBCLASS:
>> @Entity
>> @Table(name = "mgr_table")
>> @PrimaryKeyJoinColumn(name = "mgr_id")
>> public class Manager extends Employee implements Serializable {
>>         private static final long serialVersionUID = 48L;
>>
>>         private String dept;
>>
>>         private Set<Employee> employees = new HashSet<Employee>();
>>
>>         private Set<CheckBack> checks = new HashSet<CheckBack>();
>>
>>         public Manager() {
>>         }
>>
>>         public Manager(String dept) {
>>                 this.dept = dept;
>>         }
>>
>>         @OneToMany(mappedBy = "id")
>>         public Set<CheckBack> getChecks() {
>>                 return checks;
>>         }
>>
>>         public void setChecks(Set<CheckBack> checks) {
>>                 this.checks = checks;
>>         }
>>
>>         @Column(name = "dept_name", nullable = false, length = 50)
>>         public String getDept() {
>>                 return dept;
>>         }
>>
>>         public void setDept(String dept) {
>>                 this.dept = dept;
>>         }
>>
>>         @OneToMany(mappedBy = "id")
>>         public Set<Employee> getEmployees() {
>>                 return employees;
>>         }
>>
>>         public void setEmployees(Set<Employee> employees) {
>>                 this.employees = employees;
>>         }
>> }
>> ------------------
>> I receive the error indication like this when I execute the command "mvn
>> appfuse:gen -Dentity=Manager":
> D:\Program Files\eclipse\workspace\myworkflow>mvn appfuse:gen
> -Dentity=Manager
> [INFO] Scanning for projects...
> [INFO] Searching repository for plugin with prefix: 'appfuse'.
> [INFO] org.apache.maven.plugins: checking for updates from appfuse
> [INFO] org.codehaus.mojo: checking for updates from appfuse
> [INFO]
> -------------------------------------------------------------------------
> ---
> [INFO] Building Personal WorkFlow System
> [INFO]    task-segment: [appfuse:gen]
> [INFO]
> -------------------------------------------------------------------------
> ---
> [INFO] Preparing appfuse:gen
> [INFO] artifact org.apache.maven.plugins:maven-resources-plugin: checking
> for updates from appfuse
> [INFO] [aspectj:compile {execution: default}]
> [INFO] [native2ascii:native2ascii {execution: native2ascii-utf8}]
> [INFO] [native2ascii:native2ascii {execution: native2ascii-8859_1}]
> [INFO] [resources:resources]
> [INFO] Using default encoding to copy filtered resources.
> [INFO] [compiler:compile]
> [INFO] Nothing to compile - all classes are up to date
> [INFO] [appfuse:gen]
> [INFO] Configuration XML file loaded: D:\Program
> Files\eclipse\workspace\myworkflow\src\main\resources\hibernate.cfg.xml
> [INFO] Configuration XML file loaded: D:\Program
> Files\eclipse\workspace\myworkflow\src\main\resources\hibernate.cfg.xml
> [INFO] src/main/resources/database.properties not found within the
> project. Trying absolute path.
> [INFO] No hibernate properties file loaded.
> ERROR [main] runtime.error(96) |
> Expression idFieldName is undefined on line 78, column 78 in
> appfuse/web/jsf/form-view.ftl.
> The problematic instruction:
> ----------
> ==> ${idFieldName} [on line 78, column 76 in
> appfuse/web/jsf/form-view.ftl]
> ----------
> 
> Java backtrace for programmers:
> ----------
> freemarker.core.InvalidReferenceException: Expression idFieldName is
> undefined o
> n line 78, column 78 in appfuse/web/jsf/form-view.ftl.
>         at
> freemarker.core.TemplateObject.assertNonNull(TemplateObject.java:124)
> 
>         at freemarker.core.Expression.getStringValue(Expression.java:118)
>         at freemarker.core.Expression.getStringValue(Expression.java:93)
>         at freemarker.core.DollarVariable.accept(DollarVariable.java:76)
>         at freemarker.core.Environment.visit(Environment.java:196)
>         at freemarker.core.MixedContent.accept(MixedContent.java:92)
>         at freemarker.core.Environment.visit(Environment.java:196)
>         at freemarker.core.Environment.process(Environment.java:176)
>         at freemarker.template.Template.process(Template.java:231)
>         at
> org.hibernate.tool.hbm2x.TemplateHelper.processTemplate(TemplateHelpe
> r.java:247)
>         at
> org.hibernate.tool.hbm2x.TemplateProducer.produceToString(TemplatePro
> ducer.java:67)
>         at
> org.hibernate.tool.hbm2x.TemplateProducer.produce(TemplateProducer.ja
> va:28)
>         at
> org.hibernate.tool.hbm2x.TemplateProducer.produce(TemplateProducer.ja
> va:97)
>         at
> org.hibernate.tool.hbm2x.GenericExporter.exportPOJO(GenericExporter.j
> ava:146)
>         at
> org.appfuse.tool.AppFuseExporter$1.exportPOJO(AppFuseExporter.java:21
> 4)
>         at
> org.hibernate.tool.hbm2x.GenericExporter.exportPersistentClass(Generi
> cExporter.java:135)
>         at
> org.hibernate.tool.hbm2x.GenericExporter$2.process(GenericExporter.ja
> va:41)
>         at
> org.hibernate.tool.hbm2x.GenericExporter.doStart(GenericExporter.java
> :126)
>         at
> org.hibernate.tool.hbm2x.AbstractExporter.start(AbstractExporter.java
> :95)
>         at
> org.appfuse.tool.AppFuseExporter.generateWeb(AppFuseExporter.java:126
> )
>         at
> org.appfuse.tool.AppFuseExporter.doStart(AppFuseExporter.java:50)
>         at
> org.hibernate.tool.hbm2x.AbstractExporter.start(AbstractExporter.java
> :95)
>         at
> org.appfuse.mojo.HibernateExporterMojo.doExecute(HibernateExporterMoj
> o.java:228)
>         at
> org.appfuse.mojo.exporter.AppFuseGeneratorMojo.doExecute(AppFuseGener
> atorMojo.java:241)
>         at
> org.appfuse.mojo.HibernateExporterMojo.execute(HibernateExporterMojo.
> java:138)
>         at
> org.appfuse.mojo.exporter.AppFuseGeneratorMojo.execute(AppFuseGenerat
> orMojo.java:194)
>         at
> org.apache.maven.plugin.DefaultPluginManager.executeMojo(DefaultPlugi
> nManager.java:443)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoals(Defa
> ultLifecycleExecutor.java:539)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeStandalone
> Goal(DefaultLifecycleExecutor.java:493)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoal(Defau
> ltLifecycleExecutor.java:463)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoalAndHan
> dleFailures(DefaultLifecycleExecutor.java:311)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeTaskSegmen
> ts(DefaultLifecycleExecutor.java:278)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.execute(DefaultLi
> fecycleExecutor.java:143)
>         at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:334)
>         at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:125)
>         at org.apache.maven.cli.MavenCli.main(MavenCli.java:280)
>         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>         at
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.
> java:39)
>         at
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces
> sorImpl.java:25)
>         at java.lang.reflect.Method.invoke(Method.java:585)
>         at
> org.codehaus.classworlds.Launcher.launchEnhanced(Launcher.java:315)
>         at org.codehaus.classworlds.Launcher.launch(Launcher.java:255)
>         at
> org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:430)
> 
>         at org.codehaus.classworlds.Launcher.main(Launcher.java:375)
> [INFO]
> ------------------------------------------------------------------------
> [ERROR] FATAL ERROR
> [INFO]
> ------------------------------------------------------------------------
> [INFO] Error while processing template appfuse/web/jsf/form-view.ftl
> Expression idFieldName is undefined on line 78, column 78 in
> appfuse/web/jsf/for
> m-view.ftl.
> [INFO]
> ------------------------------------------------------------------------
> [INFO] Trace
> org.hibernate.tool.hbm2x.ExporterException: Error while processing
> template appf
> use/web/jsf/form-view.ftl
>         at
> org.hibernate.tool.hbm2x.TemplateHelper.processTemplate(TemplateHelpe
> r.java:253)
>         at
> org.hibernate.tool.hbm2x.TemplateProducer.produceToString(TemplatePro
> ducer.java:67)
>         at
> org.hibernate.tool.hbm2x.TemplateProducer.produce(TemplateProducer.ja
> va:28)
>         at
> org.hibernate.tool.hbm2x.TemplateProducer.produce(TemplateProducer.ja
> va:97)
>         at
> org.hibernate.tool.hbm2x.GenericExporter.exportPOJO(GenericExporter.j
> ava:146)
>         at
> org.appfuse.tool.AppFuseExporter$1.exportPOJO(AppFuseExporter.java:21
> 4)
>         at
> org.hibernate.tool.hbm2x.GenericExporter.exportPersistentClass(Generi
> cExporter.java:135)
>         at
> org.hibernate.tool.hbm2x.GenericExporter$2.process(GenericExporter.ja
> va:41)
>         at
> org.hibernate.tool.hbm2x.GenericExporter.doStart(GenericExporter.java
> :126)
>         at
> org.hibernate.tool.hbm2x.AbstractExporter.start(AbstractExporter.java
> :95)
>         at
> org.appfuse.tool.AppFuseExporter.generateWeb(AppFuseExporter.java:126
> )
>         at
> org.appfuse.tool.AppFuseExporter.doStart(AppFuseExporter.java:50)
>         at
> org.hibernate.tool.hbm2x.AbstractExporter.start(AbstractExporter.java
> :95)
>         at
> org.appfuse.mojo.HibernateExporterMojo.doExecute(HibernateExporterMoj
> o.java:228)
>         at
> org.appfuse.mojo.exporter.AppFuseGeneratorMojo.doExecute(AppFuseGener
> atorMojo.java:241)
>         at
> org.appfuse.mojo.HibernateExporterMojo.execute(HibernateExporterMojo.
> java:138)
>         at
> org.appfuse.mojo.exporter.AppFuseGeneratorMojo.execute(AppFuseGenerat
> orMojo.java:194)
>         at
> org.apache.maven.plugin.DefaultPluginManager.executeMojo(DefaultPlugi
> nManager.java:443)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoals(Defa
> ultLifecycleExecutor.java:539)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeStandalone
> Goal(DefaultLifecycleExecutor.java:493)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoal(Defau
> ltLifecycleExecutor.java:463)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeGoalAndHan
> dleFailures(DefaultLifecycleExecutor.java:311)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.executeTaskSegmen
> ts(DefaultLifecycleExecutor.java:278)
>         at
> org.apache.maven.lifecycle.DefaultLifecycleExecutor.execute(DefaultLi
> fecycleExecutor.java:143)
>         at org.apache.maven.DefaultMaven.doExecute(DefaultMaven.java:334)
>         at org.apache.maven.DefaultMaven.execute(DefaultMaven.java:125)
>         at org.apache.maven.cli.MavenCli.main(MavenCli.java:280)
>         at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
>         at
> sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.
> java:39)
>         at
> sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAcces
> sorImpl.java:25)
>         at java.lang.reflect.Method.invoke(Method.java:585)
>         at
> org.codehaus.classworlds.Launcher.launchEnhanced(Launcher.java:315)
>         at org.codehaus.classworlds.Launcher.launch(Launcher.java:255)
>         at
> org.codehaus.classworlds.Launcher.mainWithExitCode(Launcher.java:430)
> 
>         at org.codehaus.classworlds.Launcher.main(Launcher.java:375)
> Caused by: freemarker.core.InvalidReferenceException: Expression
> idFieldName is
> undefined on line 78, column 78 in appfuse/web/jsf/form-view.ftl.
>         at
> freemarker.core.TemplateObject.assertNonNull(TemplateObject.java:124)
> 
>         at freemarker.core.Expression.getStringValue(Expression.java:118)
>         at freemarker.core.Expression.getStringValue(Expression.java:93)
>         at freemarker.core.DollarVariable.accept(DollarVariable.java:76)
>         at freemarker.core.Environment.visit(Environment.java:196)
>         at freemarker.core.MixedContent.accept(MixedContent.java:92)
>         at freemarker.core.Environment.visit(Environment.java:196)
>         at freemarker.core.Environment.process(Environment.java:176)
>         at freemarker.template.Template.process(Template.java:231)
>         at
> org.hibernate.tool.hbm2x.TemplateHelper.processTemplate(TemplateHelpe
> r.java:247)
>         ... 34 more
> [INFO]
> ------------------------------------------------------------------------
> [INFO] Total time: 58 seconds
> [INFO] Finished at: Thu Dec 20 11:28:38 CST 2007
> [INFO] Final Memory: 16M/29M
> [INFO]
> ------------------------------------------------------------------------
> 
> ---------------------------------------------------------------------
> To unsubscribe, e-mail: [EMAIL PROTECTED]
> For additional commands, e-mail: [EMAIL PROTECTED]
> 
> 
> 

-- 
View this message in context: 
http://www.nabble.com/Cannt-using-gen-command-in-AppFuse-tp14414609s2369p14430534.html
Sent from the AppFuse - User mailing list archive at Nabble.com.

---------------------------------------------------------------------
To unsubscribe, e-mail: [EMAIL PROTECTED]
For additional commands, e-mail: [EMAIL PROTECTED]

Reply via email to