Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(1011)

Unified Diff: content/child/indexed_db/indexed_db_callbacks_impl.h

Issue 2370643004: Port messages sent by WebIDBFactoryImpl to Mojo. (Closed)
Patch Set: Require explicit wrapping when discarding map keys. Created 4 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/child/indexed_db/indexed_db_callbacks_impl.h
diff --git a/content/child/indexed_db/indexed_db_callbacks_impl.h b/content/child/indexed_db/indexed_db_callbacks_impl.h
new file mode 100644
index 0000000000000000000000000000000000000000..7e38b8359b48a2197c525e838dcda0573be426ee
--- /dev/null
+++ b/content/child/indexed_db/indexed_db_callbacks_impl.h
@@ -0,0 +1,56 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CONTENT_CHILD_INDEXED_DB_INDEXED_DB_CALLBACKS_IMPL_H_
+#define CONTENT_CHILD_INDEXED_DB_INDEXED_DB_CALLBACKS_IMPL_H_
+
+#include "content/common/indexed_db/indexed_db.mojom.h"
+#include "mojo/public/cpp/bindings/associated_binding.h"
+
+namespace blink {
+class WebIDBCallbacks;
+}
+
+namespace content {
+
+class ThreadSafeSender;
+
+// Implements the child-process end of the pipe used to deliver callbacks. It
+// is owned by the IO thread. |callback_runner_| is used to post tasks back to
+// the thread which owns the blink::WebIDBCallbacks.
+class IndexedDBCallbacksImpl : public indexed_db::mojom::Callbacks {
+ public:
+ IndexedDBCallbacksImpl(blink::WebIDBCallbacks* callbacks,
+ scoped_refptr<ThreadSafeSender> thread_safe_sender);
+ ~IndexedDBCallbacksImpl() override;
+
+ // indexed_db::mojom::Callbacks implementation:
+ void Error(int32_t code, const base::string16& message) override;
+ void SuccessStringList(const std::vector<base::string16>& value) override;
+ void Blocked(int64_t existing_version) override;
+ void UpgradeNeeded(
+ int32_t database_id,
+ int64_t old_version,
+ blink::WebIDBDataLoss data_loss,
+ const std::string& data_loss_message,
+ const content::IndexedDBDatabaseMetadata& metadata) override;
+ void SuccessDatabase(
+ int32_t database_id,
+ const content::IndexedDBDatabaseMetadata& metadata) override;
+ void SuccessInteger(int64_t value) override;
+
+ private:
+ class InternalState;
+
+ // |internal_state_| is owned by the thread on which |callback_runner_|
+ // executes tasks and must be destroyed there.
+ InternalState* internal_state_;
+ scoped_refptr<base::SingleThreadTaskRunner> callback_runner_;
+
+ DISALLOW_COPY_AND_ASSIGN(IndexedDBCallbacksImpl);
+};
+
+} // namespace content
+
+#endif // CONTENT_CHILD_INDEXED_DB_INDEXED_DB_CALLBACKS_IMPL_H_

Powered by Google App Engine
This is Rietveld 408576698