| Index: tools/skiaserve/skiaserve.cpp
|
| diff --git a/tools/skiaserve/skiaserve.cpp b/tools/skiaserve/skiaserve.cpp
|
| index fad8aa4acec211b6bc7eab81f3e07a99a28eb5fe..85e9c87c17b490eb32c1522152be9d30fcf8d368 100644
|
| --- a/tools/skiaserve/skiaserve.cpp
|
| +++ b/tools/skiaserve/skiaserve.cpp
|
| @@ -11,6 +11,7 @@
|
| #include "SkCommandLineFlags.h"
|
| #include "SkDebugCanvas.h"
|
| #include "SkJSONCanvas.h"
|
| +#include "SkJSONCPP.h"
|
| #include "SkPicture.h"
|
| #include "SkPictureRecorder.h"
|
| #include "SkPixelSerializer.h"
|
| @@ -117,6 +118,12 @@ SkData* setupAndDrawToCanvasReturnPng(SkDebugCanvas* debugCanvas, int n) {
|
| return writeCanvasToPng(canvas);
|
| }
|
|
|
| +SkSurface* setupCpuSurface() {
|
| + SkImageInfo info = SkImageInfo::Make(kImageWidth, kImageHeight, kN32_SkColorType,
|
| + kPremul_SkAlphaType);
|
| + return SkSurface::NewRaster(info);
|
| +}
|
| +
|
| static const size_t kBufferSize = 1024;
|
|
|
| static int process_upload_data(void* cls, enum MHD_ValueKind kind,
|
| @@ -188,7 +195,7 @@ public:
|
| const char* upload_data, size_t* upload_data_size) = 0;
|
| };
|
|
|
| -class InfoHandler : public UrlHandler {
|
| +class CmdHandler : public UrlHandler {
|
| public:
|
| bool canHandle(const char* method, const char* url) override {
|
| const char* kBasePath = "/cmd";
|
| @@ -356,6 +363,55 @@ public:
|
| }
|
| };
|
|
|
| +class InfoHandler : public UrlHandler {
|
| +public:
|
| + bool canHandle(const char* method, const char* url) override {
|
| + const char* kBaseName = "/info";
|
| + return 0 == strcmp(method, MHD_HTTP_METHOD_GET) &&
|
| + 0 == strncmp(url, kBaseName, strlen(kBaseName));
|
| + }
|
| +
|
| + int handle(Request* request, MHD_Connection* connection,
|
| + const char* url, const char* method,
|
| + const char* upload_data, size_t* upload_data_size) override {
|
| + SkTArray<SkString> commands;
|
| + SkStrSplit(url, "/", &commands);
|
| +
|
| + if (!request->fPicture.get() || commands.count() > 2) {
|
| + return MHD_NO;
|
| + }
|
| +
|
| + // drawTo
|
| + SkAutoTUnref<SkSurface> surface(setupCpuSurface());
|
| + SkCanvas* canvas = surface->getCanvas();
|
| +
|
| + int n;
|
| + // /info or /info/N
|
| + if (commands.count() == 1) {
|
| + n = request->fDebugCanvas->getSize() - 1;
|
| + } else {
|
| + sscanf(commands[1].c_str(), "%d", &n);
|
| + }
|
| +
|
| + // TODO this is really slow and we should cache the matrix and clip
|
| + request->fDebugCanvas->drawTo(canvas, n);
|
| +
|
| + // make some json
|
| + SkMatrix vm = request->fDebugCanvas->getCurrentMatrix();
|
| + SkIRect clip = request->fDebugCanvas->getCurrentClip();
|
| + Json::Value info(Json::objectValue);
|
| + info["ViewMatrix"] = SkJSONCanvas::MakeMatrix(vm);
|
| + info["ClipRect"] = SkJSONCanvas::MakeIRect(clip);
|
| +
|
| + std::string json = Json::FastWriter().write(info);
|
| +
|
| + // We don't want the null terminator so strlen is correct
|
| + SkAutoTUnref<SkData> data(SkData::NewWithCopy(json.c_str(), strlen(json.c_str())));
|
| + return SendData(connection, data, "application/json");
|
| + }
|
| +};
|
| +
|
| +
|
| class RootHandler : public UrlHandler {
|
| public:
|
| bool canHandle(const char* method, const char* url) override {
|
| @@ -377,6 +433,7 @@ public:
|
| fHandlers.push_back(new RootHandler);
|
| fHandlers.push_back(new PostHandler);
|
| fHandlers.push_back(new ImgHandler);
|
| + fHandlers.push_back(new CmdHandler);
|
| fHandlers.push_back(new InfoHandler);
|
| fHandlers.push_back(new DownloadHandler);
|
| }
|
|
|