14a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/*---------------------------------------------------------------------------*
24a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  linklist_impl.c  *
34a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
44a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Copyright 2007, 2008 Nuance Communciations, Inc.                               *
54a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
64a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Licensed under the Apache License, Version 2.0 (the 'License');          *
74a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  you may not use this file except in compliance with the License.         *
84a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
94a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  You may obtain a copy of the License at                                  *
104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *      http://www.apache.org/licenses/LICENSE-2.0                           *
114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  Unless required by applicable law or agreed to in writing, software      *
134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  distributed under the License is distributed on an 'AS IS' BASIS,        *
144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. *
154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  See the License for the specific language governing permissions and      *
164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *  limitations under the License.                                           *
174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *                                                                           *
184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project *---------------------------------------------------------------------------*/
194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include <stdlib.h>
234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "pmemory.h"
254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "plog.h"
264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#include "linklist.h"
284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectextern void *lts_alloc(int num, int size);
304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/* very simple static memory allocation:
334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   1. pool of linked list nodes - from static allocated array
344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   2. each node is marked "used" when allocated; marked "unused" when deallocated
354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   3. since the stress linked lists deal with single words, an array will suffice.
364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project*/
374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#ifdef USE_STATIC_SLTS
394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#define NUM_ALLOC_NODES 30  /* Max 30 syllables per word */
404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projecttypedef struct LNodeAllocElement
424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  LNode node;
444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  short usedflag;
454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project} LNodeAllocElement;
464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectstatic LNodeAllocElement g_LNodeAllocArray[NUM_ALLOC_NODES];
484a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
494a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectvoid ClearLNodeArray()
504a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
514a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  int i;
524a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  LNode *n;
534a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
544a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  for(i=0; i<NUM_ALLOC_NODES; i++){
554a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    g_LNodeAllocArray[i].usedflag = 0;
564a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    n = &(g_LNodeAllocArray[i].node);
574a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    n->data = 0;
584a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    n->next = n->prev = 0;
594a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
604a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
614a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
624a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectstatic LNode *AllocNode()
634a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
644a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  int i;
654a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
664a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  /* return first unused element */
674a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  for(i=0; i<NUM_ALLOC_NODES; i++){
684a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if(g_LNodeAllocArray[i].usedflag == 0){
694a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      g_LNodeAllocArray[i].usedflag = 1;
704a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
714a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project	  /* zero out the node first*/
724a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project	  (g_LNodeAllocArray[i].node).data = NULL;
734a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project	  (g_LNodeAllocArray[i].node).prev = NULL;
744a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project	  (g_LNodeAllocArray[i].node).next = NULL;
754a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
764a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      return &(g_LNodeAllocArray[i].node);
774a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    }
784a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
794a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  /* ran out of nodes */
804a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  return NULL;
814a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
824a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
834a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectstatic void FreeNode(LNode *n)
844a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
854a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  int i;
864a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  long addr;
874a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
884a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  /* compare addresses of pointers */
894a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  for(i=0; i<NUM_ALLOC_NODES; i++){
904a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    addr = (long) (&(g_LNodeAllocArray[i].node));
914a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if(addr == (long)n){
924a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      g_LNodeAllocArray[i].usedflag = 0;
934a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      return;
944a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    }
954a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
964a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
974a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  /* not found. don't do anything */
984a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   return;
994a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
1004a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1014a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1024a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#else /* !USE_STATIC_SLTS */
1034a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1044a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectstatic LNode *AllocNode()
1054a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
1064a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  return (LNode *)lts_alloc(1, sizeof(LNode));
1074a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
1084a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Projectstatic void FreeNode(LNode *n)
1094a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
1104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  FREE(n);
1114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
1124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project#endif
1144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/* Inserts after current element
1184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   At return, current element will be point to newly created node
1194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   handle static allocation later - possibly using a pool of nodes?
1214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   For now, dynamically allocate a new list node with the data
1224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project*/
1234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source ProjectLListResult Insert(LList *list, void *data)
1244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
1254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  LNode *newnode = AllocNode();
1264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if(newnode == NULL){
1274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project     return LListResourceAllocError;
1284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
1294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  newnode->data = data;
1304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if(list->head == NULL){
1324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* if list is empty, assign to head */
1334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->head = newnode;
1344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    (list->head)->next = NULL;
1354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    (list->head)->prev = NULL;
1364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* update curr to newly inserted node */
1384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = list->head;
1394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->tail = list->head;
1404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    return LListSuccess;
1414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
1424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* curr not specified, insert from the end */
1444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if(list->curr == NULL){
1454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = list->tail;
1464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
1474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1484a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  /* in cases with single node, default to insert at end */
1494a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if(list->curr == list->tail){
1504a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* insert at the end */
1514a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    newnode->prev = list->curr;
1524a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    newnode->next = NULL;
1534a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    (list->curr)->next = newnode;
1544a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1554a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* update both curr and end */
1564a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = newnode;
1574a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->tail = newnode;
1584a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    return LListSuccess;
1594a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1604a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }else if(list->curr == list->head){
1614a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* insert at head */
1624a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    newnode->next = list->head;
1634a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    newnode->prev = NULL;
1644a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    (list->head)->prev = newnode;
1654a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1664a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* update curr to newly inserted node */
1674a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = list->head;
1684a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->head = newnode;
1694a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1704a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    return LListSuccess;
1714a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1724a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }else{
1734a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* insert somewhere in middle */
1744a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    newnode->prev = list->curr;
1754a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    newnode->next = (list->curr)->next;
1764a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    (list->curr)->next = newnode;
1774a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    (newnode->next)->prev = newnode;
1784a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1794a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* update curr to newly inserted node */
1804a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = newnode;
1814a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    return LListSuccess;
1824a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
1834a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
1844a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1854a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project/* Deletes at current element
1864a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   At return, current element will point to previous node
1874a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1884a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   handle static deallocation later - possibly using a pool of nodes?
1894a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project   For now, dynamically free a new list node
1904a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project*/
1914a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1924a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source ProjectLListResult Delete(LList *list)
1934a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project{
1944a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  LNode *curr;
1954a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
1964a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if(list->head == NULL){
1974a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    return LListEmpty;
1984a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
1994a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2004a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  /* start deleting from the end if curr not specified */
2014a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if(list->curr == NULL){
2024a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = list->tail;
2034a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
2044a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2054a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  curr = list->curr;
2064a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2074a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  if(curr == list->head){
2084a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  /* delete from the head */
2094a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->head = curr->next;
2104a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2114a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if(list->head != NULL){
2124a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      (list->head)->prev = NULL;
2134a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    }
2144a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2154a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    FreeNode(curr);
2164a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = list->head;
2174a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    return LListSuccess;
2184a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2194a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }else if(curr == list->tail){
2204a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* delete from the end */
2214a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->tail = curr->prev;
2224a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2234a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if(list->tail != NULL){
2244a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      (list->tail)->next = NULL;
2254a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    }
2264a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2274a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    FreeNode(curr);
2284a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = list->tail;
2294a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    return LListSuccess;
2304a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2314a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }else{
2324a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* delete somewhere in the middle */
2334a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    list->curr = curr->next;
2344a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2354a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    /* still check, just in case*/
2364a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if(curr->next != NULL){
2374a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      (curr->next)->prev = curr->prev;
2384a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    }
2394a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    if(curr->prev != NULL){
2404a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project      (curr->prev)->next = curr->next;
2414a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    }
2424a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
2434a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    FreeNode(curr);
2444a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project    return LListSuccess;
2454a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project  }
2464a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project}
2474a68b3365c8c50aa93505e99ead2565ab73dcdb0The Android Open Source Project
248