Associative Lists / Dictionaries

From MemCP
Revision as of 17:48, 25 August 2025 by Aiagent (talk | contribs) (Created page with "= Associative Lists / Dictionaries = The '''Associative Lists / Dictionaries''' module provides key-value data structure operations for the SCM programming language. This module includes: * '''Dictionary filtering''': Functions to filter dictionaries based on key-value conditions (filter_assoc) * '''Dictionary mapping''': Transform dictionary values while preserving keys (map_assoc) * '''Dictionary reduction''': Aggregate dictionary data into single values (reduce_asso...")
(diff) ← Older revision | Latest revision (diff) | Newer revision → (diff)
Jump to navigation Jump to search

Associative Lists / Dictionaries

The Associative Lists / Dictionaries module provides key-value data structure operations for the SCM programming language. This module includes:

  • Dictionary filtering: Functions to filter dictionaries based on key-value conditions (filter_assoc)
  • Dictionary mapping: Transform dictionary values while preserving keys (map_assoc)
  • Dictionary reduction: Aggregate dictionary data into single values (reduce_assoc)
  • Dictionary queries: Check for key existence and extract data (has_assoc?, extract_assoc)
  • Dictionary modification: Set individual values and merge dictionaries (set_assoc, merge_assoc)

These functions provide essential tools for working with associative data structures, enabling efficient key-value operations and dictionary manipulation in SCM programs.

← Back to Full SCM API documentation

filter_assoc

returns a filtered dictionary according to a filter function

Allowed number of parameters: 2–2

Parameters:

  • dict (list): dictionary that has to be filtered
  • condition (func): filter function func(string any)->bool where the first parameter is the key, the second is the value

Returns: list

map_assoc

returns a mapped dictionary according to a map function. Keys will stay the same but values are mapped.

Allowed number of parameters: 2–2

Parameters:

  • dict (list): dictionary that has to be mapped
  • map (func): map function func(string any)->any where the first parameter is the key, the second is the value. It must return the new value.

Returns: list

reduce_assoc

reduces a dictionary according to a reduce function

Allowed number of parameters: 3–3

Parameters:

  • dict (list): dictionary that has to be reduced
  • reduce (func): reduce function func(any string any)->any where the first parameter is the accumulator, second is key, third is value. It must return the new accumulator.
  • neutral (any): initial value for the accumulator

Returns: any

has_assoc?

checks if a dictionary has a key present

Allowed number of parameters: 2–2

Parameters:

  • dict (list): dictionary that has to be checked
  • key (string): key to test

Returns: bool

extract_assoc

applies a function (key value) on the dictionary and returns the results as a flat list

Allowed number of parameters: 2–2

Parameters:

  • dict (list): dictionary that has to be checked
  • map (func): func(string any)->any that flattens down each element

Returns: list

set_assoc

returns a dictionary where a single value has been changed. This function may destroy the input value for the sake of performance. You must not use the input value again.

Allowed number of parameters: 3–4

Parameters:

  • dict (list): input dictionary that has to be changed. You must not use this value again.
  • key (string): key that has to be set
  • value (any): new value to set
  • merge (func): (optional) func(any any)->any that is called when a value is overwritten. The first parameter is the old value, the second is the new value. It must return the merged value that shall be pysically stored in the new dictionary.

Returns: list

merge_assoc

returns a dictionary where all keys from dict1 and all keys from dict2 are present. If a key is present in both inputs, the second one will be dominant so the first value will be overwritten unless you provide a merge function

Allowed number of parameters: 2–3

Parameters:

  • dict1 (list): first input dictionary that has to be changed. You must not use this value again.
  • dict2 (list): input dictionary that contains the new values that have to be added
  • merge (func): (optional) func(any any)->any that is called when a value is overwritten. The first parameter is the old value, the second is the new value from dict2. It must return the merged value that shall be pysically stored in the new dictionary.

Returns: list