0

我刚开始学习字符串模板,我遇到了这里显示的示例:

group simple;
vardef(type,name) ::= "<type> <name>;"

method(type,name,args) ::= <<
  <type> <name>(<args; separator=",">) {
      <statements; separator="\n">
  }
>>

我想要做的是将一个字符串模板作为参数传递给方法字符串模板,如下所示:

statements(function, arguments) ::= <<
    <function>(<arguments; separator=",">);
>>

 method(type,name,args, <statements> ) ::= <<
     <type> <name>(<args; separator=",">) {
     <statements; separator="\n">
  }
>>

然而这并没有成功,所以我猜测它不可能将字符串模板传递给字符串模板?那么语句是如何填充的呢?

尝试此操作时出现以下错误:

mytemplate.stg 14:26: invalid character '<'
mytemplate.stg 14:36: invalid character '>'
4

1 回答 1

2

我将 stringtemplate 4 与 C# 一起使用,并且在创建通用“定界”模板时遇到了同样的问题,该模板将接受集合、每个项目上的映射操作(匿名模板)和定界符(也是匿名模板)作为参数)。模板参数工作,但我无法让参数传递机制工作;相反,我不得不依赖动态范围和调用者上下文中存在的名为 item 的变量。

NormalGet(schema, table) ::= <<
CREATE PROCEDURE [<schema.Name>].[Get<table.Name>] 
    <Delimit(items = table.Cols, itemTransformer = {@<item.Name> <item.ListType> readonly},     delimiter = ",\n")>
AS
BEGIN
END
>>

和定界:

Delimit(items, itemTransformer, delimiter) ::= <<
<trunc(items): { item | <itemTransformer><delimiter>} ><last(items): { item |<itemTransformer> } >
>>

给了我类似的东西:

CREATE PROCEDURE [data].[GetCluster] 
    @idCluster common.intList readonly,
    @Name common.varcharList readonly,
    @Category common.varcharList readonly,
    @DisplayOrder common.intList readonly,
    @IsEditable common.bitList readonly 
AS
BEGIN
END

我想做的是将我对 Delimit 的调用替换为以下内容:

    <Delimit(items = table.Cols, itemTransformer = {col | @<col.Name> <col.ListType> readonly},     delimiter = ",\n")>

但我无法计算出它的语法,或者它是否可能。

于 2013-08-28T23:15:31.500 回答