v8  3.25.30(node0.11.13)
V8 is Google's open source JavaScript engine
 All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Pages
zone-allocator.h
Go to the documentation of this file.
1 // Copyright 2014 the V8 project authors. All rights reserved.
2 // Redistribution and use in source and binary forms, with or without
3 // modification, are permitted provided that the following conditions are
4 // met:
5 //
6 // * Redistributions of source code must retain the above copyright
7 // notice, this list of conditions and the following disclaimer.
8 // * Redistributions in binary form must reproduce the above
9 // copyright notice, this list of conditions and the following
10 // disclaimer in the documentation and/or other materials provided
11 // with the distribution.
12 // * Neither the name of Google Inc. nor the names of its
13 // contributors may be used to endorse or promote products derived
14 // from this software without specific prior written permission.
15 //
16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
19 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
20 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
21 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
22 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
23 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
24 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 
28 #ifndef V8_ZONE_ALLOCATOR_H_
29 #define V8_ZONE_ALLOCATOR_H_
30 
31 #include "zone.h"
32 
33 namespace v8 {
34 namespace internal {
35 
36 template<typename T>
38  public:
39  typedef T* pointer;
40  typedef const T* const_pointer;
41  typedef T& reference;
42  typedef const T& const_reference;
43  typedef T value_type;
44  typedef size_t size_type;
45  typedef ptrdiff_t difference_type;
46  template<class O> struct rebind {
48  };
49 
50  explicit zone_allocator(Zone* zone) throw() : zone_(zone) {}
51  explicit zone_allocator(const zone_allocator& other) throw()
52  : zone_(other.zone_) {}
53  template<typename U> zone_allocator(const zone_allocator<U>& other) throw()
54  : zone_(other.zone_) {}
55  template<typename U> friend class zone_allocator;
56 
57  pointer address(reference x) const {return &x;}
58  const_pointer address(const_reference x) const {return &x;}
59 
60  pointer allocate(size_type count, const void* hint = 0) {
61  size_t size = count * sizeof(value_type);
62  size = RoundUp(size, kPointerSize);
63  return static_cast<pointer>(zone_->New(size));
64  }
65  void deallocate(pointer p, size_type) { /* noop for Zones */ }
66 
67  size_type max_size() const throw() {
68  size_type max = static_cast<size_type>(-1) / sizeof(T);
69  return (max > 0 ? max : 1);
70  }
71  void construct(pointer p, const T& val) {
72  new(static_cast<void*>(p)) T(val);
73  }
74  void destroy(pointer p) { p->~T(); }
75 
76  bool operator==(zone_allocator const& other) {
77  return zone_ == other.zone_;
78  }
79  bool operator!=(zone_allocator const& other) {
80  return zone_ != other.zone_;
81  }
82 
83  private:
85  Zone* zone_;
86 };
87 
88 } } // namespace v8::internal
89 
90 #endif // V8_ZONE_ALLOCATOR_H_
bool operator==(zone_allocator const &other)
zone_allocator(const zone_allocator< U > &other)
size_type max_size() const
bool operator!=(zone_allocator const &other)
pointer allocate(size_type count, const void *hint=0)
enable upcoming ES6 features enable harmony block scoping enable harmony enable harmony proxies enable harmony generators enable harmony numeric enable harmony string enable harmony math functions harmony_scoping harmony_symbols harmony_collections harmony_iteration harmony_strings harmony_scoping harmony_maths tracks arrays with only smi values Optimize object size
Definition: flags.cc:211
zone_allocator(const zone_allocator &other)
const int kPointerSize
Definition: globals.h:268
pointer address(reference x) const
T RoundUp(T x, intptr_t m)
Definition: utils.h:144
#define T(name, string, precedence)
Definition: token.cc:48
const_pointer address(const_reference x) const
void construct(pointer p, const T &val)
void deallocate(pointer p, size_type)
void * New(int size)
Definition: zone-inl.h:51