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

Side by Side Diff: extensions/common/permissions/permission_set.cc

Issue 1349613003: [Extensions] Un-refcount PermissionSet (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 3 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 #include "extensions/common/permissions/permission_set.h" 5 #include "extensions/common/permissions/permission_set.h"
6 6
7 #include "extensions/common/permissions/permissions_info.h" 7 #include "extensions/common/permissions/permissions_info.h"
8 #include "extensions/common/url_pattern.h" 8 #include "extensions/common/url_pattern.h"
9 #include "url/gurl.h" 9 #include "url/gurl.h"
10 10
(...skipping 26 matching lines...) Expand all
37 : apis_(apis), 37 : apis_(apis),
38 manifest_permissions_(manifest_permissions), 38 manifest_permissions_(manifest_permissions),
39 scriptable_hosts_(scriptable_hosts), 39 scriptable_hosts_(scriptable_hosts),
40 should_warn_all_hosts_(UNINITIALIZED) { 40 should_warn_all_hosts_(UNINITIALIZED) {
41 AddPatternsAndRemovePaths(explicit_hosts, &explicit_hosts_); 41 AddPatternsAndRemovePaths(explicit_hosts, &explicit_hosts_);
42 InitImplicitPermissions(); 42 InitImplicitPermissions();
43 InitEffectiveHosts(); 43 InitEffectiveHosts();
44 } 44 }
45 45
46 // static 46 // static
47 scoped_refptr<const PermissionSet> PermissionSet::CreateDifference( 47 scoped_ptr<const PermissionSet> PermissionSet::CreateDifference(
48 const PermissionSet& set1, 48 const PermissionSet& set1,
49 const PermissionSet& set2) { 49 const PermissionSet& set2) {
50 APIPermissionSet apis; 50 APIPermissionSet apis;
51 APIPermissionSet::Difference(set1.apis(), set2.apis(), &apis); 51 APIPermissionSet::Difference(set1.apis(), set2.apis(), &apis);
52 52
53 ManifestPermissionSet manifest_permissions; 53 ManifestPermissionSet manifest_permissions;
54 ManifestPermissionSet::Difference(set1.manifest_permissions(), 54 ManifestPermissionSet::Difference(set1.manifest_permissions(),
55 set2.manifest_permissions(), 55 set2.manifest_permissions(),
56 &manifest_permissions); 56 &manifest_permissions);
57 57
58 URLPatternSet explicit_hosts = URLPatternSet::CreateDifference( 58 URLPatternSet explicit_hosts = URLPatternSet::CreateDifference(
59 set1.explicit_hosts(), set2.explicit_hosts()); 59 set1.explicit_hosts(), set2.explicit_hosts());
60 60
61 URLPatternSet scriptable_hosts = URLPatternSet::CreateDifference( 61 URLPatternSet scriptable_hosts = URLPatternSet::CreateDifference(
62 set1.scriptable_hosts(), set2.scriptable_hosts()); 62 set1.scriptable_hosts(), set2.scriptable_hosts());
63 63
64 return make_scoped_refptr(new PermissionSet( 64 return make_scoped_ptr(new PermissionSet(apis, manifest_permissions,
65 apis, manifest_permissions, explicit_hosts, scriptable_hosts)); 65 explicit_hosts, scriptable_hosts));
66 } 66 }
67 67
68 // static 68 // static
69 scoped_refptr<const PermissionSet> PermissionSet::CreateIntersection( 69 scoped_ptr<const PermissionSet> PermissionSet::CreateIntersection(
70 const PermissionSet& set1, 70 const PermissionSet& set1,
71 const PermissionSet& set2) { 71 const PermissionSet& set2) {
72 APIPermissionSet apis; 72 APIPermissionSet apis;
73 APIPermissionSet::Intersection(set1.apis(), set2.apis(), &apis); 73 APIPermissionSet::Intersection(set1.apis(), set2.apis(), &apis);
74 74
75 ManifestPermissionSet manifest_permissions; 75 ManifestPermissionSet manifest_permissions;
76 ManifestPermissionSet::Intersection(set1.manifest_permissions(), 76 ManifestPermissionSet::Intersection(set1.manifest_permissions(),
77 set2.manifest_permissions(), 77 set2.manifest_permissions(),
78 &manifest_permissions); 78 &manifest_permissions);
79 79
80 URLPatternSet explicit_hosts = URLPatternSet::CreateSemanticIntersection( 80 URLPatternSet explicit_hosts = URLPatternSet::CreateSemanticIntersection(
81 set1.explicit_hosts(), set2.explicit_hosts()); 81 set1.explicit_hosts(), set2.explicit_hosts());
82 URLPatternSet scriptable_hosts = URLPatternSet::CreateSemanticIntersection( 82 URLPatternSet scriptable_hosts = URLPatternSet::CreateSemanticIntersection(
83 set1.scriptable_hosts(), set2.scriptable_hosts()); 83 set1.scriptable_hosts(), set2.scriptable_hosts());
84 84
85 return new PermissionSet(apis, manifest_permissions, 85 return make_scoped_ptr(new PermissionSet(apis, manifest_permissions,
86 explicit_hosts, scriptable_hosts); 86 explicit_hosts, scriptable_hosts));
87 } 87 }
88 88
89 // static 89 // static
90 scoped_refptr<const PermissionSet> PermissionSet::CreateUnion( 90 scoped_ptr<const PermissionSet> PermissionSet::CreateUnion(
91 const PermissionSet& set1, 91 const PermissionSet& set1,
92 const PermissionSet& set2) { 92 const PermissionSet& set2) {
93 APIPermissionSet apis; 93 APIPermissionSet apis;
94 APIPermissionSet::Union(set1.apis(), set2.apis(), &apis); 94 APIPermissionSet::Union(set1.apis(), set2.apis(), &apis);
95 95
96 ManifestPermissionSet manifest_permissions; 96 ManifestPermissionSet manifest_permissions;
97 ManifestPermissionSet::Union(set1.manifest_permissions(), 97 ManifestPermissionSet::Union(set1.manifest_permissions(),
98 set2.manifest_permissions(), 98 set2.manifest_permissions(),
99 &manifest_permissions); 99 &manifest_permissions);
100 100
101 URLPatternSet explicit_hosts = 101 URLPatternSet explicit_hosts =
102 URLPatternSet::CreateUnion(set1.explicit_hosts(), set2.explicit_hosts()); 102 URLPatternSet::CreateUnion(set1.explicit_hosts(), set2.explicit_hosts());
103 103
104 URLPatternSet scriptable_hosts = URLPatternSet::CreateUnion( 104 URLPatternSet scriptable_hosts = URLPatternSet::CreateUnion(
105 set1.scriptable_hosts(), set2.scriptable_hosts()); 105 set1.scriptable_hosts(), set2.scriptable_hosts());
106 106
107 return new PermissionSet(apis, manifest_permissions, 107 return make_scoped_ptr(new PermissionSet(apis, manifest_permissions,
108 explicit_hosts, scriptable_hosts); 108 explicit_hosts, scriptable_hosts));
109 } 109 }
110 110
111 bool PermissionSet::operator==( 111 bool PermissionSet::operator==(
112 const PermissionSet& rhs) const { 112 const PermissionSet& rhs) const {
113 return apis_ == rhs.apis_ && 113 return apis_ == rhs.apis_ &&
114 manifest_permissions_ == rhs.manifest_permissions_ && 114 manifest_permissions_ == rhs.manifest_permissions_ &&
115 scriptable_hosts_ == rhs.scriptable_hosts_ && 115 scriptable_hosts_ == rhs.scriptable_hosts_ &&
116 explicit_hosts_ == rhs.explicit_hosts_; 116 explicit_hosts_ == rhs.explicit_hosts_;
117 } 117 }
118 118
119 bool PermissionSet::operator!=(const PermissionSet& rhs) const { 119 bool PermissionSet::operator!=(const PermissionSet& rhs) const {
120 return !(*this == rhs); 120 return !(*this == rhs);
121 } 121 }
122 122
123 scoped_ptr<const PermissionSet> PermissionSet::Clone() const {
124 return make_scoped_ptr(new PermissionSet(apis_, manifest_permissions_,
125 explicit_hosts_, scriptable_hosts_));
not at google - send to devlin 2015/09/22 21:51:26 It would be good to copy the should_warn_all_hosts
Devlin 2015/09/23 17:08:59 I like it. Done.
126 }
127
123 bool PermissionSet::Contains(const PermissionSet& set) const { 128 bool PermissionSet::Contains(const PermissionSet& set) const {
124 return apis_.Contains(set.apis()) && 129 return apis_.Contains(set.apis()) &&
125 manifest_permissions_.Contains(set.manifest_permissions()) && 130 manifest_permissions_.Contains(set.manifest_permissions()) &&
126 explicit_hosts().Contains(set.explicit_hosts()) && 131 explicit_hosts().Contains(set.explicit_hosts()) &&
127 scriptable_hosts().Contains(set.scriptable_hosts()); 132 scriptable_hosts().Contains(set.scriptable_hosts());
128 } 133 }
129 134
130 std::set<std::string> PermissionSet::GetAPIsAsStrings() const { 135 std::set<std::string> PermissionSet::GetAPIsAsStrings() const {
131 std::set<std::string> apis_str; 136 std::set<std::string> apis_str;
132 for (APIPermissionSet::const_iterator i = apis_.begin(); 137 for (APIPermissionSet::const_iterator i = apis_.begin();
(...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after
247 if (iter->ImpliesAllHosts()) { 252 if (iter->ImpliesAllHosts()) {
248 should_warn_all_hosts_ = WARN_ALL_HOSTS; 253 should_warn_all_hosts_ = WARN_ALL_HOSTS;
249 return; 254 return;
250 } 255 }
251 } 256 }
252 257
253 should_warn_all_hosts_ = DONT_WARN_ALL_HOSTS; 258 should_warn_all_hosts_ = DONT_WARN_ALL_HOSTS;
254 } 259 }
255 260
256 } // namespace extensions 261 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698