From eaea8ab540171542f7c1ac6f6ce47130da5d1a0e Mon Sep 17 00:00:00 2001 From: "erikkay@google.com" Date: Thu, 31 Jul 2008 23:23:45 +0000 Subject: Command-line flag to allow the debugger UI to be loaded from the filesystem rather than the DLL. Very useful for rapid development. git-svn-id: svn://svn.chromium.org/chrome/trunk/src@208 0039d316-1c4b-4281-b951-d872f2087c98 --- chrome/browser/debugger/debugger_contents.cc | 22 ++++++++++++++++++++-- chrome/common/chrome_switches.cc | 3 +++ chrome/common/chrome_switches.h | 2 ++ 3 files changed, 25 insertions(+), 2 deletions(-) (limited to 'chrome') diff --git a/chrome/browser/debugger/debugger_contents.cc b/chrome/browser/debugger/debugger_contents.cc index 7b2e0a3..85a1c01 100644 --- a/chrome/browser/debugger/debugger_contents.cc +++ b/chrome/browser/debugger/debugger_contents.cc @@ -29,12 +29,15 @@ // // This file defines utility functions for working with strings. +#include "base/command_line.h" +#include "base/file_util.h" #include "chrome/browser/browser_process.h" #include "chrome/browser/debugger/debugger_contents.h" #include "chrome/browser/debugger/debugger_shell.h" #include "chrome/browser/debugger/debugger_wrapper.h" #include "chrome/browser/debugger/resources/debugger_resources.h" #include "chrome/browser/dom_ui/chrome_url_data_manager.h" +#include "chrome/common/chrome_switches.h" #include "chrome/common/resource_bundle.h" class DebuggerHTMLSource : public ChromeURLDataManager::DataSource { @@ -47,7 +50,6 @@ class DebuggerHTMLSource : public ChromeURLDataManager::DataSource { // Called when the network layer has requested a resource underneath // the path we registered. virtual void StartDataRequest(const std::string& path, int request_id) { - ResourceBundle& rb = ResourceBundle::GetSharedInstance(); int resource_id = 0; if (!path.length()) { @@ -60,7 +62,23 @@ class DebuggerHTMLSource : public ChromeURLDataManager::DataSource { SendResponse(request_id, NULL); return; } - const std::string& data_str = rb.GetDataResource(resource_id); + + std::wstring debugger_path = + CommandLine().GetSwitchValue(switches::kJavaScriptDebuggerPath); + std::string data_str; + if (!debugger_path.empty() && file_util::PathExists(debugger_path)) { + if (path.empty()) + file_util::AppendToPath(&debugger_path, L"debugger.html"); + else + file_util::AppendToPath(&debugger_path, UTF8ToWide(path)); + if (!file_util::ReadFileToString(debugger_path, &data_str)) { + SendResponse(request_id, NULL); + return; + } + } else { + ResourceBundle& rb = ResourceBundle::GetSharedInstance(); + data_str = rb.GetDataResource(resource_id); + } scoped_refptr data_bytes(new RefCountedBytes); data_bytes->data.resize(data_str.size()); std::copy(data_str.begin(), data_str.end(), data_bytes->data.begin()); diff --git a/chrome/common/chrome_switches.cc b/chrome/common/chrome_switches.cc index 2f47beb..5b9985e 100644 --- a/chrome/common/chrome_switches.cc +++ b/chrome/common/chrome_switches.cc @@ -337,4 +337,7 @@ const wchar_t kGearsPluginPathOverride[] = L"gears-plugin-path"; // Enable new HTTP stack. const wchar_t kUseNewHttp[] = L"new-http"; +// Allow loading of the javascript debugger UI from the filesystem. +const wchar_t kJavaScriptDebuggerPath[] = L"javascript-debugger-path"; + } // namespace switches diff --git a/chrome/common/chrome_switches.h b/chrome/common/chrome_switches.h index f6ac2d4..591eded 100644 --- a/chrome/common/chrome_switches.h +++ b/chrome/common/chrome_switches.h @@ -140,6 +140,8 @@ extern const wchar_t kGearsPluginPathOverride[]; extern const wchar_t kUseNewHttp[]; +extern const wchar_t kJavaScriptDebuggerPath[]; + } // namespace switches #endif // CHROME_COMMON_CHROME_SWITCHES_H__ -- cgit v1.1