Ignore:
File:
1 edited

Legend:

Unmodified
Added
Removed
  • kernel/generic/src/adt/list.c

    rc14762e r9d58539  
    6868}
    6969
    70 /** Moves items of one list into another after the specified item.
    71  *
    72  * Inserts all items of @a list after item at @a pos in another list.
    73  * Both lists may be empty.
    74  *
    75  * @param list Source list to move after pos. Empty afterwards.
    76  * @param pos Source items will be placed after this item.
     70/** Concatenate two lists
     71 *
     72 * Concatenate lists @a list1 and @a list2, producing a single
     73 * list @a list1 containing items from both (in @a list1, @a list2
     74 * order) and empty list @a list2.
     75 *
     76 * @param list1         First list and concatenated output
     77 * @param list2         Second list and empty output.
     78 *
    7779 */
    78 void list_splice(list_t *list, link_t *pos)
     80void list_concat(list_t *list1, list_t *list2)
    7981{
    80         if (list_empty(list))
     82        if (list_empty(list2))
    8183                return;
    82        
    83         /* Attach list to destination. */
    84         list->head.next->prev = pos;
    85         list->head.prev->next = pos->next;
    86        
    87         /* Link destination list to the added list. */
    88         pos->next->prev = list->head.prev;
    89         pos->next = list->head.next;
    90        
    91         list_initialize(list);
     84
     85        list2->head.next->prev = list1->head.prev;
     86        list2->head.prev->next = &list1->head;
     87        list1->head.prev->next = list2->head.next;
     88        list1->head.prev = list2->head.prev;
     89        list_initialize(list2);
    9290}
    9391
Note: See TracChangeset for help on using the changeset viewer.