stack_simple.h 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. /****************************************************************************
  2. *
  3. * Copyright (c) 2017, Michael Becker (michael.f.becker@gmail.com)
  4. *
  5. * This file is part of the FreeRTOS Add-ons project.
  6. *
  7. * Source Code:
  8. * https://github.com/michaelbecker/freertos-addons
  9. *
  10. * Project Page:
  11. * http://michaelbecker.github.io/freertos-addons/
  12. *
  13. * On-line Documentation:
  14. * http://michaelbecker.github.io/freertos-addons/docs/html/index.html
  15. *
  16. * Permission is hereby granted, free of charge, to any person obtaining a
  17. * copy of this software and associated documentation files
  18. * (the "Software"), to deal in the Software without restriction, including
  19. * without limitation the rights to use, copy, modify, merge, publish,
  20. * distribute, sublicense, and/or sell copies of the Software, and to
  21. * permit persons to whom the Software is furnished to do so,subject to the
  22. * following conditions:
  23. *
  24. * + The above copyright notice and this permission notice shall be included
  25. * in all copies or substantial portions of the Software.
  26. * + Credit is appreciated, but not required, if you find this project
  27. * useful enough to include in your application, product, device, etc.
  28. *
  29. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
  30. * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  31. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
  32. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
  33. * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
  34. * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
  35. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  36. *
  37. ***************************************************************************/
  38. #ifndef STACK_H_
  39. #define STACK_H_
  40. #include "slist.h"
  41. /**
  42. * The stack structure, we leverage low overhead singly linked lists here.
  43. */
  44. typedef struct Stack_t_ {
  45. /**
  46. * How many items are in the stack.
  47. */
  48. int Count;
  49. /**
  50. * The head of the stack.
  51. */
  52. SlNode_t Head;
  53. } Stack_t;
  54. /**
  55. * Initialize a Stack structure you provide.
  56. *
  57. * @param Stack Pointer to your stack structure.
  58. */
  59. void InitStack(Stack_t *Stack);
  60. /**
  61. * Push an item onto the stack.
  62. *
  63. * Note that you have to have embedded an SListNode inside your data
  64. * structure.
  65. *
  66. * @param Stack Pointer to your stack structure.
  67. * @param Node The SListNode you want on the stack.
  68. */
  69. void PushOnStack( Stack_t *Stack,
  70. SlNode_t *Node);
  71. /**
  72. * Pop an item off the stack.
  73. *
  74. * Note that you have to have embedded an SListNode inside your data
  75. * structure.
  76. *
  77. * @param Stack Pointer to your stack structure.
  78. * @return An SListNode from the stack, or NULL if it's empty.
  79. */
  80. SlNode_t *PopOffStack(Stack_t *Stack);
  81. /**
  82. * @return True if the stack is empty, false otherwise.
  83. */
  84. #define IsStackEmpty(_stack) \
  85. ((_stack)->Count == 0)
  86. #endif