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

Side by Side Diff: chrome/browser/upgrade_detector_impl.h

Issue 11440020: Add an outdated upgrade bubble view. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Addressed OWNERS comments... Created 7 years, 10 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
« no previous file with comments | « chrome/browser/upgrade_detector.cc ('k') | chrome/browser/upgrade_detector_impl.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_UPGRADE_DETECTOR_IMPL_H_ 5 #ifndef CHROME_BROWSER_UPGRADE_DETECTOR_IMPL_H_
6 #define CHROME_BROWSER_UPGRADE_DETECTOR_IMPL_H_ 6 #define CHROME_BROWSER_UPGRADE_DETECTOR_IMPL_H_
7 7
8 #include "base/memory/weak_ptr.h" 8 #include "base/memory/weak_ptr.h"
9 #include "base/timer.h" 9 #include "base/timer.h"
10 #include "chrome/browser/upgrade_detector.h" 10 #include "chrome/browser/upgrade_detector.h"
11 11
12 template <typename T> struct DefaultSingletonTraits; 12 template <typename T> struct DefaultSingletonTraits;
13 13
14 class UpgradeDetectorImpl : public UpgradeDetector { 14 class UpgradeDetectorImpl : public UpgradeDetector {
15 public: 15 public:
16 virtual ~UpgradeDetectorImpl(); 16 virtual ~UpgradeDetectorImpl();
17 17
18 // Returns the singleton instance. 18 // Returns the singleton instance.
19 static UpgradeDetectorImpl* GetInstance(); 19 static UpgradeDetectorImpl* GetInstance();
20 20
21 private: 21 private:
22 friend struct DefaultSingletonTraits<UpgradeDetectorImpl>; 22 friend struct DefaultSingletonTraits<UpgradeDetectorImpl>;
23 23
24 UpgradeDetectorImpl(); 24 UpgradeDetectorImpl();
25 25
26 // Start the timer that will call |CheckForUpgrade()|.
27 void StartTimerForUpgradeCheck();
28
26 // Launches a task on the file thread to check if we have the latest version. 29 // Launches a task on the file thread to check if we have the latest version.
27 void CheckForUpgrade(); 30 void CheckForUpgrade();
28 31
29 // Sends out a notification and starts a one shot timer to wait until 32 // Sends out a notification and starts a one shot timer to wait until
30 // notifying the user. 33 // notifying the user.
31 void UpgradeDetected(); 34 void UpgradeDetected(UpgradeAvailable upgrade_available);
35
36 // Returns true after calling UpgradeDetected if current install is outdated.
37 bool DetectOutdatedInstall();
32 38
33 // The function that sends out a notification (after a certain time has 39 // The function that sends out a notification (after a certain time has
34 // elapsed) that lets the rest of the UI know we should start notifying the 40 // elapsed) that lets the rest of the UI know we should start notifying the
35 // user that a new version is available. 41 // user that a new version is available.
36 void NotifyOnUpgrade(); 42 void NotifyOnUpgrade();
37 43
44 // Called on the FILE thread to detect an upgrade. Calls back UpgradeDetected
45 // on the UI thread if so. Although it looks weird, this needs to be a static
46 // method receiving a WeakPtr<> to this object so that we can interrupt
47 // the UpgradeDetected callback before it runs. Having this method non-static
48 // and using |this| directly wouldn't be thread safe. And keeping it as a
49 // non-class function would prevent it from calling UpgradeDetected.
50 static void DetectUpgradeTask(
51 base::WeakPtr<UpgradeDetectorImpl> upgrade_detector);
52
38 // We periodically check to see if Chrome has been upgraded. 53 // We periodically check to see if Chrome has been upgraded.
39 base::RepeatingTimer<UpgradeDetectorImpl> detect_upgrade_timer_; 54 base::RepeatingTimer<UpgradeDetectorImpl> detect_upgrade_timer_;
40 55
41 // After we detect an upgrade we start a recurring timer to see if enough time 56 // After we detect an upgrade we start a recurring timer to see if enough time
42 // has passed and we should start notifying the user. 57 // has passed and we should start notifying the user.
43 base::RepeatingTimer<UpgradeDetectorImpl> upgrade_notification_timer_; 58 base::RepeatingTimer<UpgradeDetectorImpl> upgrade_notification_timer_;
44 59
45 // We use this factory to create callback tasks for UpgradeDetected. We pass 60 // We use this factory to create callback tasks for UpgradeDetected. We pass
46 // the task to the actual upgrade detection code, which is in 61 // the task to the actual upgrade detection code, which is in
47 // DetectUpgradeTask. 62 // DetectUpgradeTask.
48 base::WeakPtrFactory<UpgradeDetectorImpl> weak_factory_; 63 base::WeakPtrFactory<UpgradeDetectorImpl> weak_factory_;
49 64
50 // True if this build is a dev or canary channel build. 65 // True if this build is a dev or canary channel build.
51 bool is_unstable_channel_; 66 bool is_unstable_channel_;
52 67
68 // The date the binaries were built.
69 base::Time build_date_;
70
53 DISALLOW_COPY_AND_ASSIGN(UpgradeDetectorImpl); 71 DISALLOW_COPY_AND_ASSIGN(UpgradeDetectorImpl);
54 }; 72 };
55 73
56 74
57 #endif // CHROME_BROWSER_UPGRADE_DETECTOR_IMPL_H_ 75 #endif // CHROME_BROWSER_UPGRADE_DETECTOR_IMPL_H_
OLDNEW
« no previous file with comments | « chrome/browser/upgrade_detector.cc ('k') | chrome/browser/upgrade_detector_impl.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698