From 4156601e88fecd15f59111d9f30658c26d7a7241 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Johannes=20M=C3=BCller?= Date: Wed, 25 Jan 2023 13:04:09 +0100 Subject: [PATCH] Avoid `Array` allocation in `Channel.select(Tuple)` (#12960) --- src/channel.cr | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/src/channel.cr b/src/channel.cr index 999e0af6855d..74010d9c2c15 100644 --- a/src/channel.cr +++ b/src/channel.cr @@ -431,6 +431,11 @@ class Channel(T) # * `StaticArray`: This avoids a heap allocation because we can dup a # static array on the stack. ops_locks = ops.dup + elsif ops.responds_to?(:to_static_array) + # If the collection type implements `to_static_array` we can create a + # copy without allocating an array. This applies to `Tuple` types, which + # the compiler generates for `select` expressions. + ops_locks = ops.to_static_array else ops_locks = ops.to_a end