aboutsummaryrefslogtreecommitdiffhomepage
path: root/tools/skiaserve/skiaserve.cpp
diff options
context:
space:
mode:
authorGravatar joshualitt <joshualitt@chromium.org>2016-02-17 11:20:26 -0800
committerGravatar Commit bot <commit-bot@chromium.org>2016-02-17 11:20:26 -0800
commit6b3cf73af525fdbf6fd093304db840bb998e3dd6 (patch)
tree59b9b55fee42e6041f6f87cadca2efec108c0150 /tools/skiaserve/skiaserve.cpp
parent91e457d17f8c6c06de33eb2bb430a90ba472eda5 (diff)
Add batch information to json
Diffstat (limited to 'tools/skiaserve/skiaserve.cpp')
-rw-r--r--tools/skiaserve/skiaserve.cpp14
1 files changed, 10 insertions, 4 deletions
diff --git a/tools/skiaserve/skiaserve.cpp b/tools/skiaserve/skiaserve.cpp
index 119f065ac0..717e6855c4 100644
--- a/tools/skiaserve/skiaserve.cpp
+++ b/tools/skiaserve/skiaserve.cpp
@@ -136,13 +136,18 @@ SkData* writeCanvasToPng(SkCanvas* canvas) {
return buffer.copyToData();
}
-SkData* setupAndDrawToCanvasReturnPng(Request* request, int n) {
+SkCanvas* getCanvasFromRequest(Request* request) {
GrContextFactory* factory = request->fContextFactory;
SkGLContext* gl = factory->getContextInfo(GrContextFactory::kNative_GLContextType,
GrContextFactory::kNone_GLContextOptions).fGLContext;
gl->makeCurrent();
SkASSERT(request->fDebugCanvas);
SkCanvas* target = request->fSurface->getCanvas();
+ return target;
+}
+
+SkData* setupAndDrawToCanvasReturnPng(Request* request, int n) {
+ SkCanvas* target = getCanvasFromRequest(request);
request->fDebugCanvas->drawTo(target, n);
return writeCanvasToPng(target);
}
@@ -195,9 +200,9 @@ static int SendData(MHD_Connection* connection, const SkData* data, const char*
return ret;
}
-static int SendJSON(MHD_Connection* connection, SkDebugCanvas* debugCanvas,
+static int SendJSON(MHD_Connection* connection, SkCanvas* canvas, SkDebugCanvas* debugCanvas,
UrlDataManager* urlDataManager, int n) {
- Json::Value root = debugCanvas->toJSON(*urlDataManager, n);
+ Json::Value root = debugCanvas->toJSON(*urlDataManager, n, canvas);
SkDynamicMemoryWStream stream;
stream.writeText(Json::FastWriter().write(root).c_str());
@@ -261,7 +266,8 @@ public:
} else {
sscanf(commands[1].c_str(), "%d", &n);
}
- return SendJSON(connection, request->fDebugCanvas, &request->fUrlDataManager, n);
+ return SendJSON(connection, getCanvasFromRequest(request), request->fDebugCanvas,
+ &request->fUrlDataManager, n);
}
// /cmd/N, for now only delete supported