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

Side by Side Diff: chrome/browser/extensions/api/permissions/permissions_api.h

Issue 10071035: RefCounted types should not have public destructors, chrome/browser/extensions (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Compile fix Created 8 years, 8 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
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 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 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_EXTENSIONS_API_PERMISSIONS_PERMISSIONS_API_H_ 5 #ifndef CHROME_BROWSER_EXTENSIONS_API_PERMISSIONS_PERMISSIONS_API_H_
6 #define CHROME_BROWSER_EXTENSIONS_API_PERMISSIONS_PERMISSIONS_API_H_ 6 #define CHROME_BROWSER_EXTENSIONS_API_PERMISSIONS_PERMISSIONS_API_H_
7 #pragma once 7 #pragma once
8 8
9 #include <string> 9 #include <string>
10 10
11 #include "base/compiler_specific.h" 11 #include "base/compiler_specific.h"
12 #include "chrome/browser/extensions/extension_function.h" 12 #include "chrome/browser/extensions/extension_function.h"
13 #include "chrome/browser/extensions/extension_install_ui.h" 13 #include "chrome/browser/extensions/extension_install_ui.h"
14 #include "chrome/common/extensions/extension_permission_set.h" 14 #include "chrome/common/extensions/extension_permission_set.h"
15 15
16 class Extension; 16 class Extension;
17 class ExtensionPermissionSet; 17 class ExtensionPermissionSet;
18 class ExtensionService; 18 class ExtensionService;
19 19
20 // chrome.permissions.contains 20 // chrome.permissions.contains
21 class ContainsPermissionsFunction : public SyncExtensionFunction { 21 class ContainsPermissionsFunction : public SyncExtensionFunction {
22 public:
23 DECLARE_EXTENSION_FUNCTION_NAME("permissions.contains")
24
25 protected:
22 virtual ~ContainsPermissionsFunction() {} 26 virtual ~ContainsPermissionsFunction() {}
27
28 // ExtensionFunction:
23 virtual bool RunImpl() OVERRIDE; 29 virtual bool RunImpl() OVERRIDE;
24 DECLARE_EXTENSION_FUNCTION_NAME("permissions.contains")
25 }; 30 };
26 31
27 // chrome.permissions.getAll 32 // chrome.permissions.getAll
28 class GetAllPermissionsFunction : public SyncExtensionFunction { 33 class GetAllPermissionsFunction : public SyncExtensionFunction {
34 public:
35 DECLARE_EXTENSION_FUNCTION_NAME("permissions.getAll")
36
37 protected:
29 virtual ~GetAllPermissionsFunction() {} 38 virtual ~GetAllPermissionsFunction() {}
39
40 // ExtensionFunction:
30 virtual bool RunImpl() OVERRIDE; 41 virtual bool RunImpl() OVERRIDE;
31 DECLARE_EXTENSION_FUNCTION_NAME("permissions.getAll")
32 }; 42 };
33 43
34 // chrome.permissions.remove 44 // chrome.permissions.remove
35 class RemovePermissionsFunction : public SyncExtensionFunction { 45 class RemovePermissionsFunction : public SyncExtensionFunction {
46 public:
47 DECLARE_EXTENSION_FUNCTION_NAME("permissions.remove")
48
49 protected:
36 virtual ~RemovePermissionsFunction() {} 50 virtual ~RemovePermissionsFunction() {}
51
52 // ExtensionFunction:
37 virtual bool RunImpl() OVERRIDE; 53 virtual bool RunImpl() OVERRIDE;
38 DECLARE_EXTENSION_FUNCTION_NAME("permissions.remove")
39 }; 54 };
40 55
41 // chrome.permissions.request 56 // chrome.permissions.request
42 class RequestPermissionsFunction : public AsyncExtensionFunction, 57 class RequestPermissionsFunction : public AsyncExtensionFunction,
43 public ExtensionInstallUI::Delegate { 58 public ExtensionInstallUI::Delegate {
44 public: 59 public:
60 DECLARE_EXTENSION_FUNCTION_NAME("permissions.request")
61
62 RequestPermissionsFunction();
63
45 // FOR TESTS ONLY to bypass the confirmation UI. 64 // FOR TESTS ONLY to bypass the confirmation UI.
46 static void SetAutoConfirmForTests(bool should_proceed); 65 static void SetAutoConfirmForTests(bool should_proceed);
47 static void SetIgnoreUserGestureForTests(bool ignore); 66 static void SetIgnoreUserGestureForTests(bool ignore);
48 67
49 RequestPermissionsFunction(); 68 // ExtensionInstallUI::Delegate:
50
51 // Implementing ExtensionInstallUI::Delegate interface.
52 virtual void InstallUIProceed() OVERRIDE; 69 virtual void InstallUIProceed() OVERRIDE;
53 virtual void InstallUIAbort(bool user_initiated) OVERRIDE; 70 virtual void InstallUIAbort(bool user_initiated) OVERRIDE;
54 71
55 protected: 72 protected:
56 virtual ~RequestPermissionsFunction(); 73 virtual ~RequestPermissionsFunction();
74
75 // ExtensionFunction:
57 virtual bool RunImpl() OVERRIDE; 76 virtual bool RunImpl() OVERRIDE;
58 77
59 private: 78 private:
60 scoped_ptr<ExtensionInstallUI> install_ui_; 79 scoped_ptr<ExtensionInstallUI> install_ui_;
61 scoped_refptr<ExtensionPermissionSet> requested_permissions_; 80 scoped_refptr<ExtensionPermissionSet> requested_permissions_;
62 DECLARE_EXTENSION_FUNCTION_NAME("permissions.request")
63 }; 81 };
64 82
65 #endif // CHROME_BROWSER_EXTENSIONS_API_PERMISSIONS_PERMISSIONS_API_H_ 83 #endif // CHROME_BROWSER_EXTENSIONS_API_PERMISSIONS_PERMISSIONS_API_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698