X-Git-Url: http://git.onelab.eu/?p=sface.git;a=blobdiff_plain;f=sface%2Fxmlrpcwindow.py;h=ae8b6d15707bae1d5b4a0ea5cec63c8f0e596782;hp=72b0f68980f5288d261709482fe419b95d7cedf7;hb=18d18184d52738060acf301261c9d7412936ffc2;hpb=3f712fe77f9809d493ecd7c0aec9ec1005254c3c diff --git a/sface/xmlrpcwindow.py b/sface/xmlrpcwindow.py index 72b0f68..ae8b6d1 100644 --- a/sface/xmlrpcwindow.py +++ b/sface/xmlrpcwindow.py @@ -1,4 +1,5 @@ import re +import xmlrpclib from lxml import etree from PyQt4.QtXml import QDomDocument from sface.xmlwidget import XmlWindow, DomModel, XmlView, XmlDelegate, ElemNodeDelegate, TextNodeDelegate, CommentNodeDelegate @@ -15,39 +16,6 @@ class XmlrpcReader(): def store(self, rawOutput): self.rawOutput = rawOutput - def paramString(self, item): - """ - Convert an xmlrpc into a human-readable string - Is there an easier way? - """ - if item.tag == "string": - return item.text - elif item.tag == "array": - arrayValues = item.xpath("data/value") - if arrayValues: - children = list(arrayValues[0]) - if children: - return self.paramString(children[0]) + ", ..." - else: - return "[]" - else: - return "[]" - elif item.tag == "struct": - dict = {} - members = item.xpath("member") - for member in members: - names = member.xpath("name") - values = member.xpath("value") - if (names) and (values): - name = names[0] - value = values[0] - if len(list(value))>0: - data = list(value)[0] - dict[name.text] = self.paramString(list(value)[0]) - return str(dict) - else: - return "unknown" - def parseMethodCall(self, mc): mc = str(mc) @@ -61,20 +29,14 @@ class XmlrpcReader(): if tree.tag != "methodCall" or (len(list(tree))==0): return request - methodNames = tree.xpath("//methodCall/methodName") - - if len(methodNames) == 0: - return request - - request["args"] = [] - - params = tree.xpath("//methodCall/params/param/value") - for param in params: - children = list(param) - if children: - request["args"].append(self.paramString(children[0])) + try: + (pythonParams, methodName) = xmlrpclib.loads(etree.tostring(tree)) + except: # in case something went wrong when unmarashaling... + pythonParams = [] + methodName = "" - request["methodName"] = methodNames[0].text + request["args"] = [str(x) for x in pythonParams] + request["methodName"] = methodName return request @@ -215,8 +177,8 @@ class XmlrpcTracker(QWidget): def updateCallTable(self): self.callTable.clear() - self.callTable.setColumnCount(2) - self.callTable.setHorizontalHeaderLabels(["name", "status"]) + self.callTable.setColumnCount(3) + self.callTable.setHorizontalHeaderLabels(["name", "status", "faultString"]) calls = self.reader.calls self.callTable.setRowCount(len(calls)) @@ -235,6 +197,11 @@ class XmlrpcTracker(QWidget): item.setData(Qt.UserRole, index) self.callTable.setItem(row, 1, item) + item = QTableWidgetItem(call.get("faultString", "")) + item.setFlags(Qt.ItemIsSelectable | Qt.ItemIsEnabled) + item.setData(Qt.UserRole, index) + self.callTable.setItem(row, 2, item) + row = row + 1 self.callTable.resizeColumnsToContents()