File: slist.h

package info (click to toggle)
libiscsi 1.20.0-4
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 3,080 kB
  • sloc: ansic: 40,928; xml: 749; sh: 689; makefile: 352
file content (56 lines) | stat: -rw-r--r-- 2,648 bytes parent folder | download
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
/*
   Copyright (C) 2010 by Ronnie Sahlberg <ronniesahlberg@gmail.com>

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU Lesser General Public License as published by
   the Free Software Foundation; either version 2.1 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public License
   along with this program; if not, see <http://www.gnu.org/licenses/>.
*/

#ifndef __iscsi_slist_h__
#define __iscsi_slist_h__

#define ISCSI_LIST_ADD(list, item)              \
do {                                            \
        (item)->next = (*list);                 \
        (*list) = (item);                       \
} while (0)

#define ISCSI_LIST_ADD_END(list, item)                  \
do {                                                    \
	if ((*list) == NULL) {                          \
                ISCSI_LIST_ADD((list), (item));         \
        } else {                                        \
                typeof(*list) head = (*list);           \
                while ((*list)->next)                   \
                        (*list) = (*list)->next;        \
                (*list)->next = (item);                 \
                (item)->next = NULL;                    \
                (*list) = head;                         \
        }                                               \
} while (0)

#define ISCSI_LIST_REMOVE(list, item)                                   \
do {                                                                    \
        if ((*list) == (item)) {                                        \
                (*list) = (item)->next;                                 \
        } else {                                                        \
                typeof(*list) head = (*list);                           \
                while ((*list)->next && (*list)->next != (item))        \
                        (*list) = (*list)->next;                        \
                if ((*list)->next != NULL) {		    	    	\
                        (*list)->next = (*list)->next->next;		\
                }  		      					\
                (*list) = head;                                         \
        }                                                               \
} while (0)

#endif /* __iscsi_slist_h__ */