| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- //
- // Mono.Xml.XPath.Pattern
- //
- // Author:
- // Ben Maurer ([email protected])
- //
- // (C) 2003 Ben Maurer
- //
- using System;
- using System.Collections;
- using System.IO;
- using System.Xml;
- using System.Xml.Schema;
- using System.Xml.XPath;
- using System.Xml.Xsl;
- using Mono.Xml.Xsl;
- namespace Mono.Xml.XPath {
- public abstract class Pattern {
-
- internal static Pattern Compile (string s, Compiler comp)
- {
- return Compile (comp.parser.Compile (s));
- }
-
- internal static Pattern Compile (Expression e)
- {
- if (e is ExprUNION)
- return new UnionPattern (
- Compile (((ExprUNION)e).left),
- Compile (((ExprUNION)e).right)
- );
-
- if (e is ExprRoot)
- return new LocationPathPattern (
- new NodeTypeTest (Axes.Self, XPathNodeType.Root)
- );
-
- if (e is NodeTest)
- return new LocationPathPattern (
- (NodeTest)e
- );
-
- if (e is ExprFilter)
- return new LocationPathPattern (
- (ExprFilter)e
- );
-
- if (e is ExprSLASH)
- {
- Pattern p0 = Compile (((ExprSLASH)e).left);
- LocationPathPattern p1
- = (LocationPathPattern)Compile (((ExprSLASH)e).right);
-
- p1.SetPreviousPattern (p0, false);
- return p1;
- }
-
- if (e is ExprSLASH2)
- {
- if (((ExprSLASH2)e).right is ExprRoot)
- return Compile (((ExprSLASH2)e).left);
-
- Pattern p0 = Compile (((ExprSLASH2)e).left);
- LocationPathPattern p1
- = (LocationPathPattern)Compile (((ExprSLASH2)e).right);
-
- p1.SetPreviousPattern (p0, true);
- return p1;
- }
-
- // TODO: Handle ID/KEY
-
- throw new Exception ("Invalid Pattern");
- }
-
- public virtual double DefaultPriority { get { return 0.5; }}
-
- public abstract bool Matches (XPathNavigator node, XsltContext ctx);
- }
- }
|