//===- TextStubCommon.cpp -------------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // Implememts common Text Stub YAML mappings. // //===----------------------------------------------------------------------===// #include "TextStubCommon.h" #include "TextAPIContext.h" #include "llvm/ADT/StringSwitch.h" using namespace llvm::MachO; namespace llvm { namespace yaml { void ScalarTraits::output(const FlowStringRef &Value, void *Ctx, raw_ostream &OS) { ScalarTraits::output(Value, Ctx, OS); } StringRef ScalarTraits::input(StringRef Value, void *Ctx, FlowStringRef &Out) { return ScalarTraits::input(Value, Ctx, Out.value); } QuotingType ScalarTraits::mustQuote(StringRef Name) { return ScalarTraits::mustQuote(Name); } void ScalarEnumerationTraits::enumeration( IO &IO, ObjCConstraintType &Constraint) { IO.enumCase(Constraint, "none", ObjCConstraintType::None); IO.enumCase(Constraint, "retain_release", ObjCConstraintType::Retain_Release); IO.enumCase(Constraint, "retain_release_for_simulator", ObjCConstraintType::Retain_Release_For_Simulator); IO.enumCase(Constraint, "retain_release_or_gc", ObjCConstraintType::Retain_Release_Or_GC); IO.enumCase(Constraint, "gc", ObjCConstraintType::GC); } void ScalarTraits::output(const PlatformSet &Values, void *IO, raw_ostream &OS) { const auto *Ctx = reinterpret_cast(IO); assert((!Ctx || Ctx->FileKind != FileType::Invalid) && "File type is not set in context"); if (Ctx && Ctx->FileKind == TBD_V3 && Values.count(PlatformKind::macOS) && Values.count(PlatformKind::macCatalyst)) { OS << "zippered"; return; } assert(Values.size() == 1U); switch (*Values.begin()) { default: llvm_unreachable("unexpected platform"); break; case PlatformKind::macOS: OS << "macosx"; break; case PlatformKind::iOSSimulator: LLVM_FALLTHROUGH; case PlatformKind::iOS: OS << "ios"; break; case PlatformKind::watchOSSimulator: LLVM_FALLTHROUGH; case PlatformKind::watchOS: OS << "watchos"; break; case PlatformKind::tvOSSimulator: LLVM_FALLTHROUGH; case PlatformKind::tvOS: OS << "tvos"; break; case PlatformKind::bridgeOS: OS << "bridgeos"; break; case PlatformKind::macCatalyst: OS << "iosmac"; break; case PlatformKind::driverKit: OS << "driverkit"; break; } } StringRef ScalarTraits::input(StringRef Scalar, void *IO, PlatformSet &Values) { const auto *Ctx = reinterpret_cast(IO); assert((!Ctx || Ctx->FileKind != FileType::Invalid) && "File type is not set in context"); if (Scalar == "zippered") { if (Ctx && Ctx->FileKind == FileType::TBD_V3) { Values.insert(PlatformKind::macOS); Values.insert(PlatformKind::macCatalyst); return {}; } return "invalid platform"; } auto Platform = StringSwitch(Scalar) .Case("unknown", PlatformKind::unknown) .Case("macosx", PlatformKind::macOS) .Case("ios", PlatformKind::iOS) .Case("watchos", PlatformKind::watchOS) .Case("tvos", PlatformKind::tvOS) .Case("bridgeos", PlatformKind::bridgeOS) .Case("iosmac", PlatformKind::macCatalyst) .Default(PlatformKind::unknown); if (Platform == PlatformKind::macCatalyst) if (Ctx && Ctx->FileKind != FileType::TBD_V3) return "invalid platform"; if (Platform == PlatformKind::unknown) return "unknown platform"; Values.insert(Platform); return {}; } QuotingType ScalarTraits::mustQuote(StringRef) { return QuotingType::None; } void ScalarBitSetTraits::bitset(IO &IO, ArchitectureSet &Archs) { #define ARCHINFO(arch, type, subtype, numbits) \ IO.bitSetCase(Archs, #arch, 1U << static_cast(AK_##arch)); #include "llvm/TextAPI/MachO/Architecture.def" #undef ARCHINFO } void ScalarTraits::output(const Architecture &Value, void *, raw_ostream &OS) { OS << Value; } StringRef ScalarTraits::input(StringRef Scalar, void *, Architecture &Value) { Value = getArchitectureFromName(Scalar); return {}; } QuotingType ScalarTraits::mustQuote(StringRef) { return QuotingType::None; } void ScalarTraits::output(const PackedVersion &Value, void *, raw_ostream &OS) { OS << Value; } StringRef ScalarTraits::input(StringRef Scalar, void *, PackedVersion &Value) { if (!Value.parse32(Scalar)) return "invalid packed version string."; return {}; } QuotingType ScalarTraits::mustQuote(StringRef) { return QuotingType::None; } void ScalarTraits::output(const SwiftVersion &Value, void *, raw_ostream &OS) { switch (Value) { case 1: OS << "1.0"; break; case 2: OS << "1.1"; break; case 3: OS << "2.0"; break; case 4: OS << "3.0"; break; default: OS << (unsigned)Value; break; } } StringRef ScalarTraits::input(StringRef Scalar, void *IO, SwiftVersion &Value) { const auto *Ctx = reinterpret_cast(IO); assert((!Ctx || Ctx->FileKind != FileType::Invalid) && "File type is not set in context"); if (Ctx->FileKind == FileType::TBD_V4) { if (Scalar.getAsInteger(10, Value)) return "invalid Swift ABI version."; return {}; } else { Value = StringSwitch(Scalar) .Case("1.0", 1) .Case("1.1", 2) .Case("2.0", 3) .Case("3.0", 4) .Default(0); } if (Value != SwiftVersion(0)) return {}; if (Scalar.getAsInteger(10, Value)) return "invalid Swift ABI version."; return StringRef(); } QuotingType ScalarTraits::mustQuote(StringRef) { return QuotingType::None; } void ScalarTraits::output(const UUID &Value, void *, raw_ostream &OS) { OS << Value.first << ": " << Value.second; } StringRef ScalarTraits::input(StringRef Scalar, void *, UUID &Value) { auto Split = Scalar.split(':'); auto Arch = Split.first.trim(); auto UUID = Split.second.trim(); if (UUID.empty()) return "invalid uuid string pair"; Value.second = std::string(UUID); Value.first = Target{getArchitectureFromName(Arch), PlatformKind::unknown}; return {}; } QuotingType ScalarTraits::mustQuote(StringRef) { return QuotingType::Single; } } // end namespace yaml. } // end namespace llvm.