/usr/include/libical/icalarray.h is in libical2-dev 2.0.0-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 | /*======================================================================
FILE: icalarray.h
CREATOR: Damon Chaplin 07 March 2001
(C) COPYRIGHT 2001, Ximian, Inc.
This program is free software; you can redistribute it and/or modify
it under the terms of either:
The LGPL as published by the Free Software Foundation, version
2.1, available at: http://www.gnu.org/licenses/lgpl-2.1.html
Or:
The Mozilla Public License Version 1.0. You may obtain a copy of
the License at http://www.mozilla.org/MPL/
======================================================================*/
/** @file icalarray.h
*
* @brief An array of arbitrarily-sized elements which grows
* dynamically as elements are added.
*/
#ifndef ICALARRAY_H
#define ICALARRAY_H
#include "libical_ical_export.h"
typedef struct _icalarray icalarray;
struct _icalarray
{
size_t element_size;
size_t increment_size;
size_t num_elements;
size_t space_allocated;
void **chunks;
};
LIBICAL_ICAL_EXPORT icalarray *icalarray_new(size_t element_size, size_t increment_size);
LIBICAL_ICAL_EXPORT icalarray *icalarray_copy(icalarray *array);
LIBICAL_ICAL_EXPORT void icalarray_free(icalarray *array);
LIBICAL_ICAL_EXPORT void icalarray_append(icalarray *array, const void *element);
LIBICAL_ICAL_EXPORT void icalarray_remove_element_at(icalarray *array, size_t position);
LIBICAL_ICAL_EXPORT void *icalarray_element_at(icalarray *array, size_t position);
LIBICAL_ICAL_EXPORT void icalarray_sort(icalarray *array,
int (*compare) (const void *, const void *));
#endif /* ICALARRAY_H */
|