X-Git-Url: http://git.onelab.eu/?p=sfa.git;a=blobdiff_plain;f=sfatables%2Fxmlrule.py;h=b749147d366a63b32e5aa365c6884802a8cac2e6;hp=d8b30dcf869612377cd76147fd1be53d8dc283ab;hb=HEAD;hpb=f58fc949070f5f17d4dea42aa31b6d72ed6073ec diff --git a/sfatables/xmlrule.py b/sfatables/xmlrule.py index d8b30dcf..b749147d 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("WARNING, could not import libxslt", file=sys.stderr) + +from sfatables.globals import sfatables_config class XMLRule: def apply_processor(self, type, doc, output_xpath_filter=None): @@ -56,8 +61,8 @@ class XMLRule: def add_rule_context_to_rspec(self, doc): p = doc.xpathNewContext() - context = p.xpathEval("//RSpec") - if (not context): + context = p.xpathEval("//*") + if not context or context[0].name not in ['RSpec', 'rspec']: raise Exception('Request is not an rspec') else: # Add the request context @@ -85,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