I think it depends on what you are doing in the with. In that specific case of Map.fetch/2, it will probably take longer with the overhead of spawning additional processes. However, I could potentially see this as being useful if you have longer running clauses.
With that said, you should be careful when using something like this. It is possible that you actually want all of the previous clauses to run before running the following. Even if it doesn’t rely on the result of the previous (I’m sorry if that doesn’t make sense).
A question for anyone that knows about this library. If multiple clauses fail, which value gets returned?
Yes! this was just an example… I’m using it to call multiple endpoints which doesn’t require to be sequential.
You can use the else as same as the with clause for failed ones.
opts = %{width: 10, height: 15}
async with {:ok, width} <- Map.fetch(opts, :width)
{:ok, height} <- Map.fetch(opts, :height) do
{:ok, width * height}
else
{:error, n} ->
... do what you want...
end
What exactly happens when you have sequential clauses? And if you had 2 non-sequential followed by 2 clauses dependent upon those? It seems its just syntactic sugar for doing something like:
IMHO I’d just prefer to see the tasks being spawned rather than using this library. It seems like its an attempt to implement JavaScript’s async keyword when Elixir already handles asynchronous communication much better than JavaScript does.