/* * Copyright (C) 2016 Apple Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS'' * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF * THE POSSIBILITY OF SUCH DAMAGE. */ #pragma once #include "root.h" #include "ZigGlobalObject.h" #include "JSDOMGlobalObject.h" #include "JSDOMExceptionHandling.h" #include namespace WebCore { // Conversion from JSValue -> Implementation template struct Converter; namespace Detail { template inline T* getPtrOrRef(const T* p) { return const_cast(p); } template inline T& getPtrOrRef(const T& p) { return const_cast(p); } template inline T* getPtrOrRef(const RefPtr& p) { return p.get(); } template inline T& getPtrOrRef(const Ref& p) { return p.get(); } } struct DefaultExceptionThrower { void operator()(JSC::JSGlobalObject& lexicalGlobalObject, JSC::ThrowScope& scope) { throwTypeError(&lexicalGlobalObject, scope); } }; template typename Converter::ReturnType convert(JSC::JSGlobalObject&, JSC::JSValue); template typename Converter::ReturnType convert(JSC::JSGlobalObject&, JSC::JSValue, JSC::JSObject&); template typename Converter::ReturnType convert(JSC::JSGlobalObject&, JSC::JSValue, JSDOMGlobalObject&); template typename Converter::ReturnType convert(JSC::JSGlobalObject&, JSC::JSValue, ExceptionThrower&&); template typename Converter::ReturnType convert(JSC::JSGlobalObject&, JSC::JSValue, JSC::JSObject&, ExceptionThrower&&); template typename Converter::ReturnType convert(JSC::JSGlobalObject&, JSC::JSValue, JSDOMGlobalObject&, ExceptionThrower&&); template inline typename Converter::ReturnType convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value) { return Converter::convert(lexicalGlobalObject, value); } template inline typename Converter::ReturnType convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value, JSC::JSObject& thisObject) { return Converter::convert(lexicalGlobalObject, value, thisObject); } template inline typename Converter::ReturnType convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value, JSDOMGlobalObject& globalObject) { return Converter::convert(lexicalGlobalObject, value, globalObject); } template inline typename Converter::ReturnType convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value, ExceptionThrower&& exceptionThrower) { return Converter::convert(lexicalGlobalObject, value, std::forward(exceptionThrower)); } template inline typename Converter::ReturnType convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value, JSC::JSObject& thisObject, ExceptionThrower&& exceptionThrower) { return Converter::convert(lexicalGlobalObject, value, thisObject, std::forward(exceptionThrower)); } template inline typename Converter::ReturnType convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value, JSDOMGlobalObject& globalObject, ExceptionThrower&& exceptionThrower) { return Converter::convert(lexicalGlobalObject, value, globalObject, std::forward(exceptionThrower)); } // Conversion from Implementation -> JSValue template struct JSConverter; template inline JSC::JSValue toJS(U&&); template inline JSC::JSValue toJS(JSC::JSGlobalObject&, U&&); template inline JSC::JSValue toJS(JSC::JSGlobalObject&, JSDOMGlobalObject&, U&&); template inline JSC::JSValue toJSNewlyCreated(JSC::JSGlobalObject&, JSDOMGlobalObject&, U&&); template inline JSC::JSValue toJS(JSC::JSGlobalObject&, JSC::ThrowScope&, U&& valueOrFunctor); template inline JSC::JSValue toJS(JSC::JSGlobalObject&, JSDOMGlobalObject&, JSC::ThrowScope&, U&& valueOrFunctor); template inline JSC::JSValue toJSNewlyCreated(JSC::JSGlobalObject&, JSDOMGlobalObject&, JSC::ThrowScope&, U&& valueOrFunctor); template::needsState, bool needsGlobalObject = JSConverter::needsGlobalObject> struct JSConverterOverloader; template struct JSConverterOverloader { template static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, JSDOMGlobalObject& globalObject, U&& value) { return JSConverter::convert(lexicalGlobalObject, globalObject, std::forward(value)); } }; template struct JSConverterOverloader { template static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, U&& value) { return JSConverter::convert(lexicalGlobalObject, std::forward(value)); } template static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, JSDOMGlobalObject&, U&& value) { return JSConverter::convert(lexicalGlobalObject, std::forward(value)); } }; template struct JSConverterOverloader { template static JSC::JSValue convert(JSC::JSGlobalObject&, U&& value) { return JSConverter::convert(std::forward(value)); } template static JSC::JSValue convert(JSC::JSGlobalObject&, JSDOMGlobalObject&, U&& value) { return JSConverter::convert(std::forward(value)); } }; template inline JSC::JSValue toJS(U&& value) { return JSConverter::convert(std::forward(value)); } template inline JSC::JSValue toJS(JSC::JSGlobalObject& lexicalGlobalObject, U&& value) { return JSConverterOverloader::convert(lexicalGlobalObject, std::forward(value)); } template inline JSC::JSValue toJS(JSC::JSGlobalObject& lexicalGlobalObject, JSDOMGlobalObject& globalObject, U&& value) { return JSConverterOverloader::convert(lexicalGlobalObject, globalObject, std::forward(value)); } template inline JSC::JSValue toJSNewlyCreated(JSC::JSGlobalObject& lexicalGlobalObject, JSDOMGlobalObject& globalObject, U&& value) { return JSConverter::convertNewlyCreated(lexicalGlobalObject, globalObject, std::forward(value)); } template inline JSC::JSValue toJS(JSC::JSGlobalObject& lexicalGlobalObject, JSC::ThrowScope& throwScope, U&& valueOrFunctor) { if constexpr (std::is_invocable_v) { using FunctorReturnType = std::invoke_result_t; if constexpr (std::is_same_v) { valueOrFunctor(); return JSC::jsUndefined(); } else if constexpr (std::is_same_v, FunctorReturnType>) { auto result = valueOrFunctor(); if (UNLIKELY(result.hasException())) { propagateException(lexicalGlobalObject, throwScope, result.releaseException()); return {}; } return JSC::jsUndefined(); } else return toJS(lexicalGlobalObject, throwScope, valueOrFunctor()); } else { if constexpr (IsExceptionOr) { if (UNLIKELY(valueOrFunctor.hasException())) { propagateException(lexicalGlobalObject, throwScope, valueOrFunctor.releaseException()); return {}; } return toJS(lexicalGlobalObject, valueOrFunctor.releaseReturnValue()); } else return toJS(lexicalGlobalObject, std::forward(valueOrFunctor)); } } template inline JSC::JSValue toJS(JSC::JSGlobalObject& lexicalGlobalObject, JSDOMGlobalObject& globalObject, JSC::ThrowScope& throwScope, U&& valueOrFunctor) { if constexpr (std::is_invocable_v) { using FunctorReturnType = std::invoke_result_t; if constexpr (std::is_same_v) { valueOrFunctor(); return JSC::jsUndefined(); } else if constexpr (std::is_same_v, FunctorReturnType>) { auto result = valueOrFunctor(); if (UNLIKELY(result.hasException())) { propagateException(lexicalGlobalObject, throwScope, result.releaseException()); return {}; } return JSC::jsUndefined(); } else return toJS(lexicalGlobalObject, globalObject, throwScope, valueOrFunctor()); } else { if constexpr (IsExceptionOr) { if (UNLIKELY(valueOrFunctor.hasException())) { propagateException(lexicalGlobalObject, throwScope, valueOrFunctor.releaseException()); return {}; } return toJS(lexicalGlobalObject, globalObject, valueOrFunctor.releaseReturnValue()); } else return toJS(lexicalGlobalObject, globalObject, std::forward(valueOrFunctor)); } } template inline JSC::JSValue toJSNewlyCreated(JSC::JSGlobalObject& lexicalGlobalObject, JSDOMGlobalObject& globalObject, JSC::ThrowScope& throwScope, U&& valueOrFunctor) { if constexpr (std::is_invocable_v) { using FunctorReturnType = std::invoke_result_t; if constexpr (std::is_same_v) { valueOrFunctor(); return JSC::jsUndefined(); } else if constexpr (std::is_same_v, FunctorReturnType>) { auto result = valueOrFunctor(); if (UNLIKELY(result.hasException())) { propagateException(lexicalGlobalObject, throwScope, result.releaseException()); return {}; } return JSC::jsUndefined(); } else return toJSNewlyCreated(lexicalGlobalObject, globalObject, throwScope, valueOrFunctor()); } else { if constexpr (IsExceptionOr) { if (UNLIKELY(valueOrFunctor.hasException())) { propagateException(lexicalGlobalObject, throwScope, valueOrFunctor.releaseException()); return {}; } return toJSNewlyCreated(lexicalGlobalObject, globalObject, valueOrFunctor.releaseReturnValue()); } else return toJSNewlyCreated(lexicalGlobalObject, globalObject, std::forward(valueOrFunctor)); } } template struct DefaultConverter { using ReturnType = typename T::ImplementationType; // We assume the worst, subtypes can override to be less pessimistic. // An example of something that can have side effects // is having a converter that does JSC::JSValue::toNumber. // toNumber() in JavaScript can call arbitrary JS functions. // // An example of something that does not have side effects // is something having a converter that does JSC::JSValue::toBoolean. // toBoolean() in JS can't call arbitrary functions. static constexpr bool conversionHasSideEffects = true; }; // Conversion from JSValue -> Implementation for variadic arguments template struct VariadicConverter; } // namespace WebCores='sub'>Unnamed repository; edit this file 'description' to name the repository.
aboutsummaryrefslogtreecommitdiff
path: root/src (unfollow)
AgeCommit message (Expand)AuthorFilesLines
2023-10-18Adds macOS Keychain certs to default CA storeGravatar Anshul Gupta 2-2/+175
2023-10-18fix(node:buffer): fix the behavior of `totalLength` in `Buffer.concat` (#6574)Gravatar Ai Hoshino 2-3/+23
2023-10-18fix: change `--no-scripts` to `--ignore-scripts` (#6587)Gravatar Dawid Sowa 1-2/+2
2023-10-18fix: online docs moved (#6579)Gravatar Mountain/\Ash 1-1/+1
2023-10-18Fix minimum kernel version in docs (#6153)Gravatar Kevin Latka 1-1/+1
2023-10-18build-id++Gravatar Dylan Conway 1-1/+1
2023-10-18fix(web): stub `performance.getEntriesByName` (#6542)Gravatar Liz 1-0/+18
2023-10-17update root package variableGravatar Dylan Conway 1-8/+3
2023-10-17Fix missing `{port: 0}` causing flaky testGravatar Ashcon Partovi 1-0/+2
2023-10-17test changes in usockets in ciGravatar Dylan Conway 5-0/+9
2023-10-17fix #4766 (#6563)Gravatar Pierre CM 1-4/+4
2023-10-17Update ZigGeneratedClasses.cppGravatar Dylan Conway 1-2/+0
2023-10-17use npm alias in dependencies (#6545)Gravatar Dylan Conway 7-29/+271
2023-10-17fix(node:http): fix `server.address()` (#6442)Gravatar Ai Hoshino 12-12/+453
2023-10-17docs: fix ws.publish (#6558)Gravatar Aral Roca Gomez 1-1/+1
2023-10-17perf(bun-types): remove needless some call (#6550)Gravatar Mikhail 1-1/+1
2023-10-16fix(runtime): make some things more stable (partial jsc debug build) (#5881)Gravatar dave caruso 116-1446/+1830
2023-10-16fix(runtime): improve IPC reliability + organization pass on that code (#6475)Gravatar dave caruso 15-98/+266
2023-10-16Simplify getting Set of extentions (#4975)Gravatar Mikhail 1-3/+3
2023-10-16Fix formattingGravatar Ashcon Partovi 1-3/+1
2023-10-16fix(test): when tests run with --only the nested describe blocks `.on… (#5616)Gravatar Igor Shapiro 2-13/+45
2023-10-16perf(node:events): optimize `emit(...)` function (#5485)Gravatar Yannik Schröder 3-11/+132
2023-10-16fix: don't remove content-encoding header from header table (#5743)Gravatar Liz 2-2/+25
2023-10-16fix(sqlite) Insert .all() does not return an array #5872 (#5946)Gravatar Hugo Galan 2-7/+11
2023-10-16Fix formattingGravatar Ashcon Partovi 2-5/+4
2023-10-16Fix `Response.statusText` (#6151)Gravatar Chris Toshok 10-238/+269
2023-10-16fix-subprocess-argument-missing (#6407)Gravatar Nicolae-Rares Ailincai 4-2/+40
2023-10-16Add type parameter to `expect` (#6128)Gravatar Voldemat 1-3/+3
2023-10-16fix(node:worker_threads): ensure threadId property is exposed on worker_threa...Gravatar Jérôme Benoit 6-15/+75
2023-10-16Fix use before define bug in sqliteGravatar Ashcon Partovi 2-5/+5
2023-10-16fix(jest): fix toStrictEqual on same URLs (#6528)Gravatar João Alisson 2-13/+16
2023-10-16Fix `toHaveBeenCalled` having wrong error signatureGravatar Ashcon Partovi 1-2/+2
2023-10-16Fix formattingGravatar Ashcon Partovi 1-2/+1
2023-10-16Add `reusePort` to `Bun.serve` typesGravatar Ashcon Partovi 1-0/+9
2023-10-16Fix `request.url` having incorrect portGravatar Ashcon Partovi 4-1/+92
2023-10-16Remove uWebSockets header from Bun.serve responsesGravatar Ashcon Partovi 1-6/+6
2023-10-16Rename some testsGravatar Ashcon Partovi 3-0/+0
2023-10-16Fix #6467Gravatar Ashcon Partovi 2-3/+10
2023-10-16Update InternalModuleRegistryConstants.hGravatar Dylan Conway 1-3/+3
2023-10-16Development -> Contributing (#6538)Gravatar Colin McDonnell 2-1/+1
2023-10-14fix(net/tls) fix pg hang on end + hanging on query (#6487)Gravatar Ciro Spaciari 3-8/+36
2023-10-13fix installing dependencies that match workspace versions (#6494)Gravatar Dylan Conway 4-2/+64
2023-10-13fix lockfile struct padding (#6495)Gravatar Dylan Conway 3-3/+18