aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--toolsrc/include/vcpkg/base/files.h35
-rw-r--r--toolsrc/include/vcpkg/base/strings.h10
-rw-r--r--toolsrc/include/vcpkg/base/work_queue.h182
-rw-r--r--toolsrc/src/tests.files.cpp80
-rw-r--r--toolsrc/src/tests.strings.cpp38
-rw-r--r--toolsrc/src/vcpkg/base/files.cpp3
-rw-r--r--toolsrc/src/vcpkg/base/strings.cpp72
-rw-r--r--toolsrc/vcpkg/vcpkg.vcxproj4
-rw-r--r--toolsrc/vcpkglib/vcpkglib.vcxproj4
-rw-r--r--toolsrc/vcpkgmetricsuploader/vcpkgmetricsuploader.vcxproj4
-rw-r--r--toolsrc/vcpkgtest/vcpkgtest.vcxproj10
-rw-r--r--toolsrc/vcpkgtest/vcpkgtest.vcxproj.filters6
12 files changed, 295 insertions, 153 deletions
diff --git a/toolsrc/include/vcpkg/base/files.h b/toolsrc/include/vcpkg/base/files.h
index 6cad3d461..a5e04db25 100644
--- a/toolsrc/include/vcpkg/base/files.h
+++ b/toolsrc/include/vcpkg/base/files.h
@@ -12,8 +12,8 @@ namespace fs
using stdfs::copy_options;
using stdfs::file_status;
using stdfs::file_type;
- using stdfs::perms;
using stdfs::path;
+ using stdfs::perms;
using stdfs::u8path;
/*
@@ -26,25 +26,24 @@ namespace fs
// we want to poison ADL with these niebloids
- namespace detail {
- struct symlink_status_t {
+ namespace detail
+ {
+ struct symlink_status_t
+ {
file_status operator()(const path& p, std::error_code& ec) const noexcept;
file_status operator()(const path& p, vcpkg::LineInfo li) const noexcept;
};
- struct is_symlink_t {
- inline bool operator()(file_status s) const {
- return stdfs::is_symlink(s);
- }
+ struct is_symlink_t
+ {
+ inline bool operator()(file_status s) const { return stdfs::is_symlink(s); }
};
- struct is_regular_file_t {
- inline bool operator()(file_status s) const {
- return stdfs::is_regular_file(s);
- }
+ struct is_regular_file_t
+ {
+ inline bool operator()(file_status s) const { return stdfs::is_regular_file(s); }
};
- struct is_directory_t {
- inline bool operator()(file_status s) const {
- return stdfs::is_directory(s);
- }
+ struct is_directory_t
+ {
+ inline bool operator()(file_status s) const { return stdfs::is_directory(s); }
};
}
@@ -63,10 +62,10 @@ namespace fs
We also want to poison the ADL on is_regular_file and is_directory, because
we don't want people calling these functions on paths
*/
-using fs::symlink_status;
-using fs::is_symlink;
-using fs::is_regular_file;
using fs::is_directory;
+using fs::is_regular_file;
+using fs::is_symlink;
+using fs::symlink_status;
namespace vcpkg::Files
{
diff --git a/toolsrc/include/vcpkg/base/strings.h b/toolsrc/include/vcpkg/base/strings.h
index 625c0240f..a1906790f 100644
--- a/toolsrc/include/vcpkg/base/strings.h
+++ b/toolsrc/include/vcpkg/base/strings.h
@@ -188,13 +188,5 @@ namespace vcpkg::Strings
// base 64 encoding with URL and filesafe alphabet (base64url)
// based on IETF RFC 4648
// ignores padding, since one implicitly knows the length from the size of x
- namespace detail {
-
- struct b64url_encode_t {
- std::string operator()(std::uint64_t x) const noexcept;
- };
-
- }
-
- constexpr detail::b64url_encode_t b64url_encode{};
+ std::string b64url_encode(std::uint64_t x) noexcept;
}
diff --git a/toolsrc/include/vcpkg/base/work_queue.h b/toolsrc/include/vcpkg/base/work_queue.h
index 1836404ca..d6666770b 100644
--- a/toolsrc/include/vcpkg/base/work_queue.h
+++ b/toolsrc/include/vcpkg/base/work_queue.h
@@ -4,78 +4,67 @@
#include <memory>
#include <queue>
-namespace vcpkg {
- template <class Action, class ThreadLocalData>
+namespace vcpkg
+{
+ template<class Action, class ThreadLocalData>
struct WorkQueue;
- namespace detail {
+ namespace detail
+ {
// for SFINAE purposes, keep out of the class
- template <class Action, class ThreadLocalData>
- auto call_moved_action(
- Action& action,
- const WorkQueue<Action, ThreadLocalData>& work_queue,
- ThreadLocalData& tld
- ) -> decltype(static_cast<void>(std::move(action)(tld, work_queue)))
+ template<class Action, class ThreadLocalData>
+ auto call_moved_action(Action& action,
+ const WorkQueue<Action, ThreadLocalData>& work_queue,
+ ThreadLocalData& tld) -> decltype(static_cast<void>(std::move(action)(tld, work_queue)))
{
std::move(action)(tld, work_queue);
}
- template <class Action, class ThreadLocalData>
- auto call_moved_action(
- Action& action,
- const WorkQueue<Action, ThreadLocalData>&,
- ThreadLocalData& tld
- ) -> decltype(static_cast<void>(std::move(action)(tld)))
+ template<class Action, class ThreadLocalData>
+ auto call_moved_action(Action& action, const WorkQueue<Action, ThreadLocalData>&, ThreadLocalData& tld)
+ -> decltype(static_cast<void>(std::move(action)(tld)))
{
std::move(action)(tld);
}
-
- struct immediately_run_t {};
}
- constexpr detail::immediately_run_t immediately_run{};
-
-
- template <class Action, class ThreadLocalData>
- struct WorkQueue {
- template <class F>
- WorkQueue(std::size_t num_threads, LineInfo li, const F& tld_init) noexcept {
+ template<class Action, class ThreadLocalData>
+ struct WorkQueue
+ {
+ template<class F>
+ WorkQueue(std::uint16_t num_threads, LineInfo li, const F& tld_init) noexcept
+ {
m_line_info = li;
- m_state = State::BeforeRun;
+ m_unjoined_workers = num_threads;
m_threads.reserve(num_threads);
- for (std::size_t i = 0; i < num_threads; ++i) {
+ for (std::size_t i = 0; i < num_threads; ++i)
+ {
m_threads.push_back(std::thread(Worker{this, tld_init()}));
}
}
- template <class F>
- WorkQueue(
- detail::immediately_run_t,
- std::size_t num_threads,
- LineInfo li,
- const F& tld_init
- ) noexcept : WorkQueue(num_threads, li, tld_init) {
- m_state = State::Running;
- }
-
WorkQueue(WorkQueue const&) = delete;
WorkQueue(WorkQueue&&) = delete;
- ~WorkQueue() {
+ ~WorkQueue()
+ {
auto lck = std::unique_lock<std::mutex>(m_mutex);
- if (m_state == State::Running) {
+ if (!is_joined(m_state))
+ {
Checks::exit_with_message(m_line_info, "Failed to call join() on a WorkQueue that was destroyed");
}
}
// should only be called once; anything else is an error
- void run(LineInfo li) {
+ void run(LineInfo li)
+ {
// this should _not_ be locked before `run()` is called; however, we
// want to terminate if someone screws up, rather than cause UB
auto lck = std::unique_lock<std::mutex>(m_mutex);
- if (m_state != State::BeforeRun) {
+ if (m_state != State::BeforeRun)
+ {
Checks::exit_with_message(li, "Attempted to run() twice");
}
@@ -86,18 +75,40 @@ namespace vcpkg {
// if this is called in an existing task, _will block forever_
// DO NOT DO THAT
// thread-unsafe
- void join(LineInfo li) {
+ void join(LineInfo li)
+ {
{
auto lck = std::unique_lock<std::mutex>(m_mutex);
- if (is_joined(m_state)) {
+ if (is_joined(m_state))
+ {
Checks::exit_with_message(li, "Attempted to call join() more than once");
- } else if (m_state == State::Terminated) {
+ }
+ else if (m_state == State::Terminated)
+ {
m_state = State::TerminatedJoined;
- } else {
+ }
+ else
+ {
m_state = State::Joined;
}
}
- for (auto& thrd : m_threads) {
+
+ for (;;)
+ {
+ auto lck = std::unique_lock<std::mutex>(m_mutex);
+ if (!m_unjoined_workers)
+ break;
+
+ else if (!m_running_workers)
+ {
+ lck.unlock();
+ m_cv.notify_all();
+ }
+ }
+
+ // all threads have returned -- now, it's time to join them
+ for (auto& thrd : m_threads)
+ {
thrd.join();
}
}
@@ -105,19 +116,24 @@ namespace vcpkg {
// useful in the case of errors
// doesn't stop any existing running tasks
// returns immediately, so that one can call this in a task
- void terminate() const {
+ void terminate() const
+ {
{
auto lck = std::unique_lock<std::mutex>(m_mutex);
- if (is_joined(m_state)) {
+ if (is_joined(m_state))
+ {
m_state = State::TerminatedJoined;
- } else {
+ }
+ else
+ {
m_state = State::Terminated;
}
}
m_cv.notify_all();
}
- void enqueue_action(Action a) const {
+ void enqueue_action(Action a) const
+ {
{
auto lck = std::unique_lock<std::mutex>(m_mutex);
m_actions.push_back(std::move(a));
@@ -127,8 +143,9 @@ namespace vcpkg {
m_cv.notify_one();
}
- template <class Rng>
- void enqueue_all_actions_by_move(Rng&& rng) const {
+ template<class Rng>
+ void enqueue_all_actions_by_move(Rng&& rng) const
+ {
{
using std::begin;
using std::end;
@@ -148,8 +165,9 @@ namespace vcpkg {
m_cv.notify_all();
}
- template <class Rng>
- void enqueue_all_actions(Rng&& rng) const {
+ template<class Rng>
+ void enqueue_all_actions(Rng&& rng) const
+ {
{
using std::begin;
using std::end;
@@ -170,37 +188,41 @@ namespace vcpkg {
}
private:
- struct Worker {
+ struct Worker
+ {
const WorkQueue* work_queue;
ThreadLocalData tld;
- void operator()() {
+ void operator()()
+ {
// unlocked when waiting, or when in the action
// locked otherwise
auto lck = std::unique_lock<std::mutex>(work_queue->m_mutex);
- work_queue->m_cv.wait(lck, [&] {
- return work_queue->m_state != State::BeforeRun;
- });
+ work_queue->m_cv.wait(lck, [&] { return work_queue->m_state != State::BeforeRun; });
- for (;;) {
+ for (;;)
+ {
const auto state = work_queue->m_state;
- if (is_terminated(state)) {
- return;
+ if (is_terminated(state))
+ {
+ break;
}
- if (work_queue->m_actions.empty()) {
- if (state == State::Running || work_queue->running_workers > 0) {
- --work_queue->running_workers;
+ if (work_queue->m_actions.empty())
+ {
+ if (state == State::Running || work_queue->m_running_workers > 1)
+ {
+ --work_queue->m_running_workers;
work_queue->m_cv.wait(lck);
- ++work_queue->running_workers;
+ ++work_queue->m_running_workers;
continue;
}
// the queue isn't running, and we are the only worker
// no more work!
- return;
+ break;
}
Action action = std::move(work_queue->m_actions.back());
@@ -210,10 +232,13 @@ namespace vcpkg {
detail::call_moved_action(action, *work_queue, tld);
lck.lock();
}
+
+ --work_queue->m_unjoined_workers;
}
};
- enum class State : std::int16_t {
+ enum class State : std::int16_t
+ {
// can only exist upon construction
BeforeRun = -1,
@@ -223,22 +248,19 @@ namespace vcpkg {
TerminatedJoined,
};
- static bool is_terminated(State st) {
- return st == State::Terminated || st == State::TerminatedJoined;
- }
+ static bool is_terminated(State st) { return st == State::Terminated || st == State::TerminatedJoined; }
- static bool is_joined(State st) {
- return st != State::Joined || st == State::TerminatedJoined;
- }
+ static bool is_joined(State st) { return st == State::Joined || st == State::TerminatedJoined; }
- mutable std::mutex m_mutex;
- // these four are under m_mutex
- mutable State m_state;
- mutable std::uint16_t running_workers;
- mutable std::vector<Action> m_actions;
- mutable std::condition_variable m_cv;
+ mutable std::mutex m_mutex{};
+ // these are all under m_mutex
+ mutable State m_state = State::BeforeRun;
+ mutable std::uint16_t m_running_workers = 0;
+ mutable std::uint16_t m_unjoined_workers = 0; // num_threads
+ mutable std::vector<Action> m_actions{};
+ mutable std::condition_variable m_cv{};
- std::vector<std::thread> m_threads;
+ std::vector<std::thread> m_threads{};
LineInfo m_line_info;
};
}
diff --git a/toolsrc/src/tests.files.cpp b/toolsrc/src/tests.files.cpp
new file mode 100644
index 000000000..73c7eb5bc
--- /dev/null
+++ b/toolsrc/src/tests.files.cpp
@@ -0,0 +1,80 @@
+#include "tests.pch.h"
+
+#include <vcpkg/base/files.h>
+#include <vcpkg/base/strings.h>
+
+#include <iostream>
+#include <random>
+
+#include <windows.h>
+
+using namespace Microsoft::VisualStudio::CppUnitTestFramework;
+
+namespace UnitTest1 {
+ class FilesTest : public TestClass<FilesTest> {
+ using uid = std::uniform_int_distribution<std::uint64_t>;
+
+ std::string get_random_filename()
+ {
+ std::random_device rd;
+ return vcpkg::Strings::b64url_encode(uid{}(rd));
+ }
+
+ void create_directory_tree(
+ vcpkg::Files::Filesystem& fs,
+ std::uint64_t depth,
+ const fs::path& base)
+ {
+ std::random_device rd;
+ constexpr auto max_depth = std::uint64_t(3);
+ const auto width = depth ? uid{0, (max_depth - depth) * 3 / 2}(rd) : 5;
+
+ std::error_code ec;
+ if (width == 0) {
+ fs.write_contents(base, "", ec);
+ Assert::IsFalse(bool(ec));
+
+ return;
+ }
+
+ fs.create_directory(base, ec);
+ Assert::IsFalse(bool(ec));
+
+ for (int i = 0; i < width; ++i) {
+ create_directory_tree(fs, depth + 1, base / get_random_filename());
+ }
+ }
+
+ TEST_METHOD(remove_all) {
+ fs::path temp_dir;
+
+ {
+ wchar_t* tmp = static_cast<wchar_t*>(calloc(32'767, 2));
+
+ if (!GetEnvironmentVariableW(L"TEMP", tmp, 32'767)) {
+ Assert::Fail(L"GetEnvironmentVariable(\"TEMP\") failed");
+ }
+
+ temp_dir = tmp;
+
+ std::string dir_name = "vcpkg-tmp-dir-";
+ dir_name += get_random_filename();
+
+ temp_dir /= dir_name;
+ }
+
+ auto& fs = vcpkg::Files::get_real_filesystem();
+
+ std::cout << "temp dir is: " << temp_dir << '\n';
+
+ std::error_code ec;
+ create_directory_tree(fs, 0, temp_dir);
+
+ fs::path fp;
+ fs.remove_all(temp_dir, ec, fp);
+ Assert::IsFalse(bool(ec));
+
+ Assert::IsFalse(fs.exists(temp_dir));
+ }
+ };
+}
diff --git a/toolsrc/src/tests.strings.cpp b/toolsrc/src/tests.strings.cpp
new file mode 100644
index 000000000..14b449e86
--- /dev/null
+++ b/toolsrc/src/tests.strings.cpp
@@ -0,0 +1,38 @@
+#include "tests.pch.h"
+
+#include <vcpkg/base/strings.h>
+
+#include <cstdint>
+#include <utility>
+#include <vector>
+
+using namespace Microsoft::VisualStudio::CppUnitTestFramework;
+
+namespace UnitTest1 {
+ class StringsTest : public TestClass<StringsTest> {
+ TEST_METHOD(b64url_encode)
+ {
+ using u64 = std::uint64_t;
+
+ std::vector<std::pair<std::uint64_t, std::string>> map;
+
+ map.emplace_back(0, "AAAAAAAAAAA");
+ map.emplace_back(1, "BAAAAAAAAAA");
+
+ map.emplace_back(u64(1) << 32, "AAAAAEAAAAA");
+ map.emplace_back((u64(1) << 32) + 1, "BAAAAEAAAAA");
+
+ map.emplace_back(0xE4D0'1065'D11E'0229, "pIgHRXGEQTO");
+ map.emplace_back(0xA626'FE45'B135'07FF, "_fQNxWk_mYK");
+ map.emplace_back(0xEE36'D228'0C31'D405, "FQdMMgi024O");
+ map.emplace_back(0x1405'64E7'FE7E'A88C, "Miqf-fOZFQB");
+ map.emplace_back(0xFFFF'FFFF'FFFF'FFFF, "__________P");
+
+ std::string result;
+ for (const auto& pr : map) {
+ result = vcpkg::Strings::b64url_encode(pr.first);
+ Assert::AreEqual(result, pr.second);
+ }
+ }
+ };
+}
diff --git a/toolsrc/src/vcpkg/base/files.cpp b/toolsrc/src/vcpkg/base/files.cpp
index a4e67a142..4e36fe990 100644
--- a/toolsrc/src/vcpkg/base/files.cpp
+++ b/toolsrc/src/vcpkg/base/files.cpp
@@ -23,7 +23,7 @@
namespace fs::detail
{
- file_status symlink_status_t::operator()(const path& p, std::error_code& ec) const noexcept
+ file_status symlink_status_t::operator()(const path& p, std::error_code&) const noexcept
{
#if defined(_WIN32)
/*
@@ -406,6 +406,7 @@ namespace vcpkg::Files
if (!info.ec)
{
info.ec = ec;
+ info.failure_point = failure_point;
}
return true;
diff --git a/toolsrc/src/vcpkg/base/strings.cpp b/toolsrc/src/vcpkg/base/strings.cpp
index 16543046e..ade4384a9 100644
--- a/toolsrc/src/vcpkg/base/strings.cpp
+++ b/toolsrc/src/vcpkg/base/strings.cpp
@@ -289,44 +289,46 @@ bool Strings::contains(StringView haystack, StringView needle)
return Strings::search(haystack, needle) != haystack.end();
}
-namespace vcpkg::Strings::detail {
-
- template <class Integral>
- std::string b64url_encode_implementation(Integral x) {
- static_assert(std::is_integral<Integral>::value, "b64url_encode must take an integer type");
- using Unsigned = std::make_unsigned_t<Integral>;
- auto value = static_cast<Unsigned>(x);
-
- // 64 values, plus the implicit \0
- constexpr static char map[0x41] =
- /* 0123456789ABCDEF */
- /*0*/ "ABCDEFGHIJKLMNOP"
- /*1*/ "QRSTUVWXYZabcdef"
- /*2*/ "ghijklmnopqrstuv"
- /*3*/ "wxyz0123456789-_"
- ;
-
- constexpr static int shift = 5;
- constexpr static auto mask = (static_cast<Unsigned>(1) << shift) - 1;
-
- std::string result;
- // reserve ceiling(number of bits / 3)
- result.resize((sizeof(value) * 8 + 2) / 3, map[0]);
-
- for (char& c: result) {
- if (value == 0) {
- break;
+namespace vcpkg::Strings
+{
+ namespace
+ {
+ template<class Integral>
+ std::string b64url_encode_implementation(Integral x)
+ {
+ static_assert(std::is_integral<Integral>::value, "b64url_encode must take an integer type");
+ using Unsigned = std::make_unsigned_t<Integral>;
+ auto value = static_cast<Unsigned>(x);
+
+ // 64 values, plus the implicit \0
+ constexpr static char map[65] =
+ /* 0123456789ABCDEF */
+ /*0*/ "ABCDEFGHIJKLMNOP"
+ /*1*/ "QRSTUVWXYZabcdef"
+ /*2*/ "ghijklmnopqrstuv"
+ /*3*/ "wxyz0123456789-_";
+
+ // log2(64)
+ constexpr static int shift = 6;
+ // 64 - 1
+ constexpr static auto mask = 63;
+
+ // ceiling(bitsize(Integral) / log2(64))
+ constexpr static auto result_size = (sizeof(value) * 8 + shift - 1) / shift;
+
+ std::string result;
+ result.reserve(result_size);
+
+ for (std::size_t i = 0; i < result_size; ++i)
+ {
+ result.push_back(map[value & mask]);
+ value >>= shift;
}
- c = map[value & mask];
- value >>= shift;
- }
- return result;
+ return result;
+ }
}
- std::string b64url_encode_t::operator()(std::uint64_t x) const noexcept{
- return b64url_encode_implementation(x);
- }
+ std::string b64url_encode(std::uint64_t x) noexcept { return b64url_encode_implementation(x); }
}
-
diff --git a/toolsrc/vcpkg/vcpkg.vcxproj b/toolsrc/vcpkg/vcpkg.vcxproj
index 8edea2244..06d849a74 100644
--- a/toolsrc/vcpkg/vcpkg.vcxproj
+++ b/toolsrc/vcpkg/vcpkg.vcxproj
@@ -21,8 +21,8 @@
<PropertyGroup Label="Globals">
<ProjectGuid>{34671B80-54F9-46F5-8310-AC429C11D4FB}</ProjectGuid>
<RootNamespace>vcpkg</RootNamespace>
- <WindowsTargetPlatformVersion>8.1</WindowsTargetPlatformVersion>
- <PlatformToolset>v140</PlatformToolset>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
diff --git a/toolsrc/vcpkglib/vcpkglib.vcxproj b/toolsrc/vcpkglib/vcpkglib.vcxproj
index 2eff1abee..9312dd627 100644
--- a/toolsrc/vcpkglib/vcpkglib.vcxproj
+++ b/toolsrc/vcpkglib/vcpkglib.vcxproj
@@ -21,8 +21,8 @@
<PropertyGroup Label="Globals">
<ProjectGuid>{B98C92B7-2874-4537-9D46-D14E5C237F04}</ProjectGuid>
<RootNamespace>vcpkglib</RootNamespace>
- <WindowsTargetPlatformVersion>8.1</WindowsTargetPlatformVersion>
- <PlatformToolset>v140</PlatformToolset>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
diff --git a/toolsrc/vcpkgmetricsuploader/vcpkgmetricsuploader.vcxproj b/toolsrc/vcpkgmetricsuploader/vcpkgmetricsuploader.vcxproj
index e533d0e15..2e689c7fc 100644
--- a/toolsrc/vcpkgmetricsuploader/vcpkgmetricsuploader.vcxproj
+++ b/toolsrc/vcpkgmetricsuploader/vcpkgmetricsuploader.vcxproj
@@ -21,8 +21,8 @@
<PropertyGroup Label="Globals">
<ProjectGuid>{7D6FDEEB-B299-4A23-85EE-F67C4DED47BE}</ProjectGuid>
<RootNamespace>vcpkgmetricsuploader</RootNamespace>
- <WindowsTargetPlatformVersion>8.1</WindowsTargetPlatformVersion>
- <PlatformToolset>v140</PlatformToolset>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
diff --git a/toolsrc/vcpkgtest/vcpkgtest.vcxproj b/toolsrc/vcpkgtest/vcpkgtest.vcxproj
index 4cda29461..ac7675ba5 100644
--- a/toolsrc/vcpkgtest/vcpkgtest.vcxproj
+++ b/toolsrc/vcpkgtest/vcpkgtest.vcxproj
@@ -22,6 +22,7 @@
<ClCompile Include="..\src\tests.arguments.cpp" />
<ClCompile Include="..\src\tests.chrono.cpp" />
<ClCompile Include="..\src\tests.dependencies.cpp" />
+ <ClCompile Include="..\src\tests.files.cpp" />
<ClCompile Include="..\src\tests.packagespec.cpp" />
<ClCompile Include="..\src\tests.paragraph.cpp" />
<ClCompile Include="..\src\tests.pch.cpp">
@@ -32,6 +33,7 @@
</ClCompile>
<ClCompile Include="..\src\tests.plan.cpp" />
<ClCompile Include="..\src\tests.statusparagraphs.cpp" />
+ <ClCompile Include="..\src\tests.strings.cpp" />
<ClCompile Include="..\src\tests.update.cpp" />
<ClCompile Include="..\src\tests.utils.cpp" />
</ItemGroup>
@@ -48,8 +50,8 @@
<ProjectGuid>{F27B8DB0-1279-4AF8-A2E3-1D49C4F0220D}</ProjectGuid>
<Keyword>Win32Proj</Keyword>
<RootNamespace>vcpkgtest</RootNamespace>
- <WindowsTargetPlatformVersion>8.1</WindowsTargetPlatformVersion>
- <PlatformToolset>v140</PlatformToolset>
+ <WindowsTargetPlatformVersion>10.0</WindowsTargetPlatformVersion>
+ <PlatformToolset>v142</PlatformToolset>
</PropertyGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.Default.props" />
<PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'" Label="Configuration">
@@ -84,7 +86,7 @@
<ImportGroup Label="Shared">
</ImportGroup>
<PropertyGroup Label="UserMacros" />
- <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
+ <PropertyGroup Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">
<IntDir>$(SolutionDir)msbuild.x86.debug\$(ProjectName)\</IntDir>
<OutDir>$(SolutionDir)msbuild.x86.debug\</OutDir>
</PropertyGroup>
@@ -193,4 +195,4 @@
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
<ImportGroup Label="ExtensionTargets">
</ImportGroup>
-</Project> \ No newline at end of file
+</Project>
diff --git a/toolsrc/vcpkgtest/vcpkgtest.vcxproj.filters b/toolsrc/vcpkgtest/vcpkgtest.vcxproj.filters
index 0f799426e..057c50a99 100644
--- a/toolsrc/vcpkgtest/vcpkgtest.vcxproj.filters
+++ b/toolsrc/vcpkgtest/vcpkgtest.vcxproj.filters
@@ -45,6 +45,12 @@
<ClCompile Include="..\src\tests.chrono.cpp">
<Filter>Source Files</Filter>
</ClCompile>
+ <ClCompile Include="..\src\tests.files.cpp">
+ <Filter>Source Files</Filter>
+ </ClCompile>
+ <ClCompile Include="..\src\tests.strings.cpp">
+ <Filter>Source Files</Filter>
+ </ClCompile>
</ItemGroup>
<ItemGroup>
<ClInclude Include="..\include\tests.pch.h">