X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=manifold%2Fmanifoldresult.py;h=a20c5b03ca082f104215f7878b5cf5dbccc36eb1;hb=71c5af2da6325002d0418468ebe9a1c2036a8549;hp=c99d861eb2666a87e9c93516a9f4e5183f79889f;hpb=57c5bcefb1eac66d1db27db28a0c6d3b3b52a407;p=myslice.git diff --git a/manifold/manifoldresult.py b/manifold/manifoldresult.py index c99d861e..a20c5b03 100644 --- a/manifold/manifoldresult.py +++ b/manifold/manifoldresult.py @@ -5,7 +5,8 @@ def enum(*sequential, **named): ManifoldCode = enum ( SUCCESS=0, SESSION_EXPIRED=1, - OTHERS=2, + NOT_IMPLEMENTED=2, + UNKNOWN_ERROR=3, ) # being a dict this can be used with json.dumps @@ -14,17 +15,43 @@ class ManifoldResult (dict): self['code']=code self['value']=value self['output']=output + self['description'] = '' # Jordan: needed by javascript code def from_json (self, json_string): d=json.dumps(json_string) for k in ['code','value','output']: self[k]=d[k] + # raw accessors + def code (self): return self['code'] + def output (self): return self['output'] + # this returns None if there's a problem, the value otherwise def ok_value (self): if self['code']==ManifoldCode.SUCCESS: return self['value'] + # both data in a single string def error (self): return "code=%s -- %s"%(self['code'],self['output']) + + def __repr__ (self): + result="[[MFresult code=%s"%self['code'] + if self['code']==0: + value=self['value'] + if isinstance(value,list): result += " [value=list with %d elts]"%len(value) + elif isinstance(value,dict): result += " [value=dict with keys %s]"%value.keys() + else: result += " [value=%s: %s]"%(type(value).__name__,value) + else: + result += " [output=%s]"%self['output'] + result += "]]" + return result + +# probably simpler to use a single class and transport the whole result there +# instead of a clumsy set of derived classes +class ManifoldException (Exception): + def __init__ (self, manifold_result): + self.manifold_result=manifold_result + def __repr__ (self): + return "Manifold Exception %s"%(self.manifold_result.error())