Created a branch here <https://github.com/elixir-lang/elixir/compare/main...christhekeele:elixir:if-else-do-end> if folk wanna play with this form and see if it improves readability around conditional re-assignment in their codebases: https://github.com/elixir-lang/elixir/compare/main...christhekeele:elixir:if-else-do-end
map = %{} condition = true map = if condition, else: map do Map.put(map, :key, :value) end #=> %{key: :value} On Friday, December 6, 2024 at 7:02:48 PM UTC-6 sabi...@gmail.com wrote: > For reference, there has been a previous discussion about then_if: > > https://groups.google.com/g/elixir-lang-core/c/uM_M-DWh42A/m/6pNKZcLyAQAJ?pli=1 > > > Le ven. 6 déc. 2024 à 23:59, José Valim <jose....@gmail.com> a écrit : > >> Hi Juan! >> >> My initial gut feeling is that this approach does not scale. What if you >> want to delete a key conditionally? Should we have delete_if? >> >> It feels a more general approach would be to introduce `then_if`: >> >> then_if(subject, condition?, function) >> >> Or similar. :) >> >> *José Valimhttps://dashbit.co/ <https://dashbit.co/>* >> >> >> On Fri, Dec 6, 2024 at 3:27 PM Juan Manuel Azambuja <ju...@mimiquate.com> >> wrote: >> >>> Hello, >>> >>> After working with Elixir for some time I have found myself repeating >>> some patterns when dealing with maps. >>> >>> One pattern I see repeated constantly in different apps developed by >>> myself or others is adding values to a map conditionally or returning the >>> map unchanged. This comes in different flavors: >>> >>> [image: Screenshot 2024-12-06 at 11.13.23 AM.png] >>> or >>> [image: Screenshot 2024-12-06 at 11.14.32 AM.png] >>> >>> When this pattern gets used enough in an app, it's normal to see it >>> abstracted in a MapUtils module that updates the map conditionally if a >>> condition is met or returns the map unchanged otherwise. >>> >>> My proposal is to include Map.put_if/4 which would abstract the >>> condition check and return the map unchanged if the condition is not met: >>> >>> [image: Screenshot 2024-12-06 at 11.17.21 AM.png] >>> >>> Enhancing the API by doing this will result in less code and more >>> readable solutions. >>> >>> Thanks for reading! >>> >>> -- >>> You received this message because you are subscribed to the Google >>> Groups "elixir-lang-core" group. >>> To unsubscribe from this group and stop receiving emails from it, send >>> an email to elixir-lang-co...@googlegroups.com. >>> To view this discussion visit >>> https://groups.google.com/d/msgid/elixir-lang-core/ed7da716-b9f5-4f64-a77d-d32696326b9en%40googlegroups.com >>> >>> <https://groups.google.com/d/msgid/elixir-lang-core/ed7da716-b9f5-4f64-a77d-d32696326b9en%40googlegroups.com?utm_medium=email&utm_source=footer> >>> . >>> >> -- >> You received this message because you are subscribed to the Google Groups >> "elixir-lang-core" group. >> To unsubscribe from this group and stop receiving emails from it, send an >> email to elixir-lang-co...@googlegroups.com. >> > To view this discussion visit >> https://groups.google.com/d/msgid/elixir-lang-core/CAGnRm4%2BLFJvKvdZX%3DnZEJj77sjmkXNm19KQz_vJr%2BAmKrecXPQ%40mail.gmail.com >> >> <https://groups.google.com/d/msgid/elixir-lang-core/CAGnRm4%2BLFJvKvdZX%3DnZEJj77sjmkXNm19KQz_vJr%2BAmKrecXPQ%40mail.gmail.com?utm_medium=email&utm_source=footer> >> . >> > -- You received this message because you are subscribed to the Google Groups "elixir-lang-core" group. To unsubscribe from this group and stop receiving emails from it, send an email to elixir-lang-core+unsubscr...@googlegroups.com. To view this discussion visit https://groups.google.com/d/msgid/elixir-lang-core/71780c50-6527-46ac-87f8-ee5846f534ebn%40googlegroups.com.