1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
// shared_ptr-examples.cpp
// based on https://docs.microsoft.com/en-us/cpp/cpp/how-to-create-and-use-shared-ptr-instances?view=msvc-160
#include <stc/cstr.h>
typedef struct
{
cstr artist;
cstr title;
} Song;
int Song_cmp(const Song* x, const Song* y)
{ return cstr_cmp(&x->title, &y->title); }
uint64_t Song_hash(const Song* x) { return cstr_hash(&x->title); }
Song Song_make(const char* artist, const char* title)
{ return (Song){cstr_from(artist), cstr_from(title)}; }
void Song_drop(Song* s) {
printf("drop: %s\n", cstr_str(&s->title));
c_drop(cstr, &s->artist, &s->title);
}
// Define the reference counted type
#define i_type SongArc
#define i_valclass Song
//#define i_opt c_no_hash
#include <stc/carc.h>
// ... and a vector of it
#define i_type SongVec
#define i_valboxed SongArc
#include <stc/cstack.h>
void example3()
{
c_auto (SongVec, vec1, vec2)
{
vec1 = c_make(SongVec, {
Song_make("Bob Dylan", "The Times They Are A Changing"),
Song_make("Aretha Franklin", "Bridge Over Troubled Water"),
Song_make("Thalia", "Entre El Mar y Una Estrella")
});
// Share all entries in vec with vec2, except Bob Dylan.
c_foreach (s, SongVec, vec1)
if (!cstr_equals(&s.ref->get->artist, "Bob Dylan"))
SongVec_push(&vec2, SongArc_clone(*s.ref));
// Add a few more to vec2. We can use emplace when creating new entries
SongVec_emplace(&vec2, Song_make("Michael Jackson", "Billie Jean"));
SongVec_emplace(&vec2, Song_make("Rihanna", "Stay"));
// If we use push, we would need to construct the Arc explicitly (as in c++, make_shared):
// SongVec_push(&vec2, SongArc_from(Song_make("Rihanna", "Stay")));
// We now have two vectors with some shared, some unique entries.
c_forlist (i, SongVec, {vec1, vec2}) {
puts("VEC:");
c_foreach (s, SongVec, *i.ref)
printf(" %s - %s, REFS: %ld\n", cstr_str(&s.ref->get->artist),
cstr_str(&s.ref->get->title),
*s.ref->use_count);
}
} // because the shared elem. are ref. counted, they are only dropped once here.
}
int main()
{
example3();
}
|