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

Side by Side Diff: third_party/WebKit/Source/core/experiments/Experiments.h

Issue 1531443003: [bindings] Implement an ExperimentEnabled IDL extended attribute. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: More sharing. Created 4 years, 12 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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 Experiments_h 5 #ifndef Experiments_h
6 #define Experiments_h 6 #define Experiments_h
7 7
8 #include "core/CoreExport.h" 8 #include "core/CoreExport.h"
9 #include "core/dom/DOMException.h" 9 #include "core/dom/DOMException.h"
10 #include "core/dom/ExecutionContext.h" 10 #include "core/dom/ExecutionContext.h"
11 #include "wtf/text/WTFString.h" 11 #include "wtf/text/WTFString.h"
12 12
13 namespace blink { 13 namespace blink {
14 14
15 // The Experimental Framework (EF) provides limited access to experimental APIs, 15 // The Experimental Framework (EF) provides limited access to experimental APIs,
16 // on a per-origin basis. This class provides an interface to API implementers, 16 // on a per-origin basis. This class provides an interface to API implementers,
17 // for checking if the experimental API should be enabled for the current 17 // for checking if the experimental API should be enabled for the current
18 // context. 18 // context.
19 // 19 //
20 // Experimental APIs are defined by string names, provided by the implementers. 20 // Experimental APIs are defined by string names, provided by the implementers.
21 // The EF code does not maintain an enum or constant list for experiment names. 21 // The EF code does not maintain an enum or constant list for experiment names.
22 // Instead, the EF validates the name provided by the API implementation against 22 // Instead, the EF validates the name provided by the API implementation against
23 // any provided API keys. 23 // any provided API keys.
24 // TODO(chasej): Link to documentation, or provide more detail on keys, .etc 24 // TODO(chasej): Link to documentation, or provide more detail on keys, .etc
25 class CORE_EXPORT Experiments { 25 class CORE_EXPORT Experiments {
26 public: 26 public:
27 static bool isApiEnabled(ExecutionContext*, const String& apiName, String& e rrorMessage); 27 static bool isApiEnabled(ExecutionContext*, const String& apiName, String& e rrorMessage);
28 static bool isApiEnabled(ExecutionContext*, const String& apiName);
chasej 2015/12/22 16:58:26 Makes sense to add this overload without an error
28 // Creates a NotSupportedError exception with a message explaining to 29 // Creates a NotSupportedError exception with a message explaining to
29 // external developers why the API is disabled and how to join API 30 // external developers why the API is disabled and how to join API
30 // experiments. 31 // experiments.
31 static DOMException* createApiDisabledException(const String& apiName); 32 static DOMException* createApiDisabledException(const String& apiName);
32 33
33 private: 34 private:
34 explicit Experiments(); 35 explicit Experiments();
36
37 static bool isApiEnabledInternal(ExecutionContext*, const String& apiName, S tring& errorMessage);
35 }; 38 };
36 39
37 } // namespace blink 40 } // namespace blink
38 41
39 #endif // Experiments_h 42 #endif // Experiments_h
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698