| OLD | NEW |
| 1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2009 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 20 matching lines...) Expand all Loading... |
| 31 #include "debug-agent.h" | 31 #include "debug-agent.h" |
| 32 | 32 |
| 33 #ifdef ENABLE_DEBUGGER_SUPPORT | 33 #ifdef ENABLE_DEBUGGER_SUPPORT |
| 34 | 34 |
| 35 namespace v8 { | 35 namespace v8 { |
| 36 namespace internal { | 36 namespace internal { |
| 37 | 37 |
| 38 // Public V8 debugger API message handler function. This function just delegates | 38 // Public V8 debugger API message handler function. This function just delegates |
| 39 // to the debugger agent through it's data parameter. | 39 // to the debugger agent through it's data parameter. |
| 40 void DebuggerAgentMessageHandler(const v8::Debug::Message& message) { | 40 void DebuggerAgentMessageHandler(const v8::Debug::Message& message) { |
| 41 DebuggerAgent::instance_->DebuggerMessage(message); | 41 DebuggerAgent* agent = Isolate::Current()->debugger_agent_instance(); |
| 42 ASSERT(agent != NULL); |
| 43 agent->DebuggerMessage(message); |
| 42 } | 44 } |
| 43 | 45 |
| 44 // static | |
| 45 DebuggerAgent* DebuggerAgent::instance_ = NULL; | |
| 46 | 46 |
| 47 // Debugger agent main thread. | 47 // Debugger agent main thread. |
| 48 void DebuggerAgent::Run() { | 48 void DebuggerAgent::Run() { |
| 49 const int kOneSecondInMicros = 1000000; | 49 const int kOneSecondInMicros = 1000000; |
| 50 | 50 |
| 51 // Allow this socket to reuse port even if still in TIME_WAIT. | 51 // Allow this socket to reuse port even if still in TIME_WAIT. |
| 52 server_->SetReuseAddress(true); | 52 server_->SetReuseAddress(true); |
| 53 | 53 |
| 54 // First bind the socket to the requested port. | 54 // First bind the socket to the requested port. |
| 55 bool bound = false; | 55 bool bound = false; |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 95 | 95 |
| 96 // Close existing session if any. | 96 // Close existing session if any. |
| 97 CloseSession(); | 97 CloseSession(); |
| 98 } | 98 } |
| 99 | 99 |
| 100 | 100 |
| 101 void DebuggerAgent::WaitUntilListening() { | 101 void DebuggerAgent::WaitUntilListening() { |
| 102 listening_->Wait(); | 102 listening_->Wait(); |
| 103 } | 103 } |
| 104 | 104 |
| 105 static const char* kCreateSessionMessage = |
| 106 "Remote debugging session already active\r\n"; |
| 107 |
| 105 void DebuggerAgent::CreateSession(Socket* client) { | 108 void DebuggerAgent::CreateSession(Socket* client) { |
| 106 ScopedLock with(session_access_); | 109 ScopedLock with(session_access_); |
| 107 | 110 |
| 108 // If another session is already established terminate this one. | 111 // If another session is already established terminate this one. |
| 109 if (session_ != NULL) { | 112 if (session_ != NULL) { |
| 110 static const char* message = "Remote debugging session already active\r\n"; | 113 client->Send(kCreateSessionMessage, StrLength(kCreateSessionMessage)); |
| 111 | |
| 112 client->Send(message, StrLength(message)); | |
| 113 delete client; | 114 delete client; |
| 114 return; | 115 return; |
| 115 } | 116 } |
| 116 | 117 |
| 117 // Create a new session and hook up the debug message handler. | 118 // Create a new session and hook up the debug message handler. |
| 118 session_ = new DebuggerAgentSession(this, client); | 119 session_ = new DebuggerAgentSession(isolate(), this, client); |
| 119 v8::Debug::SetMessageHandler2(DebuggerAgentMessageHandler); | 120 v8::Debug::SetMessageHandler2(DebuggerAgentMessageHandler); |
| 120 session_->Start(); | 121 session_->Start(); |
| 121 } | 122 } |
| 122 | 123 |
| 123 | 124 |
| 124 void DebuggerAgent::CloseSession() { | 125 void DebuggerAgent::CloseSession() { |
| 125 ScopedLock with(session_access_); | 126 ScopedLock with(session_access_); |
| 126 | 127 |
| 127 // Terminate the session. | 128 // Terminate the session. |
| 128 if (session_ != NULL) { | 129 if (session_ != NULL) { |
| (...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 217 DebuggerAgentUtil::SendMessage(client_, message); | 218 DebuggerAgentUtil::SendMessage(client_, message); |
| 218 } | 219 } |
| 219 | 220 |
| 220 | 221 |
| 221 void DebuggerAgentSession::Shutdown() { | 222 void DebuggerAgentSession::Shutdown() { |
| 222 // Shutdown the socket to end the blocking receive. | 223 // Shutdown the socket to end the blocking receive. |
| 223 client_->Shutdown(); | 224 client_->Shutdown(); |
| 224 } | 225 } |
| 225 | 226 |
| 226 | 227 |
| 227 const char* DebuggerAgentUtil::kContentLength = "Content-Length"; | 228 const char* const DebuggerAgentUtil::kContentLength = "Content-Length"; |
| 228 int DebuggerAgentUtil::kContentLengthSize = | 229 const int DebuggerAgentUtil::kContentLengthSize = |
| 229 StrLength(kContentLength); | 230 StrLength(kContentLength); |
| 230 | 231 |
| 231 | 232 |
| 232 SmartPointer<char> DebuggerAgentUtil::ReceiveMessage(const Socket* conn) { | 233 SmartPointer<char> DebuggerAgentUtil::ReceiveMessage(const Socket* conn) { |
| 233 int received; | 234 int received; |
| 234 | 235 |
| 235 // Read header. | 236 // Read header. |
| 236 int content_length = 0; | 237 int content_length = 0; |
| 237 while (true) { | 238 while (true) { |
| 238 const int kHeaderBufferSize = 80; | 239 const int kHeaderBufferSize = 80; |
| (...skipping 198 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 437 return total_received; | 438 return total_received; |
| 438 } | 439 } |
| 439 total_received += received; | 440 total_received += received; |
| 440 } | 441 } |
| 441 return total_received; | 442 return total_received; |
| 442 } | 443 } |
| 443 | 444 |
| 444 } } // namespace v8::internal | 445 } } // namespace v8::internal |
| 445 | 446 |
| 446 #endif // ENABLE_DEBUGGER_SUPPORT | 447 #endif // ENABLE_DEBUGGER_SUPPORT |
| OLD | NEW |