aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src/triplet.cpp
diff options
context:
space:
mode:
authorRobert Schumacher <roschuma@microsoft.com>2017-10-16 17:17:28 -0700
committerRobert Schumacher <roschuma@microsoft.com>2017-10-16 17:17:28 -0700
commitee2831c548b54cdccf064663b3fffda5d6a4c6b8 (patch)
tree70390dc6e2e22877cb6ede677076c8005fab8a1c /toolsrc/src/triplet.cpp
parentd88f53de9c284cfc67ba21707d60a44ba41ede8a (diff)
parent374253cb1b12a60925693130132f1a6ab6c3a83a (diff)
downloadvcpkg-ee2831c548b54cdccf064663b3fffda5d6a4c6b8.tar.gz
vcpkg-ee2831c548b54cdccf064663b3fffda5d6a4c6b8.zip
Merge from master
Diffstat (limited to 'toolsrc/src/triplet.cpp')
-rw-r--r--toolsrc/src/triplet.cpp55
1 files changed, 0 insertions, 55 deletions
diff --git a/toolsrc/src/triplet.cpp b/toolsrc/src/triplet.cpp
deleted file mode 100644
index 451deb040..000000000
--- a/toolsrc/src/triplet.cpp
+++ /dev/null
@@ -1,55 +0,0 @@
-#include "pch.h"
-
-#include "Triplet.h"
-#include "vcpkg_Checks.h"
-#include "vcpkg_Strings.h"
-
-namespace vcpkg
-{
- struct TripletInstance
- {
- TripletInstance(std::string&& s) : value(std::move(s)), hash(std::hash<std::string>()(value)) {}
-
- const std::string value;
- const size_t hash = 0;
-
- bool operator==(const TripletInstance& o) const { return o.value == value; }
- };
- const TripletInstance Triplet::default_instance({});
-}
-
-template<>
-struct std::hash<vcpkg::TripletInstance>
-{
- size_t operator()(const vcpkg::TripletInstance& t) const { return t.hash; }
-};
-
-namespace vcpkg
-{
- static std::unordered_set<TripletInstance> g_triplet_instances;
-
- const Triplet Triplet::X86_WINDOWS = from_canonical_name("x86-windows");
- const Triplet Triplet::X64_WINDOWS = from_canonical_name("x64-windows");
- const Triplet Triplet::X86_UWP = from_canonical_name("x86-uwp");
- const Triplet Triplet::X64_UWP = from_canonical_name("x64-uwp");
- const Triplet Triplet::ARM_UWP = from_canonical_name("arm-uwp");
-
- bool Triplet::operator==(const Triplet& other) const { return this->m_instance == other.m_instance; }
-
- bool operator!=(const Triplet& left, const Triplet& right) { return !(left == right); }
-
- Triplet Triplet::from_canonical_name(const std::string& triplet_as_string)
- {
- std::string s(Strings::ascii_to_lowercase(triplet_as_string));
- auto it = std::find(s.cbegin(), s.cend(), '-');
- Checks::check_exit(VCPKG_LINE_INFO, it != s.cend(), "Invalid triplet: %s", triplet_as_string);
-
- auto p = g_triplet_instances.emplace(std::move(s));
- return &*p.first;
- }
-
- const std::string& Triplet::canonical_name() const { return this->m_instance->value; }
-
- const std::string& Triplet::to_string() const { return this->canonical_name(); }
- size_t Triplet::hash_code() const { return m_instance->hash; }
-}