Serene Runtime 1.0.0
C runtime for the Serene programming language
Loading...
Searching...
No Matches
maps.c
Go to the documentation of this file.
1/* -*- C -*-
2 * Serene programming language
3 * Copyright (C) 2019-2026 Sameer Rahmani <[email protected]>
4 *
5 * This library is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU Lesser General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
9 *
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU Lesser General Public License for more details.
14 *
15 * You should have received a copy of the GNU Lesser General Public License
16 * along with this library. If not, see <https://www.gnu.org/licenses/>.
17 */
18#include "serene/rt/maps.h"
19
20#include "serene/rt/context.h"
21#include "serene/rt/core.h"
22#include "serene/rt/engine.h"
23#include "serene/rt/errors.h"
25#include "serene/rt/protocols.h"
26#include "serene/utils.h"
27
28static bool srn_vmap_cmp(srn_context_t *ctx, const hmap_key_t *a, const hmap_key_t *b) {
29 srn_value_t *va = (srn_value_t *)a->data;
30 srn_value_t *vb = (srn_value_t *)b->data;
31 srn_value_t *res = srn_value_eq(ctx, va, vb);
32 switch (TYPE(res)) {
33 case VFalse:
34 return false;
35 case VTrue:
36 return true;
37 default:
38 PANIC("Should never happen");
39 }
40}
41
42[[gnu::nonnull(1)]]
46 srn_value_t *v = (srn_value_t *)k->data;
47
49 return srn_value_hash(ctx, v);
50}
51
52static const hmap_control_t value_map = {
53 .cmp = &srn_vmap_cmp,
54 .hash = &srn_vmap_hash,
55 .insert = hmap_insert_ctl,
56 .lookup = hmap_lookup_ctl,
57};
58
60 PANIC_IF_NULL(ctx);
61 srn_map_t *m = ALLOC(ctx, srn_map_t);
62 m->inner = hmap_empty(ctx);
63 return srn_value_make(ctx, VMap, metadata, (void *)m);
64}
65
67 srn_value_t *key, srn_value_t *value) {
68 PANIC_IF_NULL(ctx);
69 PANIC_IF_NULL(map);
70 PANIC_IF_NULL(key);
71 PANIC_IF_NULL(value);
72
73 if (!IS_A(map, VMap)) {
74 return srn_errors_make_error(ctx, metadata, ABSURD, "expected a map");
75 }
76
77 hmap_key_t *k = hmap_make_key(ctx, key, sizeof(*key));
78
79 srn_map_t *old = AS_MAP(map);
80 srn_map_t *neu = ALLOC(ctx, srn_map_t);
81
82 neu->inner = value_map.insert(&value_map, ctx, &old->inner, k, value);
83 return srn_value_make(ctx, VMap, metadata, (void *)neu);
84}
#define ALLOC(ctx, T)
Definition context.h:82
srn_value_t * srn_value_make(srn_context_t *ctx, srn_value_tag_t tag, srn_metadata_t *metadata, void *payload)
Creates a new serene value.
Definition core.c:24
#define TYPE(value_ref)
Definition core.h:160
@ VFalse
Definition core.h:115
@ VMap
Definition core.h:126
@ VTrue
Definition core.h:114
#define AS_MAP(value_ref)
Definition core.h:177
#define IS_A(value_ref, field)
Definition core.h:162
@ ABSURD
Definition errors.h:45
hmap_t hmap_empty(srn_context_t *ctx)
Create, initialize and return a new hashmap.
Definition hashmap.c:612
void * hmap_lookup_ctl(const hmap_control_t *ctl, srn_context_t *ctx, const hmap_t *hmap, const hmap_key_t *k, void *default_value)
Just like the hmap_lookup function but, it receives a hmap_control_t to customize the comparison and ...
Definition hashmap.c:597
hmap_key_t * hmap_make_key(srn_context_t *ctx, void *data, size_t len)
Create a new key out of the given data, with the given len.
Definition hashmap.c:627
hmap_t hmap_insert_ctl(const hmap_control_t *ctl, srn_context_t *ctx, const hmap_t *hmap, hmap_key_t *k, void *v)
Just like the hmap_insert function but, it receives a hmap_control_t to customize the comparison and ...
Definition hashmap.c:559
This is an implementation of Compressed Hash-Array Mapped Prefix-tree, which is a bit-partitioned,...
HMAP_HASH_TYPE hmap_hash_t
Definition hashmap.h:61
srn_value_t * srn_map_assoc(srn_context_t *ctx, srn_metadata_t *metadata, srn_value_t *map, srn_value_t *key, srn_value_t *value)
Definition maps.c:66
static hmap_hash_t srn_vmap_hash(srn_context_t *ctx, const hmap_key_t *k)
Definition maps.c:43
srn_value_t * srn_map_empty(srn_context_t *ctx, srn_metadata_t *metadata)
Definition maps.c:59
static bool srn_vmap_cmp(srn_context_t *ctx, const hmap_key_t *a, const hmap_key_t *b)
Definition maps.c:28
static const hmap_control_t value_map
Definition maps.c:52
srn_value_t * srn_value_eq(srn_context_t *ctx, const srn_value_t *a, const srn_value_t *b)
Check to values for equality. Return a boolean.
Definition protocols.c:38
srn_hash_t srn_value_hash(srn_context_t *ctx, const srn_value_t *v)
Compute the xxHash32 of a value using the engine seed.
Definition protocols.c:138
If we ever want to modify some of these behaviours for a new instance of hashmap, we should use this ...
Definition hashmap.h:103
Note: For key equality we use the memcpy function.
Definition hashmap.h:66
void * data
len 0 -> data == nullptr
Definition hashmap.h:68
A persistent, immutable map.
Definition maps.h:29
hmap_t inner
Definition maps.h:30
#define PANIC_IF_NULL(ptr)
Definition utils.h:64
#define PANIC(msg)
Definition utils.h:51