diff options
Diffstat (limited to 'lib/math/function.ex')
| -rw-r--r-- | lib/math/function.ex | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/lib/math/function.ex b/lib/math/function.ex new file mode 100644 index 0000000..2acf2c4 --- /dev/null +++ b/lib/math/function.ex @@ -0,0 +1,28 @@ +defmodule ElixirMathParser.Math.Function do + alias ElixirMathParser.Math.Function + + defstruct relation: nil, parameters: %{} + + def is_function(val) when is_map(val) and is_map_key(val, :__struct__) and is_struct(val), + do: :erlang.map_get(:__struct__, val) == __MODULE__ + + def new(relation, parameters) do + params = + Enum.with_index(parameters) + |> Enum.reduce(%{}, fn {v, id}, acc -> Map.merge(acc, %{id => v}) end) + + %Function{relation: relation, parameters: params} + end + + def eval(fun, parameters) do + if Enum.count(parameters) != Enum.count(fun.parameters) do + {:error, "wrong count of parameters"} + else + params = + Enum.with_index(parameters) + |> Enum.reduce(%{}, fn {v, id}, acc -> Map.merge(acc, %{v => id}) end) + + fun.relation.(fun.parameters, params) + end + end +end |
