| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2012-05-02 15:21:36 -07:00
										 |  |  |  * Copyright (c) 2008, 2009, 2010, 2011 Nicira, Inc. | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-06-15 15:11:30 -07:00
										 |  |  |  * Licensed under the Apache License, Version 2.0 (the "License"); | 
					
						
							|  |  |  |  * you may not use this file except in compliance with the License. | 
					
						
							|  |  |  |  * You may obtain a copy of the License at: | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2009-06-15 15:11:30 -07:00
										 |  |  |  *     http://www.apache.org/licenses/LICENSE-2.0
 | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Unless required by applicable law or agreed to in writing, software | 
					
						
							|  |  |  |  * distributed under the License is distributed on an "AS IS" BASIS, | 
					
						
							|  |  |  |  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
					
						
							|  |  |  |  * See the License for the specific language governing permissions and | 
					
						
							|  |  |  |  * limitations under the License. | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  |  */ | 
					
						
							|  |  |  | #ifndef LIST_H
 | 
					
						
							|  |  |  | #define LIST_H 1
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Doubly linked list. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <stdbool.h>
 | 
					
						
							|  |  |  | #include <stddef.h>
 | 
					
						
							|  |  |  | #include "util.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Doubly linked list head or element. */ | 
					
						
							| 
									
										
										
										
											2010-02-04 11:23:23 -08:00
										 |  |  | struct list { | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  |     struct list *prev;     /* Previous list element. */ | 
					
						
							|  |  |  |     struct list *next;     /* Next list element. */ | 
					
						
							| 
									
										
										
										
											2010-02-04 11:23:23 -08:00
										 |  |  | }; | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define LIST_INITIALIZER(LIST) { LIST, LIST }
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void list_init(struct list *); | 
					
						
							| 
									
										
										
										
											2010-12-06 10:03:31 -08:00
										 |  |  | void list_poison(struct list *); | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* List insertion. */ | 
					
						
							|  |  |  | void list_insert(struct list *, struct list *); | 
					
						
							|  |  |  | void list_splice(struct list *before, struct list *first, struct list *last); | 
					
						
							|  |  |  | void list_push_front(struct list *, struct list *); | 
					
						
							|  |  |  | void list_push_back(struct list *, struct list *); | 
					
						
							|  |  |  | void list_replace(struct list *, const struct list *); | 
					
						
							|  |  |  | void list_moved(struct list *); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* List removal. */ | 
					
						
							|  |  |  | struct list *list_remove(struct list *); | 
					
						
							|  |  |  | struct list *list_pop_front(struct list *); | 
					
						
							|  |  |  | struct list *list_pop_back(struct list *); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* List elements. */ | 
					
						
							| 
									
										
										
										
											2011-03-21 14:06:35 -07:00
										 |  |  | struct list *list_front(const struct list *); | 
					
						
							|  |  |  | struct list *list_back(const struct list *); | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* List properties. */ | 
					
						
							|  |  |  | size_t list_size(const struct list *); | 
					
						
							|  |  |  | bool list_is_empty(const struct list *); | 
					
						
							| 
									
										
										
										
											2011-03-24 09:40:07 -07:00
										 |  |  | bool list_is_singleton(const struct list *); | 
					
						
							|  |  |  | bool list_is_short(const struct list *); | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2010-09-17 10:33:10 -07:00
										 |  |  | #define LIST_FOR_EACH(ITER, MEMBER, LIST)                               \
 | 
					
						
							| 
									
										
										
										
											2010-11-17 14:25:33 -08:00
										 |  |  |     for (ASSIGN_CONTAINER(ITER, (LIST)->next, MEMBER);                  \ | 
					
						
							| 
									
										
										
										
											2010-09-17 10:33:10 -07:00
										 |  |  |          &(ITER)->MEMBER != (LIST);                                     \ | 
					
						
							| 
									
										
										
										
											2010-11-17 14:25:33 -08:00
										 |  |  |          ASSIGN_CONTAINER(ITER, (ITER)->MEMBER.next, MEMBER)) | 
					
						
							| 
									
										
										
										
											2010-09-17 10:33:10 -07:00
										 |  |  | #define LIST_FOR_EACH_REVERSE(ITER, MEMBER, LIST)                       \
 | 
					
						
							| 
									
										
										
										
											2010-11-17 14:25:33 -08:00
										 |  |  |     for (ASSIGN_CONTAINER(ITER, (LIST)->prev, MEMBER);                  \ | 
					
						
							| 
									
										
										
										
											2010-09-17 10:33:10 -07:00
										 |  |  |          &(ITER)->MEMBER != (LIST);                                     \ | 
					
						
							| 
									
										
										
										
											2010-11-17 14:25:33 -08:00
										 |  |  |          ASSIGN_CONTAINER(ITER, (ITER)->MEMBER.prev, MEMBER)) | 
					
						
							|  |  |  | #define LIST_FOR_EACH_SAFE(ITER, NEXT, MEMBER, LIST)            \
 | 
					
						
							|  |  |  |     for (ASSIGN_CONTAINER(ITER, (LIST)->next, MEMBER);          \ | 
					
						
							|  |  |  |          (&(ITER)->MEMBER != (LIST)                             \ | 
					
						
							|  |  |  |           ? ASSIGN_CONTAINER(NEXT, (ITER)->MEMBER.next, MEMBER) \ | 
					
						
							|  |  |  |           : 0);                                                 \ | 
					
						
							|  |  |  |          (ITER) = (NEXT)) | 
					
						
							| 
									
										
										
										
											2009-07-08 13:19:16 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #endif /* list.h */
 |