summaryrefslogtreecommitdiffstats
path: root/Source/WebKit/android/wds/DebugServer.cpp
blob: 2fde6bd5464b3272e51e9124707dbfbb495dcc59 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
/*
 * Copyright 2008, The Android Open Source Project
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 *  * Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *  * Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS ``AS IS'' AND ANY
 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
 * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE COPYRIGHT OWNER OR
 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

#define LOG_TAG "wds"
#include "config.h"

#include "Command.h"
#include "Connection.h"
#include "DebugServer.h"
#include "wtf/MainThread.h"
#include "wtf/Threading.h"
#include <arpa/inet.h>
#include <cutils/properties.h>
#include <errno.h>
#include <string.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <utils/Log.h>

#if ENABLE(WDS)

#define DEFAULT_PORT 9999
#define log_errno(x) ALOGE("%s: %d", x, strerror(errno))

namespace android {

namespace WDS {

static DebugServer* s_server = NULL;

// Main thread function for createThread
static void* mainThread(void* v) {
    DebugServer* server = static_cast<DebugServer*>(v);
    server->start();
    delete server;
    s_server = NULL;
    return NULL;
}

DebugServer* server() {
    if (s_server == NULL)
        s_server = new DebugServer();
    return s_server;
}

DebugServer::DebugServer() {
    // Read webcore.wds.enable to determine if the debug server should run
    char buf[PROPERTY_VALUE_MAX];
    int ret = property_get("webcore.wds.enable", buf, NULL);
    if (ret != -1 && strcmp(buf, "1") == 0) {
        ALOGD("WDS Enabled");
        m_threadId = createThread(mainThread, this, "WDS");
    }
    // Initialize the available commands.
    Command::Init();
}

void DebugServer::start() {
    ALOGD("DebugServer thread started");

    ConnectionServer cs;
    if (!cs.connect(DEFAULT_PORT)) {
        ALOGE("Failed to start the server socket connection");
        return;
    }

    while (true ) {
        ALOGD("Waiting for incoming connections...");
        Connection* conn = cs.accept();
        if (!conn) {
            log_errno("Failed to accept new connections");
            return;
        }
        ALOGD("...Connection established");

        Command* c = Command::Find(conn);
        if (!c) {
            ALOGE("Could not find matching command");
            delete conn;
        } else {
            // Dispatch the command, it will handle cleaning up the connection
            // when finished.
            c->dispatch();
        }
    }

    ALOGD("DebugServer thread finished");
}

} // end namespace WDS

} // end namespace android

#endif