blob: 6987d4e84e094489e0f45361362e34f135ad9214 [file] [log] [blame]
// Copyright (c) 2012 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_BROWSER_RENDERER_HOST_RENDER_VIEW_HOST_FACTORY_H_
#define CONTENT_BROWSER_RENDERER_HOST_RENDER_VIEW_HOST_FACTORY_H_
#include <stdint.h>
#include "base/macros.h"
#include "content/common/content_export.h"
namespace content {
class RenderViewHost;
class RenderViewHostDelegate;
class RenderWidgetHostDelegate;
class SiteInstance;
// A factory for creating RenderViewHosts. There is a global factory function
// that can be installed for the purposes of testing to provide a specialized
// RenderViewHost class.
class RenderViewHostFactory {
public:
// Creates a RenderViewHost using the currently registered factory, or the
// default one if no factory is registered. Ownership of the returned
// pointer will be passed to the caller.
static RenderViewHost* Create(SiteInstance* instance,
RenderViewHostDelegate* delegate,
RenderWidgetHostDelegate* widget_delegate,
int32_t routing_id,
int32_t main_frame_routing_id,
int32_t widget_routing_id,
bool swapped_out,
bool hidden);
// Returns true if there is currently a globally-registered factory.
static bool has_factory() {
return !!factory_;
}
// Returns true if the RenderViewHost instance is not a test instance.
CONTENT_EXPORT static bool is_real_render_view_host() {
return is_real_render_view_host_;
}
// Sets the is_real_render_view_host flag which indicates that the
// RenderViewHost instance is not a test instance.
CONTENT_EXPORT static void set_is_real_render_view_host(
bool is_real_render_view_host) {
is_real_render_view_host_ = is_real_render_view_host;
}
protected:
RenderViewHostFactory() {}
virtual ~RenderViewHostFactory() {}
// You can derive from this class and specify an implementation for this
// function to create a different kind of RenderViewHost for testing.
virtual RenderViewHost* CreateRenderViewHost(
SiteInstance* instance,
RenderViewHostDelegate* delegate,
RenderWidgetHostDelegate* widget_delegate,
int32_t routing_id,
int32_t main_frame_routing_id,
int32_t widget_routing_id,
bool swapped_out) = 0;
// Registers your factory to be called when new RenderViewHosts are created.
// We have only one global factory, so there must be no factory registered
// before the call. This class does NOT take ownership of the pointer.
CONTENT_EXPORT static void RegisterFactory(RenderViewHostFactory* factory);
// Unregister the previously registered factory. With no factory registered,
// the default RenderViewHosts will be created.
CONTENT_EXPORT static void UnregisterFactory();
private:
// The current globally registered factory. This is NULL when we should
// create the default RenderViewHosts.
CONTENT_EXPORT static RenderViewHostFactory* factory_;
// Set to true if the RenderViewHost is not a test instance. Defaults to
// false.
CONTENT_EXPORT static bool is_real_render_view_host_;
DISALLOW_COPY_AND_ASSIGN(RenderViewHostFactory);
};
} // namespace content
#endif // CONTENT_BROWSER_RENDERER_HOST_RENDER_VIEW_HOST_FACTORY_H_