From 2d48e6b0911c65ccfb27f82e15376c828f491def Mon Sep 17 00:00:00 2001 From: Hernan Date: Sat, 28 Dec 2019 02:17:36 -0300 Subject: [PATCH] wraps(strict=True) now accept strings as arguments in the wrapper function Closes #711, #723 --- pint/registry_helpers.py | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/pint/registry_helpers.py b/pint/registry_helpers.py index 686c4f626..18089aeec 100644 --- a/pint/registry_helpers.py +++ b/pint/registry_helpers.py @@ -139,13 +139,20 @@ def _converter(ureg, values, strict): ) else: if strict: - raise ValueError( - "A wrapped function using strict=True requires " - "quantity for all arguments with not None units. " - "(error found for {}, {})".format( - args_as_uc[ndx][0], new_values[ndx] + if isinstance(values[ndx], str): + # if the value is a string, we try to parse it + tmp_value = ureg.parse_expression(values[ndx]) + new_values[ndx] = ureg._convert( + tmp_value._magnitude, tmp_value._units, args_as_uc[ndx][0] + ) + else: + raise ValueError( + "A wrapped function using strict=True requires " + "quantity or a string for all arguments with not None units. " + "(error found for {}, {})".format( + args_as_uc[ndx][0], new_values[ndx] + ) ) - ) return new_values, values_by_name