Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4)

Side by Side Diff: third_party/WebKit/Source/core/css/CSSValue.h

Issue 1721333002: Bug fix: Add BlinkGC allocation hooks to CSS, Node and vector/table backing (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Hook in allocateOnHeapIndex Created 4 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 /* 1 /*
2 * (C) 1999-2003 Lars Knoll (knoll@kde.org) 2 * (C) 1999-2003 Lars Knoll (knoll@kde.org)
3 * Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved. 3 * Copyright (C) 2004, 2005, 2006, 2007, 2008 Apple Inc. All rights reserved.
4 * 4 *
5 * This library is free software; you can redistribute it and/or 5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Library General Public 6 * modify it under the terms of the GNU Library General Public
7 * License as published by the Free Software Foundation; either 7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version. 8 * version 2 of the License, or (at your option) any later version.
9 * 9 *
10 * This library is distributed in the hope that it will be useful, 10 * This library is distributed in the hope that it will be useful,
(...skipping 26 matching lines...) Expand all
37 // Override operator new to allocate CSSValue subtype objects onto 37 // Override operator new to allocate CSSValue subtype objects onto
38 // a dedicated heap. 38 // a dedicated heap.
39 GC_PLUGIN_IGNORE("crbug.com/443854") 39 GC_PLUGIN_IGNORE("crbug.com/443854")
40 void* operator new(size_t size) 40 void* operator new(size_t size)
41 { 41 {
42 return allocateObject(size, false); 42 return allocateObject(size, false);
43 } 43 }
44 static void* allocateObject(size_t size, bool isEager) 44 static void* allocateObject(size_t size, bool isEager)
45 { 45 {
46 ThreadState* state = ThreadStateFor<ThreadingTrait<CSSValue>::Affinity>: :state(); 46 ThreadState* state = ThreadStateFor<ThreadingTrait<CSSValue>::Affinity>: :state();
47 return Heap::allocateOnHeapIndex(state, size, isEager ? BlinkGC::EagerSw eepHeapIndex : BlinkGC::CSSValueHeapIndex, GCInfoTrait<CSSValue>::index()); 47 const char* typeName = WTF_HEAP_PROFILER_TYPE_NAME(CSSValue);
Primiano Tucci (use gerrit) 2016/02/29 17:23:14 Considering that IIUC this is a pretty heavy user
hajimehoshi 2016/03/03 10:12:31 Right. It'd be best if we could get children class
48 return Heap::allocateOnHeapIndex(state, size, isEager ? BlinkGC::EagerSw eepHeapIndex : BlinkGC::CSSValueHeapIndex, GCInfoTrait<CSSValue>::index(), typeN ame);
48 } 49 }
49 #else 50 #else
50 USING_FAST_MALLOC_WITH_TYPE_NAME(blink::CSSValue); 51 USING_FAST_MALLOC_WITH_TYPE_NAME(blink::CSSValue);
51 public: 52 public:
52 // Override RefCounted's deref() to ensure operator delete is called on 53 // Override RefCounted's deref() to ensure operator delete is called on
53 // the appropriate subclass type. 54 // the appropriate subclass type.
54 void deref() 55 void deref()
55 { 56 {
56 if (derefBase()) 57 if (derefBase())
57 destroy(); 58 destroy();
(...skipping 209 matching lines...) Expand 10 before | Expand all | Expand 10 after
267 return false; 268 return false;
268 return first->equals(*second); 269 return first->equals(*second);
269 } 270 }
270 271
271 #define DEFINE_CSS_VALUE_TYPE_CASTS(thisType, predicate) \ 272 #define DEFINE_CSS_VALUE_TYPE_CASTS(thisType, predicate) \
272 DEFINE_TYPE_CASTS(thisType, CSSValue, value, value->predicate, value.predica te) 273 DEFINE_TYPE_CASTS(thisType, CSSValue, value, value->predicate, value.predica te)
273 274
274 } // namespace blink 275 } // namespace blink
275 276
276 #endif // CSSValue_h 277 #endif // CSSValue_h
OLDNEW
« no previous file with comments | « no previous file | third_party/WebKit/Source/core/dom/Node.h » ('j') | third_party/WebKit/Source/core/dom/Node.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698