diff options
author | brettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-02-06 00:19:17 +0000 |
---|---|---|
committer | brettw@google.com <brettw@google.com@0039d316-1c4b-4281-b951-d872f2087c98> | 2009-02-06 00:19:17 +0000 |
commit | 5986ed239f7f2fc3f6b1d5f6385819151ae533db (patch) | |
tree | a07be3bc493c5dd34c5f62c6195a85c49ec22c2a | |
parent | 8ad85c0ef39433a26a0093853f34d7eec9be0706 (diff) | |
download | chromium_src-5986ed239f7f2fc3f6b1d5f6385819151ae533db.zip chromium_src-5986ed239f7f2fc3f6b1d5f6385819151ae533db.tar.gz chromium_src-5986ed239f7f2fc3f6b1d5f6385819151ae533db.tar.bz2 |
Make ResourceMessageFilter compile on Mac. It stubs out a substantial part of
the printing. It creates new base functions for converting PIDs to handles, and
then closing them (since Windows requires this). This also fixes the formatting
of image_util.
Review URL: http://codereview.chromium.org/20109
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@9291 0039d316-1c4b-4281-b951-d872f2087c98
-rw-r--r-- | base/image_util.h | 69 | ||||
-rw-r--r-- | base/process_util.h | 7 | ||||
-rw-r--r-- | base/process_util_posix.cc | 11 | ||||
-rw-r--r-- | base/process_util_win.cc | 8 | ||||
-rw-r--r-- | chrome/browser/renderer_host/resource_message_filter.cc | 45 | ||||
-rw-r--r-- | chrome/browser/renderer_host/resource_message_filter.h | 2 | ||||
-rw-r--r-- | chrome/chrome.xcodeproj/project.pbxproj | 2 | ||||
-rw-r--r-- | chrome/common/temp_scaffolding_stubs.cc | 44 | ||||
-rw-r--r-- | chrome/common/temp_scaffolding_stubs.h | 68 |
9 files changed, 173 insertions, 83 deletions
diff --git a/base/image_util.h b/base/image_util.h index 6f0a19a..33ca08f 100644 --- a/base/image_util.h +++ b/base/image_util.h @@ -6,22 +6,25 @@ // information about PE (Portable Executable) headers within // images (dll's / exe's ) -#ifndef BASE_IMAGE_UTIL_H__ -#define BASE_IMAGE_UTIL_H__ +#ifndef BASE_IMAGE_UTIL_H_ +#define BASE_IMAGE_UTIL_H_ +#include <windows.h> #include <vector> + #include "base/basictypes.h" -#include <windows.h> namespace image_util { // Contains both the PE section name (.text, .reloc etc) and its size. struct ImageSectionData { + ImageSectionData (const std::string& section_name, size_t section_size) + : name (section_name), + size_in_bytes(section_size) { + } + std::string name; size_t size_in_bytes; - ImageSectionData (const std::string& section_name, size_t section_size) : - name (section_name), size_in_bytes(section_size) { - } }; typedef std::vector<ImageSectionData> ImageSectionsData; @@ -31,34 +34,34 @@ typedef std::vector<ImageSectionData> ImageSectionsData; // to get an instance for a specified process, then access the information via // methods. class ImageMetrics { - public: - // Creates an ImageMetrics instance for given process owned by - // the caller. - explicit ImageMetrics(HANDLE process); - ~ImageMetrics(); - - // Fills a vector of ImageSectionsData containing name/size info - // for every section found in the specified dll's PE section table. - // The DLL must be loaded by the process associated with this ImageMetrics - // instance. - bool GetDllImageSectionData(const std::string& loaded_dll_name, - ImageSectionsData* section_sizes); - - // Fills a vector if ImageSectionsData containing name/size info - // for every section found in the executable file of the process - // associated with this ImageMetrics instance. - bool GetProcessImageSectionData(ImageSectionsData* section_sizes); - - private: - // Helper for GetDllImageSectionData and GetProcessImageSectionData - bool GetImageSectionSizes(char* qualified_path, ImageSectionsData* result); - - HANDLE process_; - - DISALLOW_EVIL_CONSTRUCTORS(ImageMetrics); + public: + // Creates an ImageMetrics instance for given process owned by + // the caller. + explicit ImageMetrics(HANDLE process); + ~ImageMetrics(); + + // Fills a vector of ImageSectionsData containing name/size info + // for every section found in the specified dll's PE section table. + // The DLL must be loaded by the process associated with this ImageMetrics + // instance. + bool GetDllImageSectionData(const std::string& loaded_dll_name, + ImageSectionsData* section_sizes); + + // Fills a vector if ImageSectionsData containing name/size info + // for every section found in the executable file of the process + // associated with this ImageMetrics instance. + bool GetProcessImageSectionData(ImageSectionsData* section_sizes); + + private: + // Helper for GetDllImageSectionData and GetProcessImageSectionData + bool GetImageSectionSizes(char* qualified_path, ImageSectionsData* result); + + HANDLE process_; + + DISALLOW_COPY_AND_ASSIGN(ImageMetrics); }; -} // namespace image_util +} // namespace image_util -#endif +#endif // BASE_IMAGE_UTIL_H_ diff --git a/base/process_util.h b/base/process_util.h index 8c4c5d4..c921d7a 100644 --- a/base/process_util.h +++ b/base/process_util.h @@ -66,6 +66,13 @@ int GetCurrentProcId(); // Returns the ProcessHandle of the current process. ProcessHandle GetCurrentProcessHandle(); + +// Converts a PID to a process handle. This handle must be closed by +// CloseProcessHandle when you are done with it. +ProcessHandle OpenProcessHandle(int pid); + +// Closes the process handle opened by OpenProcessHandle. +void CloseProcessHandle(ProcessHandle process); // Returns the unique ID for the specified process. This is functionally the // same as Windows' GetProcessId(), but works on versions of Windows before diff --git a/base/process_util_posix.cc b/base/process_util_posix.cc index 680cacc..7cabb3a 100644 --- a/base/process_util_posix.cc +++ b/base/process_util_posix.cc @@ -34,6 +34,17 @@ ProcessHandle GetCurrentProcessHandle() { return GetCurrentProcId(); } +ProcessHandle OpenProcessHandle(int pid) { + // On Posix platforms, process handles are the same as PIDs, so we + // don't need to do anything. + return pid; +} + +void CloseProcessHandle(ProcessHandle process) { + // See OpenProcessHandle, nothing to do. + return; +} + int GetProcId(ProcessHandle process) { return process; } diff --git a/base/process_util_win.cc b/base/process_util_win.cc index f1fd72c..bb0e626 100644 --- a/base/process_util_win.cc +++ b/base/process_util_win.cc @@ -33,6 +33,14 @@ ProcessHandle GetCurrentProcessHandle() { return ::GetCurrentProcess(); } +ProcessHandle OpenProcessHandle(int pid) { + return OpenProcess(PROCESS_DUP_HANDLE | PROCESS_TERMINATE, FALSE, pid); +} + +void CloseProcessHandle(ProcessHandle process) { + CloseHandle(process); +} + // Helper for GetProcId() bool GetProcIdViaGetProcessId(ProcessHandle process, DWORD* id) { // Dynamically get a pointer to GetProcessId(). diff --git a/chrome/browser/renderer_host/resource_message_filter.cc b/chrome/browser/renderer_host/resource_message_filter.cc index 15b3f28..2db7124 100644 --- a/chrome/browser/renderer_host/resource_message_filter.cc +++ b/chrome/browser/renderer_host/resource_message_filter.cc @@ -7,20 +7,16 @@ #include "base/clipboard.h" #include "base/gfx/native_widget_types.h" #include "base/histogram.h" +#include "base/process_util.h" #include "base/thread.h" #include "chrome/browser/chrome_plugin_browsing_context.h" #include "chrome/browser/chrome_thread.h" #include "chrome/browser/net/dns_global.h" -#include "chrome/browser/printing/print_job_manager.h" -#include "chrome/browser/printing/printer_query.h" #include "chrome/browser/profile.h" -#include "chrome/browser/plugin_service.h" #include "chrome/browser/renderer_host/browser_render_process_host.h" #include "chrome/browser/renderer_host/render_widget_helper.h" -#include "chrome/browser/spellchecker.h" #include "chrome/common/chrome_plugin_lib.h" #include "chrome/common/chrome_plugin_util.h" -#include "chrome/common/clipboard_service.h" #include "chrome/common/notification_service.h" #include "chrome/common/pref_names.h" #include "chrome/common/pref_service.h" @@ -30,6 +26,17 @@ #include "webkit/glue/webkit_glue.h" #include "webkit/glue/webplugin.h" +#if defined(OS_WIN) +#include "chrome/browser/plugin_service.h" +#include "chrome/browser/printing/print_job_manager.h" +#include "chrome/browser/printing/printer_query.h" +#include "chrome/browser/spellchecker.h" +#include "chrome/common/clipboard_service.h" +#elif defined(OS_MACOSX) || defined(OS_LINUX) +// TODO(port) remove this. +#include "chrome/common/temp_scaffolding_stubs.h" +#endif + namespace { // Context menus are somewhat complicated. We need to intercept them here on @@ -96,12 +103,12 @@ ResourceMessageFilter::ResourceMessageFilter( plugin_service_(plugin_service), print_job_manager_(print_job_manager), render_process_host_id_(render_process_host_id), + spellchecker_(spellchecker), + ALLOW_THIS_IN_INITIALIZER_LIST(resolve_proxy_msg_helper_(this, NULL)), render_handle_(NULL), request_context_(profile->GetRequestContext()), profile_(profile), - render_widget_helper_(render_widget_helper), - spellchecker_(spellchecker), - ALLOW_THIS_IN_INITIALIZER_LIST(resolve_proxy_msg_helper_(this, NULL)) { + render_widget_helper_(render_widget_helper) { DCHECK(request_context_.get()); DCHECK(request_context_->cookie_store()); @@ -109,7 +116,7 @@ ResourceMessageFilter::ResourceMessageFilter( ResourceMessageFilter::~ResourceMessageFilter() { if (render_handle_) - CloseHandle(render_handle_); + base::CloseProcessHandle(render_handle_); // This function should be called on the IO thread. DCHECK(MessageLoop::current() == @@ -134,8 +141,7 @@ void ResourceMessageFilter::OnFilterAdded(IPC::Channel* channel) { // Called on the IPC thread: void ResourceMessageFilter::OnChannelConnected(int32 peer_pid) { DCHECK(!render_handle_); - render_handle_ = OpenProcess(PROCESS_DUP_HANDLE | PROCESS_TERMINATE, - FALSE, peer_pid); + render_handle_ = base::OpenProcessHandle(peer_pid); DCHECK(render_handle_); } @@ -170,7 +176,9 @@ bool ResourceMessageFilter::OnMessageReceived(const IPC::Message& message) { IPC_MESSAGE_HANDLER(ViewHostMsg_GetDataDir, OnGetDataDir) IPC_MESSAGE_HANDLER(ViewHostMsg_PluginMessage, OnPluginMessage) IPC_MESSAGE_HANDLER(ViewHostMsg_PluginSyncMessage, OnPluginSyncMessage) +#if defined(OS_WIN) // This hack is Windows-specific. IPC_MESSAGE_HANDLER(ViewHostMsg_LoadFont, OnLoadFont) +#endif IPC_MESSAGE_HANDLER(ViewHostMsg_GetScreenInfo, OnGetScreenInfo) IPC_MESSAGE_HANDLER(ViewHostMsg_GetPlugins, OnGetPlugins) IPC_MESSAGE_HANDLER(ViewHostMsg_GetPluginPath, OnGetPluginPath) @@ -385,6 +393,7 @@ void ResourceMessageFilter::OnPluginSyncMessage(const FilePath& plugin_path, } } +#if defined(OS_WIN) // This hack is Windows-specific. void ResourceMessageFilter::OnLoadFont(LOGFONT font) { // If renderer is running in a sandbox, GetTextMetrics // can sometimes fail. If a font has not been loaded @@ -426,6 +435,7 @@ void ResourceMessageFilter::OnLoadFont(LOGFONT font) { hdcs[font_index] = hdc; font_index = (font_index + 1) % kFontCacheSize; } +#endif void ResourceMessageFilter::OnGetScreenInfo( gfx::NativeViewId window, webkit_glue::ScreenInfo* results) { @@ -476,7 +486,11 @@ void ResourceMessageFilter::OnClipboardWriteObjects( // We pass the render_handle_ to assist the clipboard with using shared // memory objects. render_handle_ is a handle to the process that would // own any shared memory that might be in the object list. +#if defined(OS_WIN) Clipboard::DuplicateRemoteHandles(render_handle_, long_living_objects); +#else + NOTIMPLEMENTED(); // TODO(port) implement this. +#endif render_widget_helper_->ui_loop()->PostTask(FROM_HERE, new WriteClipboardTask(long_living_objects)); @@ -484,8 +498,13 @@ void ResourceMessageFilter::OnClipboardWriteObjects( void ResourceMessageFilter::OnClipboardIsFormatAvailable(unsigned int format, bool* result) { +#if defined(OS_WIN) DCHECK(result); *result = GetClipboardService()->IsFormatAvailable(format); +#else + NOTIMPLEMENTED(); // TODO(port) this function should take a + // Clipboard::FormatType instead of an int. +#endif } void ResourceMessageFilter::OnClipboardReadText(std::wstring* result) { @@ -558,7 +577,7 @@ void ResourceMessageFilter::OnDuplicateSection( // Duplicate the handle in this process right now so the memory is kept alive // (even if it is not mapped) base::SharedMemory shared_buf(renderer_handle, true, render_handle_); - shared_buf.GiveToProcess(GetCurrentProcess(), browser_handle); + shared_buf.GiveToProcess(base::GetCurrentProcessHandle(), browser_handle); } void ResourceMessageFilter::OnResourceTypeStats( @@ -576,7 +595,7 @@ void ResourceMessageFilter::OnResourceTypeStats( } void ResourceMessageFilter::OnResolveProxy(const GURL& url, - IPC::Message* reply_msg) { + IPC::Message* reply_msg) { resolve_proxy_msg_helper_.Start(url, reply_msg); } diff --git a/chrome/browser/renderer_host/resource_message_filter.h b/chrome/browser/renderer_host/resource_message_filter.h index 6ec697f..c4d75e3 100644 --- a/chrome/browser/renderer_host/resource_message_filter.h +++ b/chrome/browser/renderer_host/resource_message_filter.h @@ -115,7 +115,7 @@ class ResourceMessageFilter : public IPC::ChannelProxy::MessageFilter, const std::wstring& filter, uint32 user_data); -#if defined(OS_WIN) +#if defined(OS_WIN) // This hack is Windows-specific. // Cache fonts for the renderer. See ResourceMessageFilter::OnLoadFont // implementation for more details void OnLoadFont(LOGFONT font); diff --git a/chrome/chrome.xcodeproj/project.pbxproj b/chrome/chrome.xcodeproj/project.pbxproj index 2abc67f..e3041c8 100644 --- a/chrome/chrome.xcodeproj/project.pbxproj +++ b/chrome/chrome.xcodeproj/project.pbxproj @@ -244,6 +244,7 @@ A76E43A40F29039C009A7E88 /* browser_render_process_host.cc in Sources */ = {isa = PBXBuildFile; fileRef = A76E43A30F29039C009A7E88 /* browser_render_process_host.cc */; }; A7A20BF20F3A16DC00F62B4D /* render_widget.cc in Sources */ = {isa = PBXBuildFile; fileRef = 4D640CD50EAE868600EBCFC0 /* render_widget.cc */; }; A7A20E650F3A1E1C00F62B4D /* render_view.cc in Sources */ = {isa = PBXBuildFile; fileRef = 4D640CD30EAE868600EBCFC0 /* render_view.cc */; }; + A7A214A00F3B91B100F62B4D /* resource_message_filter.cc in Sources */ = {isa = PBXBuildFile; fileRef = A7A211730F3A248300F62B4D /* resource_message_filter.cc */; }; A7C612990F30D63D008CEE5D /* render_process_host.cc in Sources */ = {isa = PBXBuildFile; fileRef = B5D16EC10F2144D500861FAC /* render_process_host.cc */; }; A7C613C10F30D7E4008CEE5D /* mock_render_process_host.cc in Sources */ = {isa = PBXBuildFile; fileRef = A7C613BF0F30D7E4008CEE5D /* mock_render_process_host.cc */; }; A7C6146F0F30DA1D008CEE5D /* ipc_test_sink.cc in Sources */ = {isa = PBXBuildFile; fileRef = A7C6146D0F30DA1D008CEE5D /* ipc_test_sink.cc */; }; @@ -4643,6 +4644,7 @@ E434BFA40F3A03E200B665C7 /* render_widget_host.cc in Sources */, E434BBEB0F37DFA500B665C7 /* renderer_security_policy.cc in Sources */, BADB8B710F3A35AC00989B26 /* resource_dispatcher_host.cc in Sources */, + A7A214A00F3B91B100F62B4D /* resource_message_filter.cc in Sources */, B0AC9501DED2809AC208AEEA /* resolve_proxy_msg_helper.cc in Sources */, 4D7BFAF30E9D49EF009A6919 /* safe_browsing_database.cc in Sources */, E48FB9590EC4E9C10052B72B /* safe_browsing_database_bloom.cc in Sources */, diff --git a/chrome/common/temp_scaffolding_stubs.cc b/chrome/common/temp_scaffolding_stubs.cc index df04efe..f902539 100644 --- a/chrome/common/temp_scaffolding_stubs.cc +++ b/chrome/common/temp_scaffolding_stubs.cc @@ -259,7 +259,8 @@ void SetRecordPlaybackMode(bool) { } void SetJavaScriptFlags(const std::wstring&) { } void CheckForLeaks() { } std::string CreateHistoryStateForURL(const GURL& url) { return ""; } -} +void GetScreenInfoHelper(NSView*) { NOTIMPLEMENTED(); } +} // namespace webkit_glue #endif //-------------------------------------------------------------------------- @@ -267,11 +268,18 @@ std::string CreateHistoryStateForURL(const GURL& url) { return ""; } namespace chrome_browser_net { void EnableDnsPrefetch(bool) { NOTIMPLEMENTED(); } + +void DnsPrefetchList(const std::vector<std::string>& hostnames) { NOTIMPLEMENTED(); } } // namespace chrome_browser_net //-------------------------------------------------------------------------- +// This is from chrome_plugin_util.cc. +void CPB_Free(void* memory) { NOTIMPLEMENTED(); } + +//-------------------------------------------------------------------------- + void RunJavascriptMessageBox(WebContents* web_contents, int dialog_flags, const std::wstring& message_text, @@ -303,40 +311,6 @@ void SSLManager::OnSSLCertificateError( //-------------------------------------------------------------------------- -ResourceMessageFilter::ResourceMessageFilter( - ResourceDispatcherHost* resource_dispatcher_host, - PluginService* plugin_service, - printing::PrintJobManager* print_job_manager, - int render_process_host_id, - Profile* profile, - RenderWidgetHelper* render_widget_helper, - SpellChecker* spellchecker) - : ALLOW_THIS_IN_INITIALIZER_LIST(resolve_proxy_msg_helper_(this, NULL)) { -} -ResourceMessageFilter::~ResourceMessageFilter() { NOTIMPLEMENTED(); } -void ResourceMessageFilter::OnFilterAdded(IPC::Channel* channel) { - NOTIMPLEMENTED(); -} -void ResourceMessageFilter::OnChannelConnected(int32 peer_pid) { - NOTIMPLEMENTED(); -} -void ResourceMessageFilter::OnChannelClosing() { NOTIMPLEMENTED(); } -bool ResourceMessageFilter::OnMessageReceived(const IPC::Message& message) { - NOTIMPLEMENTED(); - return false; -} -bool ResourceMessageFilter::Send(IPC::Message* message) { - NOTIMPLEMENTED(); - return false; -} -void ResourceMessageFilter::Observe(NotificationType type, - const NotificationSource& source, - const NotificationDetails& details) { } -void ResourceMessageFilter::OnResolveProxyCompleted( - IPC::Message* reply_msg,int result, const std::string& proxy_list) { - NOTIMPLEMENTED(); -} - void RunRepostFormWarningDialog(NavigationController*) { } diff --git a/chrome/common/temp_scaffolding_stubs.h b/chrome/common/temp_scaffolding_stubs.h index 8b72a7e..681fdae 100644 --- a/chrome/common/temp_scaffolding_stubs.h +++ b/chrome/common/temp_scaffolding_stubs.h @@ -12,6 +12,7 @@ #include <string> #include "base/basictypes.h" +#include "base/clipboard.h" #include "base/file_path.h" #include "base/logging.h" #include "base/message_loop.h" @@ -62,6 +63,7 @@ class ProfileManager; class Profile; class RenderProcessHost; class RenderWidgetHelper; +class ResourceMessageFilter; class SessionID; class SiteInstance; class SpellChecker; @@ -75,6 +77,7 @@ class URLRequestContext; class UserScriptMaster; class VisitedLinkMaster; class WebContents; +struct WebPluginInfo; struct WebPluginGeometry; class WebPreferences; @@ -290,14 +293,53 @@ GURL NewTabUIURL(); //--------------------------------------------------------------------------- // These stubs are for BrowserProcessImpl -class ClipboardService { +class ClipboardService : public Clipboard { + public: }; +class CancelableTask; +class ViewMsg_Print_Params; + namespace printing { + +class PrintingContext { + public: + enum Result { OK, CANCEL, FAILED }; +}; + +class PrintSettings { + public: + void RenderParams(ViewMsg_Print_Params* params) const { NOTIMPLEMENTED(); } + int dpi() const { NOTIMPLEMENTED(); return 92; } +}; + +class PrinterQuery : public base::RefCountedThreadSafe<PrinterQuery> { + public: + enum GetSettingsAskParam { + DEFAULTS, + ASK_USER, + }; + + void GetSettings(GetSettingsAskParam ask_user_for_settings, + int parent_window, + int expected_page_count, + CancelableTask* callback) { NOTIMPLEMENTED(); } + PrintingContext::Result last_status() { return PrintingContext::FAILED; } + const PrintSettings& settings() { NOTIMPLEMENTED(); return settings_; } + int cookie() { NOTIMPLEMENTED(); return 0; } + void StopWorker() { NOTIMPLEMENTED(); } + + private: + PrintSettings settings_; +}; class PrintJobManager { public: void OnQuit() { NOTIMPLEMENTED(); } + void PopPrinterQuery(int document_cookie, scoped_refptr<PrinterQuery>* job) { + NOTIMPLEMENTED(); + } + void QueuePrinterQuery(PrinterQuery* job) { NOTIMPLEMENTED(); } }; } // namespace printing @@ -831,6 +873,15 @@ class SpellChecker : public base::RefCountedThreadSafe<SpellChecker> { const Language& language, URLRequestContext* request_context, const std::wstring& custom_dictionary_file_name) {} + + bool SpellCheckWord(const wchar_t* in_word, + int in_word_len, + int* misspelling_start, + int* misspelling_len, + std::vector<std::wstring>* optional_suggestions) { + NOTIMPLEMENTED(); + return true; + } }; class WebAppLauncher { @@ -984,6 +1035,21 @@ class PluginService { return true; } void SetChromePluginDataDir(const FilePath& data_dir); + FilePath GetChromePluginDataDir() { return chrome_plugin_data_dir_; } + void GetPlugins(bool reload, std::vector<WebPluginInfo>* plugins) {} + FilePath GetPluginPath(const GURL& url, + const std::string& mime_type, + const std::string& clsid, + std::string* actual_mime_type) { + NOTIMPLEMENTED(); + return FilePath(); + } + void OpenChannelToPlugin(ResourceMessageFilter* renderer_msg_filter, + const GURL& url, + const std::string& mime_type, + const std::string& clsid, + const std::wstring& locale, + IPC::Message* reply_msg) { NOTIMPLEMENTED(); } private: MessageLoop* main_message_loop_; ResourceDispatcherHost* resource_dispatcher_host_; |