fune/dom/base/nsNameSpaceManager.h
Simon Giesecke ad01a10a3b Bug 1634281 - Use nsTHashMap instead of nsDataHashtable. r=xpcom-reviewers,necko-reviewers,jgilbert,nika,valentin
Note that this patch only transforms the use of the nsDataHashtable type alias
to a directly equivalent use of nsTHashMap. It does not change the specification
of the hash key type to make use of the key class deduction that nsTHashMap
allows for in some cases. That can be done in a separate step, but requires more
attention.

Differential Revision: https://phabricator.services.mozilla.com/D106008
2021-03-10 10:47:47 +00:00

84 lines
3 KiB
C++

/* -*- 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 nsNameSpaceManager_h___
#define nsNameSpaceManager_h___
#include "nsTHashMap.h"
#include "nsHashKeys.h"
#include "nsAtom.h"
#include "nsStringFwd.h"
#include "nsTArray.h"
#include "mozilla/StaticPtr.h"
/**
* The Name Space Manager tracks the association between a NameSpace
* URI and the int32_t runtime id. Mappings between NameSpaces and
* NameSpace prefixes are managed by nsINameSpaces.
*
* All NameSpace URIs are stored in a global table so that IDs are
* consistent accross the app. NameSpace IDs are only consistent at runtime
* ie: they are not guaranteed to be consistent accross app sessions.
*
* The nsNameSpaceManager needs to have a live reference for as long as
* the NameSpace IDs are needed.
*
*/
class nsNameSpaceManager final {
public:
NS_INLINE_DECL_REFCOUNTING(nsNameSpaceManager)
virtual nsresult RegisterNameSpace(const nsAString& aURI,
int32_t& aNameSpaceID);
nsresult RegisterNameSpace(already_AddRefed<nsAtom> aURI,
int32_t& aNameSpaceID);
virtual nsresult GetNameSpaceURI(int32_t aNameSpaceID, nsAString& aURI);
// Returns the atom for the namespace URI associated with the given ID. The
// ID must be within range and not be kNameSpaceID_None (i.e. zero);
//
// NB: The requirement of mapping from the first entry to the empty atom is
// necessary for Servo, though it can be removed if needed adding a branch in
// GeckoElement::get_namespace().
nsAtom* NameSpaceURIAtom(int32_t aNameSpaceID) {
MOZ_ASSERT(aNameSpaceID > 0);
MOZ_ASSERT((int64_t)aNameSpaceID < (int64_t)mURIArray.Length());
return mURIArray.ElementAt(aNameSpaceID);
}
int32_t GetNameSpaceID(const nsAString& aURI, bool aInChromeDoc);
int32_t GetNameSpaceID(nsAtom* aURI, bool aInChromeDoc);
static const char* GetNameSpaceDisplayName(uint32_t aNameSpaceID);
bool HasElementCreator(int32_t aNameSpaceID);
static nsNameSpaceManager* GetInstance();
bool mMathMLDisabled;
bool mSVGDisabled;
private:
static void PrefChanged(const char* aPref, void* aSelf);
void PrefChanged(const char* aPref);
bool Init();
nsresult AddNameSpace(already_AddRefed<nsAtom> aURI,
const int32_t aNameSpaceID);
nsresult AddDisabledNameSpace(already_AddRefed<nsAtom> aURI,
const int32_t aNameSpaceID);
~nsNameSpaceManager() = default;
nsTHashMap<nsRefPtrHashKey<nsAtom>, int32_t> mURIToIDTable;
nsTHashMap<nsRefPtrHashKey<nsAtom>, int32_t> mDisabledURIToIDTable;
nsTArray<RefPtr<nsAtom>> mURIArray;
static mozilla::StaticRefPtr<nsNameSpaceManager> sInstance;
};
#endif // nsNameSpaceManager_h___