net.sf.saxon.query.XQueryFunctionBinder Maven / Gradle / Ivy
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// Copyright (c) 2018-2023 Saxonica Limited
// This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
// If a copy of the MPL was not distributed with this file, You can obtain one at http://mozilla.org/MPL/2.0/.
// This Source Code Form is "Incompatible With Secondary Licenses", as defined by the Mozilla Public License, v. 2.0.
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
package net.sf.saxon.query;
import net.sf.saxon.expr.UserFunctionCall;
import net.sf.saxon.functions.FunctionLibrary;
import net.sf.saxon.om.StructuredQName;
import java.util.List;
/**
* XQueryFunctionBinder is an extension of the FunctionLibrary interface used for function libraries
* that contain user-written XQuery functions. It provides a method that allows the XQueryFunction
* with a given name and arity to be located.
*/
public interface XQueryFunctionBinder extends FunctionLibrary {
/**
* Get the function declaration corresponding to a given function name and arity
*
* @param functionName the name of the function as a QName
* @param staticArgs the number of expressions supplied as arguments in the function call
* @return the XQueryFunction if there is one, or null if not.
*/
/*@Nullable*/
XQueryFunction getDeclaration(StructuredQName functionName, int staticArgs);
/**
* Bind a function call using this XQuery function library, in the situation where
* it was not possible to bind it earlier, typically because it was encountered as a forwards
* reference.
* @param call The unbound function call, which will include a non-null UnboundFunctionCallDetails
* @param reasons a list which can be populated with messages indicating why binding failed
* @return true if the function call is now bound; false if it remains unbound.
*/
boolean bindUnboundFunctionCall(UserFunctionCall call, List reasons);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy