aboutsummaryrefslogtreecommitdiffhomepage
path: root/tools/skiaserve/skiaserve.cpp
diff options
context:
space:
mode:
authorGravatar joshualitt <joshualitt@chromium.org>2016-02-25 11:09:36 -0800
committerGravatar Commit bot <commit-bot@chromium.org>2016-02-25 11:09:36 -0800
commit26cc3f5ad0aacf80bba162bab4b23a2901ffed17 (patch)
tree168101fd5149e573de913509b090a37296039b4c /tools/skiaserve/skiaserve.cpp
parentb56f92783a5d84347b65f4f01ec3668096649d13 (diff)
Create Response namespace for skiaserve response functions
Diffstat (limited to 'tools/skiaserve/skiaserve.cpp')
-rw-r--r--tools/skiaserve/skiaserve.cpp99
1 files changed, 3 insertions, 96 deletions
diff --git a/tools/skiaserve/skiaserve.cpp b/tools/skiaserve/skiaserve.cpp
index a76e2aa537..d5a0132d0d 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() {}