#include "SkImageDecoder.h"
#include "SkOSFile.h"
#include "SkStream.h"
+#include "SkTDict.h"
#include "SkDiffContext.h"
#include "SkImageDiffer.h"
stream.writeText("}\n");
}
}
+
+void SkDiffContext::outputCsv(SkWStream& stream) {
+ SkTDict<int> columns(2);
+ int cntColumns = 0;
+
+ stream.writeText("key");
+
+ DiffRecord* currentRecord = fRecords;
+
+ // Write CSV header and create a dictionary of all columns.
+ while (NULL != currentRecord) {
+ for (int diffIndex = 0; diffIndex < currentRecord->fDiffs.count(); diffIndex++) {
+ DiffData& data = currentRecord->fDiffs[diffIndex];
+ if (!columns.find(data.fDiffName)) {
+ columns.set(data.fDiffName, cntColumns);
+ stream.writeText(", ");
+ stream.writeText(data.fDiffName);
+ cntColumns++;
+ }
+ }
+ currentRecord = currentRecord->fNext;
+ }
+ stream.writeText("\n");
+
+ double values[100];
+ SkASSERT(cntColumns < 100); // Make the array larger, if we ever have so many diff types.
+
+ currentRecord = fRecords;
+ while (NULL != currentRecord) {
+ for (int i = 0; i < cntColumns; i++) {
+ values[i] = -1;
+ }
+
+ for (int diffIndex = 0; diffIndex < currentRecord->fDiffs.count(); diffIndex++) {
+ DiffData& data = currentRecord->fDiffs[diffIndex];
+ int index = -1;
+ SkAssertResult(columns.find(data.fDiffName, &index));
+ SkASSERT(index >= 0 && index < cntColumns);
+ values[index] = data.fResult;
+ }
+
+ const char* filename = currentRecord->fBaselinePath.c_str() +
+ strlen(currentRecord->fBaselinePath.c_str()) - 1;
+ while (filename > currentRecord->fBaselinePath.c_str() && *(filename - 1) != '/') {
+ filename--;
+ }
+
+ stream.writeText(filename);
+
+ for (int i = 0; i < cntColumns; i++) {
+ SkString str;
+ str.printf(", %f", values[i]);
+ stream.writeText(str.c_str());
+ }
+ stream.writeText("\n");
+
+ currentRecord = currentRecord->fNext;
+ }
+}
DEFINE_string2(patterns, p, "", "Use two patterns to compare images: <baseline> <test>");
DEFINE_string2(output, o, "skpdiff_output.json", "Writes the output of these diffs to output: <output>");
DEFINE_bool(jsonp, true, "Output JSON with padding");
+DEFINE_string(csv, "", "Writes the output of these diffs to a csv file");
#if SK_SUPPORT_OPENCL
/// A callback for any OpenCL errors
}
}
+ if (!FLAGS_csv.isEmpty()) {
+ if (1 != FLAGS_csv.count()) {
+ SkDebugf("csv flag expects one argument: <csv file>\n");
+ return 1;
+ }
+ }
+
SkDiffContext ctx;
ctx.setDiffers(chosenDiffers);
ctx.outputRecords(outputStream, FLAGS_jsonp);
}
+ if (!FLAGS_csv.isEmpty()) {
+ SkFILEWStream outputStream(FLAGS_csv[0]);
+ ctx.outputCsv(outputStream);
+ }
+
return 0;
}