diff options
Diffstat (limited to 'js/src/builtin/streams/ReadableStreamBYOBReader.cpp')
-rw-r--r-- | js/src/builtin/streams/ReadableStreamBYOBReader.cpp | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/js/src/builtin/streams/ReadableStreamBYOBReader.cpp b/js/src/builtin/streams/ReadableStreamBYOBReader.cpp new file mode 100644 index 0000000000..9d8225dde4 --- /dev/null +++ b/js/src/builtin/streams/ReadableStreamBYOBReader.cpp @@ -0,0 +1,51 @@ +/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- + * vim: set ts=8 sts=2 et sw=2 tw=80: + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +/* + * Class ReadableStreamBYOBReader. + * + * Byte streams and BYOB readers are unimplemented, so this is skeletal -- yet + * helpful to ensure certain trivial tests of the functionality in wpt, that + * don't actually test fully-constructed byte streams/BYOB readers, pass. 🙄 + */ + +#include "mozilla/Attributes.h" // MOZ_MUST_USE + +#include "jsapi.h" // JS_ReportErrorNumberASCII + +#include "builtin/streams/ReadableStream.h" // js::ReadableStream +#include "builtin/streams/ReadableStreamReader.h" // js::CreateReadableStreamBYOBReader, js::ForAuthorCodeBool +#include "js/friend/ErrorMessages.h" // js::GetErrorMessage, JSMSG_* + +using JS::Handle; + +/*** 3.7. Class ReadableStreamBYOBReader *********************************/ + +/** + * Stream spec, 3.7.3. new ReadableStreamBYOBReader ( stream ) + * Steps 2-5. + */ +MOZ_MUST_USE JSObject* js::CreateReadableStreamBYOBReader( + JSContext* cx, Handle<ReadableStream*> unwrappedStream, + ForAuthorCodeBool forAuthorCode, Handle<JSObject*> proto /* = nullptr */) { + // Step 2: If ! IsReadableByteStreamController( + // stream.[[readableStreamController]]) is false, throw a + // TypeError exception. + // We don't implement byte stream controllers yet, so always throw here. Note + // that JSMSG_READABLESTREAM_BYTES_TYPE_NOT_IMPLEMENTED can't be used here + // because it's a RangeError (and sadly wpt actually tests this and we have a + // spurious failure if we don't make this a TypeError). + JS_ReportErrorNumberASCII( + cx, GetErrorMessage, nullptr, + JSMSG_READABLESTREAM_BYOB_READER_FOR_NON_BYTE_STREAM); + + // Step 3: If ! IsReadableStreamLocked(stream) is true, throw a TypeError + // exception. + // Step 4: Perform ! ReadableStreamReaderGenericInitialize(this, stream). + // Step 5: Set this.[[readIntoRequests]] to a new empty List. + // Steps 3-5 are presently unreachable. + return nullptr; +} |