diff options
author | jam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-15 00:30:05 +0000 |
---|---|---|
committer | jam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-15 00:30:05 +0000 |
commit | 8704f89ba45ee9419201a3f32d5be9abeedca164 (patch) | |
tree | 1db86fe7b36607d3db0ffc1a6c3e42787b4cec1a /content/renderer/render_process.h | |
parent | f9861ac25d3fad3635e8104d9ae661729183d97f (diff) | |
download | chromium_src-8704f89ba45ee9419201a3f32d5be9abeedca164.zip chromium_src-8704f89ba45ee9419201a3f32d5be9abeedca164.tar.gz chromium_src-8704f89ba45ee9419201a3f32d5be9abeedca164.tar.bz2 |
Move RenderProcess to content.
TBR=avi
Review URL: http://codereview.chromium.org/6864001
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@81681 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'content/renderer/render_process.h')
-rw-r--r-- | content/renderer/render_process.h | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/content/renderer/render_process.h b/content/renderer/render_process.h new file mode 100644 index 0000000..2fb2a61 --- /dev/null +++ b/content/renderer/render_process.h @@ -0,0 +1,64 @@ +// Copyright (c) 2010 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. + +#ifndef CONTENT_RENDERER_RENDER_PROCESS_H_ +#define CONTENT_RENDERER_RENDER_PROCESS_H_ +#pragma once + +#include "content/common/child_process.h" +#include "skia/ext/platform_canvas.h" + +class TransportDIB; + +namespace gfx { +class Rect; +} + +namespace skia { +class PlatformCanvas; +} + +// A abstract interface representing the renderer end of the browser<->renderer +// connection. The opposite end is the RenderProcessHost. This is a singleton +// object for each renderer. +// +// RenderProcessImpl implements this interface for the regular browser. +// MockRenderProcess implements this interface for certain tests, especially +// ones derived from RenderViewTest. +class RenderProcess : public ChildProcess { + public: + RenderProcess() {} + virtual ~RenderProcess() {} + + // Get a canvas suitable for drawing and transporting to the browser + // memory: (output) the transport DIB memory + // rect: the rectangle which will be painted, use for sizing the canvas + // returns: NULL on error + // + // When no longer needed, you should pass the TransportDIB to + // ReleaseTransportDIB so that it can be recycled. + virtual skia::PlatformCanvas* GetDrawingCanvas(TransportDIB** memory, + const gfx::Rect& rect) = 0; + + // Frees shared memory allocated by AllocSharedMemory. You should only use + // this function to free the SharedMemory object. + virtual void ReleaseTransportDIB(TransportDIB* memory) = 0; + + // Returns true if plugisn should be loaded in-process. + virtual bool UseInProcessPlugins() const = 0; + + virtual bool HasInitializedMediaLibrary() const = 0; + + // Returns a pointer to the RenderProcess singleton instance. Assuming that + // we're actually a renderer or a renderer test, this static cast will + // be correct. + static RenderProcess* current() { + return static_cast<RenderProcess*>(ChildProcess::current()); + } + + private: + DISALLOW_COPY_AND_ASSIGN(RenderProcess); +}; + +#endif // CONTENT_RENDERER_RENDER_PROCESS_H_ |