+
+ self.raw_data = None
+ if (self.raw_filename != None) and os.path.exists(self.raw_filename):
+ if hasattr(json, "loads"):
+ self.raw_data = json.loads(open(self.raw_filename,"r").read()) # python 2.6
+ else:
+ self.raw_data = json.read(open(self.raw_filename,"r").read()) # python 2.5
+
+ os.remove(self.raw_filename)
+
+ self.geni_code=None
+ self.geni_output=None
+ if (self.raw_data!=None) and (type(self.raw_data)==dict):
+ code = self.raw_data.get("code",{})
+ self.geni_code = code.get("geni_code",None)
+ self.geni_output = self.raw_data.get("output","")
+
+ if self.save_filename:
+ value = self.raw_data.get("value", None)
+ if value == None:
+ if os.path.exists(self.save_filename):
+ os.remove(self.save_filename)
+ elif type(value) == str:
+ open(self.save_filename, "w").write(value)
+ elif hasattr(json, "dumps"):
+ open(self.save_filename, "w").write(json.dumps(value)) # python 2.6
+ else:
+ open(self.save_filename, "w").write(json.write(value)) # python 2.5
+
+ # extract any faults from the XMLRPC response(s)
+ self.xmlrpcreader.responses = []
+ self.xmlrpcreader.store(self.output)
+ self.xmlrpcreader.extractXml()
+ self.responses = self.xmlrpcreader.responses
+ self.faults = [x for x in self.responses if (x["kind"]=="fault")]
+
+ # if we got a nonzero
+ if (self.geni_code!=None) and (self.geni_code!=0):
+ x = {"kind": "bad_geni_code"}
+ x["faultCode"] = str(self.geni_code)
+ faultString = "Nonzero geni_code: " + str(self.geni_code)
+ if self.geni_output:
+ faultString = faultString + " output: " + str(self.geni_output)
+ x["faultString"] = faultString
+ self.faults.append(x)
+