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
|
// 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 CHROME_BROWSER_ALTERNATE_NAV_URL_FETCHER_H_
#define CHROME_BROWSER_ALTERNATE_NAV_URL_FETCHER_H_
#pragma once
#include <string>
#include "chrome/browser/tab_contents/infobar_delegate.h"
#include "chrome/common/net/url_fetcher.h"
#include "chrome/common/notification_observer.h"
#include "chrome/common/notification_registrar.h"
class NavigationController;
// Attempts to get the HEAD of a host name and displays an info bar if the
// request was successful. This is used for single-word queries where we can't
// tell if the entry was a search or an intranet hostname. The autocomplete bar
// assumes it's a query and issues an AlternateNavURLFetcher to display a "did
// you mean" infobar suggesting a navigation.
//
// The memory management of this object is a bit tricky. The location bar view
// will create us and be responsible for us until we attach as an observer
// after a pending load starts (it will delete us if this doesn't happen).
// Once this pending load starts, we're responsible for deleting ourselves.
// We'll do this when the load commits, or when the navigation controller
// itself is deleted.
class AlternateNavURLFetcher : public NotificationObserver,
public URLFetcher::Delegate,
public LinkInfoBarDelegate {
public:
enum State {
NOT_STARTED,
IN_PROGRESS,
SUCCEEDED,
FAILED,
};
explicit AlternateNavURLFetcher(const GURL& alternate_nav_url);
State state() const { return state_; }
// NotificationObserver
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
// URLFetcher::Delegate
virtual void OnURLFetchComplete(const URLFetcher* source,
const GURL& url,
const URLRequestStatus& status,
int response_code,
const ResponseCookies& cookies,
const std::string& data);
// LinkInfoBarDelegate
virtual string16 GetMessageTextWithOffset(size_t* link_offset) const;
virtual string16 GetLinkText() const;
virtual SkBitmap* GetIcon() const;
virtual bool LinkClicked(WindowOpenDisposition disposition);
virtual void InfoBarClosed();
private:
// Sets |state_| to either SUCCEEDED or FAILED depending on the result of the
// fetch.
void SetStatusFromURLFetch(const GURL& url,
const URLRequestStatus& status,
int response_code);
// Displays the infobar if all conditions are met (the page has loaded and
// the fetch of the alternate URL succeeded).
void ShowInfobarIfPossible();
GURL alternate_nav_url_;
scoped_ptr<URLFetcher> fetcher_;
NavigationController* controller_;
State state_;
bool navigated_to_entry_;
// The TabContents the InfoBarDelegate was added to.
TabContents* infobar_contents_;
NotificationRegistrar registrar_;
DISALLOW_COPY_AND_ASSIGN(AlternateNavURLFetcher);
};
#endif // CHROME_BROWSER_ALTERNATE_NAV_URL_FETCHER_H_
|