aboutsummaryrefslogtreecommitdiffhomepage
path: root/tools/get_images_from_skps.cpp
diff options
context:
space:
mode:
authorGravatar Leon Scroggins III <scroggo@google.com>2017-06-05 10:22:53 -0400
committerGravatar Skia Commit-Bot <skia-commit-bot@chromium.org>2017-06-05 14:51:33 +0000
commit4b0b00e0c3eefd08057b7f713143df3b2a7cc911 (patch)
tree83e60ea1255ab989464c057705b1714154ed635c /tools/get_images_from_skps.cpp
parentc928fe2056514a64e14d1082aa747a1a98c73f97 (diff)
Support passing single SKP to get_images_from_skps
In addition to allowing the user to supply a directory, allow them to supply a file. Simplifies my typical use case of testing a single file. Change-Id: I4f268cfb33fc70ff3121135941693023b6840cd3 Reviewed-on: https://skia-review.googlesource.com/18586 Reviewed-by: Matt Sarett <msarett@google.com> Commit-Queue: Leon Scroggins <scroggo@google.com>
Diffstat (limited to 'tools/get_images_from_skps.cpp')
-rw-r--r--tools/get_images_from_skps.cpp28
1 files changed, 17 insertions, 11 deletions
diff --git a/tools/get_images_from_skps.cpp b/tools/get_images_from_skps.cpp
index c413c6d961..11faa42854 100644
--- a/tools/get_images_from_skps.cpp
+++ b/tools/get_images_from_skps.cpp
@@ -23,7 +23,7 @@
#include <iostream>
#include <map>
-DEFINE_string2(skps, s, "skps", "A path to a directory of skps.");
+DEFINE_string2(skps, s, "skps", "A path to a directory of skps or a single skp.");
DEFINE_string2(out, o, "img-out", "A path to an output directory.");
DEFINE_bool(testDecode, false, "Indicates if we want to test that the images decode successfully.");
DEFINE_bool(writeImages, true,
@@ -142,6 +142,14 @@ struct Sniffer : public SkPixelSerializer {
SkData* onEncode(const SkPixmap&) override { return nullptr; }
};
+static void get_images_from_file(const SkString& file) {
+ auto stream = SkStream::MakeFromFile(file.c_str());
+ sk_sp<SkPicture> picture(SkPicture::MakeFromStream(stream.get()));
+
+ SkDynamicMemoryWStream scratch;
+ Sniffer sniff(file.c_str());
+ picture->serialize(&scratch, &sniff);
+}
int main(int argc, char** argv) {
SkCommandLineFlags::SetUsage(
@@ -152,7 +160,7 @@ int main(int argc, char** argv) {
const char* inputs = FLAGS_skps[0];
gOutputDir = FLAGS_out[0];
- if (!sk_isdir(inputs) || !sk_isdir(gOutputDir)) {
+ if (!sk_isdir(gOutputDir)) {
SkCommandLineFlags::PrintUsage();
return 1;
}
@@ -163,15 +171,13 @@ int main(int argc, char** argv) {
}
#endif
- SkOSFile::Iter iter(inputs, "skp");
- for (SkString file; iter.next(&file); ) {
- std::unique_ptr<SkStream> stream =
- SkStream::MakeFromFile(SkOSPath::Join(inputs, file.c_str()).c_str());
- sk_sp<SkPicture> picture(SkPicture::MakeFromStream(stream.get()));
-
- SkDynamicMemoryWStream scratch;
- Sniffer sniff(file.c_str());
- picture->serialize(&scratch, &sniff);
+ if (sk_isdir(inputs)) {
+ SkOSFile::Iter iter(inputs, "skp");
+ for (SkString file; iter.next(&file); ) {
+ get_images_from_file(SkOSPath::Join(inputs, file.c_str()));
+ }
+ } else {
+ get_images_from_file(SkString(inputs));
}
/**
JSON results are written out in the following format: