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 (995b67ef37a9)

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
/* -*- 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 final : 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