Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(984)

Unified Diff: content/browser/debugger/devtools_netlog_observer.cc

Issue 11630004: DevTools: rename debugger/ to devtools/, move DevTools files into content/renderer/devtools. (Closed) Base URL: http://git.chromium.org/chromium/src.git@master
Patch Set: For landing Created 8 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/browser/debugger/devtools_netlog_observer.cc
diff --git a/content/browser/debugger/devtools_netlog_observer.cc b/content/browser/debugger/devtools_netlog_observer.cc
deleted file mode 100644
index fc024436f3c6cf014804eb014d838589386a1610..0000000000000000000000000000000000000000
--- a/content/browser/debugger/devtools_netlog_observer.cc
+++ /dev/null
@@ -1,329 +0,0 @@
-// Copyright (c) 2012 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#include "content/browser/debugger/devtools_netlog_observer.h"
-
-#include "base/string_tokenizer.h"
-#include "base/string_util.h"
-#include "base/values.h"
-#include "content/public/browser/browser_thread.h"
-#include "content/public/browser/content_browser_client.h"
-#include "content/public/common/resource_response.h"
-#include "net/base/load_flags.h"
-#include "net/http/http_response_headers.h"
-#include "net/http/http_util.h"
-#include "net/spdy/spdy_header_block.h"
-#include "net/url_request/url_request.h"
-#include "net/url_request/url_request_netlog_params.h"
-#include "webkit/glue/resource_loader_bridge.h"
-
-namespace content {
-const size_t kMaxNumEntries = 1000;
-
-DevToolsNetLogObserver* DevToolsNetLogObserver::instance_ = NULL;
-
-DevToolsNetLogObserver::DevToolsNetLogObserver() {
-}
-
-DevToolsNetLogObserver::~DevToolsNetLogObserver() {
-}
-
-DevToolsNetLogObserver::ResourceInfo*
-DevToolsNetLogObserver::GetResourceInfo(uint32 id) {
- RequestToInfoMap::iterator it = request_to_info_.find(id);
- if (it != request_to_info_.end())
- return it->second;
- return NULL;
-}
-
-void DevToolsNetLogObserver::OnAddEntry(const net::NetLog::Entry& entry) {
- // The events that the Observer is interested in only occur on the IO thread.
- if (!BrowserThread::CurrentlyOn(BrowserThread::IO))
- return;
-
- if (entry.source().type == net::NetLog::SOURCE_URL_REQUEST)
- OnAddURLRequestEntry(entry);
- else if (entry.source().type == net::NetLog::SOURCE_HTTP_STREAM_JOB)
- OnAddHTTPStreamJobEntry(entry);
- else if (entry.source().type == net::NetLog::SOURCE_SOCKET)
- OnAddSocketEntry(entry);
-}
-
-void DevToolsNetLogObserver::OnAddURLRequestEntry(
- const net::NetLog::Entry& entry) {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
-
- bool is_begin = entry.phase() == net::NetLog::PHASE_BEGIN;
- bool is_end = entry.phase() == net::NetLog::PHASE_END;
-
- if (entry.type() == net::NetLog::TYPE_URL_REQUEST_START_JOB) {
- if (is_begin) {
- int load_flags;
- scoped_ptr<Value> event_param(entry.ParametersToValue());
- if (!net::StartEventLoadFlagsFromEventParams(event_param.get(),
- &load_flags)) {
- return;
- }
-
- if (!(load_flags & net::LOAD_REPORT_RAW_HEADERS))
- return;
-
- if (request_to_info_.size() > kMaxNumEntries) {
- LOG(WARNING) << "The raw headers observer url request count has grown "
- "larger than expected, resetting";
- request_to_info_.clear();
- }
-
- request_to_info_[entry.source().id] = new ResourceInfo();
-
- if (request_to_encoded_data_length_.size() > kMaxNumEntries) {
- LOG(WARNING) << "The encoded data length observer url request count "
- "has grown larger than expected, resetting";
- request_to_encoded_data_length_.clear();
- }
-
- request_to_encoded_data_length_[entry.source().id] = 0;
- }
- return;
- } else if (entry.type() == net::NetLog::TYPE_REQUEST_ALIVE) {
- // Cleanup records based on the TYPE_REQUEST_ALIVE entry.
- if (is_end) {
- request_to_info_.erase(entry.source().id);
- request_to_encoded_data_length_.erase(entry.source().id);
- }
- return;
- }
-
- ResourceInfo* info = GetResourceInfo(entry.source().id);
- if (!info)
- return;
-
- switch (entry.type()) {
- case net::NetLog::TYPE_HTTP_TRANSACTION_SEND_REQUEST_HEADERS: {
- scoped_ptr<Value> event_params(entry.ParametersToValue());
- std::string request_line;
- net::HttpRequestHeaders request_headers;
-
- if (!net::HttpRequestHeaders::FromNetLogParam(event_params.get(),
- &request_headers,
- &request_line)) {
- NOTREACHED();
- }
-
- // We need to clear headers in case the same url_request is reused for
- // several http requests (e.g. see http://crbug.com/80157).
- info->request_headers.clear();
-
- for (net::HttpRequestHeaders::Iterator it(request_headers);
- it.GetNext();) {
- info->request_headers.push_back(std::make_pair(it.name(), it.value()));
- }
- info->request_headers_text = request_line + request_headers.ToString();
- break;
- }
- case net::NetLog::TYPE_HTTP_TRANSACTION_SPDY_SEND_REQUEST_HEADERS: {
- scoped_ptr<Value> event_params(entry.ParametersToValue());
- net::SpdyHeaderBlock request_headers;
-
- if (!net::SpdyHeaderBlockFromNetLogParam(event_params.get(),
- &request_headers)) {
- NOTREACHED();
- }
-
- // We need to clear headers in case the same url_request is reused for
- // several http requests (e.g. see http://crbug.com/80157).
- info->request_headers.clear();
-
- for (net::SpdyHeaderBlock::const_iterator it = request_headers.begin();
- it != request_headers.end(); ++it) {
- info->request_headers.push_back(std::make_pair(it->first, it->second));
- }
- info->request_headers_text = "";
- break;
- }
- case net::NetLog::TYPE_HTTP_TRANSACTION_READ_RESPONSE_HEADERS: {
- scoped_ptr<Value> event_params(entry.ParametersToValue());
-
- scoped_refptr<net::HttpResponseHeaders> response_headers;
-
- if (!net::HttpResponseHeaders::FromNetLogParam(event_params.get(),
- &response_headers)) {
- NOTREACHED();
- }
-
- info->http_status_code = response_headers->response_code();
- info->http_status_text = response_headers->GetStatusText();
- std::string name, value;
-
- // We need to clear headers in case the same url_request is reused for
- // several http requests (e.g. see http://crbug.com/80157).
- info->response_headers.clear();
-
- for (void* it = NULL;
- response_headers->EnumerateHeaderLines(&it, &name, &value); ) {
- info->response_headers.push_back(std::make_pair(name, value));
- }
- info->response_headers_text =
- net::HttpUtil::ConvertHeadersBackToHTTPResponse(
- response_headers->raw_headers());
- break;
- }
- case net::NetLog::TYPE_HTTP_STREAM_REQUEST_BOUND_TO_JOB: {
- scoped_ptr<Value> event_params(entry.ParametersToValue());
- net::NetLog::Source http_stream_job_source;
- if (!net::NetLog::Source::FromEventParameters(event_params.get(),
- &http_stream_job_source)) {
- NOTREACHED();
- break;
- }
-
- uint32 http_stream_job_id = http_stream_job_source.id;
- HTTPStreamJobToSocketMap::iterator it =
- http_stream_job_to_socket_.find(http_stream_job_id);
- if (it == http_stream_job_to_socket_.end())
- return;
- uint32 socket_id = it->second;
-
- if (socket_to_request_.size() > kMaxNumEntries) {
- LOG(WARNING) << "The url request observer socket count has grown "
- "larger than expected, resetting";
- socket_to_request_.clear();
- }
-
- socket_to_request_[socket_id] = entry.source().id;
- http_stream_job_to_socket_.erase(http_stream_job_id);
- break;
- }
- default:
- break;
- }
-}
-
-void DevToolsNetLogObserver::OnAddHTTPStreamJobEntry(
- const net::NetLog::Entry& entry) {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
-
- if (entry.type() == net::NetLog::TYPE_SOCKET_POOL_BOUND_TO_SOCKET) {
- scoped_ptr<Value> event_params(entry.ParametersToValue());
- net::NetLog::Source socket_source;
- if (!net::NetLog::Source::FromEventParameters(event_params.get(),
- &socket_source)) {
- NOTREACHED();
- return;
- }
-
- // Prevents us from passively growing the memory unbounded in
- // case something went wrong. Should not happen.
- if (http_stream_job_to_socket_.size() > kMaxNumEntries) {
- LOG(WARNING) << "The load timing observer http stream job count "
- "has grown larger than expected, resetting";
- http_stream_job_to_socket_.clear();
- }
- http_stream_job_to_socket_[entry.source().id] = socket_source.id;
- }
-}
-
-void DevToolsNetLogObserver::OnAddSocketEntry(
- const net::NetLog::Entry& entry) {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
-
- bool is_end = entry.phase() == net::NetLog::PHASE_END;
-
- SocketToRequestMap::iterator it =
- socket_to_request_.find(entry.source().id);
- if (it == socket_to_request_.end())
- return;
- uint32 request_id = it->second;
-
- if (entry.type() == net::NetLog::TYPE_SOCKET_IN_USE) {
- if (is_end)
- socket_to_request_.erase(entry.source().id);
- return;
- }
-
- RequestToEncodedDataLengthMap::iterator encoded_data_length_it =
- request_to_encoded_data_length_.find(request_id);
- if (encoded_data_length_it == request_to_encoded_data_length_.end())
- return;
-
- if (net::NetLog::TYPE_SOCKET_BYTES_RECEIVED == entry.type()) {
- int byte_count = 0;
- scoped_ptr<Value> value(entry.ParametersToValue());
- if (!value->IsType(Value::TYPE_DICTIONARY))
- return;
-
- DictionaryValue* dValue = static_cast<DictionaryValue*>(value.get());
- if (!dValue->GetInteger("byte_count", &byte_count))
- return;
-
- encoded_data_length_it->second += byte_count;
- }
-}
-
-void DevToolsNetLogObserver::Attach() {
- DCHECK(!instance_);
- net::NetLog* net_log = GetContentClient()->browser()->GetNetLog();
- if (net_log) {
- instance_ = new DevToolsNetLogObserver();
- net_log->AddThreadSafeObserver(instance_, net::NetLog::LOG_ALL_BUT_BYTES);
- }
-}
-
-void DevToolsNetLogObserver::Detach() {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
-
- if (instance_) {
- // Safest not to do this in the destructor to maintain thread safety across
- // refactorings.
- instance_->net_log()->RemoveThreadSafeObserver(instance_);
- delete instance_;
- instance_ = NULL;
- }
-}
-
-DevToolsNetLogObserver* DevToolsNetLogObserver::GetInstance() {
- DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
-
- return instance_;
-}
-
-// static
-void DevToolsNetLogObserver::PopulateResponseInfo(
- net::URLRequest* request,
- ResourceResponse* response) {
- if (!(request->load_flags() & net::LOAD_REPORT_RAW_HEADERS))
- return;
-
- uint32 source_id = request->net_log().source().id;
- DevToolsNetLogObserver* dev_tools_net_log_observer =
- DevToolsNetLogObserver::GetInstance();
- if (dev_tools_net_log_observer == NULL)
- return;
- response->head.devtools_info =
- dev_tools_net_log_observer->GetResourceInfo(source_id);
-}
-
-// static
-int DevToolsNetLogObserver::GetAndResetEncodedDataLength(
- net::URLRequest* request) {
- if (!(request->load_flags() & net::LOAD_REPORT_RAW_HEADERS))
- return -1;
-
- uint32 source_id = request->net_log().source().id;
- DevToolsNetLogObserver* dev_tools_net_log_observer =
- DevToolsNetLogObserver::GetInstance();
- if (dev_tools_net_log_observer == NULL)
- return -1;
-
- RequestToEncodedDataLengthMap::iterator it =
- dev_tools_net_log_observer->request_to_encoded_data_length_.find(
- source_id);
- if (it == dev_tools_net_log_observer->request_to_encoded_data_length_.end())
- return -1;
- int encoded_data_length = it->second;
- it->second = 0;
- return encoded_data_length;
-}
-
-} // namespace content
« no previous file with comments | « content/browser/debugger/devtools_netlog_observer.h ('k') | content/browser/debugger/devtools_resources.gyp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698