Skip to content

Commit

Permalink
Fix prying functions with only literals, closes elixir-lang#13133
Browse files Browse the repository at this point in the history
  • Loading branch information
josevalim committed Nov 23, 2023
1 parent 1ef9eaf commit 9daef61
Showing 1 changed file with 5 additions and 3 deletions.
8 changes: 5 additions & 3 deletions lib/iex/lib/iex/pry.ex
Original file line number Diff line number Diff line change
Expand Up @@ -520,7 +520,7 @@ defmodule IEx.Pry do
next_binding = binding(expr, binding)
{min_line, max_line} = line_range(expr, line)

if force? or (min_line > line and min_line != :infinity) do
if force? or min_line > line do
pry_var = next_var(version)
pry_binding = Map.to_list(binding)
pry_opts = [line: min_line] ++ opts
Expand All @@ -546,7 +546,9 @@ defmodule IEx.Pry do
end

defp line_range(ast, line) do
{_, min_max} =
# We want min_line to start from infinity because
# if it starts from line it will always just return line.
{_, {min, max}} =
Macro.prewalk(ast, {:infinity, line}, fn
{_, meta, _} = ast, {min_line, max_line} when is_list(meta) ->
line = meta[:line]
Expand All @@ -561,7 +563,7 @@ defmodule IEx.Pry do
{ast, acc}
end)

min_max
if min == :infinity, do: {line, max}, else: {min, max}
end

defp binding(ast, binding) do
Expand Down

0 comments on commit 9daef61

Please sign in to comment.