| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright 2013 Google Inc. | 2 * Copyright 2013 Google Inc. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
| 5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
| 6 */ | 6 */ |
| 7 | 7 |
| 8 #define __NO_STD_VECTOR // Uses cl::vectpr instead of std::vectpr | 8 #define __NO_STD_VECTOR // Uses cl::vectpr instead of std::vectpr |
| 9 #define __NO_STD_STRING // Uses cl::STRING_CLASS instead of std::string | 9 #define __NO_STD_STRING // Uses cl::STRING_CLASS instead of std::string |
| 10 #include <CL/cl.hpp> | 10 #include <CL/cl.hpp> |
| 11 | 11 |
| 12 #include "SkCommandLineFlags.h" | 12 #include "SkCommandLineFlags.h" |
| 13 #include "SkGraphics.h" | 13 #include "SkGraphics.h" |
| 14 #include "SkPoint.h" |
| 14 #include "SkOSFile.h" | 15 #include "SkOSFile.h" |
| 15 #include "SkString.h" | 16 #include "SkString.h" |
| 16 #include "SkTArray.h" | 17 #include "SkTArray.h" |
| 17 #include "SkTDArray.h" | 18 #include "SkTDArray.h" |
| 18 | 19 |
| 19 #include "SkImageDiffer.h" | 20 #include "SkImageDiffer.h" |
| 20 #include "SkCLImageDiffer.h" | 21 #include "SkCLImageDiffer.h" |
| 21 #include "SkPMetric.h" | 22 #include "SkPMetric.h" |
| 22 #include "skpdiff_util.h" | 23 #include "skpdiff_util.h" |
| 23 | 24 |
| (...skipping 52 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 76 // Get the files in the baseline, we will then look for those inside the tes
t path | 77 // Get the files in the baseline, we will then look for those inside the tes
t path |
| 77 SkTArray<SkString> baselineEntries; | 78 SkTArray<SkString> baselineEntries; |
| 78 if (!get_directory(baselinePath, &baselineEntries)) { | 79 if (!get_directory(baselinePath, &baselineEntries)) { |
| 79 SkDebugf("Unable to open path \"%s\"\n", baselinePath); | 80 SkDebugf("Unable to open path \"%s\"\n", baselinePath); |
| 80 return; | 81 return; |
| 81 } | 82 } |
| 82 | 83 |
| 83 SkTDArray<int> queuedDiffIDs; | 84 SkTDArray<int> queuedDiffIDs; |
| 84 for (int baselineIndex = 0; baselineIndex < baselineEntries.count(); baselin
eIndex++) { | 85 for (int baselineIndex = 0; baselineIndex < baselineEntries.count(); baselin
eIndex++) { |
| 85 const char* baseFilename = baselineEntries[baselineIndex].c_str(); | 86 const char* baseFilename = baselineEntries[baselineIndex].c_str(); |
| 86 SkDebugf("%s\n", baseFilename); | 87 SkDebugf("\n%s\n", baseFilename); |
| 87 | 88 |
| 88 // Find the real location of each file to compare | 89 // Find the real location of each file to compare |
| 89 SkString baselineFile = SkOSPath::SkPathJoin(baselinePath, baseFilename)
; | 90 SkString baselineFile = SkOSPath::SkPathJoin(baselinePath, baseFilename)
; |
| 90 SkString testFile = SkOSPath::SkPathJoin(testPath, baseFilename); | 91 SkString testFile = SkOSPath::SkPathJoin(testPath, baseFilename); |
| 91 | 92 |
| 92 // Check that the test file exists and is a file | 93 // Check that the test file exists and is a file |
| 93 if (sk_exists(testFile.c_str()) && !sk_isdir(testFile.c_str())) { | 94 if (sk_exists(testFile.c_str()) && !sk_isdir(testFile.c_str())) { |
| 94 // Queue up the comparison with the differ | 95 // Queue up the comparison with the differ |
| 95 int diffID = differ->queueDiffOfFile(baselineFile.c_str(), testFile.
c_str()); | 96 int diffID = differ->queueDiffOfFile(baselineFile.c_str(), testFile.
c_str()); |
| 96 if (diffID >= 0) { | 97 if (diffID >= 0) { |
| 97 queuedDiffIDs.push(diffID); | 98 queuedDiffIDs.push(diffID); |
| 98 SkDebugf("Result: %f\n", differ->getResult(diffID)); | 99 SkDebugf("Result: %f\n", differ->getResult(diffID)); |
| 100 SkDebugf("POI Count: %i\n", differ->getPointsOfInterestCount(dif
fID)); |
| 101 differ->deleteDiff(diffID); |
| 99 } | 102 } |
| 100 } else { | 103 } else { |
| 101 SkDebugf("Baseline file \"%s\" has no corresponding test file\n", ba
selineFile.c_str()); | 104 SkDebugf("Baseline file \"%s\" has no corresponding test file\n", ba
selineFile.c_str()); |
| 102 } | 105 } |
| 103 } | 106 } |
| 104 } | 107 } |
| 105 | 108 |
| 106 | 109 |
| 107 /// Compares two sets of images identified by glob style patterns with the given
differ | 110 /// Compares two sets of images identified by glob style patterns with the given
differ |
| 108 static void diff_patterns(const char baselinePattern[], const char testPattern[]
, SkImageDiffer* differ) { | 111 static void diff_patterns(const char baselinePattern[], const char testPattern[]
, SkImageDiffer* differ) { |
| (...skipping 14 matching lines...) Expand all Loading... |
| 123 | 126 |
| 124 if (baselineEntries.count() != testEntries.count()) { | 127 if (baselineEntries.count() != testEntries.count()) { |
| 125 SkDebugf("Baseline and test patterns do not yield corresponding number o
f files\n"); | 128 SkDebugf("Baseline and test patterns do not yield corresponding number o
f files\n"); |
| 126 return; | 129 return; |
| 127 } | 130 } |
| 128 | 131 |
| 129 SkTDArray<int> queuedDiffIDs; | 132 SkTDArray<int> queuedDiffIDs; |
| 130 for (int entryIndex = 0; entryIndex < baselineEntries.count(); entryIndex++)
{ | 133 for (int entryIndex = 0; entryIndex < baselineEntries.count(); entryIndex++)
{ |
| 131 const char* baselineFilename = baselineEntries[entryIndex].c_str(); | 134 const char* baselineFilename = baselineEntries[entryIndex].c_str(); |
| 132 const char* testFilename = testEntries [entryIndex].c_str(); | 135 const char* testFilename = testEntries [entryIndex].c_str(); |
| 133 SkDebugf("%s %s\n", baselineFilename, testFilename); | 136 SkDebugf("\n%s %s\n", baselineFilename, testFilename); |
| 134 | 137 |
| 135 int diffID = differ->queueDiffOfFile(baselineFilename, testFilename); | 138 int diffID = differ->queueDiffOfFile(baselineFilename, testFilename); |
| 136 if (diffID >= 0) { | 139 if (diffID >= 0) { |
| 137 queuedDiffIDs.push(diffID); | 140 queuedDiffIDs.push(diffID); |
| 138 SkDebugf("Result: %f\n", differ->getResult(diffID)); | 141 SkDebugf("Result: %f\n", differ->getResult(diffID)); |
| 142 SkDebugf("POI Count: %i\n", differ->getPointsOfInterestCount(diffID)
); |
| 143 differ->deleteDiff(diffID); |
| 139 } | 144 } |
| 140 } | 145 } |
| 141 } | 146 } |
| 142 | 147 |
| 143 | 148 |
| 144 static bool init_cl_diff(SkImageDiffer* differ) { | 149 static bool init_cl_diff(SkImageDiffer* differ) { |
| 145 // Setup OpenCL | 150 // Setup OpenCL |
| 146 cl::Device device; | 151 cl::Device device; |
| 147 cl::Context context; | 152 cl::Context context; |
| 148 if (!init_device_and_context(&device, &context)) { | 153 if (!init_device_and_context(&device, &context)) { |
| (...skipping 103 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 252 } | 257 } |
| 253 | 258 |
| 254 // Perform a pattern diff if one is requested | 259 // Perform a pattern diff if one is requested |
| 255 if (!FLAGS_patterns.isEmpty()) { | 260 if (!FLAGS_patterns.isEmpty()) { |
| 256 diff_patterns(FLAGS_patterns[0], FLAGS_patterns[1], differ); | 261 diff_patterns(FLAGS_patterns[0], FLAGS_patterns[1], differ); |
| 257 } | 262 } |
| 258 } | 263 } |
| 259 | 264 |
| 260 return 0; | 265 return 0; |
| 261 } | 266 } |
| OLD | NEW |