aboutsummaryrefslogtreecommitdiff
path: root/toolsrc/src/commands_cache.cpp
diff options
context:
space:
mode:
authorLiGuilin <liguilin0522@qq.com>2016-10-08 08:34:12 +0800
committerLiGuilin <liguilin0522@qq.com>2016-10-08 08:34:12 +0800
commitc91da2b0c4c3d9218c0b4d1712d744bb35245a61 (patch)
treee1ae0664a4f21f3948bde8c8f9f9e55dea0cb11f /toolsrc/src/commands_cache.cpp
parent280d88b34033ab728e02f725d8d8ff5f9250c6de (diff)
parenta0f621c0fca2c3de8bd5249f023979b800c543cf (diff)
downloadvcpkg-c91da2b0c4c3d9218c0b4d1712d744bb35245a61.tar.gz
vcpkg-c91da2b0c4c3d9218c0b4d1712d744bb35245a61.zip
Merge remote-tracking branch 'upstream/master'
Diffstat (limited to 'toolsrc/src/commands_cache.cpp')
-rw-r--r--toolsrc/src/commands_cache.cpp39
1 files changed, 39 insertions, 0 deletions
diff --git a/toolsrc/src/commands_cache.cpp b/toolsrc/src/commands_cache.cpp
new file mode 100644
index 000000000..0d70f0f29
--- /dev/null
+++ b/toolsrc/src/commands_cache.cpp
@@ -0,0 +1,39 @@
+#include "vcpkg_Commands.h"
+#include "vcpkg_System.h"
+#include "vcpkg_Files.h"
+#include "vcpkg.h"
+
+namespace vcpkg
+{
+ void cache_command(const vcpkg_cmd_arguments& args, const vcpkg_paths& paths)
+ {
+ args.check_exact_arg_count(0);
+
+ auto begin_it = fs::directory_iterator(paths.packages);
+ auto end_it = fs::directory_iterator();
+
+ if (begin_it == end_it)
+ {
+ System::println("No packages are cached.");
+ exit(EXIT_SUCCESS);
+ }
+
+ for (; begin_it != end_it; ++begin_it)
+ {
+ const auto& path = begin_it->path();
+
+ auto file_contents = Files::get_contents(path / "CONTROL");
+ if (auto text = file_contents.get())
+ {
+ auto pghs = parse_paragraphs(*text);
+ if (pghs.size() != 1)
+ continue;
+
+ auto src = BinaryParagraph(pghs[0]);
+ System::println(src.displayname().c_str());
+ }
+ }
+
+ exit(EXIT_SUCCESS);
+ }
+}