2
0

list.h 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. /*
  2. * Copyright (C) 2005 iptelorg GmbH
  3. *
  4. * This file is part of ser, a free SIP server.
  5. *
  6. * ser is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License as published by
  8. * the Free Software Foundation; either version 2 of the License, or
  9. * (at your option) any later version
  10. *
  11. * For a license to use the ser software under conditions
  12. * other than those described here, or to purchase support for this
  13. * software, please contact iptel.org by e-mail at the following addresses:
  14. * [email protected]
  15. *
  16. * ser is distributed in the hope that it will be useful,
  17. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  18. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  19. * GNU General Public License for more details.
  20. *
  21. * You should have received a copy of the GNU General Public License
  22. * along with this program; if not, write to the Free Software
  23. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  24. */
  25. #ifndef __LIST_H
  26. #define __LIST_H
  27. #define DOUBLE_LINKED_LIST_ADD(first,last,e) do { \
  28. if (last) last->next = (e); \
  29. else first = (e); \
  30. (e)->next = NULL; \
  31. (e)->prev = last; \
  32. last = (e); \
  33. } while (0)
  34. #define DOUBLE_LINKED_LIST_REMOVE(first,last,e) do { \
  35. if ((e)->next) (e)->next->prev = (e)->prev; \
  36. else last = (e)->prev; \
  37. if ((e)->prev) (e)->prev->next = (e)->next; \
  38. else first = (e)->next; \
  39. (e)->next = NULL; \
  40. (e)->prev = NULL; \
  41. } while (0)
  42. #define LINKED_LIST_ADD(first,last,e) do { \
  43. if (last) last->next = (e); \
  44. else first = (e); \
  45. (e)->next = NULL; \
  46. last = (e); \
  47. } while (0)
  48. #endif