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

Unified Diff: extensions/renderer/blob_native_handler.cc

Issue 250143002: Media Galleries API: Audio/Video attached pictures support. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Create Blobs on browser-process, eliminating two IPC copies. Created 6 years, 8 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: extensions/renderer/blob_native_handler.cc
diff --git a/extensions/renderer/blob_native_handler.cc b/extensions/renderer/blob_native_handler.cc
index c887af63f67aa23d73089ac876e0db794f9ec451..dd10289d21a3f38e992a50b21bac4bef15dccefd 100644
--- a/extensions/renderer/blob_native_handler.cc
+++ b/extensions/renderer/blob_native_handler.cc
@@ -5,6 +5,8 @@
#include "extensions/renderer/blob_native_handler.h"
#include "base/bind.h"
+#include "third_party/WebKit/public/platform/Platform.h"
+#include "third_party/WebKit/public/platform/WebBlobRegistry.h"
#include "third_party/WebKit/public/platform/WebCString.h"
#include "third_party/WebKit/public/platform/WebURL.h"
#include "third_party/WebKit/public/web/WebBlob.h"
@@ -19,6 +21,26 @@ void GetBlobUuid(const v8::FunctionCallbackInfo<v8::Value>& args) {
v8::String::NewFromUtf8(args.GetIsolate(), blob.uuid().utf8().data()));
}
+// Take ownership of a Blob created on the browse process. Expects the Blob's
+// UUID, type, and size as arguments.
+void TakeBrowserProcessBlob(const v8::FunctionCallbackInfo<v8::Value>& args) {
+ DCHECK_EQ(3, args.Length());
+ DCHECK(args[0]->IsString());
+ DCHECK(args[1]->IsString());
+ DCHECK(args[2]->IsInt32());
+ std::string uuid(*v8::String::Utf8Value(args[0]->ToString()));
+ std::string type(*v8::String::Utf8Value(args[1]->ToString()));
+ blink::WebBlob blob = blink::WebBlob::createFromUUID(
+ blink::WebString::fromUTF8(uuid), blink::WebString::fromUTF8(type),
+ args[2]->Int32Value());
+ args.GetReturnValue().Set(blob.toV8Value());
+
+ // Need to decrement the refcount to compensate for the extra count left over
tommycli 2014/04/29 23:29:26 This is also janky, but necessary to keep the refc
michaeln 2014/05/01 21:27:35 This new case of creating a blob in the browser an
+ // from the construction process in the browser side.
+ blink::Platform::current()->blobRegistry()->removeBlobDataRef(
+ blink::WebString::fromUTF8(uuid));
+}
+
} // namespace
namespace extensions {
@@ -26,6 +48,7 @@ namespace extensions {
BlobNativeHandler::BlobNativeHandler(ScriptContext* context)
: ObjectBackedNativeHandler(context) {
RouteFunction("GetBlobUuid", base::Bind(&GetBlobUuid));
+ RouteFunction("TakeBrowserProcessBlob", base::Bind(&TakeBrowserProcessBlob));
}
} // namespace extensions

Powered by Google App Engine
This is Rietveld 408576698