From 4f335ed1eba63d8628f1fe406abffe046ff71653 Mon Sep 17 00:00:00 2001 From: Marcelo Saguas Iacovone Date: Sat, 17 Feb 2024 10:37:53 -0800 Subject: [PATCH] Implements a different approach for __repr__ --- cmdx.py | 85 +++++++++++++++++++++++++++++++------------------------- tests.py | 3 +- 2 files changed, 49 insertions(+), 39 deletions(-) diff --git a/cmdx.py b/cmdx.py index d592474..64f00d6 100644 --- a/cmdx.py +++ b/cmdx.py @@ -511,7 +511,7 @@ class Node(object): >>> transform = createNode("transform") >>> transform["tx"] = 5 >>> transform["worldMatrix"][0] >> decompose["inputMatrix"] - >>> decompose["outputTranslate"] + >>> decompose["outputTranslate"].read() (5.0, 0.0, 0.0) """ @@ -548,7 +548,8 @@ def __str__(self): return self.name(namespace=True) def __repr__(self): - return self.name(namespace=True) + cls_name = '{}.{}'.format(__name__, self.__class__.__name__) + return "<{} : '{}'>".format(cls_name, self.name(namespace=True)) def __add__(self, other): """Support legacy + '.attr' behavior @@ -578,7 +579,7 @@ def __getitem__(self, key): Example: >>> node = createNode("transform") >>> node["translate"] = (1, 1, 1) - >>> node["translate", Meters] + >>> node["translate", Meters].read() (0.01, 0.01, 0.01) """ @@ -624,7 +625,7 @@ def __setitem__(self, key, value): True >>> node["rotateX", Degrees] = 1.0 >>> node["rotateX"] = Degrees(1) - >>> node["rotateX", Degrees] + >>> node["rotateX", Degrees].read() 1.0 >>> node["myDist"] = Distance() >>> node["myDist"] = node["translateX"] @@ -980,7 +981,7 @@ def update(self, attrs): Examples: >>> node = createNode("transform") >>> node.update({"tx": 5.0, ("ry", Degrees): 30.0}) - >>> node["tx"] + >>> node["tx"].read() 5.0 """ @@ -998,14 +999,14 @@ def clear(self): Example: >>> node = createNode("transform") >>> node["translateX"] = 5 - >>> node["translateX"] + >>> node["translateX"].read() 5.0 >>> # Plug was reused - >>> node["translateX"] + >>> node["translateX"].read() 5.0 >>> # Value was reused >>> node.clear() - >>> node["translateX"] + >>> node["translateX"].read() 5.0 >>> # Plug and value was recomputed @@ -1513,7 +1514,8 @@ def __str__(self): return self.path() def __repr__(self): - return self.path() + cls_name = '{}.{}'.format(__name__, self.__class__.__name__) + return "<{} : '{}'>".format(cls_name, self.path()) def __or__(self, other): """Syntax sugar for finding a child @@ -1522,13 +1524,13 @@ def __or__(self, other): >>> _new() >>> parent = createNode("transform", "parent") >>> child = createNode("transform", "child", parent) - >>> parent | "child" - |parent|child + >>> (parent | "child").path() + '|parent|child' # Stackable too >>> grand = createNode("transform", "grand", child) - >>> parent | "child" | "grand" - |parent|child|grand + >>> (parent | "child" | "grand").path() + '|parent|child|grand' """ @@ -2301,8 +2303,8 @@ def flatten(self, type=None): >>> cc = cmds.sets([gc, b], name="child") >>> parent = cmds.sets([cc, c], name="parent") >>> mainset = encode(parent) - >>> sorted(mainset.flatten(), key=lambda n: n.name()) - [|a, |b, |c] + >>> sorted([n.path() for n in mainset.flatten()]) + ['|a', '|b', '|c'] """ @@ -2560,9 +2562,9 @@ def __add__(self, other): Example: >>> node = createNode("transform") >>> node["tx"] = 5 - >>> node["translate"] + "X" + >>> (node["translate"] + "X").read() 5.0 - >>> node["t"] + "x" + >>> (node["t"] + "x").read() 5.0 >>> try: ... node["t"] + node["r"] @@ -2597,11 +2599,11 @@ def __iadd__(self, other): >>> node["myArray"].extend([2.0, 3.0]) >>> node["myArray"] += 5.1 >>> node["myArray"] += [1.1, 2.3, 999.0] - >>> node["myArray"][0] + >>> node["myArray"][0].read() 1.0 - >>> node["myArray"][6] + >>> node["myArray"][6].read() 999.0 - >>> node["myArray"][-1] + >>> node["myArray"][-1].read() 999.0 """ @@ -2627,7 +2629,13 @@ def __str__(self): return str(self.read()) def __repr__(self): - return str(self.read()) + cls_name = '{}.{}'.format(__name__, self.__class__.__name__) + read_val = self.read() + if isinstance(read_val, string_types): + # Add surrounding single quotes, indicating the value is a string + read_val = "'{}'".format(read_val) + + return "<{} : {}>".format(cls_name, read_val) def __rshift__(self, other): """Support connecting attributes via A >> B""" @@ -2798,7 +2806,7 @@ def __setitem__(self, index, value): Example: >>> node = createNode("transform") >>> node["translate"][0] = 5 - >>> node["tx"] + >>> node["tx"].read() 5.0 """ @@ -3173,9 +3181,9 @@ def extend(self, values): >>> node = createNode("transform") >>> node["myArray"] = Double(array=True) >>> node["myArray"].extend([1.0, 2.0, 3.0]) - >>> node["myArray"][0] + >>> node["myArray"][0].read() 1.0 - >>> node["myArray"][-1] + >>> node["myArray"][-1].read() 3.0 """ @@ -4101,7 +4109,7 @@ def connections(self, True >>> b["ihi"].connection() == a True - >>> a["ihi"] + >>> a["ihi"].read() 2 >>> b["arrayAttr"] = Long(array=True) >>> b["arrayAttr"][0] >> a["ihi"] @@ -6350,16 +6358,16 @@ def connect(self, src, dst, force=True): >>> with DagModifier() as mod: ... mod.connect(tm["sx"], tm["tx"]) ... - >>> tm["tx"].connection() - |myTransform + >>> tm["tx"].connection().path() + '|myTransform' >>> cmds.undo() >>> tm["tx"].connection() is None True # Connect without undo >>> tm["tx"] << tx["output"] - >>> tm["tx"].connection() - myAnimCurve + >>> tm["tx"].connection().name() + 'myAnimCurve' # Disconnect without undo >>> tm["tx"] // tx["output"] @@ -6444,12 +6452,12 @@ def connectAttr(self, srcPlug, dstNode, dstAttr): ... otherAttr = mod.addAttr(otherNode, Message("otherAttr")) ... mod.connectAttr(newNode["newAttr"], otherNode, otherAttr) ... - >>> newNode["newAttr"].connection() - |otherNode + >>> newNode["newAttr"].connection().path() + '|otherNode' >>> cmds.undo() - >>> newNode["newAttr"].connection() - |newNode + >>> newNode["newAttr"].connection().path() + '|newNode' """ @@ -6768,9 +6776,9 @@ class DagModifier(_BaseModifier): ... >>> getAttr(node1 + ".translateX") 1.0 - >>> node2["translate"][0] + >>> node2["translate"][0].read() 1.0 - >>> node2["translate"][1] + >>> node2["translate"][1].read() 2.0 >>> with DagModifier() as mod: ... node1 = mod.createNode("transform") @@ -6778,9 +6786,9 @@ class DagModifier(_BaseModifier): ... node1["translate"] = (5, 6, 7) ... node1["translate"] >> node2["translate"] ... - >>> node2["translate"][0] + >>> node2["translate"][0].read() 5.0 - >>> node2["translate"][1] + >>> node2["translate"][1].read() 6.0 Example, without context manager: @@ -7721,7 +7729,8 @@ def __hash__(self): def __repr__(self): """Avoid repr depicting the full contents of this dict""" - return self["name"] + cls_name = '{}.{}'.format(__name__, self.__class__.__name__) + return "<{} : '{}'>".format(cls_name, self["name"]) def __new__(cls, *args, **kwargs): """Support for using name of assignment diff --git a/tests.py b/tests.py index 73ccac6..7f7834f 100644 --- a/tests.py +++ b/tests.py @@ -383,8 +383,9 @@ def test_nodeoperators(): node = cmdx.createNode(cmdx.tTransform, name="myNode") assert_equals(node, "|myNode") + assert_equals(repr(node), "") assert_not_equals(node, "|NotEquals") - assert_equals(str(node), repr(node)) + assert_not_equals(str(node), repr(node)) @with_setup(new_scene)