]>
git.saurik.com Git - apple/javascriptcore.git/blob - wtf/BlockStack.h
a4d74257fd2cc0f63eb481d2f57ae969013fcd99
2 * Copyright (C) 2011 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
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.
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.
29 #include <wtf/Assertions.h>
30 #include <wtf/Vector.h>
34 template <typename T
> class BlockStack
{
36 static const size_t blockSize
= 4096;
37 static const size_t blockLength
= blockSize
/ sizeof(T
);
45 const Vector
<T
*>& blocks();
49 T
* m_spareBlock
; // Used to avoid thrash at block boundaries.
52 template <typename T
> BlockStack
<T
>::BlockStack()
57 template <typename T
> BlockStack
<T
>::~BlockStack()
61 for (size_t i
= 0; i
< m_blocks
.size(); ++i
)
65 template <typename T
> inline const Vector
<T
*>& BlockStack
<T
>::blocks()
70 template <typename T
> T
* BlockStack
<T
>::grow()
72 T
* block
= m_spareBlock
? m_spareBlock
: static_cast<T
*>(malloc(blockSize
));
75 m_blocks
.append(block
);
79 template <typename T
> void BlockStack
<T
>::shrink(T
* newEnd
)
81 ASSERT(newEnd
!= m_blocks
.last() + blockLength
);
82 m_spareBlock
= m_blocks
.last();
83 m_blocks
.removeLast();
85 while (m_blocks
.last() + blockLength
!= newEnd
) {
86 free(m_blocks
.last());
87 m_blocks
.removeLast();
93 using WTF::BlockStack
;