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

Unified Diff: Source/core/dom/DOMSharedArrayBuffer.h

Issue 1097773004: Sharing of SharedArrayBuffer via PostMessage transfer (Closed) Base URL: https://chromium.googlesource.com/chromium/blink.git@master
Patch Set: update for non-split typedarray hierarchy Created 5 years, 6 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: Source/core/dom/DOMSharedArrayBuffer.h
diff --git a/Source/core/dom/DOMSharedArrayBuffer.h b/Source/core/dom/DOMSharedArrayBuffer.h
new file mode 100644
index 0000000000000000000000000000000000000000..32ff02dfb5b74a89094b837d2234c0339c53ad06
--- /dev/null
+++ b/Source/core/dom/DOMSharedArrayBuffer.h
@@ -0,0 +1,50 @@
+// Copyright 2015 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 DOMSharedArrayBuffer_h
+#define DOMSharedArrayBuffer_h
+
+#include "core/CoreExport.h"
+#include "core/dom/DOMArrayBufferBase.h"
+#include "wtf/ArrayBuffer.h"
+
+namespace blink {
+
+class CORE_EXPORT DOMSharedArrayBuffer final : public DOMArrayBufferBase {
+ DEFINE_WRAPPERTYPEINFO();
+public:
+ static PassRefPtr<DOMSharedArrayBuffer> create(PassRefPtr<WTF::ArrayBuffer> buffer)
+ {
+ // TODO(binji): Would be nice to be able to check this at compile time.
+ ASSERT(buffer->isShared());
+ return adoptRef(new DOMSharedArrayBuffer(buffer));
+ }
+ static PassRefPtr<DOMSharedArrayBuffer> create(unsigned numElements, unsigned elementByteSize)
+ {
+ return create(WTF::ArrayBuffer::createShared(numElements, elementByteSize));
+ }
+ static PassRefPtr<DOMSharedArrayBuffer> create(const void* source, unsigned byteLength)
+ {
+ return create(WTF::ArrayBuffer::createShared(source, byteLength));
+ }
+ static PassRefPtr<DOMSharedArrayBuffer> create(WTF::ArrayBufferContents& contents)
+ {
+ // TODO(binji): Would be nice to be able to check this at compile time.
+ ASSERT(contents.isShared());
+ return create(WTF::ArrayBuffer::create(contents));
+ }
+
+ virtual v8::Handle<v8::Object> wrap(v8::Isolate*, v8::Handle<v8::Object> creationContext) override;
Yuki 2015/06/09 06:18:07 nit: 'virtual' is no longer needed when you have '
binji 2015/06/10 06:04:39 Done.
+ virtual v8::Handle<v8::Object> associateWithWrapper(v8::Isolate*, const WrapperTypeInfo*, v8::Handle<v8::Object> wrapper) override;
+
+private:
+ explicit DOMSharedArrayBuffer(PassRefPtr<WTF::ArrayBuffer> buffer)
+ : DOMArrayBufferBase(buffer)
+ {
+ }
+};
+
+} // namespace blink
+
+#endif // DOMSharedArrayBuffer_h

Powered by Google App Engine
This is Rietveld 408576698