diff options
| author | Alexander Karatarakis <alkarata@microsoft.com> | 2016-09-18 20:50:08 -0700 |
|---|---|---|
| committer | Alexander Karatarakis <alkarata@microsoft.com> | 2016-09-18 20:54:03 -0700 |
| commit | ccca198c1b1730b0241911cb56dc8e3504958b2a (patch) | |
| tree | a2dd9b8b087a09afdcecc5cbb3377bed15127eb2 /toolsrc/src/triplet.cpp | |
| download | vcpkg-ccca198c1b1730b0241911cb56dc8e3504958b2a.tar.gz vcpkg-ccca198c1b1730b0241911cb56dc8e3504958b2a.zip | |
Initial commit
Diffstat (limited to 'toolsrc/src/triplet.cpp')
| -rw-r--r-- | toolsrc/src/triplet.cpp | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/toolsrc/src/triplet.cpp b/toolsrc/src/triplet.cpp new file mode 100644 index 000000000..9ad3d8847 --- /dev/null +++ b/toolsrc/src/triplet.cpp @@ -0,0 +1,59 @@ +#include "triplet.h" +#include "vcpkg_System.h" +#include "vcpkg_Checks.h" + +namespace vcpkg +{ + const triplet triplet::X86_WINDOWS = {"x86-windows"}; + const triplet triplet::X64_WINDOWS = {"x64-windows"}; + const triplet triplet::X86_UWP = {"x86-uwp"}; + const triplet triplet::X64_UWP = {"x64-uwp"}; + const triplet triplet::ARM_UWP = {"arm-uwp"}; + + std::string to_string(const triplet& t) + { + return t.value; + } + + std::string to_printf_arg(const triplet& t) + { + return to_string(t); + } + + bool operator==(const triplet& left, const triplet& right) + { + return left.value == right.value; + } + + bool operator!=(const triplet& left, const triplet& right) + { + return !(left == right); + } + + std::ostream& operator<<(std::ostream& os, const triplet& t) + { + return os << to_string(t); + } + + std::string triplet::architecture() const + { + if (*this == X86_WINDOWS || *this == X86_UWP) + return "x86"; + if (*this == X64_WINDOWS || *this == X64_UWP) + return "x64"; + if (*this == ARM_UWP) + return "arm"; + + Checks::exit_with_message("Unknown architecture: %s", value); + } + + std::string triplet::system() const + { + if (*this == X86_WINDOWS || *this == X64_WINDOWS) + return "windows"; + if (*this == X86_UWP || *this == X64_UWP || *this == ARM_UWP) + return "uwp"; + + Checks::exit_with_message("Unknown system: %s", value); + } +} |
