summaryrefslogtreecommitdiffstats
path: root/content/renderer/render_process.h
diff options
context:
space:
mode:
authorjam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-15 00:30:05 +0000
committerjam@chromium.org <jam@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-15 00:30:05 +0000
commit8704f89ba45ee9419201a3f32d5be9abeedca164 (patch)
tree1db86fe7b36607d3db0ffc1a6c3e42787b4cec1a /content/renderer/render_process.h
parentf9861ac25d3fad3635e8104d9ae661729183d97f (diff)
downloadchromium_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.h64
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_