aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorWilliam Hergès <william@herges.fr>2025-11-08 22:59:31 +0100
committerWilliam Hergès <william@herges.fr>2025-11-08 22:59:31 +0100
commit8a26b3d43e1adb6f9585891500a5fc856fd0ca5c (patch)
tree19b2b90ee22c9b6cc3652d128ac7bf3f1da4da3c /lib
parentc7a26d3c6125caa9239cec9bf08db935d98e19c1 (diff)
perf(var): replace atoms by charlist
Diffstat (limited to 'lib')
-rw-r--r--lib/elixir_math_parser.ex10
1 files changed, 5 insertions, 5 deletions
diff --git a/lib/elixir_math_parser.ex b/lib/elixir_math_parser.ex
index 4da4271..bb24d88 100644
--- a/lib/elixir_math_parser.ex
+++ b/lib/elixir_math_parser.ex
@@ -7,11 +7,11 @@ defmodule ElixirMathParser do
{:ok, value}
end
- defp reduce_to_value({:atom, _line, atom}, state) do
- if !Map.has_key?(state, atom) do
- {:error, "value not found for " <> to_string(atom)}
+ defp reduce_to_value({:var, _line, var}, state) do
+ if !Map.has_key?(state, var) do
+ {:error, "value not found for " <> to_string(var)}
else
- {:ok, state[atom]}
+ {:ok, state[var]}
end
end
@@ -43,7 +43,7 @@ defmodule ElixirMathParser do
end
end
- defp evaluate_tree([{:assign, {:atom, _line, lhs}, rhs} | tail], state) do
+ defp evaluate_tree([{:assign, {:var, _line, lhs}, rhs} | tail], state) do
with {:ok, val} <- reduce_to_value(rhs, state) do
evaluate_tree(tail, Map.merge(state, %{lhs => val}))
end