-
Notifications
You must be signed in to change notification settings - Fork 0
/
list.h
55 lines (49 loc) · 1.94 KB
/
list.h
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
/*
* Copyright (c) 2002 Silicon Graphics, Inc.
* All Rights Reserved.
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation.
*
* This program is distributed in the hope that it would be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write the Free Software Foundation,
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef LIST_H
#define LIST_H
struct menu_ops_s;
typedef struct node_s {
void *data;
struct node_s *next;
struct node_s *prev;
} node_t;
typedef struct {
int level; /* indentation level in menu */
int hidden; /* flag: displayed in menu */
int expanded; /* flag: children displayed in menu */
int deleted; /* flag: marked as deleted in menu */
int imported; /* flag: marked as imported in menu */
int commited; /* flag: record already commited */
int file_idx; /* index into file table */
char *text; /* text displayed in menu */
struct menu_ops_s *ops; /* table of applicable operations */
node_t *parent; /* parent node */
node_t **children; /* child nodes */
int nbr_children; /* number of children nodes */
int data_idx; /* real data in mmap file */
} data_t;
void node_free(node_t *node);
node_t *node_create(int hidden, int expanded, int level, int deleted, int file_idx, char *text,
struct menu_ops_s *ops, node_t *parent, node_t **children, int nbr_children,
int data_idx);
node_t *list_add(node_t *prevnode, node_t *newnode);
node_t *list_del(node_t *node);
node_t *free_all_children(node_t *node);
node_t *mark_all_children_commited(node_t *node);
#endif /* LIST_H */