X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=sfatables%2Fxmlrule.py;h=46f360185153c8703a6a7664fbe501377e781d65;hb=14ca7e52f6af8accc0ba6e362e2a674ea4579e7f;hp=97940de2d1d028d6ff723d13a3017e268919ac13;hpb=9a053166cdb0187d0514403e92e8719d9a3aa8ee;p=sfa.git diff --git a/sfatables/xmlrule.py b/sfatables/xmlrule.py index 97940de2..46f36018 100644 --- a/sfatables/xmlrule.py +++ b/sfatables/xmlrule.py @@ -1,6 +1,11 @@ +import sys,os + import libxml2 -import libxslt -from sfatables.globals import * +# allow to run sfa2wsdl if this is missing (for mac) +try:import libxslt +except: print >>sys.stderr, "WARNING, could not import libxslt" + +from sfatables.globals import sfatables_config class XMLRule: def apply_processor(self, type, doc, output_xpath_filter=None): @@ -10,7 +15,6 @@ class XMLRule: filepath = os.path.join(sfatables_config, 'processors', processor) # XXX - print filepath styledoc = libxml2.parseFile(filepath) style = libxslt.parseStylesheetDoc(styledoc) result = style.applyStylesheet(doc, None) @@ -57,7 +61,7 @@ class XMLRule: def add_rule_context_to_rspec(self, doc): p = doc.xpathNewContext() - context = p.xpathEval("//Rspec") + context = p.xpathEval("//RSpec") if (not context): raise Exception('Request is not an rspec') else: @@ -86,12 +90,12 @@ class XMLRule: # else rspec if (self.match(rspec)): - return self.wrap_up(self.target(rspec)) + return (True,self.wrap_up(self.target(rspec))) else: - return self.wrap_up(rspec) + return (False,self.wrap_up(rspec)) - def apply_compiled(rspec): + def apply_compiled(self, rspec): # Not supported yet return None