1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
// 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.
// Defines the public interface for the blocked popup notifications. This
// interface should only be used by TabContents. Users and subclasses of
// TabContents should use the appropriate methods on TabContents to access
// information about blocked popups.
#ifndef CHROME_BROWSER_BLOCKED_POPUP_CONTAINER_H_
#define CHROME_BROWSER_BLOCKED_POPUP_CONTAINER_H_
#pragma once
#include <vector>
#include "chrome/browser/tab_contents/tab_contents_delegate.h"
// Takes ownership of TabContents that are unrequested popup windows.
class BlockedPopupContainer : public TabContentsDelegate {
public:
typedef std::vector<TabContents*> BlockedContents;
// Creates a container for a certain TabContents:
explicit BlockedPopupContainer(TabContents* owner);
// Adds a popup to this container. |bounds| are the window bounds requested by
// the popup window.
void AddTabContents(TabContents* tab_contents,
const gfx::Rect& bounds);
// Shows the blocked popup with TabContents |tab_contents|.
void LaunchPopupForContents(TabContents* tab_contents);
// Returns the number of blocked popups.
size_t GetBlockedPopupCount() const;
// Returns the contained TabContents pointers. |blocked_contents| must be
// non-NULL.
void GetBlockedContents(BlockedContents* blocked_contents) const;
// Sets this object up to delete itself.
void Destroy();
// Overridden from TabContentsDelegate:
// Forwards OpenURLFromTab to our |owner_|.
virtual void OpenURLFromTab(TabContents* source,
const GURL& url, const GURL& referrer,
WindowOpenDisposition disposition,
PageTransition::Type transition);
// Ignored; BlockedPopupContainer doesn't display a throbber.
virtual void NavigationStateChanged(const TabContents* source,
unsigned changed_flags) {}
// Forwards AddNewContents to our |owner_|.
virtual void AddNewContents(TabContents* source,
TabContents* new_contents,
WindowOpenDisposition disposition,
const gfx::Rect& initial_position,
bool user_gesture);
// Ignore activation requests from the TabContents we're blocking.
virtual void ActivateContents(TabContents* contents) {}
// Ignored; BlockedPopupContainer doesn't display a throbber.
virtual void LoadingStateChanged(TabContents* source) {}
// Removes |source| from our internal list of blocked popups.
virtual void CloseContents(TabContents* source);
// Changes the opening rectangle associated with |source|.
virtual void MoveContents(TabContents* source, const gfx::Rect& new_bounds);
// Always returns true.
virtual bool IsPopup(const TabContents* source) const;
// Returns our |owner_|.
virtual TabContents* GetConstrainingContents(TabContents* source);
// Ignored; BlockedPopupContainer doesn't display a toolbar.
virtual void ToolbarSizeChanged(TabContents* source, bool is_animating) {}
// Ignored; BlockedPopupContainer doesn't display a bookmarking star.
virtual void URLStarredChanged(TabContents* source, bool starred) {}
// Ignored; BlockedPopupContainer doesn't display a URL bar.
virtual void UpdateTargetURL(TabContents* source, const GURL& url) {}
// A number larger than the internal popup count on the Renderer; meant for
// preventing a compromised renderer from exhausting GDI memory by spawning
// infinite windows.
static const size_t kImpossibleNumberOfPopups;
protected:
struct BlockedPopup;
typedef std::vector<BlockedPopup> BlockedPopups;
private:
// The TabContents that owns and constrains this BlockedPopupContainer.
TabContents* owner_;
// Information about all blocked popups.
BlockedPopups blocked_popups_;
DISALLOW_IMPLICIT_CONSTRUCTORS(BlockedPopupContainer);
};
#endif // CHROME_BROWSER_BLOCKED_POPUP_CONTAINER_H_
|