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); |
} |