merge with 0.30.213
[util-vserver.git] / ensc_vector / list-insertinternal.c
1 // $Id: list-insertinternal.c 1896 2005-03-17 14:51:55Z ensc $    --*- c -*--
2
3 // Copyright (C) 2005 Enrico Scholz <enrico.scholz@sigma-chemnitz.de>
4 //  
5 // This program is free software; you can redistribute it and/or modify
6 // it under the terms of the GNU General Public License as published by
7 // the Free Software Foundation; version 2 of the License.
8 //  
9 // This program is distributed in the hope that it will be useful,
10 // but WITHOUT ANY WARRANTY; without even the implied warranty of
11 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 // GNU General Public License for more details.
13 //  
14 // You should have received a copy of the GNU General Public License
15 // along with this program; if not, write to the Free Software
16 // Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
17 //  
18
19 #ifdef HAVE_CONFIG_H
20 #  include <config.h>
21 #endif
22
23 #include "list.h"
24 #include "list-internal.h"
25
26 #include <assert.h>
27 #include <string.h>
28
29 #define ENSC_WRAPPERS_STDLIB 1
30 #include <wrappers.h>
31
32 struct ListItem *
33 List_insertInternal(struct List *list, void const *data,
34                     struct ListItem **before_pos,
35                     struct ListItem *after_pos)
36 {
37   struct ListItem       *item = Emalloc(sizeof(struct ListItem));
38
39   assert((before_pos!=0 || after_pos!=0) &&
40          (before_pos==0 || after_pos==0));
41   
42   item->data = Emalloc(list->elem_size);
43   memcpy(item->data, data, list->elem_size);
44
45   if (before_pos!=0) {
46     item->next  = *before_pos;
47     *before_pos = item;
48   }
49   else {
50     item->next      = after_pos->next;
51     after_pos->next = item;
52   }
53
54   ++list->count;
55
56   return item;
57 }