2021-04-05 18:59:50 +02:00
|
|
|
//===- Target.cpp -----------------------------------------------*- C++ -*-===//
|
2019-09-20 16:32:34 +02:00
|
|
|
//
|
|
|
|
// 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
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2021-04-05 18:59:50 +02:00
|
|
|
#include "llvm/TextAPI/Target.h"
|
2019-09-20 16:32:34 +02:00
|
|
|
#include "llvm/ADT/SmallString.h"
|
|
|
|
#include "llvm/ADT/SmallVector.h"
|
|
|
|
#include "llvm/ADT/StringExtras.h"
|
|
|
|
#include "llvm/ADT/StringSwitch.h"
|
|
|
|
#include "llvm/Support/Format.h"
|
|
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
namespace MachO {
|
|
|
|
|
2019-10-10 06:24:44 +02:00
|
|
|
Expected<Target> Target::create(StringRef TargetValue) {
|
|
|
|
auto Result = TargetValue.split('-');
|
|
|
|
auto ArchitectureStr = Result.first;
|
|
|
|
auto Architecture = getArchitectureFromName(ArchitectureStr);
|
|
|
|
auto PlatformStr = Result.second;
|
|
|
|
PlatformKind Platform;
|
|
|
|
Platform = StringSwitch<PlatformKind>(PlatformStr)
|
|
|
|
.Case("macos", PlatformKind::macOS)
|
|
|
|
.Case("ios", PlatformKind::iOS)
|
|
|
|
.Case("tvos", PlatformKind::tvOS)
|
|
|
|
.Case("watchos", PlatformKind::watchOS)
|
|
|
|
.Case("bridgeos", PlatformKind::bridgeOS)
|
|
|
|
.Case("maccatalyst", PlatformKind::macCatalyst)
|
|
|
|
.Case("ios-simulator", PlatformKind::iOSSimulator)
|
|
|
|
.Case("tvos-simulator", PlatformKind::tvOSSimulator)
|
|
|
|
.Case("watchos-simulator", PlatformKind::watchOSSimulator)
|
2020-08-14 21:34:20 +02:00
|
|
|
.Case("driverkit", PlatformKind::driverKit)
|
2019-10-10 06:24:44 +02:00
|
|
|
.Default(PlatformKind::unknown);
|
|
|
|
|
|
|
|
if (Platform == PlatformKind::unknown) {
|
|
|
|
if (PlatformStr.startswith("<") && PlatformStr.endswith(">")) {
|
|
|
|
PlatformStr = PlatformStr.drop_front().drop_back();
|
|
|
|
unsigned long long RawValue;
|
|
|
|
if (!PlatformStr.getAsInteger(10, RawValue))
|
|
|
|
Platform = (PlatformKind)RawValue;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return Target{Architecture, Platform};
|
|
|
|
}
|
|
|
|
|
2019-09-20 16:32:34 +02:00
|
|
|
Target::operator std::string() const {
|
|
|
|
return (getArchitectureName(Arch) + " (" + getPlatformName(Platform) + ")")
|
|
|
|
.str();
|
|
|
|
}
|
|
|
|
|
|
|
|
raw_ostream &operator<<(raw_ostream &OS, const Target &Target) {
|
|
|
|
OS << std::string(Target);
|
|
|
|
return OS;
|
|
|
|
}
|
|
|
|
|
|
|
|
PlatformSet mapToPlatformSet(ArrayRef<Target> Targets) {
|
|
|
|
PlatformSet Result;
|
|
|
|
for (const auto &Target : Targets)
|
|
|
|
Result.insert(Target.Platform);
|
|
|
|
return Result;
|
|
|
|
}
|
|
|
|
|
|
|
|
ArchitectureSet mapToArchitectureSet(ArrayRef<Target> Targets) {
|
|
|
|
ArchitectureSet Result;
|
|
|
|
for (const auto &Target : Targets)
|
|
|
|
Result.set(Target.Arch);
|
|
|
|
return Result;
|
|
|
|
}
|
|
|
|
|
2021-06-10 06:13:31 +02:00
|
|
|
std::string getTargetTripleName(const Target &Targ) {
|
|
|
|
return (getArchitectureName(Targ.Arch) + "-apple-" +
|
|
|
|
getOSAndEnvironmentName(Targ.Platform))
|
|
|
|
.str();
|
|
|
|
}
|
|
|
|
|
2019-09-20 16:32:34 +02:00
|
|
|
} // end namespace MachO.
|
2019-10-10 06:24:44 +02:00
|
|
|
} // end namespace llvm.
|