/* * Copyright (C) 2016-2019 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 "IDLTypes.h" #include "JSDOMConvertBase.h" #include "StringAdaptors.h" namespace WebCore { WEBCORE_EXPORT String identifierToString(JSC::JSGlobalObject&, const JSC::Identifier&); WEBCORE_EXPORT String identifierToByteString(JSC::JSGlobalObject&, const JSC::Identifier&); WEBCORE_EXPORT String valueToByteString(JSC::JSGlobalObject&, JSC::JSValue); WEBCORE_EXPORT String identifierToUSVString(JSC::JSGlobalObject&, const JSC::Identifier&); WEBCORE_EXPORT String valueToUSVString(JSC::JSGlobalObject&, JSC::JSValue); inline String propertyNameToString(JSC::PropertyName propertyName) { ASSERT(!propertyName.isSymbol()); return propertyName.uid() ? propertyName.uid() : propertyName.publicName(); } inline AtomString propertyNameToAtomString(JSC::PropertyName propertyName) { return AtomString(propertyName.uid() ? propertyName.uid() : propertyName.publicName()); } // MARK: - // MARK: String types template<> struct Converter : DefaultConverter { static String convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value) { return value.toWTFString(&lexicalGlobalObject); } }; template<> struct JSConverter { static constexpr bool needsState = true; static constexpr bool needsGlobalObject = false; static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const String& value) { return JSC::jsStringWithCache(JSC::getVM(&lexicalGlobalObject), value); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const UncachedString& value) { return JSC::jsString(JSC::getVM(&lexicalGlobalObject), value.string); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const OwnedString& value) { return JSC::jsOwnedString(JSC::getVM(&lexicalGlobalObject), value.string); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const URL& value) { return JSC::jsOwnedString(JSC::getVM(&lexicalGlobalObject), value.string()); } }; template<> struct Converter : DefaultConverter { static String convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value) { return valueToByteString(lexicalGlobalObject, value); } }; template<> struct JSConverter { static constexpr bool needsState = true; static constexpr bool needsGlobalObject = false; static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const String& value) { return JSC::jsStringWithCache(JSC::getVM(&lexicalGlobalObject), value); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const UncachedString& value) { return JSC::jsString(JSC::getVM(&lexicalGlobalObject), value.string); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const OwnedString& value) { return JSC::jsOwnedString(JSC::getVM(&lexicalGlobalObject), value.string); } }; template<> struct Converter : DefaultConverter { static String convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value) { return valueToUSVString(lexicalGlobalObject, value); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const URL& value) { return JSC::jsOwnedString(JSC::getVM(&lexicalGlobalObject), value.string()); } }; template<> struct JSConverter { static constexpr bool needsState = true; static constexpr bool needsGlobalObject = false; static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const String& value) { return JSC::jsStringWithCache(JSC::getVM(&lexicalGlobalObject), value); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const UncachedString& value) { return JSC::jsString(JSC::getVM(&lexicalGlobalObject), value.string); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const OwnedString& value) { return JSC::jsOwnedString(JSC::getVM(&lexicalGlobalObject), value.string); } static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const URL& value) { return JSC::jsOwnedString(JSC::getVM(&lexicalGlobalObject), value.string()); } }; // MARK: - // MARK: String type adaptors template struct Converter> : DefaultConverter> { static String convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value) { if (value.isNull()) return emptyString(); return Converter::convert(lexicalGlobalObject, value); } }; template struct JSConverter> { static constexpr bool needsState = true; static constexpr bool needsGlobalObject = false; static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const String& value) { return JSConverter::convert(lexicalGlobalObject, value); } }; template struct Converter> : DefaultConverter> { static AtomString convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value) { static_assert(std::is_same::value, "This adaptor is only supported for IDLDOMString at the moment."); return value.toString(&lexicalGlobalObject)->toAtomString(&lexicalGlobalObject); } }; template struct JSConverter> { static constexpr bool needsState = true; static constexpr bool needsGlobalObject = false; static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const AtomString& value) { static_assert(std::is_same::value, "This adaptor is only supported for IDLDOMString at the moment."); return JSConverter::convert(lexicalGlobalObject, value); } }; template struct Converter> : DefaultConverter> { static AtomString convert(JSC::JSGlobalObject& lexicalGlobalObject, JSC::JSValue value) { static_assert(std::is_same::value, "This adaptor is only supported for IDLDOMString at the moment."); return AtomString(value.toString(&lexicalGlobalObject)->toExistingAtomString(&lexicalGlobalObject)); } }; template struct JSConverter> { static constexpr bool needsState = true; static constexpr bool needsGlobalObject = false; static JSC::JSValue convert(JSC::JSGlobalObject& lexicalGlobalObject, const AtomString& value) { static_assert(std::is_same::value, "This adaptor is only supported for IDLDOMString at the moment."); return JSConverter::convert(lexicalGlobalObject, value); } }; } // namespace WebCore