Almost there.
This commit is contained in:
parent
07b10ab336
commit
b7a2327857
|
@ -1,16 +1,16 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
C1873 SRU Hospitality
|
Application Description Language framework
|
||||||
adl2controllerclasses.xsl
|
adl2controllerclasses.xsl
|
||||||
|
|
||||||
(c) 2007 Cygnet Solutions Ltd
|
(c) 2007 Cygnet Solutions Ltd
|
||||||
|
|
||||||
Transform ADL into (partial) controller classes
|
Transform ADL into (partial) controller classes
|
||||||
|
|
||||||
$Author: af $
|
$Author: sb $
|
||||||
$Revision: 1.2 $
|
$Revision: 1.3 $
|
||||||
$Date: 2008-01-31 12:34:21 $
|
$Date: 2008-02-01 21:47:15 $
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<!-- WARNING WARNING WARNING: Do NOT reformat this file!
|
<!-- WARNING WARNING WARNING: Do NOT reformat this file!
|
||||||
|
@ -50,7 +50,7 @@
|
||||||
with the revision number of the generated file if the generated file is
|
with the revision number of the generated file if the generated file is
|
||||||
stored to CVS -->
|
stored to CVS -->
|
||||||
<xsl:variable name="transform-rev1"
|
<xsl:variable name="transform-rev1"
|
||||||
select="substring( '$Revision: 1.2 $', 11)"/>
|
select="substring( '$Revision: 1.3 $', 11)"/>
|
||||||
<xsl:variable name="transform-revision"
|
<xsl:variable name="transform-revision"
|
||||||
select="substring( $transform-rev1, 0, string-length( $transform-rev1) - 1)"/>
|
select="substring( $transform-rev1, 0, string-length( $transform-rev1) - 1)"/>
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
|
||||||
<!--
|
<!--
|
||||||
C1873 SRU Hospitality
|
Application Description Language framework
|
||||||
adl2controllerclasses.xsl
|
adl2controllerclasses.xsl
|
||||||
|
|
||||||
(c) 2007 Cygnet Solutions Ltd
|
(c) 2007 Cygnet Solutions Ltd
|
||||||
|
@ -9,16 +9,22 @@
|
||||||
Transform ADL into (partial) controller classes
|
Transform ADL into (partial) controller classes
|
||||||
|
|
||||||
$Author: sb $
|
$Author: sb $
|
||||||
$Revision: 1.1 $
|
$Revision: 1.2 $
|
||||||
$Date: 2008-01-31 17:06:35 $
|
$Date: 2008-02-01 21:47:15 $
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<!-- 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! -->
|
||||||
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
<xsl:stylesheet version="1.0"
|
||||||
<xsl:output encoding="UTF-8" method="text"/>
|
xmlns="http://cygnets.co.uk/schemas/adl-1.2"
|
||||||
|
xmlns:adl="http://cygnets.co.uk/schemas/adl-1.2"
|
||||||
|
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
|
||||||
|
|
||||||
<!-- The locale for which these controllers are generated
|
<xsl:include href="csharp-type-include.xslt"/>
|
||||||
|
|
||||||
|
<xsl:output encoding="UTF-8" method="text"/>
|
||||||
|
|
||||||
|
<!-- The locale for which these controllers are generated
|
||||||
TODO: Controllers should NOT be locale specific. Instead, the
|
TODO: Controllers should NOT be locale specific. Instead, the
|
||||||
controller should render views and generate messages based on the
|
controller should render views and generate messages based on the
|
||||||
client's locale. However, there may still need to be a concept of a
|
client's locale. However, there may still need to be a concept of a
|
||||||
|
@ -30,18 +36,21 @@
|
||||||
<xsl:param name="controllerns" select="Unset"/>
|
<xsl:param name="controllerns" select="Unset"/>
|
||||||
<!-- The C# namespace used by the entities for this project -->
|
<!-- The C# namespace used by the entities for this project -->
|
||||||
<xsl:param name="entityns" select="Unset"/>
|
<xsl:param name="entityns" select="Unset"/>
|
||||||
|
<!-- Whether to authenticate at application or at database layer.
|
||||||
<xsl:template match="application">
|
If not 'Application', then 'Database'. -->
|
||||||
<xsl:apply-templates select="entity"/>
|
<xsl:param name="authentication-layer" select="Application"/>
|
||||||
|
|
||||||
|
<xsl:template match="adl:application">
|
||||||
|
<xsl:apply-templates select="adl:entity"/>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
<xsl:template match="entity">
|
<xsl:template match="adl:entity">
|
||||||
<!-- what's all this about? the objective is to get the revision number of the
|
<!-- what's all this about? the objective is to get the revision number of the
|
||||||
transform into the output, /without/ getting that revision number overwritten
|
transform into the output, /without/ getting that revision number overwritten
|
||||||
with the revision number of the generated file if the generated file is
|
with the revision number of the generated file if the generated file is
|
||||||
stored to CVS -->
|
stored to CVS -->
|
||||||
<xsl:variable name="transform-rev1"
|
<xsl:variable name="transform-rev1"
|
||||||
select="substring( '$Revision: 1.1 $', 11)"/>
|
select="substring( '$Revision: 1.2 $', 11)"/>
|
||||||
<xsl:variable name="transform-revision"
|
<xsl:variable name="transform-revision"
|
||||||
select="substring( $transform-rev1, 0, string-length( $transform-rev1) - 1)"/>
|
select="substring( $transform-rev1, 0, string-length( $transform-rev1) - 1)"/>
|
||||||
|
|
||||||
|
@ -79,15 +88,14 @@ using System.Web.UI.WebControls;
|
||||||
using System.Web.UI.WebControls.WebParts;
|
using System.Web.UI.WebControls.WebParts;
|
||||||
using System.Web.UI.HtmlControls;
|
using System.Web.UI.HtmlControls;
|
||||||
using Castle.MonoRail.Framework.Helpers;
|
using Castle.MonoRail.Framework.Helpers;
|
||||||
|
using Cygnet.Exceptions;
|
||||||
using Cygnet.Web.Helpers;
|
using Cygnet.Web.Helpers;
|
||||||
using Cygnet.Web.Controllers;
|
using Cygnet.Web.Controllers;
|
||||||
using NHibernate;
|
using NHibernate;
|
||||||
using NHibernate.Expression;
|
using NHibernate.Expression;
|
||||||
using Castle.MonoRail.Framework;
|
using Castle.MonoRail.Framework;
|
||||||
using Cygnet.Exceptions;
|
|
||||||
using Iesi.Collections.Generic;
|
using Iesi.Collections.Generic;
|
||||||
using SRU.Hospitality.Helpers;
|
using <xsl:value-of select="$entityns"/>;
|
||||||
using SRU.Hospitality.Entities;
|
|
||||||
|
|
||||||
namespace <xsl:value-of select="$controllerns"/> {
|
namespace <xsl:value-of select="$controllerns"/> {
|
||||||
|
|
||||||
|
@ -110,9 +118,9 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
private void Store()
|
private void Store()
|
||||||
{
|
{
|
||||||
ISession hibernator =
|
ISession hibernator =
|
||||||
NHibernateHelper.GetCurrentSession( Session[ NHibernateHelper.USERTOKEN],
|
NHibernateHelper.GetCurrentSession( <xsl:if test="$authentication-layer = 'Database'">Session[ NHibernateHelper.USERTOKEN],
|
||||||
Session[NHibernateHelper.PASSTOKEN]);
|
Session[NHibernateHelper.PASSTOKEN]</xsl:if>);
|
||||||
List<string> messages = new List<string>();
|
List<string> messages = new List<string>();
|
||||||
|
|
||||||
<xsl:value-of select="$entityns"/>.<xsl:value-of select="@name"/> record;
|
<xsl:value-of select="$entityns"/>.<xsl:value-of select="@name"/> record;
|
||||||
|
|
||||||
|
@ -138,9 +146,9 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
{
|
{
|
||||||
/* it's existing, retrieve it */
|
/* it's existing, retrieve it */
|
||||||
record =
|
record =
|
||||||
hibernator.CreateCriteria(typeof(<xsl:value-of select="@name"/>))
|
hibernator.CreateCriteria(typeof(<xsl:value-of select="concat( $entityns, '.', @name)"/>))
|
||||||
.Add(Expression.Eq("<xsl:value-of select="$key"/>", Int32.Parse(id)))
|
.Add(Expression.Eq("<xsl:value-of select="$key"/>", Int32.Parse(id)))
|
||||||
.UniqueResult<<xsl:value-of select="$entityns"/>.<xsl:value-of select="@name"/>>();
|
.UniqueResult<<xsl:value-of select="concat( $entityns, '.', @name)"/>>();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( record != null)
|
if ( record != null)
|
||||||
|
@ -155,11 +163,11 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
* special - BindObjectInstance /should/ do it all. Unfortunately it sometimes
|
* special - BindObjectInstance /should/ do it all. Unfortunately it sometimes
|
||||||
* doesn't, and I haven't yet characterised why not. TODO: Fix this! */
|
* doesn't, and I haven't yet characterised why not. TODO: Fix this! */
|
||||||
record.<xsl:value-of select="@name"/> =
|
record.<xsl:value-of select="@name"/> =
|
||||||
hibernator.CreateCriteria(typeof(<xsl:value-of select="@entity"/>))
|
hibernator.CreateCriteria(typeof(<xsl:value-of select="concat( $entityns, '.', @entity)"/>))
|
||||||
.Add(Expression.Eq("<xsl:call-template name="primary-key">
|
.Add(Expression.Eq("<xsl:call-template name="primary-key">
|
||||||
<xsl:with-param name="entityname" select="@entity"/>
|
<xsl:with-param name="entityname" select="@entity"/>
|
||||||
</xsl:call-template>", Int32.Parse(Form["<xsl:value-of select="concat( 'instance.', @name)"/>"])))
|
</xsl:call-template>", Int32.Parse(Form["<xsl:value-of select="concat( $entityns, '.', @entity)"/>"])))
|
||||||
.UniqueResult<<xsl:value-of select="$entityns"/>.<xsl:value-of select="@entity"/>>();
|
.UniqueResult<<xsl:value-of select="concat( $entityns, '.', @entity)"/>>();
|
||||||
</xsl:for-each>
|
</xsl:for-each>
|
||||||
|
|
||||||
<xsl:for-each select="property[@type='link']">
|
<xsl:for-each select="property[@type='link']">
|
||||||
|
@ -258,9 +266,11 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
}
|
}
|
||||||
|
|
||||||
PropertyBag["messages"] = messages;
|
PropertyBag["messages"] = messages;
|
||||||
|
PropertyBag["instance"] = record;
|
||||||
|
<xsl:if test="$authentication-layer = 'Database'">
|
||||||
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
||||||
PropertyBag["instance"] = record;
|
</xsl:if>
|
||||||
|
|
||||||
<xsl:call-template name="menus">
|
<xsl:call-template name="menus">
|
||||||
<xsl:with-param name="entity" select="."/>
|
<xsl:with-param name="entity" select="."/>
|
||||||
</xsl:call-template>
|
</xsl:call-template>
|
||||||
|
@ -279,26 +289,26 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
public void Delete()
|
public void Delete()
|
||||||
{
|
{
|
||||||
ISession hibernator =
|
ISession hibernator =
|
||||||
NHibernateHelper.GetCurrentSession( Session[ NHibernateHelper.USERTOKEN],
|
NHibernateHelper.GetCurrentSession( <xsl:if test="$authentication-layer = 'Database'">Session[ NHibernateHelper.USERTOKEN],
|
||||||
Session[NHibernateHelper.PASSTOKEN]);
|
Session[NHibernateHelper.PASSTOKEN]</xsl:if>);
|
||||||
string id = Params["<xsl:value-of select="concat( 'instance.', $key)"/>"];
|
string id = Params["<xsl:value-of select="concat( 'instance.', $key)"/>"];
|
||||||
string reallydelete = Params["reallydelete"];
|
string reallydelete = Params["reallydelete"];
|
||||||
|
|
||||||
if ( "true".Equals( reallydelete))
|
if ( "true".Equals( reallydelete))
|
||||||
{
|
{
|
||||||
<xsl:value-of select="@name"/> record =
|
<xsl:value-of select="concat($entityns, '.', @name)"/> record =
|
||||||
hibernator.CreateCriteria(typeof(<xsl:value-of select="@name"/>))
|
hibernator.CreateCriteria(typeof(<xsl:value-of select="concat($entityns, '.', @name)"/>))
|
||||||
.Add(Expression.Eq("<xsl:value-of select="$key"/>", Int32.Parse(id)))
|
.Add(Expression.Eq("<xsl:value-of select="$key"/>", Int32.Parse(id)))
|
||||||
.UniqueResult<<xsl:value-of select="$entityns"/>.<xsl:value-of select="@name"/>>();
|
.UniqueResult<<xsl:value-of select="concat($entityns, '.', @name)"/>>();
|
||||||
|
|
||||||
if ( record != null)
|
if ( record != null)
|
||||||
{
|
{
|
||||||
record.BeforeDeleteHook( hibernator);
|
record.BeforeDeleteHook( hibernator);
|
||||||
|
|
||||||
hibernator.Delete(
|
hibernator.Delete(
|
||||||
hibernator.CreateCriteria(typeof(<xsl:value-of select="@name"/>))
|
hibernator.CreateCriteria(typeof(<xsl:value-of select="concat($entityns, '.', @name)"/>))
|
||||||
.Add(Expression.Eq("<xsl:value-of select="$key"/>", Int32.Parse(id)))
|
.Add(Expression.Eq("<xsl:value-of select="$key"/>", Int32.Parse(id)))
|
||||||
.UniqueResult<<xsl:value-of select="$entityns"/>.<xsl:value-of select="@name"/>>());
|
.UniqueResult<<xsl:value-of select="concat($entityns, '.', @name)"/>>());
|
||||||
|
|
||||||
hibernator.Flush();
|
hibernator.Flush();
|
||||||
}
|
}
|
||||||
|
@ -339,14 +349,16 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
public void InternalShowList( String view)
|
public void InternalShowList( String view)
|
||||||
{
|
{
|
||||||
ISession hibernator =
|
ISession hibernator =
|
||||||
NHibernateHelper.GetCurrentSession( Session[ NHibernateHelper.USERTOKEN],
|
NHibernateHelper.GetCurrentSession( <xsl:if test="$authentication-layer = 'Database'">Session[ NHibernateHelper.USERTOKEN],
|
||||||
Session[NHibernateHelper.PASSTOKEN]);
|
Session[NHibernateHelper.PASSTOKEN]</xsl:if>);
|
||||||
IList<<xsl:value-of select="@name"/>> instances =
|
IList<<xsl:value-of select="@name"/>> instances =
|
||||||
hibernator.CreateCriteria(typeof(<xsl:value-of select="@name"/>))<xsl:for-each select="property[@distinct='user']">
|
hibernator.CreateCriteria(typeof(<xsl:value-of select="concat($entityns, '.', @name)"/>))<xsl:for-each select="property[@distinct='user']">
|
||||||
<xsl:value-of select="concat( '.AddOrder( new Order( "', @name, '", true))')"/>
|
<xsl:value-of select="concat( '.AddOrder( new Order( "', @name, '", true))')"/>
|
||||||
</xsl:for-each>.List<<xsl:value-of select="@name"/>>();
|
</xsl:for-each>.List<<xsl:value-of select="concat($entityns, '.', @name)"/>>();
|
||||||
|
|
||||||
|
<xsl:if test="$authentication-layer = 'Database'">
|
||||||
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
||||||
|
</xsl:if>
|
||||||
PropertyBag["instances"] =
|
PropertyBag["instances"] =
|
||||||
PaginationHelper.CreatePagination( this, instances, 25);
|
PaginationHelper.CreatePagination( this, instances, 25);
|
||||||
|
|
||||||
|
@ -413,15 +425,17 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
if ( command.Equals( "delete"))
|
if ( command.Equals( "delete"))
|
||||||
{
|
{
|
||||||
ISession hibernator =
|
ISession hibernator =
|
||||||
NHibernateHelper.GetCurrentSession( Session[ NHibernateHelper.USERTOKEN],
|
NHibernateHelper.GetCurrentSession( <xsl:if test="$authentication-layer = 'Database'">Session[ NHibernateHelper.USERTOKEN],
|
||||||
Session[NHibernateHelper.PASSTOKEN]);
|
Session[NHibernateHelper.PASSTOKEN]</xsl:if>);
|
||||||
string id = Form["<xsl:value-of select="concat( 'instance.', $key)"/>"];
|
string id = Form["<xsl:value-of select="concat( 'instance.', $key)"/>"];
|
||||||
|
|
||||||
|
<xsl:if test="$authentication-layer = 'Database'">
|
||||||
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
||||||
|
</xsl:if>
|
||||||
PropertyBag["instance"] =
|
PropertyBag["instance"] =
|
||||||
hibernator.CreateCriteria(typeof(<xsl:value-of select="../@name"/>))
|
hibernator.CreateCriteria(typeof(<xsl:value-of select="concat($entityns, '.', @name)"/>))
|
||||||
.Add(Expression.Eq("<xsl:value-of select="$key"/>", Int32.Parse(id)))
|
.Add(Expression.Eq("<xsl:value-of select="$key"/>", Int32.Parse(id)))
|
||||||
.UniqueResult<<xsl:value-of select="$entityns"/>.<xsl:value-of select="../@name"/>>();
|
.UniqueResult<<xsl:value-of select="concat($entityns, '.', @name)"/>>();
|
||||||
|
|
||||||
RenderViewWithFailover( "maybedelete.vm", "maybedelete.auto.vm");
|
RenderViewWithFailover( "maybedelete.vm", "maybedelete.auto.vm");
|
||||||
}
|
}
|
||||||
|
@ -442,13 +456,15 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
public void <xsl:value-of select="@name"/>( )
|
public void <xsl:value-of select="@name"/>( )
|
||||||
{
|
{
|
||||||
ISession hibernator =
|
ISession hibernator =
|
||||||
NHibernateHelper.GetCurrentSession( Session[ NHibernateHelper.USERTOKEN],
|
NHibernateHelper.GetCurrentSession( <xsl:if test="$authentication-layer = 'Database'">Session[ NHibernateHelper.USERTOKEN],
|
||||||
Session[NHibernateHelper.PASSTOKEN]);
|
Session[NHibernateHelper.PASSTOKEN]</xsl:if>);
|
||||||
<xsl:call-template name="menus">
|
<xsl:call-template name="menus">
|
||||||
<xsl:with-param name="entity" select=".."/>
|
<xsl:with-param name="entity" select=".."/>
|
||||||
</xsl:call-template>
|
</xsl:call-template>
|
||||||
|
|
||||||
|
<xsl:if test="$authentication-layer = 'Database'">
|
||||||
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
||||||
|
</xsl:if>
|
||||||
RenderViewWithFailover("<xsl:value-of select="concat( @name, '.vm')"/>", "<xsl:value-of select="concat( @name, '.auto.vm')"/>");
|
RenderViewWithFailover("<xsl:value-of select="concat( @name, '.vm')"/>", "<xsl:value-of select="concat( @name, '.auto.vm')"/>");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -460,14 +476,16 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
public void <xsl:value-of select="@name"/>( Int32 <xsl:value-of select="concat( ../@name, 'Id')"/>)
|
public void <xsl:value-of select="@name"/>( Int32 <xsl:value-of select="concat( ../@name, 'Id')"/>)
|
||||||
{
|
{
|
||||||
ISession hibernator =
|
ISession hibernator =
|
||||||
NHibernateHelper.GetCurrentSession( Session[ NHibernateHelper.USERTOKEN],
|
NHibernateHelper.GetCurrentSession( <xsl:if test="$authentication-layer = 'Database'">Session[ NHibernateHelper.USERTOKEN],
|
||||||
Session[NHibernateHelper.PASSTOKEN]);
|
Session[NHibernateHelper.PASSTOKEN]</xsl:if>);
|
||||||
<xsl:value-of select="$entityns"/>.<xsl:value-of select="../@name"/> record =
|
<xsl:value-of select="concat($entityns, '.', @name)"/> record =
|
||||||
hibernator.CreateCriteria(typeof(<xsl:value-of select="../@name"/>))
|
hibernator.CreateCriteria(typeof(<xsl:value-of select="concat($entityns, '.', @name)"/>))
|
||||||
.Add(Expression.Eq("<xsl:value-of select="concat( ../@name, 'Id')"/>", <xsl:value-of select="../@name"/>Id))
|
.Add(Expression.Eq("<xsl:value-of select="concat( ../@name, 'Id')"/>", <xsl:value-of select="../@name"/>Id))
|
||||||
.UniqueResult<<xsl:value-of select="$entityns"/>.<xsl:value-of select="../@name"/>>();
|
.UniqueResult<<xsl:value-of select="concat($entityns, '.', @name)"/>>();
|
||||||
|
|
||||||
|
<xsl:if test="$authentication-layer = 'Database'">
|
||||||
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
PropertyBag["username"] = Session[ NHibernateHelper.USERTOKEN];
|
||||||
|
</xsl:if>
|
||||||
PropertyBag["instance"] = record;
|
PropertyBag["instance"] = record;
|
||||||
|
|
||||||
<xsl:call-template name="menus">
|
<xsl:call-template name="menus">
|
||||||
|
@ -519,9 +537,9 @@ namespace <xsl:value-of select="$controllerns"/> {
|
||||||
<xsl:variable name="ename" select="$property/@entity"/>
|
<xsl:variable name="ename" select="$property/@entity"/>
|
||||||
<xsl:variable name="entity" select="//entity[@name=$ename]"/>
|
<xsl:variable name="entity" select="//entity[@name=$ename]"/>
|
||||||
PropertyBag["<xsl:value-of select="concat('all_', $property/@name)"/>"] =
|
PropertyBag["<xsl:value-of select="concat('all_', $property/@name)"/>"] =
|
||||||
hibernator.CreateCriteria(typeof(<xsl:value-of select="$property/@entity"/>))<xsl:for-each select="$entity/property[@distinct='user']">
|
hibernator.CreateCriteria(typeof(<xsl:value-of select="concat( $entityns, '.', $property/@entity)"/>))<xsl:for-each select="$entity/property[@distinct='user']">
|
||||||
<xsl:value-of select="concat('.AddOrder( new Order( "', @name, '", true))')"/>
|
<xsl:value-of select="concat('.AddOrder( new Order( "', @name, '", true))')"/>
|
||||||
</xsl:for-each>.List<<xsl:value-of select="$property/@entity"/>>();
|
</xsl:for-each>.List<<xsl:value-of select="concat( $entityns, '.', $property/@entity)"/>>();
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
<xsl:template name="primary-key">
|
<xsl:template name="primary-key">
|
||||||
|
|
|
@ -8,8 +8,8 @@
|
||||||
Transform ADL into entity classes
|
Transform ADL into entity classes
|
||||||
|
|
||||||
$Author: sb $
|
$Author: sb $
|
||||||
$Revision: 1.2 $
|
$Revision: 1.3 $
|
||||||
$Date: 2008-02-01 18:25:38 $
|
$Date: 2008-02-01 21:47:15 $
|
||||||
-->
|
-->
|
||||||
|
|
||||||
<!-- WARNING WARNING WARNING: Do NOT reformat this file!
|
<!-- WARNING WARNING WARNING: Do NOT reformat this file!
|
||||||
|
@ -19,7 +19,10 @@
|
||||||
xmlns:exsl="http://exslt.org/common"
|
xmlns:exsl="http://exslt.org/common"
|
||||||
xmlns:adl="http://cygnets.co.uk/schemas/adl-1.2"
|
xmlns:adl="http://cygnets.co.uk/schemas/adl-1.2"
|
||||||
xmlns:msxsl="urn:schemas-microsoft-com:xslt">
|
xmlns:msxsl="urn:schemas-microsoft-com:xslt">
|
||||||
<xsl:output encoding="UTF-8" method="text"/>
|
|
||||||
|
<xsl:include href="csharp-type-include.xslt"/>
|
||||||
|
|
||||||
|
<xsl:output encoding="UTF-8" method="text"/>
|
||||||
|
|
||||||
<!-- The locale for which these entities are generated
|
<!-- The locale for which these entities are generated
|
||||||
TODO: Entities should NOT be locale specific. Instead, the
|
TODO: Entities should NOT be locale specific. Instead, the
|
||||||
|
@ -47,7 +50,7 @@
|
||||||
stored to CVS -->
|
stored to CVS -->
|
||||||
|
|
||||||
<xsl:variable name="transform-rev1"
|
<xsl:variable name="transform-rev1"
|
||||||
select="substring( '$Revision: 1.2 $', 11)"/>
|
select="substring( '$Revision: 1.3 $', 11)"/>
|
||||||
<xsl:variable name="transform-revision"
|
<xsl:variable name="transform-revision"
|
||||||
select="substring( $transform-rev1, 0, string-length( $transform-rev1) - 1)"/>
|
select="substring( $transform-rev1, 0, string-length( $transform-rev1) - 1)"/>
|
||||||
|
|
||||||
|
@ -310,6 +313,7 @@
|
||||||
<!-- when required is 'true' null is not permitted anyway; otherwise... -->
|
<!-- when required is 'true' null is not permitted anyway; otherwise... -->
|
||||||
<xsl:when test="$base-type='entity'"/>
|
<xsl:when test="$base-type='entity'"/>
|
||||||
<xsl:when test="$base-type='string'"/>
|
<xsl:when test="$base-type='string'"/>
|
||||||
|
<xsl:when test="$base-type='text'"/>
|
||||||
<!-- entities and strings are always nullable, don't need decoration -->
|
<!-- entities and strings are always nullable, don't need decoration -->
|
||||||
<xsl:when test="$base-type='list'"/>
|
<xsl:when test="$base-type='list'"/>
|
||||||
<xsl:when test="$base-type='link'"/>
|
<xsl:when test="$base-type='link'"/>
|
||||||
|
@ -352,7 +356,7 @@
|
||||||
private Regex <xsl:value-of select="@name"/>Validator = new Regex( "<xsl:value-of select="$validationpattern"/>");
|
private Regex <xsl:value-of select="@name"/>Validator = new Regex( "<xsl:value-of select="$validationpattern"/>");
|
||||||
</xsl:if>
|
</xsl:if>
|
||||||
|
|
||||||
private <xsl:value-of select="$csharp-type"/><xsl:value-of select="normalize-space( $nullable-decoration)"/> _<xsl:value-of select="@name"/> <xsl:value-of select="$initialiser"/>;
|
private <xsl:value-of select="normalize-space( $csharp-type)"/><xsl:value-of select="normalize-space( $nullable-decoration)"/> _<xsl:value-of select="@name"/> <xsl:value-of select="normalize-space( $initialiser)"/>;
|
||||||
|
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// <xsl:choose>
|
/// <xsl:choose>
|
||||||
|
@ -363,7 +367,7 @@
|
||||||
</xsl:choose><xsl:if test="help[@locale=$locale]">:
|
</xsl:choose><xsl:if test="help[@locale=$locale]">:
|
||||||
/// <xsl:value-of select="normalize-space( help[@locale=$locale])"/></xsl:if>
|
/// <xsl:value-of select="normalize-space( help[@locale=$locale])"/></xsl:if>
|
||||||
/// </summary>
|
/// </summary>
|
||||||
public virtual <xsl:value-of select="$csharp-type"/><xsl:value-of select="normalize-space( $nullable-decoration)"/><xsl:text> </xsl:text> <xsl:value-of select="@name"/>
|
public virtual <xsl:value-of select="normalize-space( $csharp-type)"/><xsl:value-of select="normalize-space( $nullable-decoration)"/><xsl:text> </xsl:text> <xsl:value-of select="@name"/>
|
||||||
{
|
{
|
||||||
get { return _<xsl:value-of select="@name"/>; }
|
get { return _<xsl:value-of select="@name"/>; }
|
||||||
set {
|
set {
|
||||||
|
@ -456,55 +460,4 @@
|
||||||
</xsl:for-each>
|
</xsl:for-each>
|
||||||
</xsl:template>
|
</xsl:template>
|
||||||
|
|
||||||
<!-- return the base ADL type of the property which is passed as a parameter -->
|
|
||||||
<xsl:template name="base-type">
|
|
||||||
<xsl:param name="property"/>
|
|
||||||
<xsl:choose>
|
|
||||||
<xsl:when test="$property/@type='defined'">
|
|
||||||
<xsl:variable name="definition">
|
|
||||||
<xsl:value-of select="$property/@typedef"/>
|
|
||||||
</xsl:variable>
|
|
||||||
<xsl:message terminate="no">
|
|
||||||
Looking for definition of '<xsl:value-of select="$definition"/>';
|
|
||||||
Found to be defined as type '<xsl:value-of select="/adl:application/adl:typedef[@name=$definition]/@type"/>'
|
|
||||||
</xsl:message>
|
|
||||||
<xsl:value-of select="/adl:application/adl:typedef[@name=$definition]/@type"/>
|
|
||||||
</xsl:when>
|
|
||||||
<xsl:otherwise>
|
|
||||||
<xsl:value-of select="$property/@type"/>
|
|
||||||
</xsl:otherwise>
|
|
||||||
</xsl:choose>
|
|
||||||
</xsl:template>
|
|
||||||
|
|
||||||
<!-- return the C# type of the property which is passed as a parameter -->
|
|
||||||
<xsl:template name="csharp-type">
|
|
||||||
<xsl:param name="property"/>
|
|
||||||
<xsl:variable name="base-type">
|
|
||||||
<xsl:call-template name="base-type">
|
|
||||||
<xsl:with-param name="property" select="$property"/>
|
|
||||||
</xsl:call-template>
|
|
||||||
</xsl:variable>
|
|
||||||
<xsl:choose>
|
|
||||||
<xsl:when test="$base-type = 'link'">
|
|
||||||
ICollection<<xsl:value-of select="@entity"/>>
|
|
||||||
</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'list'">
|
|
||||||
ICollection<<xsl:value-of select="@entity"/>>
|
|
||||||
</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'date'">DateTime</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'time'">DateTime</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'string'">String</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'text'">String</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'boolean'">bool</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'timestamp'">DateTime</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'integer'">int</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'real'">double</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'money'">Decimal</xsl:when>
|
|
||||||
<xsl:when test="$base-type = 'entity'">
|
|
||||||
<xsl:value-of select="$property/@entity"/>
|
|
||||||
</xsl:when>
|
|
||||||
<xsl:otherwise>[unknown?]</xsl:otherwise>
|
|
||||||
</xsl:choose>
|
|
||||||
</xsl:template>
|
|
||||||
|
|
||||||
</xsl:stylesheet>
|
</xsl:stylesheet>
|
56
transforms01/csharp-type-include.xslt
Executable file
56
transforms01/csharp-type-include.xslt
Executable file
|
@ -0,0 +1,56 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8" ?>
|
||||||
|
<!--
|
||||||
|
Application Description Language framework
|
||||||
|
csharp-type-include.xslt
|
||||||
|
|
||||||
|
(c) 2007 Cygnet Solutions Ltd
|
||||||
|
|
||||||
|
An XSL transform intended to be included into other XSL stylesheets,
|
||||||
|
intended to keep lookup of the C# type from ADL properties in
|
||||||
|
one place for ease of maintenance
|
||||||
|
|
||||||
|
$Author: sb $
|
||||||
|
$Revision: 1.1 $
|
||||||
|
$Date: 2008-02-01 21:47:15 $
|
||||||
|
-->
|
||||||
|
|
||||||
|
<xsl:stylesheet version="1.0"
|
||||||
|
xmlns="http://cygnets.co.uk/schemas/adl-1.2"
|
||||||
|
xmlns:adl="http://cygnets.co.uk/schemas/adl-1.2"
|
||||||
|
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
|
||||||
|
exclude-result-prefixes="adl">
|
||||||
|
|
||||||
|
<xsl:include href="base-type-include.xslt"/>
|
||||||
|
|
||||||
|
<!-- return the C# type of the property which is passed as a parameter -->
|
||||||
|
<xsl:template name="csharp-type">
|
||||||
|
<xsl:param name="property"/>
|
||||||
|
<xsl:variable name="base-type">
|
||||||
|
<xsl:call-template name="base-type">
|
||||||
|
<xsl:with-param name="property" select="$property"/>
|
||||||
|
</xsl:call-template>
|
||||||
|
</xsl:variable>
|
||||||
|
<xsl:choose>
|
||||||
|
<xsl:when test="$base-type = 'link'">
|
||||||
|
ICollection<<xsl:value-of select="@entity"/>>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'list'">
|
||||||
|
ICollection<<xsl:value-of select="@entity"/>>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'date'">DateTime</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'time'">DateTime</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'string'">String</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'text'">String</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'boolean'">bool</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'timestamp'">DateTime</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'integer'">int</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'real'">double</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'money'">Decimal</xsl:when>
|
||||||
|
<xsl:when test="$base-type = 'entity'">
|
||||||
|
<xsl:value-of select="$property/@entity"/>
|
||||||
|
</xsl:when>
|
||||||
|
<xsl:otherwise>[unknown?]</xsl:otherwise>
|
||||||
|
</xsl:choose>
|
||||||
|
</xsl:template>
|
||||||
|
|
||||||
|
</xsl:stylesheet>
|
Loading…
Reference in a new issue