Index: tools/skiaserve/skiaserve.cpp |
diff --git a/tools/skiaserve/skiaserve.cpp b/tools/skiaserve/skiaserve.cpp |
index a76e2aa537ca33063423292b30164de288354836..d5a0132d0d189833ed8d48c927c1ba4f56330471 100644 |
--- a/tools/skiaserve/skiaserve.cpp |
+++ b/tools/skiaserve/skiaserve.cpp |
@@ -9,6 +9,7 @@ |
#include "GrContextFactory.h" |
#include "Request.h" |
+#include "Response.h" |
#include "SkCanvas.h" |
#include "SkCommandLineFlags.h" |
@@ -19,37 +20,15 @@ |
#include <sys/socket.h> |
#include <microhttpd.h> |
+using namespace Response; |
+ |
// To get image decoders linked in we have to do the below magic |
#include "SkForceLinking.h" |
#include "SkImageDecoder.h" |
__SK_FORCE_IMAGE_DECODER_LINKING; |
-DEFINE_string(source, "https://debugger.skia.org", "Where to load the web UI from."); |
DEFINE_int32(port, 8888, "The port to listen on."); |
-SkString generateTemplate(SkString source) { |
- SkString debuggerTemplate; |
- debuggerTemplate.appendf( |
- "<!DOCTYPE html>\n" |
- "<html>\n" |
- "<head>\n" |
- " <title>SkDebugger</title>\n" |
- " <meta charset=\"utf-8\" />\n" |
- " <meta http-equiv=\"X-UA-Compatible\" content=\"IE=egde,chrome=1\">\n" |
- " <meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">\n" |
- " <script src=\"%s/res/js/core.js\" type=\"text/javascript\" charset=\"utf-8\"></script>\n" |
- " <link href=\"%s/res/vul/elements.html\" rel=\"import\" />\n" |
- " <link rel='shortcut icon' href='https://debugger.skia.org/res/img/favicon.ico' type='image/x-icon'/ >" |
- "</head>\n" |
- "<body class=\"fullbleed layout vertical\">\n" |
- " <debugger-app-sk>This is the app." |
- " </debugger-app-sk>\n" |
- "</body>\n" |
- "</html>", source.c_str(), source.c_str()); |
- return debuggerTemplate; |
- |
-} |
- |
static const size_t kBufferSize = 1024; |
static int process_upload_data(void* cls, enum MHD_ValueKind kind, |
@@ -64,78 +43,6 @@ static int process_upload_data(void* cls, enum MHD_ValueKind kind, |
return MHD_YES; |
} |
-// SendOK just sends an empty response with a 200 OK status code. |
-static int SendOK(MHD_Connection* connection) { |
- const char* data = ""; |
- |
- MHD_Response* response = MHD_create_response_from_buffer(strlen(data), |
- (void*)data, |
- MHD_RESPMEM_PERSISTENT); |
- int ret = MHD_queue_response(connection, 200, response); |
- MHD_destroy_response(response); |
- return ret; |
-} |
- |
-static int SendError(MHD_Connection* connection, const char* msg) { |
- MHD_Response* response = MHD_create_response_from_buffer(strlen(msg), |
- (void*) msg, |
- MHD_RESPMEM_PERSISTENT); |
- int ret = MHD_queue_response(connection, 500, response); |
- MHD_destroy_response(response); |
- return ret; |
-} |
- |
-static int SendData(MHD_Connection* connection, const SkData* data, const char* type, |
- bool setContentDisposition = false, const char* dispositionString = nullptr) { |
- MHD_Response* response = MHD_create_response_from_buffer(data->size(), |
- const_cast<void*>(data->data()), |
- MHD_RESPMEM_MUST_COPY); |
- MHD_add_response_header(response, "Content-Type", type); |
- |
- if (setContentDisposition) { |
- MHD_add_response_header(response, "Content-Disposition", dispositionString); |
- } |
- |
- int ret = MHD_queue_response(connection, MHD_HTTP_OK, response); |
- MHD_destroy_response(response); |
- return ret; |
-} |
- |
-static int SendJSON(MHD_Connection* connection, Request* request, int n) { |
- SkCanvas* canvas = request->getCanvas(); |
- SkDebugCanvas* debugCanvas = request->fDebugCanvas; |
- UrlDataManager* urlDataManager = &request->fUrlDataManager; |
- Json::Value root = debugCanvas->toJSON(*urlDataManager, n, canvas); |
- root["mode"] = Json::Value(request->fGPUEnabled ? "gpu" : "cpu"); |
- SkDynamicMemoryWStream stream; |
- stream.writeText(Json::FastWriter().write(root).c_str()); |
- |
- SkAutoTUnref<SkData> data(stream.copyToData()); |
- return SendData(connection, data, "application/json"); |
-} |
- |
-static int SendTemplate(MHD_Connection* connection, bool redirect = false, |
- const char* redirectUrl = nullptr) { |
- SkString debuggerTemplate = generateTemplate(SkString(FLAGS_source[0])); |
- |
- MHD_Response* response = MHD_create_response_from_buffer( |
- debuggerTemplate.size(), |
- (void*) const_cast<char*>(debuggerTemplate.c_str()), |
- MHD_RESPMEM_MUST_COPY); |
- MHD_add_response_header (response, "Access-Control-Allow-Origin", "*"); |
- |
- int status = MHD_HTTP_OK; |
- |
- if (redirect) { |
- MHD_add_response_header (response, "Location", redirectUrl); |
- status = MHD_HTTP_SEE_OTHER; |
- } |
- |
- int ret = MHD_queue_response(connection, status, response); |
- MHD_destroy_response(response); |
- return ret; |
-} |
- |
class UrlHandler { |
public: |
virtual ~UrlHandler() {} |