<c:function
name = identifier
as? = type_name
visibility? = "public" | "private" | "final" | "abstract" | "hidden"
partial? = boolean >
<!-- Content: (c:param*, sequence-constructor) -->
</c:function>
Defines a function.
- Category
- declaration
- Permitted parent elements
c:module
c:override
c:package
Attributes
as |
The return type. Omit this attribute for void functions. |
name |
The name of the function. |
partial |
Specifies if the function should be implemented in another partial declaration. |
visibility |
Specifies how the current component can be used in other (using) packages. |
In addition to the attributes in the preceding table, there are a number of standard attributes that may appear on any XCST element.
Remarks
While c:template
is optimized for content (markup, text), c:function
is optimized for logic. Functions can be called from C# code, because it compiles to a regular method. See the table below for more differences.
feature | c:template |
c:function |
---|---|---|
Implicit output | yes | no |
Invocation method | c:call-template |
C# (e.g. Foo() ) |
Parameter binding | by name | by position |
Tunnel parameters | yes | no |
Because functions don’t have an implicit output, to return a value you need to use the c:return
instruction, or return from code in a c:script
element.
Example: Returning from a c:script
Element
<c:function name='Truncate' as='string'>
<c:param name='s' as='string'/>
<c:param name='maxLength' as='int'/>
<c:param name='suffix'>…</c:param>
<c:script>
<![CDATA[
if (string.IsNullOrEmpty(s)) {
return string.Empty;
}
if (s.Length <= maxLength) {
return s;
}
return string.Concat(s.Substring(0, maxLength - suffix.Length), suffix);
]]>
</c:script>
</c:function>
Example: Returning with c:return
<c:function name='MailBody' as='string'>
<c:param name='contact' as='Contact'/>
<c:return>
<c:serialize method='html'>
<a:model value='contact'>
<dl>
<a:display>
<a:member-template>
<dt>
<a:display-name/>
<c:text>:</c:text>
</dt>
<dd>
<a:display/>
</dd>
</a:member-template>
</a:display>
</dl>
</a:model>
</c:serialize>
</c:return>
</c:function>
Function Parameters
Function parameters have several limitations, due to the fact that they compile to method parameters in C#. Type inference does not work when the value is supplied by the value
attribute (defaults to Object). Default values are limited to constant expressions. The order of parameters is significant. Cannot have a parameter without a default value after one with a default value.
Note: Differences with xsl:function
As explained above, values must be returned explicitly, there’s no implicit output. c:function
parameters have several limitations. c:function
parameters can have default values.
Error Conditions
It is a compilation error if a c:function
declaration has visibility='abstract'
and the content of the element, excluding any c:param
elements, is non-empty.
It is a compilation error if a c:function
declaration has visibility='abstract'
and partial='yes'
.
It is a compilation error if there’s another c:function
declaration in the containing module with the same name and number of parameters.