-
Notifications
You must be signed in to change notification settings - Fork 54
/
Copy pathDeletePolicy.h
77 lines (65 loc) · 2.48 KB
/
DeletePolicy.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
* vim: set ts=8 sts=2 et sw=2 tw=80:
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef gc_DeletePolicy_h
#define gc_DeletePolicy_h
#include "js/TracingAPI.h"
namespace js {
namespace gc {
struct ClearEdgesTracer : public JS::CallbackTracer {
ClearEdgesTracer();
#ifdef DEBUG
TracerKind getTracerKind() const override { return TracerKind::ClearEdges; }
#endif
template <typename T>
inline void clearEdge(T** thingp);
void onObjectEdge(JSObject** objp) override;
void onStringEdge(JSString** strp) override;
void onSymbolEdge(JS::Symbol** symp) override;
void onBigIntEdge(JS::BigInt** bip) override;
void onScriptEdge(JSScript** scriptp) override;
void onShapeEdge(js::Shape** shapep) override;
void onObjectGroupEdge(js::ObjectGroup** groupp) override;
void onBaseShapeEdge(js::BaseShape** basep) override;
void onJitCodeEdge(js::jit::JitCode** codep) override;
void onLazyScriptEdge(js::LazyScript** lazyp) override;
void onScopeEdge(js::Scope** scopep) override;
void onRegExpSharedEdge(js::RegExpShared** sharedp) override;
void onChild(const JS::GCCellPtr& thing) override;
};
#ifdef DEBUG
inline bool IsClearEdgesTracer(JSTracer* trc) {
return trc->isCallbackTracer() &&
trc->asCallbackTracer()->getTracerKind() ==
JS::CallbackTracer::TracerKind::ClearEdges;
}
#endif
} // namespace gc
/*
* Provides a delete policy that can be used for objects which have their
* lifetime managed by the GC so they can be safely destroyed outside of GC.
*
* This is necessary for example when initializing such an object may fail after
* the initial allocation. The partially-initialized object must be destroyed,
* but it may not be safe to do so at the current time as the store buffer may
* contain pointers into it.
*
* This policy traces GC pointers in the object and clears them, making sure to
* trigger barriers while doing so. This will remove any store buffer pointers
* into the object and make it safe to delete.
*/
template <typename T>
struct GCManagedDeletePolicy {
void operator()(const T* constPtr) {
if (constPtr) {
auto ptr = const_cast<T*>(constPtr);
gc::ClearEdgesTracer trc;
ptr->trace(&trc);
js_delete(ptr);
}
}
};
} // namespace js
#endif // gc_DeletePolicy_h