2016-08-03 10:59:49 +00:00
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
// <copyright file="QilFunction.cs" company="Microsoft">
|
|
|
|
// Copyright (c) Microsoft Corporation. All rights reserved.
|
|
|
|
// </copyright>
|
2017-08-21 15:34:15 +00:00
|
|
|
// <owner current="true" primary="true">Microsoft</owner>
|
2016-08-03 10:59:49 +00:00
|
|
|
//------------------------------------------------------------------------------
|
|
|
|
using System;
|
|
|
|
using System.Collections.Generic;
|
|
|
|
using System.Diagnostics;
|
|
|
|
|
|
|
|
namespace System.Xml.Xsl.Qil {
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// An anonymous QilExpression function node.
|
|
|
|
/// </summary>
|
|
|
|
/// <remarks>
|
|
|
|
/// <para>Function is a block, so it may introduce assignments (scoped to the function body).
|
|
|
|
/// Additionally, it has an argument list, which will be assigned values
|
|
|
|
/// when the function is invoked.</para>
|
|
|
|
/// <para>The XmlType property defines the expected return type of this function.
|
|
|
|
/// Normally, this should be the same as its definition's types, so setting the function
|
|
|
|
/// definition changes the function's types. In some rare cases, a compiler may wish to
|
|
|
|
/// override the types after setting the function's definition (for example, an XQuery
|
|
|
|
/// might define a function's return type to be wider than its definition would imply.)</para>
|
|
|
|
/// </remarks>
|
|
|
|
internal class QilFunction : QilReference {
|
|
|
|
private QilNode arguments, definition, sideEffects;
|
|
|
|
|
|
|
|
//-----------------------------------------------
|
|
|
|
// Constructor
|
|
|
|
//-----------------------------------------------
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Construct a node
|
|
|
|
/// </summary>
|
|
|
|
public QilFunction(QilNodeType nodeType, QilNode arguments, QilNode definition, QilNode sideEffects, XmlQueryType resultType)
|
|
|
|
: base(nodeType) {
|
|
|
|
this.arguments = arguments;
|
|
|
|
this.definition = definition;
|
|
|
|
this.sideEffects = sideEffects;
|
|
|
|
this.xmlType = resultType;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-----------------------------------------------
|
|
|
|
// IList<QilNode> methods -- override
|
|
|
|
//-----------------------------------------------
|
|
|
|
|
|
|
|
public override int Count {
|
|
|
|
get { return 3; }
|
|
|
|
}
|
|
|
|
|
|
|
|
public override QilNode this[int index] {
|
|
|
|
get {
|
|
|
|
switch (index) {
|
|
|
|
case 0: return this.arguments;
|
|
|
|
case 1: return this.definition;
|
|
|
|
case 2: return this.sideEffects;
|
|
|
|
default: throw new IndexOutOfRangeException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
set {
|
|
|
|
switch (index) {
|
|
|
|
case 0: this.arguments = value; break;
|
|
|
|
case 1: this.definition = value; break;
|
|
|
|
case 2: this.sideEffects = value; break;
|
|
|
|
default: throw new IndexOutOfRangeException();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
//-----------------------------------------------
|
|
|
|
// QilFunction methods
|
|
|
|
//-----------------------------------------------
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Formal arguments of this function.
|
|
|
|
/// </summary>
|
|
|
|
public QilList Arguments {
|
|
|
|
get { return (QilList) this.arguments; }
|
|
|
|
set { this.arguments = value; }
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Body of this function.
|
|
|
|
/// </summary>
|
|
|
|
public QilNode Definition {
|
|
|
|
get { return this.definition; }
|
|
|
|
set { this.definition = value; }
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// QilNodeType.True if this function might have side-effects.
|
|
|
|
/// </summary>
|
|
|
|
public bool MaybeSideEffects {
|
|
|
|
get { return this.sideEffects.NodeType == QilNodeType.True; }
|
|
|
|
set { this.sideEffects.NodeType = value ? QilNodeType.True : QilNodeType.False; }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|