summaryrefslogtreecommitdiff
path: root/liblangtag/lt-list.h
blob: b7b79f1e0170e57de87a7ff6636ee1f3cb3469a1 (plain)
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
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/* 
 * lt-list.h
 * Copyright (C) 2011-2012 Akira TAGOH
 * 
 * Authors:
 *   Akira TAGOH  <akira@tagoh.org>
 * 
 * You may distribute under the terms of either the GNU
 * Lesser General Public License or the Mozilla Public
 * License, as specified in the README file.
 */
#if !defined (__LANGTAG_H__INSIDE) && !defined (__LANGTAG_COMPILATION)
#error "Only <liblangtag/langtag.h> can be included directly."
#endif

#ifndef __LT_LIST_H__
#define __LT_LIST_H__

#include <liblangtag/lt-macros.h>

LT_BEGIN_DECLS

/**
 * lt_list_t:
 *
 * All the fields in the <structname>lt_list_t</structname>
 * structure are private to the #lt_list_t implementation.
 */
typedef struct _lt_list_t	lt_list_t;

lt_list_t    *lt_list_new        (void);
lt_list_t    *lt_list_ref        (lt_list_t          *list);
void          lt_list_unref      (lt_list_t          *list);
void          lt_list_free       (lt_pointer_t        data);
lt_list_t    *lt_list_first      (lt_list_t          *list);
lt_list_t    *lt_list_last       (lt_list_t          *list);
lt_list_t    *lt_list_previous   (const lt_list_t    *list);
lt_list_t    *lt_list_next       (const lt_list_t    *list);
lt_pointer_t  lt_list_value      (const lt_list_t    *list);
size_t        lt_list_length     (const lt_list_t    *list);
lt_list_t    *lt_list_append     (lt_list_t          *list,
                                  lt_pointer_t        data,
                                  lt_destroy_func_t   func);
lt_list_t    *lt_list_prepend    (lt_list_t          *list,
				  lt_pointer_t        data,
				  lt_destroy_func_t   func);
lt_list_t    *lt_list_remove     (lt_list_t          *list,
                                  lt_pointer_t        data);
lt_list_t    *lt_list_delete     (lt_list_t          *list,
				  lt_pointer_t        data);
lt_list_t    *lt_list_delete_link(lt_list_t          *list,
				  lt_list_t          *link_);
lt_list_t    *lt_list_find       (lt_list_t          *list,
                                  const lt_pointer_t  data);
lt_list_t    *lt_list_find_custom(lt_list_t          *list,
                                  const lt_pointer_t  data,
                                  lt_compare_func_t   func);
lt_list_t    *lt_list_sort       (lt_list_t          *list,
				  lt_compare_func_t   func);
lt_list_t    *lt_list_pop        (lt_list_t          *list,
				  lt_pointer_t       *data);

LT_END_DECLS

#endif /* __LT_LIST_H__ */