blob: 3082acad53961b352ad5693b483214eee9ab32e1 [file] [log] [blame]
/*
* Copyright (C) 2011 Google Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
*
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE AND ITS CONTRIBUTORS "AS IS" AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL APPLE OR ITS CONTRIBUTORS BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef THIRD_PARTY_BLINK_RENDERER_MODULES_INDEXEDDB_IDB_KEY_H_
#define THIRD_PARTY_BLINK_RENDERER_MODULES_INDEXEDDB_IDB_KEY_H_
#include <memory>
#include <utility>
#include "base/macros.h"
#include "base/memory/ptr_util.h"
#include "base/memory/scoped_refptr.h"
#include "third_party/blink/public/platform/modules/indexeddb/web_idb_key.h"
#include "third_party/blink/public/platform/web_vector.h"
#include "third_party/blink/renderer/modules/modules_export.h"
#include "third_party/blink/renderer/platform/shared_buffer.h"
#include "third_party/blink/renderer/platform/wtf/forward.h"
#include "third_party/blink/renderer/platform/wtf/text/wtf_string.h"
#include "third_party/blink/renderer/platform/wtf/vector.h"
namespace blink {
// An IndexedDB primary or index key.
//
// The IndexedDB backing store regards script values written as object store
// record values as fairly opaque data (see IDBValue and IDBValueWrapping).
// However, it needs a fair amount of visibility into script values used as
// primary keys and index keys. For this reason, keys are represented using a
// dedicated data type that fully exposes its contents to the backing store.
class MODULES_EXPORT IDBKey {
public:
typedef Vector<std::unique_ptr<IDBKey>> KeyArray;
static std::unique_ptr<IDBKey> CreateInvalid() {
return base::WrapUnique(new IDBKey());
}
static std::unique_ptr<IDBKey> CreateNumber(double number) {
return base::WrapUnique(new IDBKey(kNumberType, number));
}
static std::unique_ptr<IDBKey> CreateBinary(
scoped_refptr<SharedBuffer> binary) {
return base::WrapUnique(new IDBKey(std::move(binary)));
}
static std::unique_ptr<IDBKey> CreateString(const String& string) {
return base::WrapUnique(new IDBKey(string));
}
static std::unique_ptr<IDBKey> CreateDate(double date) {
return base::WrapUnique(new IDBKey(kDateType, date));
}
static std::unique_ptr<IDBKey> CreateArray(KeyArray array) {
return base::WrapUnique(new IDBKey(std::move(array)));
}
~IDBKey();
// In order of the least to the highest precedent in terms of sort order.
// These values are written to logs. New enum values can be added, but
// existing enums must never be renumbered or deleted and reused.
enum Type {
kInvalidType = 0,
kArrayType = 1,
kBinaryType = 2,
kStringType = 3,
kDateType = 4,
kNumberType = 5,
kTypeEnumMax,
};
Type GetType() const { return type_; }
bool IsValid() const;
const KeyArray& Array() const {
DCHECK_EQ(type_, kArrayType);
return array_;
}
scoped_refptr<SharedBuffer> Binary() const {
DCHECK_EQ(type_, kBinaryType);
return binary_;
}
const String& GetString() const {
DCHECK_EQ(type_, kStringType);
return string_;
}
double Date() const {
DCHECK_EQ(type_, kDateType);
return number_;
}
double Number() const {
DCHECK_EQ(type_, kNumberType);
return number_;
}
int Compare(const IDBKey* other) const;
bool IsLessThan(const IDBKey* other) const;
bool IsEqual(const IDBKey* other) const;
// Returns a new key array with invalid keys and duplicates removed.
//
// The items in the key array are moved out of the given IDBKey, which must be
// an array. For this reason, the method is a static method that receives its
// argument via an std::unique_ptr.
//
// The return value will be pasesd to the backing store, which requires
// Web types. Returning the correct types directly avoids copying later on
// (wasted CPU cycles and code size).
static WebVector<WebIDBKey> ToMultiEntryArray(
std::unique_ptr<IDBKey> array_key);
private:
DISALLOW_COPY_AND_ASSIGN(IDBKey);
IDBKey() : type_(kInvalidType) {}
IDBKey(Type type, double number) : type_(type), number_(number) {}
explicit IDBKey(const class String& value)
: type_(kStringType), string_(value) {}
explicit IDBKey(scoped_refptr<SharedBuffer> value)
: type_(kBinaryType), binary_(std::move(value)) {}
explicit IDBKey(KeyArray key_array)
: type_(kArrayType), array_(std::move(key_array)) {}
Type type_;
KeyArray array_;
scoped_refptr<SharedBuffer> binary_;
const class String string_;
const double number_ = 0;
};
} // namespace blink
#endif // THIRD_PARTY_BLINK_RENDERER_MODULES_INDEXEDDB_IDB_KEY_H_