| Index: content/renderer/gpu/gpu_benchmarking_extension.cc
|
| diff --git a/content/renderer/gpu/gpu_benchmarking_extension.cc b/content/renderer/gpu/gpu_benchmarking_extension.cc
|
| index 1eb6ef33c09af37fb66fa8e02df2b9d3e6fa2d0c..1fa1609e9748eee3a1651754696d2fa02b87754c 100644
|
| --- a/content/renderer/gpu/gpu_benchmarking_extension.cc
|
| +++ b/content/renderer/gpu/gpu_benchmarking_extension.cc
|
| @@ -9,6 +9,7 @@
|
| #include <utility>
|
|
|
| #include "base/base64.h"
|
| +#include "base/command_line.h"
|
| #include "base/files/file_path.h"
|
| #include "base/files/file_util.h"
|
| #include "base/macros.h"
|
| @@ -21,6 +22,7 @@
|
| #include "content/common/input/synthetic_smooth_scroll_gesture_params.h"
|
| #include "content/common/input/synthetic_tap_gesture_params.h"
|
| #include "content/public/child/v8_value_converter.h"
|
| +#include "content/public/common/content_switches.h"
|
| #include "content/public/renderer/chrome_object_extensions_utils.h"
|
| #include "content/public/renderer/render_thread.h"
|
| #include "content/renderer/gpu/render_widget_compositor.h"
|
| @@ -54,19 +56,52 @@ namespace content {
|
|
|
| namespace {
|
|
|
| -class PNGSerializer : public SkPixelSerializer {
|
| +class EncodingSerializer : public SkPixelSerializer {
|
| protected:
|
| bool onUseEncodedData(const void* data, size_t len) override { return true; }
|
|
|
| SkData* onEncode(const SkPixmap& pixmap) override {
|
| - SkBitmap bm;
|
| - // The const_cast is fine, since we only read from the bitmap.
|
| - if (bm.installPixels(pixmap.info(),
|
| - const_cast<void*>(pixmap.addr()),
|
| - pixmap.rowBytes())) {
|
| - std::vector<unsigned char> vector;
|
| - if (gfx::PNGCodec::EncodeBGRASkBitmap(bm, false, &vector)) {
|
| + std::vector<uint8_t> vector;
|
| +
|
| + const base::CommandLine& commandLine =
|
| + *base::CommandLine::ForCurrentProcess();
|
| + if (commandLine.HasSwitch(switches::kSkipReencodingOnSKPCapture)) {
|
| + // In this case, we just want to store some useful information
|
| + // about the image to replace the missing encoded data.
|
| +
|
| + // First make sure that the data does not accidentally match any
|
| + // image signatures.
|
| + vector.push_back(0xFF);
|
| + vector.push_back(0xFF);
|
| + vector.push_back(0xFF);
|
| + vector.push_back(0xFF);
|
| +
|
| + // Save the width and height.
|
| + uint32_t width = pixmap.width();
|
| + uint32_t height = pixmap.height();
|
| + vector.push_back(width & 0xFF);
|
| + vector.push_back((width >> 8) & 0xFF);
|
| + vector.push_back((width >> 16) & 0xFF);
|
| + vector.push_back((width >> 24) & 0xFF);
|
| + vector.push_back(height & 0xFF);
|
| + vector.push_back((height >> 8) & 0xFF);
|
| + vector.push_back((height >> 16) & 0xFF);
|
| + vector.push_back((height >> 24) & 0xFF);
|
| +
|
| + // Save any additional information about the bitmap that may be
|
| + // interesting.
|
| + vector.push_back(pixmap.colorType());
|
| + vector.push_back(pixmap.alphaType());
|
| return SkData::NewWithCopy(&vector.front(), vector.size());
|
| + } else {
|
| + SkBitmap bm;
|
| + // The const_cast is fine, since we only read from the bitmap.
|
| + if (bm.installPixels(pixmap.info(),
|
| + const_cast<void*>(pixmap.addr()),
|
| + pixmap.rowBytes())) {
|
| + if (gfx::PNGCodec::EncodeBGRASkBitmap(bm, false, &vector)) {
|
| + return SkData::NewWithCopy(&vector.front(), vector.size());
|
| + }
|
| }
|
| }
|
| return nullptr;
|
| @@ -106,7 +141,7 @@ class SkPictureSerializer {
|
| SkFILEWStream file(filepath.c_str());
|
| DCHECK(file.isValid());
|
|
|
| - PNGSerializer serializer;
|
| + EncodingSerializer serializer;
|
| picture->serialize(&file, &serializer);
|
| file.fsync();
|
| }
|
|
|