gecko-dev/dom/indexedDB/KeyPath.h
Simon Giesecke 9350e6b741 Bug 1613985 - Use MOZ_COUNTED_DEFAULT_CTOR_*/MOZ_COUNTED_DTOR_* macros. r=froydnj
This removes the need for explicit #ifdef NS_BUILD_REFCNT_LOGGING without
introducing user-defined destructors when it is not defined.

Also, some uses of virtual for declaring destructors are replaced by the
appropriate override declaration through these changes.

Differential Revision: https://phabricator.services.mozilla.com/D62604

--HG--
extra : moz-landing-system : lando
2020-02-20 11:40:14 +00:00

98 lines
2.9 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 mozilla_dom_indexeddb_keypath_h__
#define mozilla_dom_indexeddb_keypath_h__
#include "mozilla/dom/BindingDeclarations.h"
#include "mozilla/dom/Nullable.h"
namespace mozilla {
namespace dom {
class OwningStringOrStringSequence;
namespace indexedDB {
class IndexMetadata;
class Key;
class ObjectStoreMetadata;
class KeyPath {
// This private constructor is only to be used by IPDL-generated classes.
friend class IndexMetadata;
friend class ObjectStoreMetadata;
KeyPath() : mType(NONEXISTENT) { MOZ_COUNT_CTOR(KeyPath); }
public:
enum KeyPathType { NONEXISTENT, STRING, ARRAY, ENDGUARD };
void SetType(KeyPathType aType);
bool AppendStringWithValidation(const nsAString& aString);
explicit KeyPath(int aDummy) : mType(NONEXISTENT) { MOZ_COUNT_CTOR(KeyPath); }
KeyPath(const KeyPath& aOther) {
MOZ_COUNT_CTOR(KeyPath);
*this = aOther;
}
MOZ_COUNTED_DTOR(KeyPath)
static nsresult Parse(const nsAString& aString, KeyPath* aKeyPath);
static nsresult Parse(const Sequence<nsString>& aStrings, KeyPath* aKeyPath);
static nsresult Parse(const Nullable<OwningStringOrStringSequence>& aValue,
KeyPath* aKeyPath);
nsresult ExtractKey(JSContext* aCx, const JS::Value& aValue, Key& aKey) const;
nsresult ExtractKeyAsJSVal(JSContext* aCx, const JS::Value& aValue,
JS::Value* aOutVal) const;
typedef nsresult (*ExtractOrCreateKeyCallback)(JSContext* aCx,
void* aClosure);
nsresult ExtractOrCreateKey(JSContext* aCx, const JS::Value& aValue,
Key& aKey, ExtractOrCreateKeyCallback aCallback,
void* aClosure) const;
inline bool IsValid() const { return mType != NONEXISTENT; }
inline bool IsArray() const { return mType == ARRAY; }
inline bool IsString() const { return mType == STRING; }
inline bool IsEmpty() const {
return mType == STRING && mStrings[0].IsEmpty();
}
bool operator==(const KeyPath& aOther) const {
return mType == aOther.mType && mStrings == aOther.mStrings;
}
void SerializeToString(nsAString& aString) const;
static KeyPath DeserializeFromString(const nsAString& aString);
nsresult ToJSVal(JSContext* aCx, JS::MutableHandle<JS::Value> aValue) const;
nsresult ToJSVal(JSContext* aCx, JS::Heap<JS::Value>& aValue) const;
bool IsAllowedForObjectStore(bool aAutoIncrement) const;
KeyPathType mType;
nsTArray<nsString> mStrings;
};
} // namespace indexedDB
} // namespace dom
} // namespace mozilla
#endif // mozilla_dom_indexeddb_keypath_h__