diff options
| author | erikkay@google.com <erikkay@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-07-31 23:23:45 +0000 | 
|---|---|---|
| committer | erikkay@google.com <erikkay@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2008-07-31 23:23:45 +0000 | 
| commit | eaea8ab540171542f7c1ac6f6ce47130da5d1a0e (patch) | |
| tree | eb1b79f0f651595b8938f41982c2eb74fca3ada5 /chrome/browser | |
| parent | 773eec32700049ae25ec6d91cf2f7d6ee082d3d0 (diff) | |
| download | chromium_src-eaea8ab540171542f7c1ac6f6ce47130da5d1a0e.zip chromium_src-eaea8ab540171542f7c1ac6f6ce47130da5d1a0e.tar.gz chromium_src-eaea8ab540171542f7c1ac6f6ce47130da5d1a0e.tar.bz2 | |
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
Diffstat (limited to 'chrome/browser')
| -rw-r--r-- | chrome/browser/debugger/debugger_contents.cc | 22 | 
1 files changed, 20 insertions, 2 deletions
| 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<RefCountedBytes> data_bytes(new RefCountedBytes);      data_bytes->data.resize(data_str.size());      std::copy(data_str.begin(), data_str.end(), data_bytes->data.begin()); | 
