Chromium Code Reviews| Index: Source/core/dom/DOMArrayBuffer.h |
| diff --git a/Source/core/dom/DOMArrayBuffer.h b/Source/core/dom/DOMArrayBuffer.h |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..536c4970f9553e70ffeff9c5a2f4629489d586fb |
| --- /dev/null |
| +++ b/Source/core/dom/DOMArrayBuffer.h |
| @@ -0,0 +1,65 @@ |
| +// Copyright 2014 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 DOMArrayBuffer_h |
| +#define DOMArrayBuffer_h |
| + |
| +#include "bindings/core/v8/ScriptWrappable.h" |
| +#include "wtf/ArrayBuffer.h" |
| +#include "wtf/RefCounted.h" |
| + |
| +namespace blink { |
| + |
| +class DOMArrayBuffer : public RefCounted<DOMArrayBuffer>, public ScriptWrappable { |
|
haraken
2014/10/16 05:41:41
Can we add final?
Yuki
2014/10/16 14:21:51
Done.
|
| + DEFINE_WRAPPERTYPEINFO(); |
| +public: |
| + static PassRefPtr<DOMArrayBuffer> create(PassRefPtr<WTF::ArrayBuffer> buffer) |
| + { |
| + if (!buffer) |
|
haraken
2014/10/16 05:41:41
Can this happen? It's nasty that a create method c
tyoshino (SeeGerritForStatus)
2014/10/16 06:39:15
ArrayBuffer::create() returns null when it fails t
Yuki
2014/10/16 14:21:51
IIRC, XMLHttpRequest also treats nullptr to ArrayB
|
| + return nullptr; |
| + return adoptRef(new DOMArrayBuffer(buffer)); |
| + } |
| + static PassRefPtr<DOMArrayBuffer> create(unsigned numElements, unsigned elementByteSize) |
| + { |
| + return adoptRef(new DOMArrayBuffer(WTF::ArrayBuffer::create(numElements, elementByteSize))); |
| + } |
| + static PassRefPtr<DOMArrayBuffer> create(const void* source, unsigned byteLength) |
| + { |
| + return adoptRef(new DOMArrayBuffer(WTF::ArrayBuffer::create(source, byteLength))); |
| + } |
| + static PassRefPtr<DOMArrayBuffer> create(WTF::ArrayBufferContents& contents) |
| + { |
| + return adoptRef(new DOMArrayBuffer(WTF::ArrayBuffer::create(contents))); |
| + } |
| + |
| + const WTF::ArrayBuffer* buffer() const { return m_buffer.get(); } |
| + WTF::ArrayBuffer* buffer() { return m_buffer.get(); } |
| + |
| + const void* data() const { return buffer()->data(); } |
| + unsigned long byteLength() const { return buffer()->byteLength(); } |
| + void* data() { return buffer()->data(); } |
| + bool transfer(WTF::ArrayBufferContents& result) { return buffer()->transfer(result); } |
| + bool isNeutered() { return buffer()->isNeutered(); } |
| + void setDeallocationObserver(WTF::ArrayBufferDeallocationObserver* observer) |
| + { |
| + buffer()->setDeallocationObserver(observer); |
| + } |
| + |
| + virtual v8::Handle<v8::Object> wrap(v8::Handle<v8::Object> creationContext, v8::Isolate*) override; |
| + virtual v8::Handle<v8::Object> associateWithWrapper(const WrapperTypeInfo*, v8::Handle<v8::Object> wrapper, v8::Isolate*) override; |
| + |
| +protected: |
|
haraken
2014/10/16 05:41:41
DOMArrayBuffer isn't inherited, so protected won't
Yuki
2014/10/16 14:21:51
It's because I don't have any reason to make this
|
| + explicit DOMArrayBuffer(PassRefPtr<WTF::ArrayBuffer> buffer) |
| + : m_buffer(buffer) |
| + { |
| + ASSERT(m_buffer); |
| + } |
| + |
| +private: |
| + RefPtr<WTF::ArrayBuffer> m_buffer; |
| +}; |
| + |
| +} // namespace blink |
| + |
| +#endif // DOMArrayBuffer_h |