mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-11-13 23:17:57 +00:00
f51c82302b
--HG-- rename : content/xslt/src/base/moz.build => dom/xslt/base/moz.build rename : content/xslt/src/base/txCore.h => dom/xslt/base/txCore.h rename : content/xslt/src/base/txDouble.cpp => dom/xslt/base/txDouble.cpp rename : content/xslt/src/base/txErrorObserver.h => dom/xslt/base/txErrorObserver.h rename : content/xslt/src/base/txExpandedNameMap.cpp => dom/xslt/base/txExpandedNameMap.cpp rename : content/xslt/src/base/txExpandedNameMap.h => dom/xslt/base/txExpandedNameMap.h rename : content/xslt/src/base/txList.cpp => dom/xslt/base/txList.cpp rename : content/xslt/src/base/txList.h => dom/xslt/base/txList.h rename : content/xslt/src/base/txLog.h => dom/xslt/base/txLog.h rename : content/xslt/src/base/txNamespaceMap.cpp => dom/xslt/base/txNamespaceMap.cpp rename : content/xslt/src/base/txNamespaceMap.h => dom/xslt/base/txNamespaceMap.h rename : content/xslt/src/base/txOwningArray.h => dom/xslt/base/txOwningArray.h rename : content/xslt/src/base/txStack.h => dom/xslt/base/txStack.h rename : content/xslt/src/base/txStringUtils.h => dom/xslt/base/txStringUtils.h rename : content/xslt/src/base/txURIUtils.cpp => dom/xslt/base/txURIUtils.cpp rename : content/xslt/src/base/txURIUtils.h => dom/xslt/base/txURIUtils.h rename : content/xslt/crashtests/111994.xml => dom/xslt/crashtests/111994.xml rename : content/xslt/crashtests/111994.xsl => dom/xslt/crashtests/111994.xsl rename : content/xslt/crashtests/182460-select.xml => dom/xslt/crashtests/182460-select.xml rename : content/xslt/crashtests/182460-selects.xsl => dom/xslt/crashtests/182460-selects.xsl rename : content/xslt/crashtests/182460-table.xhtml => dom/xslt/crashtests/182460-table.xhtml rename : content/xslt/crashtests/226425.xml => dom/xslt/crashtests/226425.xml rename : content/xslt/crashtests/226425.xsl => dom/xslt/crashtests/226425.xsl rename : content/xslt/crashtests/406106-1.html => dom/xslt/crashtests/406106-1.html rename : content/xslt/crashtests/483444.xml => dom/xslt/crashtests/483444.xml rename : content/xslt/crashtests/485217.xml => dom/xslt/crashtests/485217.xml rename : content/xslt/crashtests/485217.xsl => dom/xslt/crashtests/485217.xsl rename : content/xslt/crashtests/485286.xml => dom/xslt/crashtests/485286.xml rename : content/xslt/crashtests/528300.xml => dom/xslt/crashtests/528300.xml rename : content/xslt/crashtests/528488.xml => dom/xslt/crashtests/528488.xml rename : content/xslt/crashtests/528963.xml => dom/xslt/crashtests/528963.xml rename : content/xslt/crashtests/545927.html => dom/xslt/crashtests/545927.html rename : content/xslt/crashtests/601543.html => dom/xslt/crashtests/601543.html rename : content/xslt/crashtests/602115.html => dom/xslt/crashtests/602115.html rename : content/xslt/crashtests/603844.html => dom/xslt/crashtests/603844.html rename : content/xslt/crashtests/667315.xml => dom/xslt/crashtests/667315.xml rename : content/xslt/crashtests/91332.xml => dom/xslt/crashtests/91332.xml rename : content/xslt/crashtests/91332.xsl => dom/xslt/crashtests/91332.xsl rename : content/xslt/crashtests/crashtests.list => dom/xslt/crashtests/crashtests.list rename : content/xslt/public/moz.build => dom/xslt/moz.build rename : content/xslt/public/nsIDocumentTransformer.h => dom/xslt/nsIDocumentTransformer.h rename : content/xslt/public/nsIXSLTException.idl => dom/xslt/nsIXSLTException.idl rename : content/xslt/public/nsIXSLTProcessor.idl => dom/xslt/nsIXSLTProcessor.idl rename : content/xslt/public/nsIXSLTProcessorPrivate.idl => dom/xslt/nsIXSLTProcessorPrivate.idl rename : content/xslt/tests/XSLTMark/XSLTMark-static.js => dom/xslt/tests/XSLTMark/XSLTMark-static.js rename : content/xslt/tests/XSLTMark/XSLTMark-test.js => dom/xslt/tests/XSLTMark/XSLTMark-test.js rename : content/xslt/tests/XSLTMark/XSLTMark-view.js => dom/xslt/tests/XSLTMark/XSLTMark-view.js rename : content/xslt/tests/XSLTMark/XSLTMark.css => dom/xslt/tests/XSLTMark/XSLTMark.css rename : content/xslt/tests/XSLTMark/XSLTMark.xul => dom/xslt/tests/XSLTMark/XSLTMark.xul rename : content/xslt/tests/buster/DiffDOM.js => dom/xslt/tests/buster/DiffDOM.js rename : content/xslt/tests/buster/DumpDOM.js => dom/xslt/tests/buster/DumpDOM.js rename : content/xslt/tests/buster/ReadMe => dom/xslt/tests/buster/ReadMe rename : content/xslt/tests/buster/buster-files.js => dom/xslt/tests/buster/buster-files.js rename : content/xslt/tests/buster/buster-handlers.js => dom/xslt/tests/buster/buster-handlers.js rename : content/xslt/tests/buster/buster-statics.js => dom/xslt/tests/buster/buster-statics.js rename : content/xslt/tests/buster/buster-test.js => dom/xslt/tests/buster/buster-test.js rename : content/xslt/tests/buster/buster-view.js => dom/xslt/tests/buster/buster-view.js rename : content/xslt/tests/buster/buster.css => dom/xslt/tests/buster/buster.css rename : content/xslt/tests/buster/buster.xul => dom/xslt/tests/buster/buster.xul rename : content/xslt/tests/buster/helper/generate-rdf.pl => dom/xslt/tests/buster/helper/generate-rdf.pl rename : content/xslt/tests/buster/install.js => dom/xslt/tests/buster/install.js rename : content/xslt/tests/buster/jar.mn => dom/xslt/tests/buster/jar.mn rename : content/xslt/tests/buster/moz.build => dom/xslt/tests/buster/moz.build rename : content/xslt/tests/buster/result-inspector.xul => dom/xslt/tests/buster/result-inspector.xul rename : content/xslt/tests/buster/result-view.css => dom/xslt/tests/buster/result-view.css rename : content/xslt/tests/buster/result-view.js => dom/xslt/tests/buster/result-view.js rename : content/xslt/tests/buster/result-view.xul => dom/xslt/tests/buster/result-view.xul rename : content/xslt/tests/buster/xslt-qa-overlay.js => dom/xslt/tests/buster/xslt-qa-overlay.js rename : content/xslt/tests/buster/xslt-qa-overlay.xul => dom/xslt/tests/buster/xslt-qa-overlay.xul rename : content/xslt/tests/mochitest/mochitest.ini => dom/xslt/tests/mochitest/mochitest.ini rename : content/xslt/tests/mochitest/moz.build => dom/xslt/tests/mochitest/moz.build rename : content/xslt/tests/mochitest/test_bug319374.xhtml => dom/xslt/tests/mochitest/test_bug319374.xhtml rename : content/xslt/tests/mochitest/test_bug427060.html => dom/xslt/tests/mochitest/test_bug427060.html rename : content/xslt/tests/mochitest/test_bug440974.html => dom/xslt/tests/mochitest/test_bug440974.html rename : content/xslt/tests/mochitest/test_bug453441.html => dom/xslt/tests/mochitest/test_bug453441.html rename : content/xslt/tests/mochitest/test_bug468208.html => dom/xslt/tests/mochitest/test_bug468208.html rename : content/xslt/tests/mochitest/test_bug511487.html => dom/xslt/tests/mochitest/test_bug511487.html rename : content/xslt/tests/mochitest/test_bug551412.html => dom/xslt/tests/mochitest/test_bug551412.html rename : content/xslt/tests/mochitest/test_bug551654.html => dom/xslt/tests/mochitest/test_bug551654.html rename : content/xslt/tests/mochitest/test_bug566629.html => dom/xslt/tests/mochitest/test_bug566629.html rename : content/xslt/tests/mochitest/test_bug566629.xhtml => dom/xslt/tests/mochitest/test_bug566629.xhtml rename : content/xslt/tests/mochitest/test_bug603159.html => dom/xslt/tests/mochitest/test_bug603159.html rename : content/xslt/tests/mochitest/test_bug616774.html => dom/xslt/tests/mochitest/test_bug616774.html rename : content/xslt/tests/mochitest/test_bug667315.html => dom/xslt/tests/mochitest/test_bug667315.html rename : content/xslt/tests/mochitest/test_exslt_regex.html => dom/xslt/tests/mochitest/test_exslt_regex.html rename : content/xslt/public/txIEXSLTRegExFunctions.idl => dom/xslt/txIEXSLTRegExFunctions.idl rename : content/xslt/public/txIFunctionEvaluationContext.idl => dom/xslt/txIFunctionEvaluationContext.idl rename : content/xslt/public/txINodeSet.idl => dom/xslt/txINodeSet.idl rename : content/xslt/public/txIXPathObject.idl => dom/xslt/txIXPathObject.idl rename : content/xslt/src/xml/moz.build => dom/xslt/xml/moz.build rename : content/xslt/src/xml/txXMLParser.cpp => dom/xslt/xml/txXMLParser.cpp rename : content/xslt/src/xml/txXMLParser.h => dom/xslt/xml/txXMLParser.h rename : content/xslt/src/xml/txXMLUtils.cpp => dom/xslt/xml/txXMLUtils.cpp rename : content/xslt/src/xml/txXMLUtils.h => dom/xslt/xml/txXMLUtils.h rename : content/xslt/src/xpath/XPathEvaluator.cpp => dom/xslt/xpath/XPathEvaluator.cpp rename : content/xslt/src/xpath/XPathEvaluator.h => dom/xslt/xpath/XPathEvaluator.h rename : content/xslt/src/xpath/moz.build => dom/xslt/xpath/moz.build rename : content/xslt/src/xpath/nsXPathExpression.cpp => dom/xslt/xpath/nsXPathExpression.cpp rename : content/xslt/src/xpath/nsXPathExpression.h => dom/xslt/xpath/nsXPathExpression.h rename : content/xslt/src/xpath/nsXPathNSResolver.cpp => dom/xslt/xpath/nsXPathNSResolver.cpp rename : content/xslt/src/xpath/nsXPathNSResolver.h => dom/xslt/xpath/nsXPathNSResolver.h rename : content/xslt/src/xpath/nsXPathResult.cpp => dom/xslt/xpath/nsXPathResult.cpp rename : content/xslt/src/xpath/nsXPathResult.h => dom/xslt/xpath/nsXPathResult.h rename : content/xslt/src/xpath/txBooleanExpr.cpp => dom/xslt/xpath/txBooleanExpr.cpp rename : content/xslt/src/xpath/txBooleanResult.cpp => dom/xslt/xpath/txBooleanResult.cpp rename : content/xslt/src/xpath/txCoreFunctionCall.cpp => dom/xslt/xpath/txCoreFunctionCall.cpp rename : content/xslt/src/xpath/txErrorExpr.cpp => dom/xslt/xpath/txErrorExpr.cpp rename : content/xslt/src/xpath/txExpr.cpp => dom/xslt/xpath/txExpr.cpp rename : content/xslt/src/xpath/txExpr.h => dom/xslt/xpath/txExpr.h rename : content/xslt/src/xpath/txExprLexer.cpp => dom/xslt/xpath/txExprLexer.cpp rename : content/xslt/src/xpath/txExprLexer.h => dom/xslt/xpath/txExprLexer.h rename : content/xslt/src/xpath/txExprParser.cpp => dom/xslt/xpath/txExprParser.cpp rename : content/xslt/src/xpath/txExprParser.h => dom/xslt/xpath/txExprParser.h rename : content/xslt/src/xpath/txExprResult.h => dom/xslt/xpath/txExprResult.h rename : content/xslt/src/xpath/txFilterExpr.cpp => dom/xslt/xpath/txFilterExpr.cpp rename : content/xslt/src/xpath/txForwardContext.cpp => dom/xslt/xpath/txForwardContext.cpp rename : content/xslt/src/xpath/txForwardContext.h => dom/xslt/xpath/txForwardContext.h rename : content/xslt/src/xpath/txFunctionCall.cpp => dom/xslt/xpath/txFunctionCall.cpp rename : content/xslt/src/xpath/txIXPathContext.h => dom/xslt/xpath/txIXPathContext.h rename : content/xslt/src/xpath/txLiteralExpr.cpp => dom/xslt/xpath/txLiteralExpr.cpp rename : content/xslt/src/xpath/txLocationStep.cpp => dom/xslt/xpath/txLocationStep.cpp rename : content/xslt/src/xpath/txMozillaXPathTreeWalker.cpp => dom/xslt/xpath/txMozillaXPathTreeWalker.cpp rename : content/xslt/src/xpath/txNameTest.cpp => dom/xslt/xpath/txNameTest.cpp rename : content/xslt/src/xpath/txNamedAttributeStep.cpp => dom/xslt/xpath/txNamedAttributeStep.cpp rename : content/xslt/src/xpath/txNodeSet.cpp => dom/xslt/xpath/txNodeSet.cpp rename : content/xslt/src/xpath/txNodeSet.h => dom/xslt/xpath/txNodeSet.h rename : content/xslt/src/xpath/txNodeSetAdaptor.cpp => dom/xslt/xpath/txNodeSetAdaptor.cpp rename : content/xslt/src/xpath/txNodeSetAdaptor.h => dom/xslt/xpath/txNodeSetAdaptor.h rename : content/xslt/src/xpath/txNodeSetContext.cpp => dom/xslt/xpath/txNodeSetContext.cpp rename : content/xslt/src/xpath/txNodeSetContext.h => dom/xslt/xpath/txNodeSetContext.h rename : content/xslt/src/xpath/txNodeTypeTest.cpp => dom/xslt/xpath/txNodeTypeTest.cpp rename : content/xslt/src/xpath/txNumberExpr.cpp => dom/xslt/xpath/txNumberExpr.cpp rename : content/xslt/src/xpath/txNumberResult.cpp => dom/xslt/xpath/txNumberResult.cpp rename : content/xslt/src/xpath/txPathExpr.cpp => dom/xslt/xpath/txPathExpr.cpp rename : content/xslt/src/xpath/txPredicateList.cpp => dom/xslt/xpath/txPredicateList.cpp rename : content/xslt/src/xpath/txPredicatedNodeTest.cpp => dom/xslt/xpath/txPredicatedNodeTest.cpp rename : content/xslt/src/xpath/txRelationalExpr.cpp => dom/xslt/xpath/txRelationalExpr.cpp rename : content/xslt/src/xpath/txResultRecycler.cpp => dom/xslt/xpath/txResultRecycler.cpp rename : content/xslt/src/xpath/txResultRecycler.h => dom/xslt/xpath/txResultRecycler.h rename : content/xslt/src/xpath/txRootExpr.cpp => dom/xslt/xpath/txRootExpr.cpp rename : content/xslt/src/xpath/txSingleNodeContext.h => dom/xslt/xpath/txSingleNodeContext.h rename : content/xslt/src/xpath/txStringResult.cpp => dom/xslt/xpath/txStringResult.cpp rename : content/xslt/src/xpath/txUnaryExpr.cpp => dom/xslt/xpath/txUnaryExpr.cpp rename : content/xslt/src/xpath/txUnionExpr.cpp => dom/xslt/xpath/txUnionExpr.cpp rename : content/xslt/src/xpath/txUnionNodeTest.cpp => dom/xslt/xpath/txUnionNodeTest.cpp rename : content/xslt/src/xpath/txVariableRefExpr.cpp => dom/xslt/xpath/txVariableRefExpr.cpp rename : content/xslt/src/xpath/txXPCOMExtensionFunction.cpp => dom/xslt/xpath/txXPCOMExtensionFunction.cpp rename : content/xslt/src/xpath/txXPathNode.h => dom/xslt/xpath/txXPathNode.h rename : content/xslt/src/xpath/txXPathObjectAdaptor.h => dom/xslt/xpath/txXPathObjectAdaptor.h rename : content/xslt/src/xpath/txXPathOptimizer.cpp => dom/xslt/xpath/txXPathOptimizer.cpp rename : content/xslt/src/xpath/txXPathOptimizer.h => dom/xslt/xpath/txXPathOptimizer.h rename : content/xslt/src/xpath/txXPathTreeWalker.h => dom/xslt/xpath/txXPathTreeWalker.h rename : content/xslt/src/xslt/moz.build => dom/xslt/xslt/moz.build rename : content/xslt/src/xslt/txBufferingHandler.cpp => dom/xslt/xslt/txBufferingHandler.cpp rename : content/xslt/src/xslt/txBufferingHandler.h => dom/xslt/xslt/txBufferingHandler.h rename : content/xslt/src/xslt/txCurrentFunctionCall.cpp => dom/xslt/xslt/txCurrentFunctionCall.cpp rename : content/xslt/src/xslt/txDocumentFunctionCall.cpp => dom/xslt/xslt/txDocumentFunctionCall.cpp rename : content/xslt/src/xslt/txEXSLTFunctions.cpp => dom/xslt/xslt/txEXSLTFunctions.cpp rename : content/xslt/src/xslt/txEXSLTRegExFunctions.js => dom/xslt/xslt/txEXSLTRegExFunctions.js rename : content/xslt/src/xslt/txEXSLTRegExFunctions.manifest => dom/xslt/xslt/txEXSLTRegExFunctions.manifest rename : content/xslt/src/xslt/txExecutionState.cpp => dom/xslt/xslt/txExecutionState.cpp rename : content/xslt/src/xslt/txExecutionState.h => dom/xslt/xslt/txExecutionState.h rename : content/xslt/src/xslt/txFormatNumberFunctionCall.cpp => dom/xslt/xslt/txFormatNumberFunctionCall.cpp rename : content/xslt/src/xslt/txGenerateIdFunctionCall.cpp => dom/xslt/xslt/txGenerateIdFunctionCall.cpp rename : content/xslt/src/xslt/txInstructions.cpp => dom/xslt/xslt/txInstructions.cpp rename : content/xslt/src/xslt/txInstructions.h => dom/xslt/xslt/txInstructions.h rename : content/xslt/src/xslt/txKey.h => dom/xslt/xslt/txKey.h rename : content/xslt/src/xslt/txKeyFunctionCall.cpp => dom/xslt/xslt/txKeyFunctionCall.cpp rename : content/xslt/src/xslt/txMozillaStylesheetCompiler.cpp => dom/xslt/xslt/txMozillaStylesheetCompiler.cpp rename : content/xslt/src/xslt/txMozillaTextOutput.cpp => dom/xslt/xslt/txMozillaTextOutput.cpp rename : content/xslt/src/xslt/txMozillaTextOutput.h => dom/xslt/xslt/txMozillaTextOutput.h rename : content/xslt/src/xslt/txMozillaXMLOutput.cpp => dom/xslt/xslt/txMozillaXMLOutput.cpp rename : content/xslt/src/xslt/txMozillaXMLOutput.h => dom/xslt/xslt/txMozillaXMLOutput.h rename : content/xslt/src/xslt/txMozillaXSLTProcessor.cpp => dom/xslt/xslt/txMozillaXSLTProcessor.cpp rename : content/xslt/src/xslt/txMozillaXSLTProcessor.h => dom/xslt/xslt/txMozillaXSLTProcessor.h rename : content/xslt/src/xslt/txNodeSorter.cpp => dom/xslt/xslt/txNodeSorter.cpp rename : content/xslt/src/xslt/txNodeSorter.h => dom/xslt/xslt/txNodeSorter.h rename : content/xslt/src/xslt/txOutputFormat.cpp => dom/xslt/xslt/txOutputFormat.cpp rename : content/xslt/src/xslt/txOutputFormat.h => dom/xslt/xslt/txOutputFormat.h rename : content/xslt/src/xslt/txPatternOptimizer.cpp => dom/xslt/xslt/txPatternOptimizer.cpp rename : content/xslt/src/xslt/txPatternOptimizer.h => dom/xslt/xslt/txPatternOptimizer.h rename : content/xslt/src/xslt/txPatternParser.cpp => dom/xslt/xslt/txPatternParser.cpp rename : content/xslt/src/xslt/txPatternParser.h => dom/xslt/xslt/txPatternParser.h rename : content/xslt/src/xslt/txRtfHandler.cpp => dom/xslt/xslt/txRtfHandler.cpp rename : content/xslt/src/xslt/txRtfHandler.h => dom/xslt/xslt/txRtfHandler.h rename : content/xslt/src/xslt/txStylesheet.cpp => dom/xslt/xslt/txStylesheet.cpp rename : content/xslt/src/xslt/txStylesheet.h => dom/xslt/xslt/txStylesheet.h rename : content/xslt/src/xslt/txStylesheetCompileHandlers.cpp => dom/xslt/xslt/txStylesheetCompileHandlers.cpp rename : content/xslt/src/xslt/txStylesheetCompileHandlers.h => dom/xslt/xslt/txStylesheetCompileHandlers.h rename : content/xslt/src/xslt/txStylesheetCompiler.cpp => dom/xslt/xslt/txStylesheetCompiler.cpp rename : content/xslt/src/xslt/txStylesheetCompiler.h => dom/xslt/xslt/txStylesheetCompiler.h rename : content/xslt/src/xslt/txTextHandler.cpp => dom/xslt/xslt/txTextHandler.cpp rename : content/xslt/src/xslt/txTextHandler.h => dom/xslt/xslt/txTextHandler.h rename : content/xslt/src/xslt/txToplevelItems.cpp => dom/xslt/xslt/txToplevelItems.cpp rename : content/xslt/src/xslt/txToplevelItems.h => dom/xslt/xslt/txToplevelItems.h rename : content/xslt/src/xslt/txUnknownHandler.cpp => dom/xslt/xslt/txUnknownHandler.cpp rename : content/xslt/src/xslt/txUnknownHandler.h => dom/xslt/xslt/txUnknownHandler.h rename : content/xslt/src/xslt/txVariableMap.h => dom/xslt/xslt/txVariableMap.h rename : content/xslt/src/xslt/txXMLEventHandler.h => dom/xslt/xslt/txXMLEventHandler.h rename : content/xslt/src/xslt/txXPathResultComparator.cpp => dom/xslt/xslt/txXPathResultComparator.cpp rename : content/xslt/src/xslt/txXPathResultComparator.h => dom/xslt/xslt/txXPathResultComparator.h rename : content/xslt/src/xslt/txXSLTEnvironmentFunctionCall.cpp => dom/xslt/xslt/txXSLTEnvironmentFunctionCall.cpp rename : content/xslt/src/xslt/txXSLTFunctions.h => dom/xslt/xslt/txXSLTFunctions.h rename : content/xslt/src/xslt/txXSLTNumber.cpp => dom/xslt/xslt/txXSLTNumber.cpp rename : content/xslt/src/xslt/txXSLTNumber.h => dom/xslt/xslt/txXSLTNumber.h rename : content/xslt/src/xslt/txXSLTNumberCounters.cpp => dom/xslt/xslt/txXSLTNumberCounters.cpp rename : content/xslt/src/xslt/txXSLTPatterns.cpp => dom/xslt/xslt/txXSLTPatterns.cpp rename : content/xslt/src/xslt/txXSLTPatterns.h => dom/xslt/xslt/txXSLTPatterns.h rename : content/xslt/src/xslt/txXSLTProcessor.cpp => dom/xslt/xslt/txXSLTProcessor.cpp rename : content/xslt/src/xslt/txXSLTProcessor.h => dom/xslt/xslt/txXSLTProcessor.h extra : rebase_source : 2ffae4527252a6937dd1ee2053d2c9d4fbe268fb
371 lines
10 KiB
C++
371 lines
10 KiB
C++
/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
/* 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/. */
|
|
|
|
/**
|
|
* Lexical analyzer for XPath expressions
|
|
*/
|
|
|
|
#include "txExprLexer.h"
|
|
#include "nsGkAtoms.h"
|
|
#include "nsString.h"
|
|
#include "nsError.h"
|
|
#include "txXMLUtils.h"
|
|
|
|
/**
|
|
* Creates a new ExprLexer
|
|
*/
|
|
txExprLexer::txExprLexer()
|
|
: mCurrentItem(nullptr),
|
|
mFirstItem(nullptr),
|
|
mLastItem(nullptr),
|
|
mTokenCount(0)
|
|
{
|
|
}
|
|
|
|
/**
|
|
* Destroys this instance of an txExprLexer
|
|
*/
|
|
txExprLexer::~txExprLexer()
|
|
{
|
|
//-- delete tokens
|
|
Token* tok = mFirstItem;
|
|
while (tok) {
|
|
Token* temp = tok->mNext;
|
|
delete tok;
|
|
tok = temp;
|
|
}
|
|
mCurrentItem = nullptr;
|
|
}
|
|
|
|
Token*
|
|
txExprLexer::nextToken()
|
|
{
|
|
if (!mCurrentItem) {
|
|
NS_NOTREACHED("nextToken called on uninitialized lexer");
|
|
return nullptr;
|
|
}
|
|
|
|
if (mCurrentItem->mType == Token::END) {
|
|
// Do not progress beyond the end token
|
|
return mCurrentItem;
|
|
}
|
|
|
|
Token* token = mCurrentItem;
|
|
mCurrentItem = mCurrentItem->mNext;
|
|
return token;
|
|
}
|
|
|
|
void
|
|
txExprLexer::addToken(Token* aToken)
|
|
{
|
|
if (mLastItem) {
|
|
mLastItem->mNext = aToken;
|
|
}
|
|
if (!mFirstItem) {
|
|
mFirstItem = aToken;
|
|
mCurrentItem = aToken;
|
|
}
|
|
mLastItem = aToken;
|
|
++mTokenCount;
|
|
}
|
|
|
|
/**
|
|
* Returns true if the following Token should be an operator.
|
|
* This is a helper for the first bullet of [XPath 3.7]
|
|
* Lexical Structure
|
|
*/
|
|
bool
|
|
txExprLexer::nextIsOperatorToken(Token* aToken)
|
|
{
|
|
if (!aToken || aToken->mType == Token::NULL_TOKEN) {
|
|
return false;
|
|
}
|
|
/* This relies on the tokens having the right order in txExprLexer.h */
|
|
return aToken->mType < Token::COMMA ||
|
|
aToken->mType > Token::UNION_OP;
|
|
|
|
}
|
|
|
|
/**
|
|
* Parses the given string into a sequence of Tokens
|
|
*/
|
|
nsresult
|
|
txExprLexer::parse(const nsASingleFragmentString& aPattern)
|
|
{
|
|
iterator start, end;
|
|
start = aPattern.BeginReading(mPosition);
|
|
aPattern.EndReading(end);
|
|
|
|
//-- initialize previous token, this will automatically get
|
|
//-- deleted when it goes out of scope
|
|
Token nullToken(nullptr, nullptr, Token::NULL_TOKEN);
|
|
|
|
Token::Type defType;
|
|
Token* newToken = nullptr;
|
|
Token* prevToken = &nullToken;
|
|
bool isToken;
|
|
|
|
while (mPosition < end) {
|
|
|
|
defType = Token::CNAME;
|
|
isToken = true;
|
|
|
|
if (*mPosition == DOLLAR_SIGN) {
|
|
if (++mPosition == end || !XMLUtils::isLetter(*mPosition)) {
|
|
return NS_ERROR_XPATH_INVALID_VAR_NAME;
|
|
}
|
|
defType = Token::VAR_REFERENCE;
|
|
}
|
|
// just reuse the QName parsing, which will use defType
|
|
// the token to construct
|
|
|
|
if (XMLUtils::isLetter(*mPosition)) {
|
|
// NCName, can get QName or OperatorName;
|
|
// FunctionName, NodeName, and AxisSpecifier may want whitespace,
|
|
// and are dealt with below
|
|
start = mPosition;
|
|
while (++mPosition < end && XMLUtils::isNCNameChar(*mPosition)) {
|
|
/* just go */
|
|
}
|
|
if (mPosition < end && *mPosition == COLON) {
|
|
// try QName or wildcard, might need to step back for axis
|
|
if (++mPosition == end) {
|
|
return NS_ERROR_XPATH_UNEXPECTED_END;
|
|
}
|
|
if (XMLUtils::isLetter(*mPosition)) {
|
|
while (++mPosition < end && XMLUtils::isNCNameChar(*mPosition)) {
|
|
/* just go */
|
|
}
|
|
}
|
|
else if (*mPosition == '*' && defType != Token::VAR_REFERENCE) {
|
|
// eat wildcard for NameTest, bail for var ref at COLON
|
|
++mPosition;
|
|
}
|
|
else {
|
|
--mPosition; // step back
|
|
}
|
|
}
|
|
if (nextIsOperatorToken(prevToken)) {
|
|
nsDependentSubstring op(Substring(start, mPosition));
|
|
if (nsGkAtoms::_and->Equals(op)) {
|
|
defType = Token::AND_OP;
|
|
}
|
|
else if (nsGkAtoms::_or->Equals(op)) {
|
|
defType = Token::OR_OP;
|
|
}
|
|
else if (nsGkAtoms::mod->Equals(op)) {
|
|
defType = Token::MODULUS_OP;
|
|
}
|
|
else if (nsGkAtoms::div->Equals(op)) {
|
|
defType = Token::DIVIDE_OP;
|
|
}
|
|
else {
|
|
// XXX QUESTION: spec is not too precise
|
|
// badops is sure an error, but is bad:ops, too? We say yes!
|
|
return NS_ERROR_XPATH_OPERATOR_EXPECTED;
|
|
}
|
|
}
|
|
newToken = new Token(start, mPosition, defType);
|
|
}
|
|
else if (isXPathDigit(*mPosition)) {
|
|
start = mPosition;
|
|
while (++mPosition < end && isXPathDigit(*mPosition)) {
|
|
/* just go */
|
|
}
|
|
if (mPosition < end && *mPosition == '.') {
|
|
while (++mPosition < end && isXPathDigit(*mPosition)) {
|
|
/* just go */
|
|
}
|
|
}
|
|
newToken = new Token(start, mPosition, Token::NUMBER);
|
|
}
|
|
else {
|
|
switch (*mPosition) {
|
|
//-- ignore whitespace
|
|
case SPACE:
|
|
case TX_TAB:
|
|
case TX_CR:
|
|
case TX_LF:
|
|
++mPosition;
|
|
isToken = false;
|
|
break;
|
|
case S_QUOTE :
|
|
case D_QUOTE :
|
|
start = mPosition;
|
|
while (++mPosition < end && *mPosition != *start) {
|
|
// eat literal
|
|
}
|
|
if (mPosition == end) {
|
|
mPosition = start;
|
|
return NS_ERROR_XPATH_UNCLOSED_LITERAL;
|
|
}
|
|
newToken = new Token(start + 1, mPosition, Token::LITERAL);
|
|
++mPosition;
|
|
break;
|
|
case PERIOD:
|
|
// period can be .., .(DIGITS)+ or ., check next
|
|
if (++mPosition == end) {
|
|
newToken = new Token(mPosition - 1, Token::SELF_NODE);
|
|
}
|
|
else if (isXPathDigit(*mPosition)) {
|
|
start = mPosition - 1;
|
|
while (++mPosition < end && isXPathDigit(*mPosition)) {
|
|
/* just go */
|
|
}
|
|
newToken = new Token(start, mPosition, Token::NUMBER);
|
|
}
|
|
else if (*mPosition == PERIOD) {
|
|
++mPosition;
|
|
newToken = new Token(mPosition - 2, mPosition, Token::PARENT_NODE);
|
|
}
|
|
else {
|
|
newToken = new Token(mPosition - 1, Token::SELF_NODE);
|
|
}
|
|
break;
|
|
case COLON: // QNames are dealt above, must be axis ident
|
|
if (++mPosition >= end || *mPosition != COLON ||
|
|
prevToken->mType != Token::CNAME) {
|
|
return NS_ERROR_XPATH_BAD_COLON;
|
|
}
|
|
prevToken->mType = Token::AXIS_IDENTIFIER;
|
|
++mPosition;
|
|
isToken = false;
|
|
break;
|
|
case FORWARD_SLASH :
|
|
if (++mPosition < end && *mPosition == FORWARD_SLASH) {
|
|
++mPosition;
|
|
newToken = new Token(mPosition - 2, mPosition, Token::ANCESTOR_OP);
|
|
}
|
|
else {
|
|
newToken = new Token(mPosition - 1, Token::PARENT_OP);
|
|
}
|
|
break;
|
|
case BANG : // can only be !=
|
|
if (++mPosition < end && *mPosition == EQUAL) {
|
|
++mPosition;
|
|
newToken = new Token(mPosition - 2, mPosition, Token::NOT_EQUAL_OP);
|
|
break;
|
|
}
|
|
// Error ! is not not()
|
|
return NS_ERROR_XPATH_BAD_BANG;
|
|
case EQUAL:
|
|
newToken = new Token(mPosition, Token::EQUAL_OP);
|
|
++mPosition;
|
|
break;
|
|
case L_ANGLE:
|
|
if (++mPosition == end) {
|
|
return NS_ERROR_XPATH_UNEXPECTED_END;
|
|
}
|
|
if (*mPosition == EQUAL) {
|
|
++mPosition;
|
|
newToken = new Token(mPosition - 2, mPosition,
|
|
Token::LESS_OR_EQUAL_OP);
|
|
}
|
|
else {
|
|
newToken = new Token(mPosition - 1, Token::LESS_THAN_OP);
|
|
}
|
|
break;
|
|
case R_ANGLE:
|
|
if (++mPosition == end) {
|
|
return NS_ERROR_XPATH_UNEXPECTED_END;
|
|
}
|
|
if (*mPosition == EQUAL) {
|
|
++mPosition;
|
|
newToken = new Token(mPosition - 2, mPosition,
|
|
Token::GREATER_OR_EQUAL_OP);
|
|
}
|
|
else {
|
|
newToken = new Token(mPosition - 1, Token::GREATER_THAN_OP);
|
|
}
|
|
break;
|
|
case HYPHEN :
|
|
newToken = new Token(mPosition, Token::SUBTRACTION_OP);
|
|
++mPosition;
|
|
break;
|
|
case ASTERIX:
|
|
if (nextIsOperatorToken(prevToken)) {
|
|
newToken = new Token(mPosition, Token::MULTIPLY_OP);
|
|
}
|
|
else {
|
|
newToken = new Token(mPosition, Token::CNAME);
|
|
}
|
|
++mPosition;
|
|
break;
|
|
case L_PAREN:
|
|
if (prevToken->mType == Token::CNAME) {
|
|
const nsDependentSubstring& val = prevToken->Value();
|
|
if (val.EqualsLiteral("comment")) {
|
|
prevToken->mType = Token::COMMENT_AND_PAREN;
|
|
}
|
|
else if (val.EqualsLiteral("node")) {
|
|
prevToken->mType = Token::NODE_AND_PAREN;
|
|
}
|
|
else if (val.EqualsLiteral("processing-instruction")) {
|
|
prevToken->mType = Token::PROC_INST_AND_PAREN;
|
|
}
|
|
else if (val.EqualsLiteral("text")) {
|
|
prevToken->mType = Token::TEXT_AND_PAREN;
|
|
}
|
|
else {
|
|
prevToken->mType = Token::FUNCTION_NAME_AND_PAREN;
|
|
}
|
|
isToken = false;
|
|
}
|
|
else {
|
|
newToken = new Token(mPosition, Token::L_PAREN);
|
|
}
|
|
++mPosition;
|
|
break;
|
|
case R_PAREN:
|
|
newToken = new Token(mPosition, Token::R_PAREN);
|
|
++mPosition;
|
|
break;
|
|
case L_BRACKET:
|
|
newToken = new Token(mPosition, Token::L_BRACKET);
|
|
++mPosition;
|
|
break;
|
|
case R_BRACKET:
|
|
newToken = new Token(mPosition, Token::R_BRACKET);
|
|
++mPosition;
|
|
break;
|
|
case COMMA:
|
|
newToken = new Token(mPosition, Token::COMMA);
|
|
++mPosition;
|
|
break;
|
|
case AT_SIGN :
|
|
newToken = new Token(mPosition, Token::AT_SIGN);
|
|
++mPosition;
|
|
break;
|
|
case PLUS:
|
|
newToken = new Token(mPosition, Token::ADDITION_OP);
|
|
++mPosition;
|
|
break;
|
|
case VERT_BAR:
|
|
newToken = new Token(mPosition, Token::UNION_OP);
|
|
++mPosition;
|
|
break;
|
|
default:
|
|
// Error, don't grok character :-(
|
|
return NS_ERROR_XPATH_ILLEGAL_CHAR;
|
|
}
|
|
}
|
|
if (isToken) {
|
|
NS_ENSURE_TRUE(newToken, NS_ERROR_OUT_OF_MEMORY);
|
|
NS_ENSURE_TRUE(newToken != mLastItem, NS_ERROR_FAILURE);
|
|
prevToken = newToken;
|
|
addToken(newToken);
|
|
}
|
|
}
|
|
|
|
// add a endToken to the list
|
|
newToken = new Token(end, end, Token::END);
|
|
if (!newToken) {
|
|
return NS_ERROR_OUT_OF_MEMORY;
|
|
}
|
|
addToken(newToken);
|
|
|
|
return NS_OK;
|
|
}
|