Added before- and after- update hooks when saving auxiliary records

This commit is contained in:
sb 2009-04-17 13:11:04 +00:00
parent 5b49d6a280
commit 6e995bfc5c
2 changed files with 36 additions and 22 deletions

View file

@ -9,8 +9,8 @@
Transform ADL into (partial) controller classes Transform ADL into (partial) controller classes
$Author: sb $ $Author: sb $
$Revision: 1.32 $ $Revision: 1.33 $
$Date: 2009-04-17 09:43:27 $ $Date: 2009-04-17 13:11:04 $
--> -->
<!-- WARNING WARNING WARNING: Do NOT reformat this file! <!-- WARNING WARNING WARNING: Do NOT reformat this file!
@ -70,7 +70,7 @@
// //
// Automatically generated abstract super class for controllers for the // Automatically generated abstract super class for controllers for the
// <xsl:value-of select="/adl:application/@name"/> application; generated using // <xsl:value-of select="/adl:application/@name"/> application; generated using
// adl2controllerclasses.xslt version <xsl:value-of select="substring( '$Revision: 1.32 $', 10)"/> // adl2controllerclasses.xslt version <xsl:value-of select="substring( '$Revision: 1.33 $', 10)"/>
// //
// <xsl:value-of select="/adl:application/@revision"/> // <xsl:value-of select="/adl:application/@revision"/>
// //
@ -180,7 +180,7 @@
// //
// Controller for auto-generated forms for editing <xsl:value-of select="@name"/>s // Controller for auto-generated forms for editing <xsl:value-of select="@name"/>s
// Automatically generated from application description using // Automatically generated from application description using
// adl2controllerclasses.xslt version <xsl:value-of select="substring( '$Revision: 1.32 $', 10)"/> // adl2controllerclasses.xslt version <xsl:value-of select="substring( '$Revision: 1.33 $', 10)"/>
// //
// This file is automatically generated; DO NOT EDIT IT. // This file is automatically generated; DO NOT EDIT IT.
// //
@ -277,12 +277,18 @@
foreach ( <xsl:value-of select="concat($entityns, '.', @name)"/> instance in instances) { foreach ( <xsl:value-of select="concat($entityns, '.', @name)"/> instance in instances) {
<xsl:for-each select="adl:property[@type='message']"> <xsl:for-each select="adl:property[@type='message']">
if ( <xsl:value-of select="concat( 'instance.', @name)"/> == null || <xsl:value-of select="concat( 'instance.', @name, '.MessageId')"/> == 0 ){ <xsl:variable name="slot" select="concat( 'instance.', @name)"/>
<xsl:value-of select="concat( 'instance.', @name)"/> = new Message(); if ( <xsl:value-of select="$slot"/> == null || <xsl:value-of select="concat( $slot, '.MessageId')"/> == 0 ){
hibernator.SaveOrUpdate( <xsl:value-of select="concat( 'instance.', @name)"/>); <xsl:value-of select="$slot"/> = new Message();
<xsl:value-of select="$slot"/>.BeforeUpdateHook( hibernator);
hibernator.SaveOrUpdate( <xsl:value-of select="$slot"/>);
<xsl:value-of select="$slot"/>.AfterUpdateHook( hibernator);
} }
</xsl:for-each> </xsl:for-each>
instance.BeforeUpdateHook( hibernator);
hibernator.SaveOrUpdate( instance); hibernator.SaveOrUpdate( instance);
instance.AfterUpdateHook( hibernator);
} }
hibernator.Flush(); hibernator.Flush();
<xsl:if test="adl:list[@name='list']"> <xsl:if test="adl:list[@name='list']">
@ -412,7 +418,9 @@
if ( mess == null) { if ( mess == null) {
mess = new Message(); mess = new Message();
} }
mess.BeforeUpdateHook( hibernator);
hibernator.SaveOrUpdate( mess); hibernator.SaveOrUpdate( mess);
mess.AfterUpdateHook( hibernator);
Translation trans = mess.GetTranslationObject( locale, hibernator); Translation trans = mess.GetTranslationObject( locale, hibernator);
if ( trans == null) { if ( trans == null) {
@ -420,7 +428,9 @@
} }
trans.MessageText = Form["<xsl:value-of select="concat( 'instance.', @name)"/>"]; trans.MessageText = Form["<xsl:value-of select="concat( 'instance.', @name)"/>"];
record.<xsl:value-of select="@name"/> = mess; record.<xsl:value-of select="@name"/> = mess;
trans.BeforeUpdateHook( hibernator);
hibernator.SaveOrUpdate( trans); hibernator.SaveOrUpdate( trans);
trans.AfterUpdateHook( hibernator);
} }
</xsl:for-each> </xsl:for-each>
</xsl:if> </xsl:if>
@ -586,13 +596,17 @@
<xsl:value-of select="concat( 'item.', $foreignkey)"/>; <xsl:value-of select="concat( 'item.', $foreignkey)"/>;
if ( oldparent != null) { if ( oldparent != null) {
oldparent.<xsl:value-of select="@name"/>.Remove( item); oldparent.<xsl:value-of select="@name"/>.Remove( item);
oldparent.BeforeUpdateHook( hibernator);
hibernator.SaveOrUpdate( oldparent); hibernator.SaveOrUpdate( oldparent);
oldparent.AfterUpdateHook( hibernator);
} }
/* then add it to my <xsl:value-of select="@name"/> */ /* then add it to my <xsl:value-of select="@name"/> */
record.<xsl:value-of select="@name"/>.Add( item); record.<xsl:value-of select="@name"/>.Add( item);
<xsl:value-of select="concat( 'item.', $foreignkey)"/> = record; <xsl:value-of select="concat( 'item.', $foreignkey)"/> = record;
item.BeforeUpdateHook( hibernator);
hibernator.SaveOrUpdate( item); hibernator.SaveOrUpdate( item);
item.AfterUpdateHook( hibernator);
} }
} /* foreach ( string index... */ } /* foreach ( string index... */
} /* if ( Form.GetValues( "<xsl:value-of select="concat( 'instance.', @name)"/>") != null) */ } /* if ( Form.GetValues( "<xsl:value-of select="concat( 'instance.', @name)"/>") != null) */

View file

@ -15,8 +15,8 @@
Transform ADL into velocity view templates Transform ADL into velocity view templates
$Author: sb $ $Author: sb $
$Revision: 1.35 $ $Revision: 1.36 $
$Date: 2009-03-05 14:14:25 $ $Date: 2009-04-17 13:11:04 $
--> -->
<!-- WARNING WARNING WARNING: Do NOT reformat this file! <!-- WARNING WARNING WARNING: Do NOT reformat this file!
Whitespace (or lack of it) is significant! --> Whitespace (or lack of it) is significant! -->
@ -124,7 +124,7 @@
Auto generated Velocity maybe-delete form for <xsl:value-of select="@name"/>, Auto generated Velocity maybe-delete form for <xsl:value-of select="@name"/>,
generated from ADL. generated from ADL.
Generated using adl2views.xslt <xsl:value-of select="substring( '$Revision: 1.35 $', 10)"/> Generated using adl2views.xslt <xsl:value-of select="substring( '$Revision: 1.36 $', 10)"/>
</xsl:comment> </xsl:comment>
<xsl:call-template name="maybe-delete"> <xsl:call-template name="maybe-delete">
<xsl:with-param name="entity" select="."/> <xsl:with-param name="entity" select="."/>
@ -161,7 +161,7 @@
Auto generated Velocity maybe-delete form for <xsl:value-of select="@name"/>, Auto generated Velocity maybe-delete form for <xsl:value-of select="@name"/>,
generated from ADL. generated from ADL.
Generated using adl2views.xslt <xsl:value-of select="substring( '$Revision: 1.35 $', 10)"/> Generated using adl2views.xslt <xsl:value-of select="substring( '$Revision: 1.36 $', 10)"/>
<xsl:value-of select="/adl:application/@revision"/> <xsl:value-of select="/adl:application/@revision"/>
</xsl:comment> </xsl:comment>
@ -244,7 +244,7 @@
Auto generated Velocity <xsl:value-of select="@name"/> form for <xsl:value-of select="ancestor::adl:entity/@name"/>, Auto generated Velocity <xsl:value-of select="@name"/> form for <xsl:value-of select="ancestor::adl:entity/@name"/>,
generated from ADL. generated from ADL.
Generated using adl2views.xslt <xsl:value-of select="substring( '$Revision: 1.35 $', 10)"/> Generated using adl2views.xslt <xsl:value-of select="substring( '$Revision: 1.36 $', 10)"/>
Generation parameters were: Generation parameters were:
locale: <xsl:value-of select="$locale"/> locale: <xsl:value-of select="$locale"/>
generate-site-navigation: <xsl:value-of select="$generate-site-navigation"/> generate-site-navigation: <xsl:value-of select="$generate-site-navigation"/>
@ -320,7 +320,7 @@
Auto generated Velocity form for <xsl:value-of select="ancestor::adl:entity/@name"/>, Auto generated Velocity form for <xsl:value-of select="ancestor::adl:entity/@name"/>,
generated from ADL. generated from ADL.
Generated using adl2views.xsl <xsl:value-of select="substring( '$Revision: 1.35 $', 10)"/> Generated using adl2views.xsl <xsl:value-of select="substring( '$Revision: 1.36 $', 10)"/>
Generation parameters were: Generation parameters were:
locale: <xsl:value-of select="$locale"/> locale: <xsl:value-of select="$locale"/>
generate-site-navigation: <xsl:value-of select="$generate-site-navigation"/> generate-site-navigation: <xsl:value-of select="$generate-site-navigation"/>
@ -917,7 +917,7 @@
Auto generated Velocity list for <xsl:value-of select="@name"/>, Auto generated Velocity list for <xsl:value-of select="@name"/>,
generated from ADL. generated from ADL.
Generated using adl2views.xslt <xsl:value-of select="substring( '$Revision: 1.35 $', 10)"/> Generated using adl2views.xslt <xsl:value-of select="substring( '$Revision: 1.36 $', 10)"/>
Generation parameters were: Generation parameters were:
locale: <xsl:value-of select="$locale"/> locale: <xsl:value-of select="$locale"/>
generate-site-navigation: <xsl:value-of select="$generate-site-navigation"/> generate-site-navigation: <xsl:value-of select="$generate-site-navigation"/>
@ -980,7 +980,7 @@
Auto generated Velocity list for <xsl:value-of select="ancestor::adl:entity/@name"/>, Auto generated Velocity list for <xsl:value-of select="ancestor::adl:entity/@name"/>,
generated from ADL. generated from ADL.
Generated using adl2listview.xsl <xsl:value-of select="substring( '$Revision: 1.35 $', 10)"/> Generated using adl2listview.xsl <xsl:value-of select="substring( '$Revision: 1.36 $', 10)"/>
Generation parameters were: Generation parameters were:
locale: <xsl:value-of select="$locale"/> locale: <xsl:value-of select="$locale"/>
generate-site-navigation: <xsl:value-of select="$generate-site-navigation"/> generate-site-navigation: <xsl:value-of select="$generate-site-navigation"/>
@ -1126,7 +1126,7 @@
</td> </td>
</xsl:for-each> </xsl:for-each>
<td> <td>
<input type="submit" value="Search!"/> <input type="submit" name="search-button" value="Search!"/>
</td> </td>
</tr> </tr>
</xsl:if> </xsl:if>
@ -1276,7 +1276,7 @@
</td> </td>
</xsl:for-each> </xsl:for-each>
<td> <td>
<input type="submit" value="Search!"/> <input type="submit" name="search-button" value="Search!"/>
</td> </td>
</tr> </tr>
</xsl:if> </xsl:if>