Libical API Documentation 4.0 UNRELEASED Go to the stable 3.0 documentation
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 SPDX-License-Identifier: LGPL-2.1-only OR MPL-2.0
7
8 The Original Code is eric. The Initial Developer of the Original
9 Code is Eric Busboom
10======================================================================*/
11
36
37#ifndef ICALDIRSET_H
38#define ICALDIRSET_H
39
40#include "libical_icalss_export.h"
41#include "icalset.h"
42
43/* icaldirset Routines for storing, fetching, and searching for ical
44 * objects in a database */
45
46typedef struct icaldirset_impl icaldirset;
47
48LIBICAL_ICALSS_EXPORT icalset *icaldirset_new(const char *dir);
49
50LIBICAL_ICALSS_EXPORT icalset *icaldirset_new_reader(const char *dir);
51
52LIBICAL_ICALSS_EXPORT icalset *icaldirset_new_writer(const char *dir);
53
54LIBICAL_ICALSS_EXPORT icalset *icaldirset_init(icalset *set, const char *dir, void *options_in);
55
56LIBICAL_ICALSS_EXPORT void icaldirset_free(icalset *set);
57
58LIBICAL_ICALSS_EXPORT const char *icaldirset_path(icalset *set);
59
60/* Marks the cluster as changed, so it will be written to disk when it
61 is freed. Commit writes to disk immediately*/
62LIBICAL_ICALSS_EXPORT void icaldirset_mark(icalset *set);
63
64LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_commit(icalset *set);
65
78LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_add_component(icalset *set, icalcomponent *comp);
79
91LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_remove_component(icalset *set,
92 icalcomponent *comp);
93
94LIBICAL_ICALSS_EXPORT int icaldirset_count_components(icalset *store, icalcomponent_kind kind);
95
96/* Restricts the component returned by icaldirset_first, _next to those
97 that pass the gauge. _clear removes the gauge. */
98LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_select(icalset *set, icalgauge *gauge);
99
100LIBICAL_ICALSS_EXPORT void icaldirset_clear(icalset *set);
101
102/* Gets a component by uid */
103LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_fetch(icalset *set,
104 icalcomponent_kind kind, const char *uid);
105
106LIBICAL_ICALSS_EXPORT int icaldirset_has_uid(icalset *set, const char *uid);
107
108LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_fetch_match(icalset *set, const icalcomponent *c);
109
110/* Modifies components according to the MODIFY method of CAP. Works on
111 the currently selected components. */
112LIBICAL_ICALSS_EXPORT icalerrorenum icaldirset_modify(icalset *set,
113 icalcomponent *oldcomp, icalcomponent *newcomp);
114
115/* Iterates through the components. If a gauge has been defined, these
116 will skip over components that do not pass the gauge */
117
118LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_get_current_component(icalset *set);
119
120LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_get_first_component(icalset *set);
121
122LIBICAL_ICALSS_EXPORT icalcomponent *icaldirset_get_next_component(icalset *set);
123
124/* External iterator for thread safety */
125LIBICAL_ICALSS_EXPORT icalsetiter icaldirset_begin_component(icalset *set,
127 icalgauge *gauge, const char *tzid);
128
129LIBICAL_ICALSS_EXPORT icalcomponent *icaldirsetiter_to_next(icalset *set, icalsetiter *i);
130
131LIBICAL_ICALSS_EXPORT icalcomponent *icaldirsetiter_to_prior(icalset *set, icalsetiter *i);
132
136
137#endif /* !ICALDIRSET_H */
icalerrorenum icaldirset_add_component(icalset *set, icalcomponent *comp)
Definition icaldirset.c:293
icalerrorenum icaldirset_remove_component(icalset *set, icalcomponent *comp)
Definition icaldirset.c:371
icalcomponent_kind
Definition icalenums.h:29
icalerrorenum
Represents the different types of errors that can be triggered in libical.
Definition icalerror.h:42
Icalset is the "base class" for representations of a collection of iCal components.