 Chromium Code Reviews
 Chromium Code Reviews Issue 294593002:
  ServiceWorker: Support longest-prefix-match for registration scope  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src
    
  
    Issue 294593002:
  ServiceWorker: Support longest-prefix-match for registration scope  (Closed) 
  Base URL: svn://svn.chromium.org/chrome/trunk/src| Index: content/browser/service_worker/service_worker_utils.cc | 
| diff --git a/content/browser/service_worker/service_worker_utils.cc b/content/browser/service_worker/service_worker_utils.cc | 
| index 165bcbec563e8226494083450aedad1f7a90c9c8..4ef3bdf501d9fd0ea82b069ed574daca65d23cb8 100644 | 
| --- a/content/browser/service_worker/service_worker_utils.cc | 
| +++ b/content/browser/service_worker/service_worker_utils.cc | 
| @@ -30,4 +30,21 @@ bool ServiceWorkerUtils::ScopeMatches(const GURL& scope, const GURL& url) { | 
| return scope_spec == url_spec; | 
| } | 
| +bool ServiceWorkerUtils::FindLongestScopeMatch( | 
| + const std::vector<GURL>& scopes, const GURL& url, size_t* pos) { | 
| + DCHECK(!url.has_ref()); | 
| + DCHECK(pos); | 
| + | 
| + bool found = false; | 
| + for (size_t i = 0; i < scopes.size(); ++i) { | 
| + if (!ScopeMatches(scopes[i], url)) | 
| + continue; | 
| + if (!found || scopes.at(*pos) < scopes.at(i)) { | 
| 
jsbell
2014/06/02 18:33:41
This use of < here is weird. Do you mean to be com
 
jsbell
2014/06/02 18:36:54
Uh, ignore this. My brain is on backwards today.
 
jsbell
2014/06/02 19:31:22
Ah, I did find a counterexample:
url......: "foo/
 
nhiroki
2014/06/03 18:05:03
You're right!
 | 
| + *pos = i; | 
| + found = true; | 
| + } | 
| + } | 
| + return found; | 
| +} | 
| + | 
| } // namespace content |