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.

Implementation

Mercurial (56e7b9127e89)

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
/* -*- 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 dom_NodeUbiReporting_h
#define dom_NodeUbiReporting_h

#include "nsINode.h"
#include "js/UbiNode.h"

/*
 * This file defines specializations of JS::ubi::Concrete for DOM nodes
 * so that the JS memory tools, which operate on the UbiNode graph, can
 * define subclasses of JS::ubi::Base that represent DOM nodes and
 * yield the outgoing edges in a DOM node graph for reporting.
*/

using mozilla::dom::Attr;

namespace JS {
namespace ubi {

// The DOM node base class.
// This is an abstract class and therefore does not require a concreteTypeName.
template<>
class Concrete<nsINode> : public Base
{
protected:
  explicit Concrete(nsINode *ptr) : Base(ptr) { }

public:
  static void construct(void *storage, nsINode *ptr);
  Size size(mozilla::MallocSizeOf mallocSizeOf) const override;
  js::UniquePtr<EdgeRange> edges(JSContext* cx, bool wantNames) const override;

  nsINode& get() const { return *static_cast<nsINode*>(ptr); }
  CoarseType coarseType() const final { return CoarseType::DOMNode; }
  const char16_t* descriptiveTypeName() const override;
};

template<>
class Concrete<nsIContent> : public Concrete<nsINode>
{
protected:
  explicit Concrete(nsIContent *ptr) : Concrete<nsINode>(ptr) { }

public:
  static void construct(void *storage, nsIContent *ptr) { new (storage) Concrete(ptr); }
  const char16_t* typeName() const override { return concreteTypeName; };
  static const char16_t concreteTypeName[];
};

template<>
class Concrete<nsIDocument> : public Concrete<nsINode>
{
protected:
  explicit Concrete(nsIDocument *ptr) : Concrete<nsINode>(ptr) { }

public:
  static void construct(void *storage, nsIDocument *ptr) { new (storage) Concrete(ptr); }
  Size size(mozilla::MallocSizeOf mallocSizeOf) const override;

  nsIDocument& getDoc() const { return *static_cast<nsIDocument*>(ptr); }
  const char16_t* typeName() const override { return concreteTypeName; };
  static const char16_t concreteTypeName[];
};

template<>
class Concrete<Attr> : public Concrete<nsINode>
{
protected:
  explicit Concrete(Attr *ptr) : Concrete<nsINode>(ptr) { }

public:
  static void construct(void *storage, Attr *ptr) { new (storage) Concrete(ptr); }
  const char16_t* typeName() const override { return concreteTypeName; };
  static const char16_t concreteTypeName[];
};

} //namespace ubi
} //namespace JS

#endif