From 2b471e12c02d673ddbf2a9759be14b1479ad434d Mon Sep 17 00:00:00 2001 From: Rohan-Salwan Date: Thu, 2 Dec 2021 08:13:42 +0530 Subject: [PATCH] Fix issue250 --- fire/core.py | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/fire/core.py b/fire/core.py index 8ca142c7..50e88d38 100644 --- a/fire/core.py +++ b/fire/core.py @@ -425,6 +425,7 @@ def _Fire(component, args, parsed_flag_args, context, name=None): instance = None remaining_args = args + ExceptionRaisedByUser = None while True: last_component = component initial_args = remaining_args @@ -546,6 +547,11 @@ def _Fire(component, args, parsed_flag_args, context, name=None): component_trace.AddAccessedProperty( component, target, consumed_args, filename, lineno) + if candidate_errors: + error, initial_args = candidate_errors[0] + component_trace.AddError(error, initial_args) + ExceptionRaisedByUser = component_trace + except FireError as error: # Couldn't access member. candidate_errors.append((error, initial_args)) @@ -563,6 +569,8 @@ def _Fire(component, args, parsed_flag_args, context, name=None): candidate_errors.append((error, initial_args)) if not handled and candidate_errors: + if ExceptionRaisedByUser: + return ExceptionRaisedByUser error, initial_args = candidate_errors[0] component_trace.AddError(error, initial_args) return component_trace