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
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
#include "vcal.h"
#include <string.h>
#define TYPE content_line
#include "hash_help.inc"
#undef TYPE
int vevent_init(vevent* ev, int init_size) {
HASH_INIT(content_line)(&ev->clines, init_size);
return 0;
}
content_line* get_property (vevent* ev, char* key) {
return HASH_GET(content_line)(&ev->clines, key);
}
int add_content_line (vevent* ev, content_line* c) {
return HASH_PUT(content_line)(&ev->clines, c);
}
int init_content_line (content_line* c, int keylen, int vallen) {
init_string(&c->key, keylen);
init_string(&c->val, vallen);
// TODO remaining fields
return 0;
}
int content_line_copy (content_line* dest, content_line* src) {
strbuf_init_copy(&dest->key, &src->key);
strbuf_init_copy(&dest->val, &src->val);
// TODO remaining fields
return 0;
}
int content_line_free (content_line* c) {
free_string(&c->key);
free_string(&c->val);
// TODO remaining fields
return 0;
}
int copy_vevent(vevent* dest, vevent* src) {
// copy_strbuf(&dest->dtstart , &src->dtstart);
// copy_strbuf(&dest->dtend , &src->dtend);
// copy_strbuf(&dest->summary , &src->summary);
// copy_strbuf(&dest->description , &src->description);
return 0;
}
int vevent_init_copy(vevent* dest, vevent* src) {
// strbuf_init_copy(&dest->dtstart , &src->dtstart);
// strbuf_init_copy(&dest->dtend , &src->dtend);
// strbuf_init_copy(&dest->summary , &src->summary);
// strbuf_init_copy(&dest->description , &src->description);
return 0;
}
int free_vevent (vevent* ev) {
// free_string(&ev->dtstart);
// free_string(&ev->dtend);
// free_string(&ev->summary);
// free_string(&ev->description);
return 0;
}
int push_event(vcalendar* cal, vevent* ev) {
/* Make sure that cal->events is large enough */
if (cal->n_events + 1 > cal->alloc) {
cal->alloc <<= 1;
cal->events = realloc(cal->events, sizeof(*cal->events) * cal->alloc);
}
// vevent_init_copy(&cal->events[cal->n_events], ev);
cal->events[cal->n_events] = *ev;
cal->n_events++;
return 0;
}
int init_vcalendar(vcalendar* cal) {
cal->events = malloc(sizeof(*cal->events));
cal->alloc = 1;
cal->n_events = 0;
return 0;
}
int free_vcalendar (vcalendar* cal) {
for (size_t i = 0; i < cal->n_events; i++) {
free_vevent(& cal->events[i]);
}
free (cal->events);
return 0;
}
|