Fuzion Logo
fuzion-lang.dev — The Fuzion Language Portal
JavaScript seems to be disabled. Functionality is limited.

lock_free/group_by.fz


# This file is part of the Fuzion language implementation.
#
# The Fuzion language implementation is free software: you can redistribute it
# and/or modify it under the terms of the GNU General Public License as published
# by the Free Software Foundation, version 3 of the License.
#
# The Fuzion language implementation is distributed in the hope that it will be
# useful, but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
# License for more details.
#
# You should have received a copy of the GNU General Public License along with The
# Fuzion language implementation.  If not, see <https://www.gnu.org/licenses/>.


# -----------------------------------------------------------------------
#
#  Tokiwa Software GmbH, Germany
#
#  Source code of Fuzion feature Sequence.group_by
#
# -----------------------------------------------------------------------


# group the elements of this sequence by a key of type K
#
# f determines the key of an element
#
public Sequence.group_by(K type : property.hashable, f T -> K) lock_free.Map K (Sequence T) =>

  # NYI It should be possible to choose the map implementation that is used.
  res := (lock_free.Map K (Sequence T)).empty

  for_each x->
    key := f x
    match res[key]
      nil => res.put key [x]
      s Sequence T => res.put key s++[x]

  res
last changed: 2025-01-23