net.sf.saxon.instruct.SlotManager Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of saxon9 Show documentation
Show all versions of saxon9 Show documentation
Provides a basic XSLT 2.0 and XQuery 1.0 processor (W3C Recommendations,
January 2007). Command line interfaces and implementations of several
Java APIs (DOM, XPath, s9api) are also included.
The newest version!
package net.sf.saxon.instruct;
import net.sf.saxon.om.StructuredQName;
import java.io.Serializable;
import java.util.List;
import java.util.ArrayList;
/**
* A SlotManager supports functions, templates, etc: specifically, any executable code that
* requires a stack frame containing local variables. In XSLT a SlotManager underpins any
* top-level element that can contain local variable declarations,
* specifically, a top-level xsl:template, xsl:variable, xsl:param, or xsl:function element
* or an xsl:attribute-set element or xsl:key element. In XQuery it underpins functions and
* global variables. The purpose of the SlotManager is to allocate slot numbers to variables
* in the stack, and to record how many slots are needed. A Debugger may define a subclass
* with additional functionality.
*/
public class SlotManager implements Serializable {
/**
* An empty SlotManager
*/
public static SlotManager EMPTY = new SlotManager(0);
private ArrayList variableMap = new ArrayList(10);
// values are StructuredQName objects representing the variable names
private int numberOfVariables = 0;
/**
* The constructor should not be called directly. A new SlotManager should be obtained using
* the factory method {@link net.sf.saxon.Configuration#makeSlotManager()}.
*/
public SlotManager(){}
/**
* Create a SlotManager with a given number of slots
*/
public SlotManager(int n) {
numberOfVariables = n;
variableMap = new ArrayList(n);
}
/**
* Get number of variables (size of stack frame)
*/
public int getNumberOfVariables() {
return numberOfVariables;
}
/**
* Set the number of variables
* @param numberOfVariables
*/
public void setNumberOfVariables(int numberOfVariables) {
this.numberOfVariables = numberOfVariables;
variableMap.trimToSize();
}
/**
* Allocate a slot number for a variable
*/
public int allocateSlotNumber(StructuredQName qName) {
variableMap.add(qName);
return numberOfVariables++;
}
/**
* Get the variable map (simply a list of variable names as structured QNames). Note that it
* is possible for several variables to have the same name.
* Changed in Saxon 9.0 to return a list of StructuredQName values rather than integers
*/
public List getVariableMap() {
return variableMap;
}
}
//
// The contents of this file are subject to the Mozilla Public License Version 1.0 (the "License");
// you may not use this file except in compliance with the License. You may obtain a copy of the
// License at http://www.mozilla.org/MPL/
//
// Software distributed under the License is distributed on an "AS IS" basis,
// WITHOUT WARRANTY OF ANY KIND, either express or implied.
// See the License for the specific language governing rights and limitations under the License.
//
// The Original Code is: all this file.
//
// The Initial Developer of the Original Code is Michael H. Kay.
//
// Portions created by (your name) are Copyright (C) (your legal entity). All Rights Reserved.
//
// Contributor(s): none.
//
© 2015 - 2025 Weber Informatics LLC | Privacy Policy