From 112b51477417a6921c610df5643db0a44d2bc862 Mon Sep 17 00:00:00 2001 From: Jason Singer Date: Wed, 1 Nov 2023 11:45:11 -0700 Subject: [PATCH] return flat list from derived object's formulate() (#629) The StdinDataRedirection command object was returning a list inside a list, which caused trouble when getting the "str()" of the command. Example: Python 3.10.8 (tags/v3.10.8:aaaf517, Oct 11 2022, 16:50:30) [MSC v.1933 64 bit (AMD64)] on win32 Type "help", "copyright", "credits" or "license" for more information. >>> from plumbum.cmd import head >>> cmd = head['-2'] << "one\ntwo\nthree\nfour" >>> print(f"{cmd}") Traceback (most recent call last): File "", line 1, in File "C:\Python310\lib\site-packages\plumbum\commands\base.py", line 66, in __str__ return " ".join(self.formulate()) TypeError: sequence item 2: expected str instance, list found >>> Co-authored-by: Jason Singer (js731079) --- plumbum/commands/base.py | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/plumbum/commands/base.py b/plumbum/commands/base.py index 3172c526e..03d74d7c9 100644 --- a/plumbum/commands/base.py +++ b/plumbum/commands/base.py @@ -533,9 +533,8 @@ def _get_encoding(self): def formulate(self, level=0, args=()): return [ f"echo {shquote(self.data)}", - "|", - self.cmd.formulate(level + 1, args), - ] + "|" + ] + self.cmd.formulate(level + 1, args), @property def machine(self):