BlockStack.h 2.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * Copyright (C) 2011 Apple Inc. All rights reserved.
  3. *
  4. * Redistribution and use in source and binary forms, with or without
  5. * modification, are permitted provided that the following conditions
  6. * are met:
  7. * 1. Redistributions of source code must retain the above copyright
  8. * notice, this list of conditions and the following disclaimer.
  9. * 2. Redistributions in binary form must reproduce the above copyright
  10. * notice, this list of conditions and the following disclaimer in the
  11. * documentation and/or other materials provided with the distribution.
  12. *
  13. * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
  14. * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
  15. * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
  16. * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
  17. * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
  18. * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
  19. * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
  20. * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
  21. * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
  22. * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
  23. * THE POSSIBILITY OF SUCH DAMAGE.
  24. */
  25. #ifndef BlockStack_h
  26. #define BlockStack_h
  27. #include <wtf/Assertions.h>
  28. #include <wtf/FastMalloc.h>
  29. #include <wtf/Vector.h>
  30. namespace WTF {
  31. template <typename T> class BlockStack {
  32. public:
  33. static const size_t blockSize = 4096;
  34. static const size_t blockLength = blockSize / sizeof(T);
  35. BlockStack();
  36. ~BlockStack();
  37. T* grow();
  38. void shrink(T*);
  39. const Vector<T*>& blocks();
  40. private:
  41. Vector<T*> m_blocks;
  42. T* m_spareBlock; // Used to avoid thrash at block boundaries.
  43. };
  44. template <typename T> BlockStack<T>::BlockStack()
  45. : m_spareBlock(0)
  46. {
  47. }
  48. template <typename T> BlockStack<T>::~BlockStack()
  49. {
  50. if (m_spareBlock)
  51. fastFree(m_spareBlock);
  52. for (size_t i = 0; i < m_blocks.size(); ++i)
  53. fastFree(m_blocks[i]);
  54. }
  55. template <typename T> inline const Vector<T*>& BlockStack<T>::blocks()
  56. {
  57. return m_blocks;
  58. }
  59. template <typename T> T* BlockStack<T>::grow()
  60. {
  61. T* block = m_spareBlock ? m_spareBlock : static_cast<T*>(fastMalloc(blockSize));
  62. m_spareBlock = 0;
  63. m_blocks.append(block);
  64. return block;
  65. }
  66. template <typename T> void BlockStack<T>::shrink(T* newEnd)
  67. {
  68. ASSERT(newEnd != m_blocks.last() + blockLength);
  69. m_spareBlock = m_blocks.last();
  70. m_blocks.removeLast();
  71. while (m_blocks.last() + blockLength != newEnd) {
  72. fastFree(m_blocks.last());
  73. m_blocks.removeLast();
  74. }
  75. }
  76. }
  77. using WTF::BlockStack;
  78. #endif