如何编写可以处理 SequenceType.SINGLE_STRING 或 SequenceType.EMPTY_SEQUENCE 的 Saxon ExtensionFunctionDefinition
How to write a Saxon ExtensionFunctionDefinition which can handle either SequenceType.SINGLE_STRING or SequenceType.EMPTY_SEQUENCE
我写了一个 Saxon HE 扩展函数如下
package com.commander4j.Transformation;
import com.commander4j.util.Utility;
import net.sf.saxon.expr.XPathContext;
import net.sf.saxon.lib.ExtensionFunctionCall;
import net.sf.saxon.lib.ExtensionFunctionDefinition;
import net.sf.saxon.om.Sequence;
import net.sf.saxon.om.StructuredQName;
import net.sf.saxon.trans.XPathException;
import net.sf.saxon.value.SequenceType;
import net.sf.saxon.value.StringValue;
public class XSLT_Ext_trim extends ExtensionFunctionDefinition
{
@Override
public SequenceType[] getArgumentTypes()
{
return new SequenceType[]{SequenceType.SINGLE_STRING};
}
@Override
public StructuredQName getFunctionQName()
{
return new StructuredQName("c4j_XSLT_Ext_trim", "http://com.commander4j.Transformation.XSLT_Ext_trim", "trim");
}
@Override
public SequenceType getResultType(SequenceType[] arg0)
{
return SequenceType.SINGLE_STRING;
}
@Override
public ExtensionFunctionCall makeCallExpression()
{
return new ExtensionFunctionCall() {
@Override
public Sequence call(XPathContext context, Sequence[] arguments) throws XPathException {
String value;
try
{
value = arguments[0].head().getStringValue();
} catch (ClassCastException ex)
{
value = "";
}
String result = Utility.replaceNullStringwithBlank(value);
return StringValue.makeStringValue(result);
}
};
}
}
它可以工作,除非从我的 XSQL select 传递给它的参数是一个空序列。
我能否修改下面的代码,使其接受其中任何一个,如果遇到空序列,则将其视为空字符串?
我已经确定在我的 XSLT select 上使用 string(....) cast 是可行的,但我正在尝试更多地理解 SAXON Java 代码,并且想知道是否对该代码的更改意味着我对该扩展函数的所有调用都将通过一次更改来修复,而不是追查所有对它的调用。
首先声明参数类型,如有必要,声明结果类型,如SequenceType.OPTIONAL_STRING
。
其次,编写代码以处理 arguments[0].head()
returns null.
的情况
我写了一个 Saxon HE 扩展函数如下
package com.commander4j.Transformation;
import com.commander4j.util.Utility;
import net.sf.saxon.expr.XPathContext;
import net.sf.saxon.lib.ExtensionFunctionCall;
import net.sf.saxon.lib.ExtensionFunctionDefinition;
import net.sf.saxon.om.Sequence;
import net.sf.saxon.om.StructuredQName;
import net.sf.saxon.trans.XPathException;
import net.sf.saxon.value.SequenceType;
import net.sf.saxon.value.StringValue;
public class XSLT_Ext_trim extends ExtensionFunctionDefinition
{
@Override
public SequenceType[] getArgumentTypes()
{
return new SequenceType[]{SequenceType.SINGLE_STRING};
}
@Override
public StructuredQName getFunctionQName()
{
return new StructuredQName("c4j_XSLT_Ext_trim", "http://com.commander4j.Transformation.XSLT_Ext_trim", "trim");
}
@Override
public SequenceType getResultType(SequenceType[] arg0)
{
return SequenceType.SINGLE_STRING;
}
@Override
public ExtensionFunctionCall makeCallExpression()
{
return new ExtensionFunctionCall() {
@Override
public Sequence call(XPathContext context, Sequence[] arguments) throws XPathException {
String value;
try
{
value = arguments[0].head().getStringValue();
} catch (ClassCastException ex)
{
value = "";
}
String result = Utility.replaceNullStringwithBlank(value);
return StringValue.makeStringValue(result);
}
};
}
}
它可以工作,除非从我的 XSQL select 传递给它的参数是一个空序列。
我能否修改下面的代码,使其接受其中任何一个,如果遇到空序列,则将其视为空字符串?
我已经确定在我的 XSLT select 上使用 string(....) cast 是可行的,但我正在尝试更多地理解 SAXON Java 代码,并且想知道是否对该代码的更改意味着我对该扩展函数的所有调用都将通过一次更改来修复,而不是追查所有对它的调用。
首先声明参数类型,如有必要,声明结果类型,如SequenceType.OPTIONAL_STRING
。
其次,编写代码以处理 arguments[0].head()
returns null.