DXR is a code search and navigation tool aimed at making sense of large projects. It supports full-text and regex searches as well as structural queries.

Mercurial (409f3966645a)

VCS Links

Line Code
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 78 79 80 81 82 83 84 85 86 87 88
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 4 -*-
 * vim: set ts=8 sts=4 et sw=4 tw=99:
 * 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"

#ifdef ENABLE_BIGINT
namespace JS {
class BigInt;
} // namespace JS
#endif

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;
#ifdef ENABLE_BIGINT
    void onBigIntEdge(JS::BigInt** bip) override;
#endif
    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