Revert "Remove --readPath/-r from DM"
This reverts commit c5245fcd8e
.
Reason for revert: Still being used.
Original change's description:
> Remove --readPath/-r from DM
>
> This was an (unused) feature to compare GM results against a previously
> generated set, while DM was running. It was also one of the users of
> JsonCPP, which is being evicted from Skia.
>
> Bug: skia:
> Change-Id: I42d6204250782681e22219863e7170744d8be111
> Reviewed-on: https://skia-review.googlesource.com/c/186867
> Auto-Submit: Brian Osman <brianosman@google.com>
> Commit-Queue: Mike Klein <mtklein@google.com>
> Reviewed-by: Mike Klein <mtklein@google.com>
TBR=mtklein@google.com,brianosman@google.com
Change-Id: I05a74166a72ce106be73f3e0809e7f96e963aab5
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: skia:
Reviewed-on: https://skia-review.googlesource.com/c/186868
Reviewed-by: Brian Osman <brianosman@google.com>
Commit-Queue: Brian Osman <brianosman@google.com>
This commit is contained in:
parent
d41c1876d8
commit
57796b340e
53
dm/DM.cpp
53
dm/DM.cpp
@ -77,6 +77,8 @@ DEFINE_string(blacklist, "",
|
||||
"'--blacklist ~8888 svg _ svgparse_' blocks non-8888 SVGs that contain \"svgparse_\" in "
|
||||
"the name.");
|
||||
|
||||
DEFINE_string2(readPath, r, "", "If set check for equality with golden results in this directory.");
|
||||
|
||||
DEFINE_string(uninterestingHashesFile, "",
|
||||
"File containing a list of uninteresting hashes. If a result hashes to something in "
|
||||
"this list, no image is written for that result.");
|
||||
@ -296,6 +298,42 @@ static void find_culprit() {
|
||||
|
||||
/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
|
||||
|
||||
struct Gold : public SkString {
|
||||
Gold() : SkString("") {}
|
||||
Gold(const SkString& sink, const SkString& src,
|
||||
const SkString& srcOptions, const SkString& name,
|
||||
const SkString& md5)
|
||||
: SkString("") {
|
||||
this->append(sink);
|
||||
this->append(src);
|
||||
this->append(srcOptions);
|
||||
this->append(name);
|
||||
this->append(md5);
|
||||
}
|
||||
struct Hash {
|
||||
uint32_t operator()(const Gold& g) const {
|
||||
return SkGoodHash()((const SkString&)g);
|
||||
}
|
||||
};
|
||||
};
|
||||
static SkTHashSet<Gold, Gold::Hash> gGold;
|
||||
|
||||
static void add_gold(JsonWriter::BitmapResult r) {
|
||||
gGold.add(Gold(r.config, r.sourceType, r.sourceOptions, r.name, r.md5));
|
||||
}
|
||||
|
||||
static void gather_gold() {
|
||||
if (!FLAGS_readPath.isEmpty()) {
|
||||
SkString path(FLAGS_readPath[0]);
|
||||
path.append("/dm.json");
|
||||
if (!JsonWriter::ReadJson(path.c_str(), add_gold)) {
|
||||
fail(SkStringPrintf("Couldn't read %s for golden results.", path.c_str()));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~*/
|
||||
|
||||
#if defined(SK_BUILD_FOR_WIN)
|
||||
static const char* kNewline = "\r\n";
|
||||
#else
|
||||
@ -1095,7 +1133,7 @@ struct Task {
|
||||
std::unique_ptr<SkStreamAsset> ownedData(data);
|
||||
|
||||
SkString md5;
|
||||
if (!FLAGS_writePath.isEmpty()) {
|
||||
if (!FLAGS_writePath.isEmpty() || !FLAGS_readPath.isEmpty()) {
|
||||
SkMD5 hash;
|
||||
if (data->getLength()) {
|
||||
hash.writeStream(data, data->getLength());
|
||||
@ -1121,6 +1159,18 @@ struct Task {
|
||||
}
|
||||
}
|
||||
|
||||
if (!FLAGS_readPath.isEmpty() &&
|
||||
!gGold.contains(Gold(task.sink.tag, task.src.tag,
|
||||
task.src.options, name, md5))) {
|
||||
fail(SkStringPrintf("%s not found for %s %s %s %s in %s",
|
||||
md5.c_str(),
|
||||
task.sink.tag.c_str(),
|
||||
task.src.tag.c_str(),
|
||||
task.src.options.c_str(),
|
||||
name.c_str(),
|
||||
FLAGS_readPath[0]));
|
||||
}
|
||||
|
||||
if (!FLAGS_writePath.isEmpty()) {
|
||||
const char* ext = task.sink->fileExtension();
|
||||
if (ext && !FLAGS_dont_write.contains(ext)) {
|
||||
@ -1314,6 +1364,7 @@ int main(int argc, char** argv) {
|
||||
if (nullptr == GetResourceAsData("images/color_wheel.png")) {
|
||||
info("Some resources are missing. Do you need to set --resourcePath?\n");
|
||||
}
|
||||
gather_gold();
|
||||
gather_uninteresting_hashes();
|
||||
|
||||
if (!gather_srcs()) {
|
||||
|
@ -9,11 +9,14 @@
|
||||
|
||||
#include "ProcStats.h"
|
||||
#include "SkCommonFlags.h"
|
||||
#include "SkData.h"
|
||||
#include "SkJSONCPP.h"
|
||||
#include "SkJSONWriter.h"
|
||||
#include "SkMutex.h"
|
||||
#include "SkOSFile.h"
|
||||
#include "SkOSPath.h"
|
||||
#include "SkStream.h"
|
||||
#include "SkTArray.h"
|
||||
|
||||
namespace DM {
|
||||
|
||||
@ -113,4 +116,36 @@ void JsonWriter::DumpJson() {
|
||||
stream.flush();
|
||||
}
|
||||
|
||||
bool JsonWriter::ReadJson(const char* path, void(*callback)(BitmapResult)) {
|
||||
sk_sp<SkData> json(SkData::MakeFromFileName(path));
|
||||
if (!json) {
|
||||
return false;
|
||||
}
|
||||
|
||||
Json::Reader reader;
|
||||
Json::Value root;
|
||||
const char* data = (const char*)json->data();
|
||||
if (!reader.parse(data, data+json->size(), root)) {
|
||||
return false;
|
||||
}
|
||||
|
||||
const Json::Value& results = root["results"];
|
||||
BitmapResult br;
|
||||
for (unsigned i = 0; i < results.size(); i++) {
|
||||
const Json::Value& r = results[i];
|
||||
br.name = r["key"]["name"].asCString();
|
||||
br.config = r["key"]["config"].asCString();
|
||||
br.sourceType = r["key"]["source_type"].asCString();
|
||||
br.ext = r["options"]["ext"].asCString();
|
||||
br.gammaCorrect = 0 == strcmp("yes", r["options"]["gamma_correct"].asCString());
|
||||
br.md5 = r["md5"].asCString();
|
||||
|
||||
if (!r["key"]["source_options"].isNull()) {
|
||||
br.sourceOptions = r["key"]["source_options"].asCString();
|
||||
}
|
||||
callback(br);
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
} // namespace DM
|
||||
|
@ -46,6 +46,12 @@ public:
|
||||
* Write all collected results to the file FLAGS_writePath[0]/dm.json.
|
||||
*/
|
||||
static void DumpJson();
|
||||
|
||||
/**
|
||||
* Read JSON file at path written by DumpJson, calling callback for each
|
||||
* BitmapResult recorded in the file. Return success.
|
||||
*/
|
||||
static bool ReadJson(const char* path, void(*callback)(BitmapResult));
|
||||
};
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user