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

map.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 standard library feature map
#
#  Author: Fridtjof Siebert (siebert@tokiwa.software)
#
# -----------------------------------------------------------------------

# map -- an abstract map from keys K to values V
#
map(K, V type) ref is

  # number of entries in this map
  #
  size i32 is abstract


  # get the value k is mapped to, or nil if none.
  #
  index [] (k K) option V is abstract


  # get a sequence of all key/value pairs in this map
  #
  items Sequence (tuple K V) is abstract


  # get a sequence of all keys in this map
  #
  keys Sequence K is
    items.mapSequence K (t -> (k,_) := t; k)


  # check if key k is present in the set of keys
  #
  has (k K) => map.this[k]??


  # get a sequence of all values in this map
  #
  values Sequence V is
    items.mapSequence V (t -> (_,v) := t; v)


  # create a string containing all mappings
  #
  redef asString =>
    for
      r := "", r + c + "($k => {index[] k})"
      k in keys
      c := "", ", "
    else
      r