Skip to content

Commit

Permalink
Take into account several plan lines in context
Browse files Browse the repository at this point in the history
plan_line attribute is reused to store several plan lines separated
by ';'. Long term solution would be to rename it plan_lines and to have
a tuple of plan lines.

For AdaCore#293
  • Loading branch information
enzbang committed Sep 9, 2019
1 parent 45824fe commit 7570918
Showing 1 changed file with 16 additions and 7 deletions.
23 changes: 16 additions & 7 deletions e3/electrolyt/plan.py
Original file line number Diff line number Diff line change
Expand Up @@ -251,31 +251,40 @@ def _add_action(self, name, *args, **kwargs):
if self.ignore_disabled and not self.env.enabled:
return

# ??? sometimes to understand the context it would be better to have
# several lines of plan, e.g. when an action is created by calling
# a function defined in a plan. Include all these lines separated
# by ';'. A better fix would be to change plan_line to plan_lines
# containing a tuple of plan_line.
plan_line = 'unknown filename:unknown lineno'
# Retrieve the plan line
try:
caller_frames = inspect.getouterframes(
frame=inspect.currentframe())
caller_frame = None
caller_frames_in_plan = []
for frame in caller_frames:
if isinstance(frame, tuple): # py2-only
frame_filename = frame[1]
else: # py3-only
frame_filename = frame.filename
if frame_filename.endswith(self.plan.plan_ext):
caller_frame = frame
caller_frames_in_plan.append(frame)
except Exception: # defensive code
# do not crash when inspect frames fails
pass
else:
if caller_frame is None: # defensive code
if not caller_frames_in_plan:
# No information ?
pass
elif isinstance(caller_frame, tuple): # py2-only
plan_line = '{}:{}'.format(caller_frame[1], caller_frame[2])
elif isinstance(caller_frames_in_plan[0], tuple): # py2-only
plan_line = ';'.join((
'{}:{}'.format(caller_frame[1], caller_frame[2])
for caller_frame in caller_frames_in_plan))
else: # py3-only
plan_line = '{}:{}'.format(
caller_frame.filename, caller_frame.lineno)
plan_line = ';'.join((
'{}:{}'.format(
caller_frame.filename, caller_frame.lineno)
for caller_frame in caller_frames_in_plan))

# First create our initial object based on current scope env
result = self.env.copy()
Expand Down

0 comments on commit 7570918

Please sign in to comment.