Libical API Documentation 4.0
Loading...
Searching...
No Matches
icaldirset.h
Go to the documentation of this file.
1/*======================================================================
2 FILE: icaldirset.h
3 CREATOR: eric 28 November 1999
4
5 SPDX-FileCopyrightText: 2000, Eric Busboom <eric@civicknowledge.com>
6
7 SPDX-License-Identifier: LGPL-2.1-only OR MPL-2.0
8
9 The Original Code is eric. The Initial Developer of the Original
10 Code is Eric Busboom
11======================================================================*/
12
38
39#ifndef ICALDIRSET_H
40#define ICALDIRSET_H
41
42#include "libical_icalss_export.h"
43#include "icalset.h"
44
45/* icaldirset Routines for storing, fetching, and searching for ical
46 * objects in a database */
47
48typedef struct icaldirset_impl icaldirset;
49
50LIBICAL_ICALSS_EXPORT icalset *icaldirset_new(const char *path);
51
52LIBICAL_ICALSS_EXPORT icalset *icaldirset_new_reader(const char *path);
53
54LIBICAL_ICALSS_EXPORT icalset *icaldirset_new_writer(const char *path);
55
56LIBICAL_ICALSS_EXPORT icalset *icaldirset_init(icalset *set, const char *dsn, void *options);
57
58LIBICAL_ICALSS_EXPORT void icaldirset_free(icalset *set);
59
60LIBICAL_ICALSS_EXPORT const char *icaldirset_path(icalset *set);
61
62/* Marks the cluster as changed, so it will be written to disk when it
63 is freed. Commit writes to disk immediately*/
64LIBICAL_ICALSS_EXPORT void icaldirset_mark(icalset *set);
65
66LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_commit(icalset *set);
67
73LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_add_component(icalset *store, icalcomponent *comp);
74LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_remove_component(icalset *store,
75 icalcomponent *comp);
76
77LIBICAL_ICALSS_EXPORT int icaldirset_count_components(icalset *store, icalcomponent_kind kind);
78
79/* Restricts the component returned by icaldirset_first, _next to those
80 that pass the gauge. _clear removes the gauge. */
81LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_select(icalset *store, icalgauge *gauge);
82
83LIBICAL_ICALSS_EXPORT void icaldirset_clear(icalset *store);
84
85/* Gets a component by uid */
86LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_fetch(icalset *store,
87 icalcomponent_kind kind, const char *uid);
88
89LIBICAL_ICALSS_EXPORT int icaldirset_has_uid(icalset *store, const char *uid);
90
91LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_fetch_match(icalset *set, icalcomponent *c);
92
93/* Modifies components according to the MODIFY method of CAP. Works on
94 the currently selected components. */
95LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_modify(icalset *store,
96 icalcomponent *oldc, icalcomponent *newc);
97
98/* Iterates through the components. If a gauge has been defined, these
99 will skip over components that do not pass the gauge */
100
101LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_get_current_component(icalset *store);
102
103LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_get_first_component(icalset *store);
104
105LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_get_next_component(icalset *store);
106
107/* External iterator for thread safety */
108LIBICAL_ICALSS_EXPORT icalsetiter icaldirset_begin_component(icalset *set,
109 icalcomponent_kind kind,
110 icalgauge *gauge, const char *tzid);
111
112LIBICAL_ICALSS_EXPORT icalcomponent *icaldirsetiter_to_next(icalset *set, icalsetiter *i);
113
114LIBICAL_ICALSS_EXPORT icalcomponent *icaldirsetiter_to_prior(icalset *set, icalsetiter *i);
115
119
120#endif /* !ICALDIRSET_H */
icalerrorenum icaldirset_add_component(icalset *store, icalcomponent *comp)
Definition icaldirset.c:286
icalerrorenum icaldirset_remove_component(icalset *store, icalcomponent *comp)
Definition icaldirset.c:371
icalerrorenum
Represents the different types of errors that can be triggered in libical.
Definition icalerror.h:67
Definition icaldirsetimpl.h:21
icaldirset_options options
Definition icaldirsetimpl.h:24
icalgauge * gauge
Definition icaldirsetimpl.h:26
Definition icaldirset.h:116
int flags
Definition icaldirset.h:117
Definition icalset.h:42