Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(214)

Side by Side Diff: chrome/browser/ui/gtk/infobars/link_infobar_gtk.cc

Issue 11721003: Eliminate the LinkInfoBar[Delegate] classes entirely. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: address some nits - testing-automation matters? Created 7 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
(Empty)
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4
5 #include "chrome/browser/ui/gtk/infobars/link_infobar_gtk.h"
6
7 #include "chrome/browser/api/infobars/link_infobar_delegate.h"
8 #include "chrome/browser/ui/gtk/event_utils.h"
9
10 // LinkInfoBarDelegate ---------------------------------------------------------
11
12 InfoBar* LinkInfoBarDelegate::CreateInfoBar(InfoBarService* owner) {
13 return new LinkInfoBarGtk(owner, this);
14 }
15
16 // LinkInfoBarGtk --------------------------------------------------------------
17
18 LinkInfoBarGtk::LinkInfoBarGtk(InfoBarService* owner,
19 LinkInfoBarDelegate* delegate)
20 : InfoBarGtk(owner, delegate) {
21 size_t link_offset;
22 string16 display_text = delegate->GetMessageTextWithOffset(&link_offset);
23 string16 link_text = delegate->GetLinkText();
24 AddLabelWithInlineLink(display_text, link_text, link_offset,
25 G_CALLBACK(OnLinkClickedThunk));
26 }
27
28 LinkInfoBarGtk::~LinkInfoBarGtk() {
29 }
30
31 void LinkInfoBarGtk::OnLinkClicked(GtkWidget* button) {
32 if (GetDelegate()->LinkClicked(
33 event_utils::DispositionForCurrentButtonPressEvent()))
34 RemoveSelf();
35 }
36
37 LinkInfoBarDelegate* LinkInfoBarGtk::GetDelegate() {
38 return delegate()->AsLinkInfoBarDelegate();
39 }
OLDNEW
« no previous file with comments | « chrome/browser/ui/gtk/infobars/link_infobar_gtk.h ('k') | chrome/browser/ui/views/infobars/alternate_nav_infobar_view.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698