diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 000000000..e69de29bb diff --git a/404.html b/404.html new file mode 100644 index 000000000..01f367b71 --- /dev/null +++ b/404.html @@ -0,0 +1,378 @@ + + + + + + + + + + + + + + + + + + + + + + Laboratory + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ +

404 - Not found

+

Whoops! Looks like the documentation is missing. Please report a bug on GitHub.

+ +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/api/images/anchor-copy-button.svg b/api/images/anchor-copy-button.svg new file mode 100644 index 000000000..19c1fa3f4 --- /dev/null +++ b/api/images/anchor-copy-button.svg @@ -0,0 +1,8 @@ + + + + + + diff --git a/api/images/arrow_down.svg b/api/images/arrow_down.svg new file mode 100644 index 000000000..639aaf12c --- /dev/null +++ b/api/images/arrow_down.svg @@ -0,0 +1,7 @@ + + + + + diff --git a/api/images/burger.svg b/api/images/burger.svg new file mode 100644 index 000000000..fcca732b7 --- /dev/null +++ b/api/images/burger.svg @@ -0,0 +1,9 @@ + + + + + + + diff --git a/api/images/copy-icon.svg b/api/images/copy-icon.svg new file mode 100644 index 000000000..2cb02ec6e --- /dev/null +++ b/api/images/copy-icon.svg @@ -0,0 +1,7 @@ + + + + + diff --git a/api/images/copy-successful-icon.svg b/api/images/copy-successful-icon.svg new file mode 100644 index 000000000..c4b95383d --- /dev/null +++ b/api/images/copy-successful-icon.svg @@ -0,0 +1,7 @@ + + + + + diff --git a/api/images/footer-go-to-link.svg b/api/images/footer-go-to-link.svg new file mode 100644 index 000000000..a87add7a3 --- /dev/null +++ b/api/images/footer-go-to-link.svg @@ -0,0 +1,7 @@ + + + + + diff --git a/api/images/go-to-top-icon.svg b/api/images/go-to-top-icon.svg new file mode 100644 index 000000000..abc3d1cef --- /dev/null +++ b/api/images/go-to-top-icon.svg @@ -0,0 +1,8 @@ + + + + + + diff --git a/api/images/homepage.svg b/api/images/homepage.svg new file mode 100644 index 000000000..e3c83b1ce --- /dev/null +++ b/api/images/homepage.svg @@ -0,0 +1,3 @@ + + + diff --git a/api/images/logo-icon.svg b/api/images/logo-icon.svg new file mode 100644 index 000000000..e42f9570c --- /dev/null +++ b/api/images/logo-icon.svg @@ -0,0 +1,14 @@ + + + + + + + + + + + + diff --git a/api/images/nav-icons/abstract-class-kotlin.svg b/api/images/nav-icons/abstract-class-kotlin.svg new file mode 100644 index 000000000..19d6148ca --- /dev/null +++ b/api/images/nav-icons/abstract-class-kotlin.svg @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/api/images/nav-icons/abstract-class.svg b/api/images/nav-icons/abstract-class.svg new file mode 100644 index 000000000..601820302 --- /dev/null +++ b/api/images/nav-icons/abstract-class.svg @@ -0,0 +1,20 @@ + + + + + + + + + + + + + + + + + + + + diff --git a/api/images/nav-icons/annotation-kotlin.svg b/api/images/nav-icons/annotation-kotlin.svg new file mode 100644 index 000000000..b90f508c4 --- /dev/null +++ b/api/images/nav-icons/annotation-kotlin.svg @@ -0,0 +1,13 @@ + + + + + + + + + + + diff --git a/api/images/nav-icons/annotation.svg b/api/images/nav-icons/annotation.svg new file mode 100644 index 000000000..b80c54b4b --- /dev/null +++ b/api/images/nav-icons/annotation.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/api/images/nav-icons/class-kotlin.svg b/api/images/nav-icons/class-kotlin.svg new file mode 100644 index 000000000..797a2423c --- /dev/null +++ b/api/images/nav-icons/class-kotlin.svg @@ -0,0 +1,13 @@ + + + + + + + + + + + diff --git a/api/images/nav-icons/class.svg b/api/images/nav-icons/class.svg new file mode 100644 index 000000000..3f1ad167e --- /dev/null +++ b/api/images/nav-icons/class.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/api/images/nav-icons/enum-kotlin.svg b/api/images/nav-icons/enum-kotlin.svg new file mode 100644 index 000000000..775a7cc90 --- /dev/null +++ b/api/images/nav-icons/enum-kotlin.svg @@ -0,0 +1,13 @@ + + + + + + + + + + + diff --git a/api/images/nav-icons/enum.svg b/api/images/nav-icons/enum.svg new file mode 100644 index 000000000..fa7f24766 --- /dev/null +++ b/api/images/nav-icons/enum.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/api/images/nav-icons/exception-class.svg b/api/images/nav-icons/exception-class.svg new file mode 100644 index 000000000..c0b2bdeba --- /dev/null +++ b/api/images/nav-icons/exception-class.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/api/images/nav-icons/field-value.svg b/api/images/nav-icons/field-value.svg new file mode 100644 index 000000000..2771ee56c --- /dev/null +++ b/api/images/nav-icons/field-value.svg @@ -0,0 +1,10 @@ + + + + + + + + diff --git a/api/images/nav-icons/field-variable.svg b/api/images/nav-icons/field-variable.svg new file mode 100644 index 000000000..e2d2bbd01 --- /dev/null +++ b/api/images/nav-icons/field-variable.svg @@ -0,0 +1,10 @@ + + + + + + + + diff --git a/api/images/nav-icons/function.svg b/api/images/nav-icons/function.svg new file mode 100644 index 000000000..f0da64a0b --- /dev/null +++ b/api/images/nav-icons/function.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/api/images/nav-icons/interface-kotlin.svg b/api/images/nav-icons/interface-kotlin.svg new file mode 100644 index 000000000..5e163260e --- /dev/null +++ b/api/images/nav-icons/interface-kotlin.svg @@ -0,0 +1,13 @@ + + + + + + + + + + + diff --git a/api/images/nav-icons/interface.svg b/api/images/nav-icons/interface.svg new file mode 100644 index 000000000..32063ba26 --- /dev/null +++ b/api/images/nav-icons/interface.svg @@ -0,0 +1,7 @@ + + + + + + + diff --git a/api/images/nav-icons/object.svg b/api/images/nav-icons/object.svg new file mode 100644 index 000000000..31f0ee3e6 --- /dev/null +++ b/api/images/nav-icons/object.svg @@ -0,0 +1,13 @@ + + + + + + + + + + + diff --git a/api/images/nav-icons/typealias-kotlin.svg b/api/images/nav-icons/typealias-kotlin.svg new file mode 100644 index 000000000..f4bb238b5 --- /dev/null +++ b/api/images/nav-icons/typealias-kotlin.svg @@ -0,0 +1,13 @@ + + + + + + + + + + + diff --git a/api/images/theme-toggle.svg b/api/images/theme-toggle.svg new file mode 100644 index 000000000..df86202bb --- /dev/null +++ b/api/images/theme-toggle.svg @@ -0,0 +1,7 @@ + + + + + diff --git a/api/index.html b/api/index.html new file mode 100644 index 000000000..9d2e7cd14 --- /dev/null +++ b/api/index.html @@ -0,0 +1,142 @@ + + + + + All modules + + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

All modules:

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
+
+
+
+ +
+
+
+ + diff --git a/api/laboratory/data-store/index.html b/api/laboratory/data-store/index.html new file mode 100644 index 000000000..098d42976 --- /dev/null +++ b/api/laboratory/data-store/index.html @@ -0,0 +1,95 @@ + + + + + data-store + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

data-store

+
+

Packages

+
+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/default-value.html b/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/default-value.html new file mode 100644 index 000000000..66e6cab8e --- /dev/null +++ b/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/default-value.html @@ -0,0 +1,76 @@ + + + + + defaultValue + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

defaultValue

+
+
open override val defaultValue: <Error class: unknown class>
+
+ +
+
+
+ + + diff --git a/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/index.html b/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/index.html new file mode 100644 index 000000000..6b2f51df9 --- /dev/null +++ b/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/index.html @@ -0,0 +1,134 @@ + + + + + FeatureFlagsSerializer + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFlagsSerializer

+
object FeatureFlagsSerializer : Serializer<<Error class: unknown class>>

Serializer that is capable of writing and reading of feature flags. It can be used, for example, as a delegate of encryption serializer.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override val defaultValue: <Error class: unknown class>
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open suspend override fun readFrom(input: InputStream): <Error class: unknown class>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open suspend override fun writeTo(t: <Error class: unknown class>, output: OutputStream)
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/read-from.html b/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/read-from.html new file mode 100644 index 000000000..a97ee523d --- /dev/null +++ b/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/read-from.html @@ -0,0 +1,76 @@ + + + + + readFrom + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

readFrom

+
+
open suspend override fun readFrom(input: InputStream): <Error class: unknown class>
+
+ +
+
+
+ + + diff --git a/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/write-to.html b/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/write-to.html new file mode 100644 index 000000000..723584e8d --- /dev/null +++ b/api/laboratory/data-store/io.mehow.laboratory.datastore/-feature-flags-serializer/write-to.html @@ -0,0 +1,76 @@ + + + + + writeTo + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

writeTo

+
+
open suspend override fun writeTo(t: <Error class: unknown class>, output: OutputStream)
+
+ +
+
+
+ + + diff --git a/api/laboratory/data-store/io.mehow.laboratory.datastore/data-store.html b/api/laboratory/data-store/io.mehow.laboratory.datastore/data-store.html new file mode 100644 index 000000000..9e81d0b1b --- /dev/null +++ b/api/laboratory/data-store/io.mehow.laboratory.datastore/data-store.html @@ -0,0 +1,76 @@ + + + + + dataStore + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

dataStore

+
+
fun FeatureStorage.Companion.dataStore(dataStore: DataStore<<Error class: unknown class>>): FeatureStorage

Creates a FeatureStorage that is backed by DataStore.

+
+ +
+
+
+ + + diff --git a/api/laboratory/data-store/io.mehow.laboratory.datastore/index.html b/api/laboratory/data-store/io.mehow.laboratory.datastore/index.html new file mode 100644 index 000000000..cba95ce11 --- /dev/null +++ b/api/laboratory/data-store/io.mehow.laboratory.datastore/index.html @@ -0,0 +1,118 @@ + + + + + io.mehow.laboratory.datastore + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Package-level declarations

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object FeatureFlagsSerializer : Serializer<<Error class: unknown class>>

Serializer that is capable of writing and reading of feature flags. It can be used, for example, as a delegate of encryption serializer.

+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun FeatureStorage.Companion.dataStore(dataStore: DataStore<<Error class: unknown class>>): FeatureStorage

Creates a FeatureStorage that is backed by DataStore.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/data-store/navigation.html b/api/laboratory/data-store/navigation.html new file mode 100644 index 000000000..09bd18bdc --- /dev/null +++ b/api/laboratory/data-store/navigation.html @@ -0,0 +1,397 @@ +
+
+ + +
+
+
+ generator +
+
+ +
+ +
+ + + + + +
+ +
+
+ +
+
+ Public +
+
+
+
+ Internal +
+
+
+
+
+
+ + +
+
+
+ inspector +
+
+ +
+ +
+
+ Selector +
+
+
+
+ Regular +
+
+
+
+ Bottom +
+
+
+
+ +
+
+ Selector +
+
+
+
+ Show +
+
+
+ +
+
+
+ Hide +
+
+
+
+ +
+
+ Companion +
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+ +
+
+ +
+
+ Limited +
+
+
+
+ Unlimited +
+
+
+
+
+
+
+
+
+ runtime +
+
+ +
+ +
+ +
+ +
+
+ +
+
+ Companion +
+
+
+
+ +
+
+
+ Feature +
+
+
+ +
+
+ Companion +
+
+
+
+ +
+
+ Companion +
+
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+
+ +
+
+ Companion +
+
+
+
+
+ options +
+
+
+
+ source +
+
+ +
+
+
+ + +
+
diff --git a/api/laboratory/generator/index.html b/api/laboratory/generator/index.html new file mode 100644 index 000000000..d3c6aa765 --- /dev/null +++ b/api/laboratory/generator/index.html @@ -0,0 +1,95 @@ + + + + + generator + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

generator

+
+

Packages

+
+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/-deprecation.html b/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/-deprecation.html new file mode 100644 index 000000000..738519957 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/-deprecation.html @@ -0,0 +1,76 @@ + + + + + Deprecation + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Deprecation

+
+
constructor(message: String, level: DeprecationLevel = WARNING)
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/index.html new file mode 100644 index 000000000..c1d8e47d1 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/index.html @@ -0,0 +1,134 @@ + + + + + Deprecation + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Deprecation

+
class Deprecation(val message: String, val level: DeprecationLevel = WARNING)
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(message: String, level: DeprecationLevel = WARNING)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/level.html b/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/level.html new file mode 100644 index 000000000..0ee6878f2 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/level.html @@ -0,0 +1,76 @@ + + + + + level + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

level

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/message.html b/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/message.html new file mode 100644 index 000000000..15f2776c4 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-deprecation/message.html @@ -0,0 +1,76 @@ + + + + + message + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

message

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/-feature-factory-model.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/-feature-factory-model.html new file mode 100644 index 000000000..75d2e78d9 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/-feature-factory-model.html @@ -0,0 +1,76 @@ + + + + + FeatureFactoryModel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFactoryModel

+
+
constructor(className: ClassName, features: List<FeatureFlagModel>, visibility: Visibility = Internal)
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/class-name.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/class-name.html new file mode 100644 index 000000000..cc039c0a0 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/class-name.html @@ -0,0 +1,76 @@ + + + + + className + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

className

+
+
val className: ClassName
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/features.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/features.html new file mode 100644 index 000000000..6297cf24a --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/features.html @@ -0,0 +1,76 @@ + + + + + features + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

features

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/index.html new file mode 100644 index 000000000..8a096dc71 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/index.html @@ -0,0 +1,168 @@ + + + + + FeatureFactoryModel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFactoryModel

+
class FeatureFactoryModel(val className: ClassName, val features: List<FeatureFlagModel>, val visibility: Visibility = Internal)
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(className: ClassName, features: List<FeatureFlagModel>, visibility: Visibility = Internal)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
val className: ClassName
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun prepare(functionName: String): FileSpec
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/prepare.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/prepare.html new file mode 100644 index 000000000..ca2e20e1e --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/prepare.html @@ -0,0 +1,76 @@ + + + + + prepare + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

prepare

+
+
fun prepare(functionName: String): FileSpec
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/visibility.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/visibility.html new file mode 100644 index 000000000..7d2d06a8d --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-factory-model/visibility.html @@ -0,0 +1,76 @@ + + + + + visibility + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

visibility

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/-feature-flag-model.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/-feature-flag-model.html new file mode 100644 index 000000000..dfda77271 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/-feature-flag-model.html @@ -0,0 +1,76 @@ + + + + + FeatureFlagModel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFlagModel

+
+
constructor(className: ClassName, options: List<FeatureFlagOption>, visibility: Visibility = Public, key: String? = null, description: String = "", deprecation: Deprecation? = null, sourceOptions: List<FeatureFlagOption> = emptyList(), supervisor: Supervisor? = null)
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/class-name.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/class-name.html new file mode 100644 index 000000000..09ede864a --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/class-name.html @@ -0,0 +1,76 @@ + + + + + className + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

className

+
+
val className: ClassName
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/deprecation.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/deprecation.html new file mode 100644 index 000000000..54a0c0878 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/deprecation.html @@ -0,0 +1,76 @@ + + + + + deprecation + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

deprecation

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/description.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/description.html new file mode 100644 index 000000000..5b35e8ef0 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/description.html @@ -0,0 +1,76 @@ + + + + + description + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

description

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/equals.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/equals.html new file mode 100644 index 000000000..404d2d6bf --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/equals.html @@ -0,0 +1,76 @@ + + + + + equals + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

equals

+
+
open operator override fun equals(other: Any?): Boolean
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/hash-code.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/hash-code.html new file mode 100644 index 000000000..523514139 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/hash-code.html @@ -0,0 +1,76 @@ + + + + + hashCode + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

hashCode

+
+
open override fun hashCode(): Int
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/index.html new file mode 100644 index 000000000..c971b9ee1 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/index.html @@ -0,0 +1,288 @@ + + + + + FeatureFlagModel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFlagModel

+ +
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(className: ClassName, options: List<FeatureFlagOption>, visibility: Visibility = Public, key: String? = null, description: String = "", deprecation: Deprecation? = null, sourceOptions: List<FeatureFlagOption> = emptyList(), supervisor: Supervisor? = null)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
val className: ClassName
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val key: String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open operator override fun equals(other: Any?): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hashCode(): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun prepare(): FileSpec
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun toString(): String
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/key.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/key.html new file mode 100644 index 000000000..2fe808fae --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/key.html @@ -0,0 +1,76 @@ + + + + + key + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

key

+
+
val key: String?
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/options.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/options.html new file mode 100644 index 000000000..edf965e13 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/options.html @@ -0,0 +1,76 @@ + + + + + options + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

options

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/prepare.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/prepare.html new file mode 100644 index 000000000..e3d864445 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/prepare.html @@ -0,0 +1,76 @@ + + + + + prepare + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

prepare

+
+
fun prepare(): FileSpec
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/source.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/source.html new file mode 100644 index 000000000..56489841f --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/source.html @@ -0,0 +1,76 @@ + + + + + source + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

source

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/supervisor.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/supervisor.html new file mode 100644 index 000000000..4e0f2603d --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/supervisor.html @@ -0,0 +1,76 @@ + + + + + supervisor + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

supervisor

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/to-string.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/to-string.html new file mode 100644 index 000000000..6095fcf67 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/to-string.html @@ -0,0 +1,76 @@ + + + + + toString + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

toString

+
+
open override fun toString(): String
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/visibility.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/visibility.html new file mode 100644 index 000000000..a8229a8e2 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-model/visibility.html @@ -0,0 +1,76 @@ + + + + + visibility + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

visibility

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/-feature-flag-option.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/-feature-flag-option.html new file mode 100644 index 000000000..cfec2315b --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/-feature-flag-option.html @@ -0,0 +1,76 @@ + + + + + FeatureFlagOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFlagOption

+
+
constructor(name: String, isDefault: Boolean = false)
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/index.html new file mode 100644 index 000000000..3fd4db8b9 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/index.html @@ -0,0 +1,134 @@ + + + + + FeatureFlagOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFlagOption

+
data class FeatureFlagOption(val name: String, val isDefault: Boolean = false)
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(name: String, isDefault: Boolean = false)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
val isDefault: Boolean = false
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/is-default.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/is-default.html new file mode 100644 index 000000000..c48cc6d6b --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/is-default.html @@ -0,0 +1,76 @@ + + + + + isDefault + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

isDefault

+
+
val isDefault: Boolean = false
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/name.html b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/name.html new file mode 100644 index 000000000..6a4aa5240 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-feature-flag-option/name.html @@ -0,0 +1,76 @@ + + + + + name + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

name

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/-option-factory-model.html b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/-option-factory-model.html new file mode 100644 index 000000000..65d7b6109 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/-option-factory-model.html @@ -0,0 +1,76 @@ + + + + + OptionFactoryModel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

OptionFactoryModel

+
+
constructor(className: ClassName, features: List<FeatureFlagModel>, visibility: Visibility = Internal)
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/class-name.html b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/class-name.html new file mode 100644 index 000000000..ec1b20ae8 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/class-name.html @@ -0,0 +1,76 @@ + + + + + className + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

className

+
+
val className: ClassName
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/features.html b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/features.html new file mode 100644 index 000000000..0f96796fa --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/features.html @@ -0,0 +1,76 @@ + + + + + features + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

features

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/index.html new file mode 100644 index 000000000..fed4376b1 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/index.html @@ -0,0 +1,168 @@ + + + + + OptionFactoryModel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

OptionFactoryModel

+
class OptionFactoryModel(val className: ClassName, val features: List<FeatureFlagModel>, val visibility: Visibility = Internal)
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(className: ClassName, features: List<FeatureFlagModel>, visibility: Visibility = Internal)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
val className: ClassName
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun prepare(): FileSpec
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/prepare.html b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/prepare.html new file mode 100644 index 000000000..61e1eba51 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/prepare.html @@ -0,0 +1,76 @@ + + + + + prepare + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

prepare

+
+
fun prepare(): FileSpec
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/visibility.html b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/visibility.html new file mode 100644 index 000000000..1dcd44f0e --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-option-factory-model/visibility.html @@ -0,0 +1,76 @@ + + + + + visibility + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

visibility

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/-sourced-feature-storage-model.html b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/-sourced-feature-storage-model.html new file mode 100644 index 000000000..03cb6481b --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/-sourced-feature-storage-model.html @@ -0,0 +1,76 @@ + + + + + SourcedFeatureStorageModel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

SourcedFeatureStorageModel

+
+
constructor(className: ClassName, sourceNames: List<String>, visibility: Visibility = Internal)
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/class-name.html b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/class-name.html new file mode 100644 index 000000000..a99e4dabb --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/class-name.html @@ -0,0 +1,76 @@ + + + + + className + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

className

+
+
val className: ClassName
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/index.html new file mode 100644 index 000000000..cc946af3c --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/index.html @@ -0,0 +1,168 @@ + + + + + SourcedFeatureStorageModel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

SourcedFeatureStorageModel

+
class SourcedFeatureStorageModel(val className: ClassName, val sourceNames: List<String>, val visibility: Visibility = Internal)
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(className: ClassName, sourceNames: List<String>, visibility: Visibility = Internal)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
val className: ClassName
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun prepare(): FileSpec
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/prepare.html b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/prepare.html new file mode 100644 index 000000000..2848a77e7 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/prepare.html @@ -0,0 +1,76 @@ + + + + + prepare + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

prepare

+
+
fun prepare(): FileSpec
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/source-names.html b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/source-names.html new file mode 100644 index 000000000..c7949627e --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/source-names.html @@ -0,0 +1,76 @@ + + + + + sourceNames + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

sourceNames

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/visibility.html b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/visibility.html new file mode 100644 index 000000000..24ddb4daa --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-sourced-feature-storage-model/visibility.html @@ -0,0 +1,76 @@ + + + + + visibility + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

visibility

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/-supervisor.html b/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/-supervisor.html new file mode 100644 index 000000000..83b071e83 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/-supervisor.html @@ -0,0 +1,76 @@ + + + + + Supervisor + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Supervisor

+
+
constructor(featureFlag: FeatureFlagModel, option: FeatureFlagOption)
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/feature-flag.html b/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/feature-flag.html new file mode 100644 index 000000000..d807b9b9c --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/feature-flag.html @@ -0,0 +1,76 @@ + + + + + featureFlag + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

featureFlag

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/index.html new file mode 100644 index 000000000..23e90d606 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/index.html @@ -0,0 +1,134 @@ + + + + + Supervisor + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Supervisor

+
class Supervisor(val featureFlag: FeatureFlagModel, val option: FeatureFlagOption)
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(featureFlag: FeatureFlagModel, option: FeatureFlagOption)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/option.html b/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/option.html new file mode 100644 index 000000000..99f74aa55 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-supervisor/option.html @@ -0,0 +1,76 @@ + + + + + option + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

option

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/-internal/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/-internal/index.html new file mode 100644 index 000000000..425c8277a --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/-internal/index.html @@ -0,0 +1,115 @@ + + + + + Internal + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Internal

+ +
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/-public/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/-public/index.html new file mode 100644 index 000000000..4cd188ef7 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/-public/index.html @@ -0,0 +1,115 @@ + + + + + Public + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Public

+ +
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/entries.html b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/entries.html new file mode 100644 index 000000000..27a8fc80c --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/entries.html @@ -0,0 +1,76 @@ + + + + + entries + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

entries

+
+

Returns a representation of an immutable list of all enum entries, in the order they're declared.

This method may be used to iterate over the enum entries.

+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/index.html new file mode 100644 index 000000000..603fbd7bc --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/index.html @@ -0,0 +1,198 @@ + + + + + Visibility + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Visibility

+ +
+
+
+
+
+

Entries

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns a representation of an immutable list of all enum entries, in the order they're declared.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns an array containing the constants of this enum type, in the order they're declared.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/value-of.html b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/value-of.html new file mode 100644 index 000000000..b6cad0267 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/value-of.html @@ -0,0 +1,76 @@ + + + + + valueOf + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

valueOf

+
+

Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)

Throws

if this enum type has no constant with the specified name

+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/values.html b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/values.html new file mode 100644 index 000000000..4ea6c0ad6 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/-visibility/values.html @@ -0,0 +1,76 @@ + + + + + values + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

values

+
+

Returns an array containing the constants of this enum type, in the order they're declared.

This method may be used to iterate over the constants.

+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/io.mehow.laboratory.generator/index.html b/api/laboratory/generator/io.mehow.laboratory.generator/index.html new file mode 100644 index 000000000..3c6528b99 --- /dev/null +++ b/api/laboratory/generator/io.mehow.laboratory.generator/index.html @@ -0,0 +1,204 @@ + + + + + io.mehow.laboratory.generator + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Package-level declarations

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
class Deprecation(val message: String, val level: DeprecationLevel = WARNING)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
class FeatureFactoryModel(val className: ClassName, val features: List<FeatureFlagModel>, val visibility: Visibility = Internal)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
data class FeatureFlagOption(val name: String, val isDefault: Boolean = false)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
class OptionFactoryModel(val className: ClassName, val features: List<FeatureFlagModel>, val visibility: Visibility = Internal)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
class SourcedFeatureStorageModel(val className: ClassName, val sourceNames: List<String>, val visibility: Visibility = Internal)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
class Supervisor(val featureFlag: FeatureFlagModel, val option: FeatureFlagOption)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/generator/navigation.html b/api/laboratory/generator/navigation.html new file mode 100644 index 000000000..09bd18bdc --- /dev/null +++ b/api/laboratory/generator/navigation.html @@ -0,0 +1,397 @@ +
+
+ + +
+
+
+ generator +
+
+ +
+ +
+ + + + + +
+ +
+
+ +
+
+ Public +
+
+
+
+ Internal +
+
+
+
+
+
+ + +
+
+
+ inspector +
+
+ +
+ +
+
+ Selector +
+
+
+
+ Regular +
+
+
+
+ Bottom +
+
+
+
+ +
+
+ Selector +
+
+
+
+ Show +
+
+
+ +
+
+
+ Hide +
+
+
+
+ +
+
+ Companion +
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+ +
+
+ +
+
+ Limited +
+
+
+
+ Unlimited +
+
+
+
+
+
+
+
+
+ runtime +
+
+ +
+ +
+ +
+ +
+
+ +
+
+ Companion +
+
+
+
+ +
+
+
+ Feature +
+
+
+ +
+
+ Companion +
+
+
+
+ +
+
+ Companion +
+
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+
+ +
+
+ Companion +
+
+
+
+
+ options +
+
+
+
+ source +
+
+ +
+
+
+ + +
+
diff --git a/api/laboratory/gradle-plugin/index.html b/api/laboratory/gradle-plugin/index.html new file mode 100644 index 000000000..9131aa2fa --- /dev/null +++ b/api/laboratory/gradle-plugin/index.html @@ -0,0 +1,95 @@ + + + + + gradle-plugin + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

gradle-plugin

+
+

Packages

+
+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-child-feature-flags-input/feature.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-child-feature-flags-input/feature.html new file mode 100644 index 000000000..7e7b8a2d7 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-child-feature-flags-input/feature.html @@ -0,0 +1,76 @@ + + + + + feature + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

feature

+
+
fun feature(name: String, action: Action<FeatureFlagInput>)

Generates a new supervised feature flag.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-child-feature-flags-input/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-child-feature-flags-input/index.html new file mode 100644 index 000000000..d7b9254fa --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-child-feature-flags-input/index.html @@ -0,0 +1,100 @@ + + + + + ChildFeatureFlagsInput + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

ChildFeatureFlagsInput

+

An entry point for configuration of supervised feature flags code generation.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun feature(name: String, action: Action<FeatureFlagInput>)

Generates a new supervised feature flag.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-error/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-error/index.html new file mode 100644 index 000000000..043bcf994 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-error/index.html @@ -0,0 +1,115 @@ + + + + + Error + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Error

+

Usage of the deprecated element will be reported as an error.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-hidden/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-hidden/index.html new file mode 100644 index 000000000..f20d44b58 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-hidden/index.html @@ -0,0 +1,115 @@ + + + + + Hidden + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Hidden

+

Deprecated element will not be accessible from code.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-warning/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-warning/index.html new file mode 100644 index 000000000..413d499b1 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/-warning/index.html @@ -0,0 +1,115 @@ + + + + + Warning + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Warning

+

Usage of the deprecated element will be reported as a warning.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/entries.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/entries.html new file mode 100644 index 000000000..d7f1dc595 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/entries.html @@ -0,0 +1,76 @@ + + + + + entries + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

entries

+
+

Returns a representation of an immutable list of all enum entries, in the order they're declared.

This method may be used to iterate over the enum entries.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/index.html new file mode 100644 index 000000000..b67f2586d --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/index.html @@ -0,0 +1,213 @@ + + + + + DeprecationLevel + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

DeprecationLevel

+

Possible levels of a deprecation. The level specifies how the deprecated element usages are reported in code.

+
+
+
+
+
+

Entries

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Usage of the deprecated element will be reported as a warning.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Usage of the deprecated element will be reported as an error.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Deprecated element will not be accessible from code.

+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns a representation of an immutable list of all enum entries, in the order they're declared.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns an array containing the constants of this enum type, in the order they're declared.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/value-of.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/value-of.html new file mode 100644 index 000000000..2f7a0c109 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/value-of.html @@ -0,0 +1,76 @@ + + + + + valueOf + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

valueOf

+
+

Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)

Throws

if this enum type has no constant with the specified name

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/values.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/values.html new file mode 100644 index 000000000..8e772cf78 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-deprecation-level/values.html @@ -0,0 +1,76 @@ + + + + + values + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

values

+
+

Returns an array containing the constants of this enum type, in the order they're declared.

This method may be used to iterate over the constants.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/index.html new file mode 100644 index 000000000..de6b8b549 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/index.html @@ -0,0 +1,115 @@ + + + + + FeatureFactoryInput + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFactoryInput

+

Representation of a generated feature factory class.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets whether the generated feature factory should be public or internal.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets package name of the generated feature factory. Overwrites any previously set values.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/is-public.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/is-public.html new file mode 100644 index 000000000..8cd8d8245 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/is-public.html @@ -0,0 +1,76 @@ + + + + + isPublic + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

isPublic

+
+

Sets whether the generated feature factory should be public or internal.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/package-name.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/package-name.html new file mode 100644 index 000000000..fa0a601b5 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-input/package-name.html @@ -0,0 +1,76 @@ + + + + + packageName + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

packageName

+
+

Sets package name of the generated feature factory. Overwrites any previously set values.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/-feature-factory-task.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/-feature-factory-task.html new file mode 100644 index 000000000..49af98519 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/-feature-factory-task.html @@ -0,0 +1,76 @@ + + + + + FeatureFactoryTask + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFactoryTask

+
+
constructor()
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/generate-feature-factory.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/generate-feature-factory.html new file mode 100644 index 000000000..01e0400b8 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/generate-feature-factory.html @@ -0,0 +1,76 @@ + + + + + generateFeatureFactory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

generateFeatureFactory

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/index.html new file mode 100644 index 000000000..2dcdcd127 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-factory-task/index.html @@ -0,0 +1,1143 @@ + + + + + FeatureFactoryTask + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFactoryTask

+
open class FeatureFactoryTask : DefaultTask
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor()
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
@get:Internal
var enabled: Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val state: TaskStateInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val timeout: Property<Duration>
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun acceptServiceReferences(serviceReferences: MutableSet<ServiceReferenceSpec>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun appendParallelSafeAction(action: Action<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open operator override fun compareTo(other: Task): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun configure(closure: Closure<Any>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun dependsOn(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doFirst(action: Closure<Any>): Task
open override fun doFirst(action: Action<in Task>): Task
open override fun doFirst(actionName: String, action: Action<in Task>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doLast(action: Closure<Any>): Task
open override fun doLast(action: Action<in Task>): Task
open override fun doLast(actionName: String, action: Action<in Task>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doNotTrackState(reasonNotToTrackState: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun finalizedBy(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getActions(): MutableList<Action<in Task>>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getAnt(): AntBuilder
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getAsDynamicObject(): DynamicObject
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getConvention(): Convention
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDependsOn(): MutableSet<Any>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDescription(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDestroyables(): TaskDestroyables
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDidWork(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExtensions(): ExtensionContainer
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getFinalizedBy(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getGroup(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getIdentityPath(): Path
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getInputs(): TaskInputsInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getLifecycleDependencies(): TaskDependencyInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLocalState(): TaskLocalState
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLogger(): Logger
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLogging(): LoggingManager
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getMustRunAfter(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getName(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOnlyIf(): Spec<in TaskInternal>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOutputs(): TaskOutputsInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getPath(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getProject(): Project
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+ +
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getRequiredServices(): TaskRequiredServices
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getSharedResources(): MutableList<ResourceLock>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getShouldRunAfter(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getStandardOutputCapture(): StandardOutputCapture
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskActions(): MutableList<InputChangesAwareTaskAction>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskDependencies(): TaskDependencyInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskIdentity(): TaskIdentity<*>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTemporaryDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTemporaryDirFactory(): Factory<File>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hasProperty(propertyName: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hasTaskActions(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun mustRunAfter(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun notCompatibleWithConfigurationCache(reason: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onlyIf(onlyIfClosure: Closure<Any>)
open override fun onlyIf(spec: Spec<in Task>)
open override fun onlyIf(onlyIfReason: String, spec: Spec<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun prependParallelSafeAction(action: Action<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun property(propertyName: String): Any?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setActions(replacements: MutableList<Action<in Task>>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDependsOn(dependsOn: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDescription(description: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDidWork(didWork: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setFinalizedBy(finalizedByTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setGroup(group: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setMustRunAfter(mustRunAfterTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setOnlyIf(onlyIfClosure: Closure<Any>)
open override fun setOnlyIf(spec: Spec<in Task>)
open override fun setOnlyIf(onlyIfReason: String, spec: Spec<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setProperty(name: String, value: Any)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setShouldRunAfter(shouldRunAfterTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun shouldRunAfter(vararg paths: Any): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun usesService(service: Provider<out BuildService<*>>)
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/deprecated.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/deprecated.html new file mode 100644 index 000000000..c605a2031 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/deprecated.html @@ -0,0 +1,76 @@ + + + + + deprecated + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

deprecated

+
+
fun deprecated(message: String, level: DeprecationLevel = Warning)

Annotates a feature flag as deprecated.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/description.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/description.html new file mode 100644 index 000000000..a7c12cdf7 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/description.html @@ -0,0 +1,76 @@ + + + + + description + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

description

+
+

Sets description of the generated feature flag.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/index.html new file mode 100644 index 000000000..0cb0db93a --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/index.html @@ -0,0 +1,224 @@ + + + + + FeatureFlagInput + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFlagInput

+

Representation of a generated feature flag. It must have at least one value and exactly one default value.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets description of the generated feature flag.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets whether the generated feature flag should be public or internal.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
var key: String?

Sets a custom key that will be used for generated option factory.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets package name of the generated feature flag. Overwrites any previously set values.

+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun deprecated(message: String, level: DeprecationLevel = Warning)

Annotates a feature flag as deprecated.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Adds a feature value that will be used as a default value. Exactly one value must be set with this method.

fun withDefaultOption(name: String, action: Action<ChildFeatureFlagsInput>)

Adds a feature value that will be used as a default value and configures features flags supervised by it. Exactly one value must be set with this method.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Adds a feature flag source that will be used a default source. Any sources that are named "Local", or any variation of this word, will be filtered out. At most one value can be set with this method.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun withOption(name: String)

Adds a feature option.

fun withOption(name: String, action: Action<ChildFeatureFlagsInput>)

Adds a feature option and configures features flags supervised by it.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun withSource(name: String)

Adds a feature flag source. Any sources that are named "Local", or any variation of this word, will be filtered out.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/is-public.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/is-public.html new file mode 100644 index 000000000..8e7740358 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/is-public.html @@ -0,0 +1,76 @@ + + + + + isPublic + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

isPublic

+
+

Sets whether the generated feature flag should be public or internal.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/key.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/key.html new file mode 100644 index 000000000..541dabe17 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/key.html @@ -0,0 +1,76 @@ + + + + + key + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

key

+
+
var key: String?

Sets a custom key that will be used for generated option factory.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/package-name.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/package-name.html new file mode 100644 index 000000000..a51004c36 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/package-name.html @@ -0,0 +1,76 @@ + + + + + packageName + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

packageName

+
+

Sets package name of the generated feature flag. Overwrites any previously set values.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-default-option.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-default-option.html new file mode 100644 index 000000000..438eb7af4 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-default-option.html @@ -0,0 +1,76 @@ + + + + + withDefaultOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

withDefaultOption

+
+

Adds a feature value that will be used as a default value. Exactly one value must be set with this method.


fun withDefaultOption(name: String, action: Action<ChildFeatureFlagsInput>)

Adds a feature value that will be used as a default value and configures features flags supervised by it. Exactly one value must be set with this method.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-default-source.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-default-source.html new file mode 100644 index 000000000..37cda6726 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-default-source.html @@ -0,0 +1,76 @@ + + + + + withDefaultSource + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

withDefaultSource

+
+

Adds a feature flag source that will be used a default source. Any sources that are named "Local", or any variation of this word, will be filtered out. At most one value can be set with this method.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-option.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-option.html new file mode 100644 index 000000000..665bb0147 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-option.html @@ -0,0 +1,76 @@ + + + + + withOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

withOption

+
+
fun withOption(name: String)

Adds a feature option.


fun withOption(name: String, action: Action<ChildFeatureFlagsInput>)

Adds a feature option and configures features flags supervised by it.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-source.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-source.html new file mode 100644 index 000000000..77a07960b --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flag-input/with-source.html @@ -0,0 +1,76 @@ + + + + + withSource + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

withSource

+
+
fun withSource(name: String)

Adds a feature flag source. Any sources that are named "Local", or any variation of this word, will be filtered out.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/-feature-flags-task.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/-feature-flags-task.html new file mode 100644 index 000000000..119b2d0a1 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/-feature-flags-task.html @@ -0,0 +1,76 @@ + + + + + FeatureFlagsTask + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFlagsTask

+
+
constructor()
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/generate-feature-flags.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/generate-feature-flags.html new file mode 100644 index 000000000..930d5348a --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/generate-feature-flags.html @@ -0,0 +1,76 @@ + + + + + generateFeatureFlags + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

generateFeatureFlags

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/index.html new file mode 100644 index 000000000..63b23daf7 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-feature-flags-task/index.html @@ -0,0 +1,1143 @@ + + + + + FeatureFlagsTask + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFlagsTask

+
open class FeatureFlagsTask : DefaultTask
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor()
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
@get:Internal
var enabled: Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val state: TaskStateInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val timeout: Property<Duration>
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun acceptServiceReferences(serviceReferences: MutableSet<ServiceReferenceSpec>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun appendParallelSafeAction(action: Action<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open operator override fun compareTo(other: Task): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun configure(closure: Closure<Any>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun dependsOn(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doFirst(action: Closure<Any>): Task
open override fun doFirst(action: Action<in Task>): Task
open override fun doFirst(actionName: String, action: Action<in Task>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doLast(action: Closure<Any>): Task
open override fun doLast(action: Action<in Task>): Task
open override fun doLast(actionName: String, action: Action<in Task>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doNotTrackState(reasonNotToTrackState: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun finalizedBy(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getActions(): MutableList<Action<in Task>>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getAnt(): AntBuilder
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getAsDynamicObject(): DynamicObject
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getConvention(): Convention
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDependsOn(): MutableSet<Any>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDescription(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDestroyables(): TaskDestroyables
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDidWork(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExtensions(): ExtensionContainer
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getFinalizedBy(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getGroup(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getIdentityPath(): Path
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getInputs(): TaskInputsInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getLifecycleDependencies(): TaskDependencyInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLocalState(): TaskLocalState
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLogger(): Logger
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLogging(): LoggingManager
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getMustRunAfter(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getName(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOnlyIf(): Spec<in TaskInternal>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOutputs(): TaskOutputsInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getPath(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getProject(): Project
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+ +
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getRequiredServices(): TaskRequiredServices
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getSharedResources(): MutableList<ResourceLock>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getShouldRunAfter(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getStandardOutputCapture(): StandardOutputCapture
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskActions(): MutableList<InputChangesAwareTaskAction>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskDependencies(): TaskDependencyInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskIdentity(): TaskIdentity<*>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTemporaryDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTemporaryDirFactory(): Factory<File>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hasProperty(propertyName: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hasTaskActions(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun mustRunAfter(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun notCompatibleWithConfigurationCache(reason: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onlyIf(onlyIfClosure: Closure<Any>)
open override fun onlyIf(spec: Spec<in Task>)
open override fun onlyIf(onlyIfReason: String, spec: Spec<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun prependParallelSafeAction(action: Action<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun property(propertyName: String): Any?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setActions(replacements: MutableList<Action<in Task>>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDependsOn(dependsOn: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDescription(description: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDidWork(didWork: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setFinalizedBy(finalizedByTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setGroup(group: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setMustRunAfter(mustRunAfterTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setOnlyIf(onlyIfClosure: Closure<Any>)
open override fun setOnlyIf(spec: Spec<in Task>)
open override fun setOnlyIf(onlyIfReason: String, spec: Spec<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setProperty(name: String, value: Any)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setShouldRunAfter(shouldRunAfterTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun shouldRunAfter(vararg paths: Any): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun usesService(service: Provider<out BuildService<*>>)
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/-laboratory-extension.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/-laboratory-extension.html new file mode 100644 index 000000000..e8a7c0e2f --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/-laboratory-extension.html @@ -0,0 +1,76 @@ + + + + + LaboratoryExtension + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

LaboratoryExtension

+
+
constructor()
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/dependency.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/dependency.html new file mode 100644 index 000000000..3f1afa0b7 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/dependency.html @@ -0,0 +1,76 @@ + + + + + dependency + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

dependency

+
+
fun dependency(project: Project)

Includes a project during feature flags contribution to featureFactory, featureSourcesFactory, sourcedStorage or optionFactory. Included project must have Laboratory plugin applied.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature-factory.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature-factory.html new file mode 100644 index 000000000..46cb7aad2 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature-factory.html @@ -0,0 +1,76 @@ + + + + + featureFactory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

featureFactory

+
+

Generates a new feature factory in this module. This should generally be used only by a top level module that needs to have information about all feature flags for QA purposes.


fun featureFactory(action: Action<FeatureFactoryInput>)

Generates and customizes a new feature factory in this module. This should generally be used only by a top level module that needs to have information about all feature flags for QA purposes.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature-source-factory.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature-source-factory.html new file mode 100644 index 000000000..e5a6f659d --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature-source-factory.html @@ -0,0 +1,76 @@ + + + + + featureSourceFactory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

featureSourceFactory

+
+

Generates a new feature sources factory in this module. This should generally be used only by a top level module that needs to have information about all feature flags for QA purposes.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature.html new file mode 100644 index 000000000..da66b2412 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/feature.html @@ -0,0 +1,76 @@ + + + + + feature + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

feature

+
+
fun feature(name: String, action: Action<FeatureFlagInput>)

Generates a new feature in this module.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/index.html new file mode 100644 index 000000000..0a2333f2b --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/index.html @@ -0,0 +1,213 @@ + + + + + LaboratoryExtension + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

LaboratoryExtension

+
abstract class LaboratoryExtension

An entry point for configuration of feature flags code generation.

+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor()
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets package name for any factories or feature flags defined in this extension. Package names can be individually overwritten in each generating block

+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun dependency(project: Project)

Includes a project during feature flags contribution to featureFactory, featureSourcesFactory, sourcedStorage or optionFactory. Included project must have Laboratory plugin applied.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun feature(name: String, action: Action<FeatureFlagInput>)

Generates a new feature in this module.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Generates a new feature factory in this module. This should generally be used only by a top level module that needs to have information about all feature flags for QA purposes.

fun featureFactory(action: Action<FeatureFactoryInput>)

Generates and customizes a new feature factory in this module. This should generally be used only by a top level module that needs to have information about all feature flags for QA purposes.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Generates a new feature sources factory in this module. This should generally be used only by a top level module that needs to have information about all feature flags for QA purposes.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun optionFactory(action: Action<OptionFactoryInput>)

Generates a new option factory in this module. All features that can be created by this factory must be visible to it during compilation.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Generates a new feature storage in this module. This should generally be used only by a top level module that needs to to have information about all sources. Feature storage generated by this method should be then used in the application.

Generates and customizes a new feature storage in this module. This should generally be used only by a top level module that needs to to have information about all sources. Feature storage generated by this method should be then used in the application.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/option-factory.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/option-factory.html new file mode 100644 index 000000000..312982b99 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/option-factory.html @@ -0,0 +1,76 @@ + + + + + optionFactory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

optionFactory

+
+
fun optionFactory(action: Action<OptionFactoryInput>)

Generates a new option factory in this module. All features that can be created by this factory must be visible to it during compilation.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/package-name.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/package-name.html new file mode 100644 index 000000000..e00fb09b9 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/package-name.html @@ -0,0 +1,76 @@ + + + + + packageName + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

packageName

+
+

Sets package name for any factories or feature flags defined in this extension. Package names can be individually overwritten in each generating block

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/sourced-storage.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/sourced-storage.html new file mode 100644 index 000000000..5b7d441c1 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-extension/sourced-storage.html @@ -0,0 +1,76 @@ + + + + + sourcedStorage + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

sourcedStorage

+
+

Generates a new feature storage in this module. This should generally be used only by a top level module that needs to to have information about all sources. Feature storage generated by this method should be then used in the application.


Generates and customizes a new feature storage in this module. This should generally be used only by a top level module that needs to to have information about all sources. Feature storage generated by this method should be then used in the application.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/-laboratory-plugin.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/-laboratory-plugin.html new file mode 100644 index 000000000..d40898fe0 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/-laboratory-plugin.html @@ -0,0 +1,76 @@ + + + + + LaboratoryPlugin + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

LaboratoryPlugin

+
+
constructor()
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/apply.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/apply.html new file mode 100644 index 000000000..49bd75127 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/apply.html @@ -0,0 +1,76 @@ + + + + + apply + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

apply

+
+
open override fun apply(project: Project)
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/index.html new file mode 100644 index 000000000..07cbbbdc7 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-laboratory-plugin/index.html @@ -0,0 +1,119 @@ + + + + + LaboratoryPlugin + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

LaboratoryPlugin

+
class LaboratoryPlugin : Plugin<Project>
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor()
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun apply(project: Project)
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/index.html new file mode 100644 index 000000000..bc4216e2d --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/index.html @@ -0,0 +1,115 @@ + + + + + OptionFactoryInput + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

OptionFactoryInput

+

Representation of a generated option factory that is aware of feature flags.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets whether the generated option factory should be public or internal.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets package name of the generated option factory. Overwrites any previously set values.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/is-public.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/is-public.html new file mode 100644 index 000000000..284315353 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/is-public.html @@ -0,0 +1,76 @@ + + + + + isPublic + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

isPublic

+
+

Sets whether the generated option factory should be public or internal.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/package-name.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/package-name.html new file mode 100644 index 000000000..85c52fa70 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-input/package-name.html @@ -0,0 +1,76 @@ + + + + + packageName + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

packageName

+
+

Sets package name of the generated option factory. Overwrites any previously set values.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/-option-factory-task.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/-option-factory-task.html new file mode 100644 index 000000000..597a39c20 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/-option-factory-task.html @@ -0,0 +1,76 @@ + + + + + OptionFactoryTask + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

OptionFactoryTask

+
+
constructor()
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/generate-sourced-feature-storage.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/generate-sourced-feature-storage.html new file mode 100644 index 000000000..94ae9422b --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/generate-sourced-feature-storage.html @@ -0,0 +1,76 @@ + + + + + generateSourcedFeatureStorage + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

generateSourcedFeatureStorage

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/index.html new file mode 100644 index 000000000..740d3b8d1 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-option-factory-task/index.html @@ -0,0 +1,1143 @@ + + + + + OptionFactoryTask + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

OptionFactoryTask

+
open class OptionFactoryTask : DefaultTask
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor()
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
@get:Internal
var enabled: Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val state: TaskStateInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val timeout: Property<Duration>
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun acceptServiceReferences(serviceReferences: MutableSet<ServiceReferenceSpec>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun appendParallelSafeAction(action: Action<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open operator override fun compareTo(other: Task): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun configure(closure: Closure<Any>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun dependsOn(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doFirst(action: Closure<Any>): Task
open override fun doFirst(action: Action<in Task>): Task
open override fun doFirst(actionName: String, action: Action<in Task>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doLast(action: Closure<Any>): Task
open override fun doLast(action: Action<in Task>): Task
open override fun doLast(actionName: String, action: Action<in Task>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doNotTrackState(reasonNotToTrackState: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun finalizedBy(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getActions(): MutableList<Action<in Task>>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getAnt(): AntBuilder
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getAsDynamicObject(): DynamicObject
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getConvention(): Convention
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDependsOn(): MutableSet<Any>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDescription(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDestroyables(): TaskDestroyables
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDidWork(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExtensions(): ExtensionContainer
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getFinalizedBy(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getGroup(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getIdentityPath(): Path
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getInputs(): TaskInputsInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getLifecycleDependencies(): TaskDependencyInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLocalState(): TaskLocalState
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLogger(): Logger
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLogging(): LoggingManager
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getMustRunAfter(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getName(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOnlyIf(): Spec<in TaskInternal>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOutputs(): TaskOutputsInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getPath(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getProject(): Project
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+ +
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getRequiredServices(): TaskRequiredServices
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getSharedResources(): MutableList<ResourceLock>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getShouldRunAfter(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getStandardOutputCapture(): StandardOutputCapture
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskActions(): MutableList<InputChangesAwareTaskAction>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskDependencies(): TaskDependencyInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskIdentity(): TaskIdentity<*>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTemporaryDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTemporaryDirFactory(): Factory<File>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hasProperty(propertyName: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hasTaskActions(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun mustRunAfter(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun notCompatibleWithConfigurationCache(reason: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onlyIf(onlyIfClosure: Closure<Any>)
open override fun onlyIf(spec: Spec<in Task>)
open override fun onlyIf(onlyIfReason: String, spec: Spec<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun prependParallelSafeAction(action: Action<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun property(propertyName: String): Any?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setActions(replacements: MutableList<Action<in Task>>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDependsOn(dependsOn: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDescription(description: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDidWork(didWork: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setFinalizedBy(finalizedByTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setGroup(group: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setMustRunAfter(mustRunAfterTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setOnlyIf(onlyIfClosure: Closure<Any>)
open override fun setOnlyIf(spec: Spec<in Task>)
open override fun setOnlyIf(onlyIfReason: String, spec: Spec<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setProperty(name: String, value: Any)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setShouldRunAfter(shouldRunAfterTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun shouldRunAfter(vararg paths: Any): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun usesService(service: Provider<out BuildService<*>>)
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/index.html new file mode 100644 index 000000000..523b1ff9b --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/index.html @@ -0,0 +1,115 @@ + + + + + SourcedFeatureStorageInput + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

SourcedFeatureStorageInput

+

Representation of a generated feature storage that is aware of feature flags sources.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets whether the generated feature storage should be public or internal.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets package name of the generated feature storage. Overwrites any previously set values.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/is-public.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/is-public.html new file mode 100644 index 000000000..b9469d4c1 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/is-public.html @@ -0,0 +1,76 @@ + + + + + isPublic + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

isPublic

+
+

Sets whether the generated feature storage should be public or internal.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/package-name.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/package-name.html new file mode 100644 index 000000000..541d6935a --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-input/package-name.html @@ -0,0 +1,76 @@ + + + + + packageName + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

packageName

+
+

Sets package name of the generated feature storage. Overwrites any previously set values.

+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/-sourced-feature-storage-task.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/-sourced-feature-storage-task.html new file mode 100644 index 000000000..9bf785eaa --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/-sourced-feature-storage-task.html @@ -0,0 +1,76 @@ + + + + + SourcedFeatureStorageTask + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

SourcedFeatureStorageTask

+
+
constructor()
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/generate-sourced-feature-storage.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/generate-sourced-feature-storage.html new file mode 100644 index 000000000..f9d4d2823 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/generate-sourced-feature-storage.html @@ -0,0 +1,76 @@ + + + + + generateSourcedFeatureStorage + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

generateSourcedFeatureStorage

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/index.html new file mode 100644 index 000000000..b26622b4c --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/-sourced-feature-storage-task/index.html @@ -0,0 +1,1143 @@ + + + + + SourcedFeatureStorageTask + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

SourcedFeatureStorageTask

+
open class SourcedFeatureStorageTask : DefaultTask
+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor()
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
@get:Internal
var enabled: Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val state: TaskStateInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val timeout: Property<Duration>
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun acceptServiceReferences(serviceReferences: MutableSet<ServiceReferenceSpec>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun appendParallelSafeAction(action: Action<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open operator override fun compareTo(other: Task): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun configure(closure: Closure<Any>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun dependsOn(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doFirst(action: Closure<Any>): Task
open override fun doFirst(action: Action<in Task>): Task
open override fun doFirst(actionName: String, action: Action<in Task>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doLast(action: Closure<Any>): Task
open override fun doLast(action: Action<in Task>): Task
open override fun doLast(actionName: String, action: Action<in Task>): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun doNotTrackState(reasonNotToTrackState: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun finalizedBy(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getActions(): MutableList<Action<in Task>>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getAnt(): AntBuilder
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getAsDynamicObject(): DynamicObject
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getConvention(): Convention
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDependsOn(): MutableSet<Any>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDescription(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDestroyables(): TaskDestroyables
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDidWork(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExtensions(): ExtensionContainer
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getFinalizedBy(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getGroup(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getIdentityPath(): Path
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getInputs(): TaskInputsInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@Internal
open override fun getLifecycleDependencies(): TaskDependencyInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLocalState(): TaskLocalState
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLogger(): Logger
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getLogging(): LoggingManager
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getMustRunAfter(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getName(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOnlyIf(): Spec<in TaskInternal>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOutputs(): TaskOutputsInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getPath(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getProject(): Project
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+ +
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getRequiredServices(): TaskRequiredServices
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getSharedResources(): MutableList<ResourceLock>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getShouldRunAfter(): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getStandardOutputCapture(): StandardOutputCapture
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskActions(): MutableList<InputChangesAwareTaskAction>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskDependencies(): TaskDependencyInternal
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTaskIdentity(): TaskIdentity<*>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTemporaryDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTemporaryDirFactory(): Factory<File>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hasProperty(propertyName: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun hasTaskActions(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun mustRunAfter(vararg paths: Any): Task
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun notCompatibleWithConfigurationCache(reason: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onlyIf(onlyIfClosure: Closure<Any>)
open override fun onlyIf(spec: Spec<in Task>)
open override fun onlyIf(onlyIfReason: String, spec: Spec<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun prependParallelSafeAction(action: Action<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun property(propertyName: String): Any?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setActions(replacements: MutableList<Action<in Task>>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDependsOn(dependsOn: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDescription(description: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setDidWork(didWork: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setFinalizedBy(finalizedByTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setGroup(group: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setMustRunAfter(mustRunAfterTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setOnlyIf(onlyIfClosure: Closure<Any>)
open override fun setOnlyIf(spec: Spec<in Task>)
open override fun setOnlyIf(onlyIfReason: String, spec: Spec<in Task>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setProperty(name: String, value: Any)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setShouldRunAfter(shouldRunAfterTasks: MutableIterable<*>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun shouldRunAfter(vararg paths: Any): TaskDependency
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun usesService(service: Provider<out BuildService<*>>)
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/index.html b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/index.html new file mode 100644 index 000000000..e29b9f8f0 --- /dev/null +++ b/api/laboratory/gradle-plugin/io.mehow.laboratory.gradle/index.html @@ -0,0 +1,264 @@ + + + + + io.mehow.laboratory.gradle + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Package-level declarations

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

An entry point for configuration of supervised feature flags code generation.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Possible levels of a deprecation. The level specifies how the deprecated element usages are reported in code.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Representation of a generated feature factory class.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open class FeatureFactoryTask : DefaultTask
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Representation of a generated feature flag. It must have at least one value and exactly one default value.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open class FeatureFlagsTask : DefaultTask
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract class LaboratoryExtension

An entry point for configuration of feature flags code generation.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
class LaboratoryPlugin : Plugin<Project>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Representation of a generated option factory that is aware of feature flags.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open class OptionFactoryTask : DefaultTask
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Representation of a generated feature storage that is aware of feature flags sources.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open class SourcedFeatureStorageTask : DefaultTask
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/gradle-plugin/navigation.html b/api/laboratory/gradle-plugin/navigation.html new file mode 100644 index 000000000..09bd18bdc --- /dev/null +++ b/api/laboratory/gradle-plugin/navigation.html @@ -0,0 +1,397 @@ +
+
+ + +
+
+
+ generator +
+
+ +
+ +
+ + + + + +
+ +
+
+ +
+
+ Public +
+
+
+
+ Internal +
+
+
+
+
+
+ + +
+
+
+ inspector +
+
+ +
+ +
+
+ Selector +
+
+
+
+ Regular +
+
+
+
+ Bottom +
+
+
+
+ +
+
+ Selector +
+
+
+
+ Show +
+
+
+ +
+
+
+ Hide +
+
+
+
+ +
+
+ Companion +
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+ +
+
+ +
+
+ Limited +
+
+
+
+ Unlimited +
+
+
+
+
+
+
+
+
+ runtime +
+
+ +
+ +
+ +
+ +
+
+ +
+
+ Companion +
+
+
+
+ +
+
+
+ Feature +
+
+
+ +
+
+ Companion +
+
+
+
+ +
+
+ Companion +
+
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+
+ +
+
+ Companion +
+
+
+
+
+ options +
+
+
+
+ source +
+
+ +
+
+
+ + +
+
diff --git a/api/laboratory/inspector/index.html b/api/laboratory/inspector/index.html new file mode 100644 index 000000000..f02b01dba --- /dev/null +++ b/api/laboratory/inspector/index.html @@ -0,0 +1,95 @@ + + + + + inspector + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

inspector

+
+

Packages

+
+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-bottom/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-bottom/index.html new file mode 100644 index 000000000..3fb978302 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-bottom/index.html @@ -0,0 +1,115 @@ + + + + + Bottom + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Bottom

+

Places deprecated feature flags at the bottom of a list.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-regular/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-regular/index.html new file mode 100644 index 000000000..e98f28f49 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-regular/index.html @@ -0,0 +1,115 @@ + + + + + Regular + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Regular

+

Does not place feature flags in any particular place of a list.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-selector/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-selector/index.html new file mode 100644 index 000000000..71a99e700 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-selector/index.html @@ -0,0 +1,100 @@ + + + + + Selector + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Selector

+
fun interface Selector

Determines alignment of features flags in a list based on their DeprecationLevel.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Selects DeprecationAlignment based on a feature flag deprecation level.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-selector/select.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-selector/select.html new file mode 100644 index 000000000..ec5543abf --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/-selector/select.html @@ -0,0 +1,76 @@ + + + + + select + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

select

+
+

Selects DeprecationAlignment based on a feature flag deprecation level.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/entries.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/entries.html new file mode 100644 index 000000000..0c6295bf0 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/entries.html @@ -0,0 +1,76 @@ + + + + + entries + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

entries

+
+

Returns a representation of an immutable list of all enum entries, in the order they're declared.

This method may be used to iterate over the enum entries.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/index.html new file mode 100644 index 000000000..2067dea46 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/index.html @@ -0,0 +1,217 @@ + + + + + DeprecationAlignment + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

DeprecationAlignment

+

Alignment of deprecated feature flags in a list.

+
+
+
+
+
+

Entries

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Does not place feature flags in any particular place of a list.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Places deprecated feature flags at the bottom of a list.

+
+
+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun interface Selector

Determines alignment of features flags in a list based on their DeprecationLevel.

+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns a representation of an immutable list of all enum entries, in the order they're declared.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns an array containing the constants of this enum type, in the order they're declared.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/value-of.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/value-of.html new file mode 100644 index 000000000..fbd1eae96 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/value-of.html @@ -0,0 +1,76 @@ + + + + + valueOf + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

valueOf

+
+

Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)

Throws

if this enum type has no constant with the specified name

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/values.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/values.html new file mode 100644 index 000000000..7d9a2bf2d --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-alignment/values.html @@ -0,0 +1,76 @@ + + + + + values + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

values

+
+

Returns an array containing the constants of this enum type, in the order they're declared.

This method may be used to iterate over the constants.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-hide/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-hide/index.html new file mode 100644 index 000000000..136a185a9 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-hide/index.html @@ -0,0 +1,115 @@ + + + + + Hide + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Hide

+

Removed feature flag from a list.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-selector/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-selector/index.html new file mode 100644 index 000000000..1a4e5e811 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-selector/index.html @@ -0,0 +1,100 @@ + + + + + Selector + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Selector

+
fun interface Selector

Determines UI representation of feature flags based on their DeprecationLevel.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Selects DeprecationPhenotype based on a feature flag deprecation level.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-selector/select.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-selector/select.html new file mode 100644 index 000000000..8b6cf16f6 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-selector/select.html @@ -0,0 +1,76 @@ + + + + + select + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

select

+
+

Selects DeprecationPhenotype based on a feature flag deprecation level.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-show/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-show/index.html new file mode 100644 index 000000000..2f1f430a2 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-show/index.html @@ -0,0 +1,115 @@ + + + + + Show + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Show

+

Does not differentiate deprecated feature flags from not deprecated ones.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-strikethrough/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-strikethrough/index.html new file mode 100644 index 000000000..46c6e6e25 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/-strikethrough/index.html @@ -0,0 +1,115 @@ + + + + + Strikethrough + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Strikethrough

+

Strikes feature flag name through.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/entries.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/entries.html new file mode 100644 index 000000000..6871fa87f --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/entries.html @@ -0,0 +1,76 @@ + + + + + entries + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

entries

+
+

Returns a representation of an immutable list of all enum entries, in the order they're declared.

This method may be used to iterate over the enum entries.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/index.html new file mode 100644 index 000000000..3590e5141 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/index.html @@ -0,0 +1,232 @@ + + + + + DeprecationPhenotype + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

DeprecationPhenotype

+

UI representation of deprecated feature flags.

+
+
+
+
+
+

Entries

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Does not differentiate deprecated feature flags from not deprecated ones.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Strikes feature flag name through.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Removed feature flag from a list.

+
+
+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun interface Selector

Determines UI representation of feature flags based on their DeprecationLevel.

+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns a representation of an immutable list of all enum entries, in the order they're declared.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Returns an array containing the constants of this enum type, in the order they're declared.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/value-of.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/value-of.html new file mode 100644 index 000000000..23aab12d0 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/value-of.html @@ -0,0 +1,76 @@ + + + + + valueOf + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

valueOf

+
+

Returns the enum constant of this type with the specified name. The string must match exactly an identifier used to declare an enum constant in this type. (Extraneous whitespace characters are not permitted.)

Throws

if this enum type has no constant with the specified name

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/values.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/values.html new file mode 100644 index 000000000..e134850f6 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-deprecation-phenotype/values.html @@ -0,0 +1,76 @@ + + + + + values + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

values

+
+

Returns an array containing the constants of this enum type, in the order they're declared.

This method may be used to iterate over the constants.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/configure.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/configure.html new file mode 100644 index 000000000..c838c52c1 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/configure.html @@ -0,0 +1,76 @@ + + + + + configure + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

configure

+
+
fun configure(laboratory: Laboratory, mainFactory: FeatureFactory, externalFactories: Map<String, FeatureFactory> = emptyMap())

Configures LaboratoryActivity with a default "Features" tab, where feature flags are taken from the mainFactory. Any additional tabs can be added in externalFactories.


Configures LaboratoryActivity with an input configuration.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/index.html new file mode 100644 index 000000000..37b779478 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/index.html @@ -0,0 +1,115 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Configures LaboratoryActivity with an input configuration.

fun configure(laboratory: Laboratory, mainFactory: FeatureFactory, externalFactories: Map<String, FeatureFactory> = emptyMap())

Configures LaboratoryActivity with a default "Features" tab, where feature flags are taken from the mainFactory. Any additional tabs can be added in externalFactories.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun start(context: Context)

Opens QA module. Configure needs to be called before you interact with LaboratoryActivity.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/start.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/start.html new file mode 100644 index 000000000..465f47c1b --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-companion/start.html @@ -0,0 +1,76 @@ + + + + + start + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

start

+
+
fun start(context: Context)

Opens QA module. Configure needs to be called before you interact with LaboratoryActivity.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/build.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/build.html new file mode 100644 index 000000000..644b4aa6e --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/build.html @@ -0,0 +1,76 @@ + + + + + build + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

build

+
+

Creates a new Configuration with provided parameters.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/deprecation-alignment-selector.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/deprecation-alignment-selector.html new file mode 100644 index 000000000..24d3fc7b8 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/deprecation-alignment-selector.html @@ -0,0 +1,76 @@ + + + + + deprecationAlignmentSelector + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

deprecationAlignmentSelector

+
+

Sets how deprecated feature flags will be sorted in a displayed group.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/deprecation-phenotype-selector.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/deprecation-phenotype-selector.html new file mode 100644 index 000000000..639c9928f --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/deprecation-phenotype-selector.html @@ -0,0 +1,76 @@ + + + + + deprecationPhenotypeSelector + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

deprecationPhenotypeSelector

+
+

Sets how deprecated feature flags will be displayed to the user.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/index.html new file mode 100644 index 000000000..16efbed2d --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/index.html @@ -0,0 +1,145 @@ + + + + + BuildingStep + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

BuildingStep

+
interface BuildingStep

The final step of a fluent builder that can set optional parameters.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Creates a new Configuration with provided parameters.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets how deprecated feature flags will be sorted in a displayed group.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets how deprecated feature flags will be displayed to the user.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets how many offscreen feature sections will be kept in memory.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/offscreen-section-behavior.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/offscreen-section-behavior.html new file mode 100644 index 000000000..b9cb0bc32 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-building-step/offscreen-section-behavior.html @@ -0,0 +1,76 @@ + + + + + offscreenSectionBehavior + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

offscreenSectionBehavior

+
+

Sets how many offscreen feature sections will be kept in memory.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/builder.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/builder.html new file mode 100644 index 000000000..ba8e65440 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/builder.html @@ -0,0 +1,76 @@ + + + + + builder + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

builder

+
+

Creates a builder that allows to customize Configuration.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/create.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/create.html new file mode 100644 index 000000000..125e04656 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/create.html @@ -0,0 +1,76 @@ + + + + + create + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

create

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/index.html new file mode 100644 index 000000000..5fbfc50df --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-companion/index.html @@ -0,0 +1,115 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Creates a builder that allows to customize Configuration.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-feature-factories-step/feature-factories.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-feature-factories-step/feature-factories.html new file mode 100644 index 000000000..d6c23698d --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-feature-factories-step/feature-factories.html @@ -0,0 +1,76 @@ + + + + + featureFactories + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

featureFactories

+
+

Sets feature factories. Each entry in this map will result in a separate tab in the QA module. Key is used as a tab name, and each tab displays all feature flags provided by FeatureFactory from value.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-feature-factories-step/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-feature-factories-step/index.html new file mode 100644 index 000000000..902143e26 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-feature-factories-step/index.html @@ -0,0 +1,100 @@ + + + + + FeatureFactoriesStep + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFactoriesStep

+

A step of a fluent builder that requires feature factories to proceed.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets feature factories. Each entry in this map will result in a separate tab in the QA module. Key is used as a tab name, and each tab displays all feature flags provided by FeatureFactory from value.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-laboratory-step/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-laboratory-step/index.html new file mode 100644 index 000000000..755696ce2 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-laboratory-step/index.html @@ -0,0 +1,100 @@ + + + + + LaboratoryStep + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

LaboratoryStep

+
interface LaboratoryStep

A step of a fluent builder that requires Laboratory to proceed.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets laboratory. Its instance should share FeatureStorage instance with your application.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-laboratory-step/laboratory.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-laboratory-step/laboratory.html new file mode 100644 index 000000000..f7e51d6fb --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-laboratory-step/laboratory.html @@ -0,0 +1,76 @@ + + + + + laboratory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

laboratory

+
+

Sets laboratory. Its instance should share FeatureStorage instance with your application.

+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/-limited.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/-limited.html new file mode 100644 index 000000000..dcba68b11 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/-limited.html @@ -0,0 +1,76 @@ + + + + + Limited + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Limited

+
+
constructor(limit: Int)
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/index.html new file mode 100644 index 000000000..40c2faef7 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/index.html @@ -0,0 +1,119 @@ + + + + + Limited + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Limited

+

Number of sections is limited.

+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor(limit: Int)
+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
val limit: Int
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/limit.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/limit.html new file mode 100644 index 000000000..a1c1638cf --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-limited/limit.html @@ -0,0 +1,76 @@ + + + + + limit + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

limit

+
+
val limit: Int
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-unlimited/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-unlimited/index.html new file mode 100644 index 000000000..27852fe67 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/-unlimited/index.html @@ -0,0 +1,80 @@ + + + + + Unlimited + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Unlimited

+

All sections are always kept in memory. This makes navigation smoother but might result in slower load time of the inspector.

+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/index.html new file mode 100644 index 000000000..fd1c4c0b5 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/-offscreen-sections-behavior/index.html @@ -0,0 +1,115 @@ + + + + + OffscreenSectionsBehavior + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

OffscreenSectionsBehavior

+

Behavior of feature sections that are not currently displayed.

Inheritors

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Number of sections is limited.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

All sections are always kept in memory. This makes navigation smoother but might result in slower load time of the inspector.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/index.html new file mode 100644 index 000000000..4f0535275 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-configuration/index.html @@ -0,0 +1,160 @@ + + + + + Configuration + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Configuration

+

Configuration data for QA module.

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
interface BuildingStep

The final step of a fluent builder that can set optional parameters.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

A step of a fluent builder that requires feature factories to proceed.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
interface LaboratoryStep

A step of a fluent builder that requires Laboratory to proceed.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Behavior of feature sections that are not currently displayed.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-laboratory-activity.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-laboratory-activity.html new file mode 100644 index 000000000..49870c31d --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/-laboratory-activity.html @@ -0,0 +1,76 @@ + + + + + LaboratoryActivity + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

LaboratoryActivity

+
+
constructor()
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/index.html new file mode 100644 index 000000000..fb9c5eeb9 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/-laboratory-activity/index.html @@ -0,0 +1,6262 @@ + + + + + LaboratoryActivity + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

LaboratoryActivity

+

Entry point for QA module that allows to interact with feature flags.

+
+
+
+
+
+

Constructors

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
constructor()
+
+
+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Configuration data for QA module.

+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@get:NonNull
open override val lifecycle: Lifecycle
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
@get:NonNull
open override val viewModelStore: ViewModelStore
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun addContentView(p0: View, p1: ViewGroup.LayoutParams)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
override fun addOnNewIntentListener(@NonNull listener: Consumer<Intent>)
+
+
+
+
+ +
+ +
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
override fun addOnTrimMemoryListener(@NonNull listener: Consumer<Int>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun bindService(p0: Intent, p1: ServiceConnection, p2: Int): Boolean
open override fun bindService(p0: Intent, p1: Int, p2: Executor, p3: ServiceConnection): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkCallingOrSelfPermission(p0: String): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkCallingOrSelfUriPermission(p0: Uri, p1: Int): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkCallingPermission(p0: String): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkCallingUriPermission(p0: Uri, p1: Int): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkCallingUriPermissions(p0: MutableList<Uri>, p1: Int): IntArray
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkPermission(p0: String, p1: Int, p2: Int): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkSelfPermission(p0: String): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkUriPermission(p0: Uri, p1: Int, p2: Int, p3: Int): Int
open override fun checkUriPermission(p0: Uri?, p1: String?, p2: String?, p3: Int, p4: Int, p5: Int): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun checkUriPermissions(p0: MutableList<Uri>, p1: Int, p2: Int, p3: Int): IntArray
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun clearWallpaper()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun closeContextMenu()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun closeOptionsMenu()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun createAttributionContext(p0: String?): Context
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun createContext(p0: ContextParams): Context
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun createContextForSplit(p0: String): Context
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun createDeviceContext(p0: Int): Context
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun createDisplayContext(p0: Display): Context
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun createPackageContext(p0: String, p1: Int): Context
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun createWindowContext(p0: Int, p1: Bundle?): Context
open override fun createWindowContext(p0: Display, p1: Int, p2: Bundle?): Context
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun databaseList(): Array<String>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun deleteDatabase(p0: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun deleteFile(p0: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun deleteSharedPreferences(p0: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun dispatchKeyEvent(event: KeyEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun dispatchKeyShortcutEvent(event: KeyEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun dispatchTouchEvent(p0: MotionEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun dump(@NonNull p0: String, @Nullable p1: FileDescriptor?, @NonNull p2: PrintWriter, @Nullable p3: Array<String>?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun enforceCallingOrSelfPermission(p0: String, p1: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun enforceCallingOrSelfUriPermission(p0: Uri, p1: Int, p2: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun enforceCallingPermission(p0: String, p1: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun enforceCallingUriPermission(p0: Uri, p1: Int, p2: String)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun enforcePermission(p0: String, p1: Int, p2: Int, p3: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun enforceUriPermission(p0: Uri, p1: Int, p2: Int, p3: Int, p4: String)
open override fun enforceUriPermission(p0: Uri?, p1: String?, p2: String?, p3: Int, p4: Int, p5: Int, p6: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun fileList(): Array<String>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun <T : View> findViewById(@IdRes p0: Int): T
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun finish()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun finishActivity(p0: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun finishAffinity()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun getActionBar(): ActionBar?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getApplicationContext(): Context
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getApplicationInfo(): ApplicationInfo
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getAssets(): AssetManager
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getAttributionTag(): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getCacheDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getClassLoader(): ClassLoader
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getCodeCacheDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun getColor(p0: Int): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getContentResolver(): ContentResolver
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun getCurrentFocus(): View?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDatabasePath(p0: String): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDataDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDeviceId(): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDir(p0: String, p1: Int): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getDisplay(): Display?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExternalCacheDir(): File?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExternalCacheDirs(): Array<File>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExternalFilesDir(p0: String?): File?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExternalFilesDirs(p0: String): Array<File>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getExternalMediaDirs(): Array<File>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun <T : ComponentActivity.ExtraData> getExtraData(extraDataClass: Class<T>): T?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getFilesDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getFileStreamPath(p0: String): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun getIntent(): Intent
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getMainExecutor(): Executor
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getMainLooper(): Looper
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getMenuInflater(): MenuInflater
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getNoBackupFilesDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getObbDir(): File
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getObbDirs(): Array<File>
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getOpPackageName(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getPackageCodePath(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getPackageManager(): PackageManager
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getPackageName(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getPackageResourcePath(): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getParams(): ContextParams?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun getReferrer(): Uri?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getResources(): Resources
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getSharedPreferences(p0: String, p1: Int): SharedPreferences
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun getString(p0: Int): String
fun getString(p0: Int, vararg p1: Any): String
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getSystemService(p0: String): Any
fun <T : Any> getSystemService(p0: Class<T>): T
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getSystemServiceName(p0: Class<*>): String?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun getTaskId(): Int
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getTheme(): Resources.Theme
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun getWallpaper(): Drawable
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun getWindow(): Window
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun grantUriPermission(p0: String, p1: Uri, p2: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun invalidateMenu()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun invalidateOptionsMenu()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun isDestroyed(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun isDeviceProtectedStorage(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun isFinishing(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun isImmersive(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun isRestricted(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun isTaskRoot(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun isUiContext(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun managedQuery(p0: Uri, p1: Array<String>, p2: String, p3: Array<String>, p4: String): Cursor
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun moveDatabaseFrom(p0: Context, p1: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun moveSharedPreferencesFrom(p0: Context, p1: String): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun navigateUpTo(p0: Intent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ + + +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onActionModeFinished(p0: ActionMode)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onActionModeStarted(p0: ActionMode)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun onActivityReenter(p0: Int, p1: Intent)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onAttachedToWindow()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onBackPressed()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onContentChanged()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun onCreate(p0: Bundle?, p1: PersistableBundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onCreatePanelMenu(p0: Int, @NonNull p1: Menu): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onCreatePanelView(p0: Int): View?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onCreateView(@NonNull p0: String, @NonNull p1: Context, @NonNull p2: AttributeSet): View?
open override fun onCreateView(@Nullable p0: View?, @NonNull p1: String, @NonNull p2: Context, @NonNull p3: AttributeSet): View?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onDetachedFromWindow()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onKeyDown(p0: Int, p1: KeyEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onKeyLongPress(p0: Int, p1: KeyEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onKeyMultiple(p0: Int, p1: Int, p2: KeyEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun onKeyShortcut(p0: Int, p1: KeyEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onKeyUp(p0: Int, p1: KeyEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onLowMemory()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
override fun onMenuItemSelected(p0: Int, @NonNull p1: MenuItem): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onMenuOpened(p0: Int, p1: Menu): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun onNavigateUp(): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onPanelClosed(p0: Int, @NonNull p1: Menu)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onPreparePanel(p0: Int, @Nullable p1: View?, @NonNull p2: Menu): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onSearchRequested(): Boolean
open override fun onSearchRequested(p0: SearchEvent?): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onStateNotSaved()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onTrimMemory(p0: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun onWindowFocusChanged(p0: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun openContextMenu(p0: View)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun openFileInput(p0: String): FileInputStream
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun openFileOutput(p0: String, p1: Int): FileOutputStream
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun openOptionsMenu()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun overrideActivityTransition(p0: Int, p1: Int, p2: Int)
open fun overrideActivityTransition(p0: Int, p1: Int, p2: Int, p3: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun overridePendingTransition(p0: Int, p1: Int)
open fun overridePendingTransition(p0: Int, p1: Int, p2: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun peekAvailableContext(): Context?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun peekWallpaper(): Drawable
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun recreate()
+
+
+
+
+ + + +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ + + +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun registerReceiver(p0: BroadcastReceiver?, p1: IntentFilter): Intent?
open override fun registerReceiver(p0: BroadcastReceiver?, p1: IntentFilter, p2: Int): Intent?
open override fun registerReceiver(p0: BroadcastReceiver?, p1: IntentFilter, p2: String?, p3: Handler?): Intent?
open override fun registerReceiver(p0: BroadcastReceiver?, p1: IntentFilter, p2: String?, p3: Handler?, p4: Int): Intent?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun removeDialog(p0: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun removeMenuProvider(@NonNull p0: MenuProvider)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ + + +
+
+
+ + +
Link copied to clipboard
+
+
+
+
override fun removeOnTrimMemoryListener(@NonNull listener: Consumer<Int>)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun removeStickyBroadcast(p0: Intent)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun removeStickyBroadcastAsUser(p0: Intent, p1: UserHandle)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun reportFullyDrawn()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun <T : View> requireViewById(p0: Int): T & Any
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun revokeUriPermission(p0: Uri, p1: Int)
open override fun revokeUriPermission(p0: String, p1: Uri, p2: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun sendBroadcast(p0: Intent)
open override fun sendBroadcast(p0: Intent, p1: String?)
open override fun sendBroadcast(p0: Intent, p1: String?, p2: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun sendBroadcastAsUser(p0: Intent, p1: UserHandle)
open override fun sendBroadcastAsUser(p0: Intent, p1: UserHandle, p2: String?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun sendOrderedBroadcast(p0: Intent, p1: String?)
open override fun sendOrderedBroadcast(p0: Intent, p1: String?, p2: Bundle?)
open override fun sendOrderedBroadcast(p0: Intent, p1: String?, p2: BroadcastReceiver?, p3: Handler?, p4: Int, p5: String?, p6: Bundle?)
open override fun sendOrderedBroadcast(p0: Intent, p1: String?, p2: Bundle?, p3: BroadcastReceiver?, p4: Handler?, p5: Int, p6: String?, p7: Bundle?)
open override fun sendOrderedBroadcast(p0: Intent, p1: String?, p2: String?, p3: BroadcastReceiver?, p4: Handler?, p5: Int, p6: String?, p7: Bundle?)
open fun sendOrderedBroadcast(p0: Intent, p1: Int, p2: String?, p3: String?, p4: BroadcastReceiver?, p5: Handler?, p6: String?, p7: Bundle?, p8: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun sendOrderedBroadcastAsUser(p0: Intent, p1: UserHandle, p2: String?, p3: BroadcastReceiver?, p4: Handler?, p5: Int, p6: String?, p7: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun sendStickyBroadcast(p0: Intent)
open override fun sendStickyBroadcast(p0: Intent, p1: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun sendStickyBroadcastAsUser(p0: Intent, p1: UserHandle)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun sendStickyOrderedBroadcast(p0: Intent, p1: BroadcastReceiver?, p2: Handler?, p3: Int, p4: String?, p5: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun sendStickyOrderedBroadcastAsUser(p0: Intent, p1: UserHandle, p2: BroadcastReceiver?, p3: Handler?, p4: Int, p5: String?, p6: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setActionBar(p0: Toolbar?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setContentView(p0: View)
open override fun setContentView(@LayoutRes p0: Int)
open override fun setContentView(p0: View, p1: ViewGroup.LayoutParams)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ + + + + +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setImmersive(p0: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setIntent(p0: Intent)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setLocusContext(p0: LocusId?, p1: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun setProgress(p0: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun setResult(p0: Int)
fun setResult(p0: Int, p1: Intent)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setSupportProgress(p0: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setTheme(p0: Resources.Theme?)
open override fun setTheme(@StyleRes p0: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setTitle(p0: CharSequence)
open fun setTitle(p0: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setTitleColor(p0: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setTurnScreenOn(p0: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun setVisible(p0: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun setWallpaper(p0: Bitmap)
open override fun setWallpaper(p0: InputStream)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun showAssist(p0: Bundle): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun showDialog(p0: Int)
fun showDialog(p0: Int, p1: Bundle): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun startActivities(p0: Array<Intent>)
open override fun startActivities(p0: Array<Intent>, p1: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun startActivity(p0: Intent)
open override fun startActivity(p0: Intent, p1: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun startActivityForResult(@NonNull p0: Intent, p1: Int)
open override fun startActivityForResult(@NonNull p0: Intent, p1: Int, @Nullable p2: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun startActivityFromChild(p0: Activity, p1: Intent, p2: Int)
open fun startActivityFromChild(p0: Activity, p1: Intent, p2: Int, p3: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun startInstrumentation(p0: ComponentName, p1: String?, p2: Bundle?): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun startIntentSender(p0: IntentSender, p1: Intent?, p2: Int, p3: Int, p4: Int)
open override fun startIntentSender(p0: IntentSender, p1: Intent?, p2: Int, p3: Int, p4: Int, p5: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun startIntentSenderForResult(@NonNull p0: IntentSender, p1: Int, @Nullable p2: Intent?, p3: Int, p4: Int, p5: Int)
open override fun startIntentSenderForResult(@NonNull p0: IntentSender, p1: Int, @Nullable p2: Intent?, p3: Int, p4: Int, p5: Int, @Nullable p6: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun startIntentSenderFromChild(p0: Activity, p1: IntentSender, p2: Int, p3: Intent, p4: Int, p5: Int, p6: Int)
open fun startIntentSenderFromChild(p0: Activity, p1: IntentSender, p2: Int, p3: Intent, p4: Int, p5: Int, p6: Int, p7: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun startIntentSenderFromFragment(@NonNull p0: Fragment, @NonNull p1: IntentSender, p2: Int, @Nullable p3: Intent?, p4: Int, p5: Int, p6: Int, @Nullable p7: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun startLockTask()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun startSearch(p0: String?, p1: Boolean, p2: Bundle?, p3: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun startService(p0: Intent): ComponentName?
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun stopLockTask()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun stopService(p0: Intent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun superDispatchKeyEvent(event: KeyEvent): Boolean
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun supportInvalidateOptionsMenu()
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun takeKeyEvents(p0: Boolean)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open fun triggerSearch(p0: String, p1: Bundle?)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun unbindService(p0: ServiceConnection)
+
+
+
+
+ + + +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun unregisterReceiver(p0: BroadcastReceiver)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+ +
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open override fun updateServiceGroup(p0: ServiceConnection, p1: Int, p2: Int)
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/io.mehow.laboratory.inspector/index.html b/api/laboratory/inspector/io.mehow.laboratory.inspector/index.html new file mode 100644 index 000000000..2039e20a6 --- /dev/null +++ b/api/laboratory/inspector/io.mehow.laboratory.inspector/index.html @@ -0,0 +1,129 @@ + + + + + io.mehow.laboratory.inspector + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Package-level declarations

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Alignment of deprecated feature flags in a list.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

UI representation of deprecated feature flags.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Entry point for QA module that allows to interact with feature flags.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/inspector/navigation.html b/api/laboratory/inspector/navigation.html new file mode 100644 index 000000000..09bd18bdc --- /dev/null +++ b/api/laboratory/inspector/navigation.html @@ -0,0 +1,397 @@ +
+
+ + +
+
+
+ generator +
+
+ +
+ +
+ + + + + +
+ +
+
+ +
+
+ Public +
+
+
+
+ Internal +
+
+
+
+
+
+ + +
+
+
+ inspector +
+
+ +
+ +
+
+ Selector +
+
+
+
+ Regular +
+
+
+
+ Bottom +
+
+
+
+ +
+
+ Selector +
+
+
+
+ Show +
+
+
+ +
+
+
+ Hide +
+
+
+
+ +
+
+ Companion +
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+ +
+
+ +
+
+ Limited +
+
+
+
+ Unlimited +
+
+
+
+
+
+
+
+
+ runtime +
+
+ +
+ +
+ +
+ +
+
+ +
+
+ Companion +
+
+
+
+ +
+
+
+ Feature +
+
+
+ +
+
+ Companion +
+
+
+
+ +
+
+ Companion +
+
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+
+ +
+
+ Companion +
+
+
+
+
+ options +
+
+
+
+ source +
+
+ +
+
+
+ + +
+
diff --git a/api/laboratory/runtime/index.html b/api/laboratory/runtime/index.html new file mode 100644 index 000000000..fe46dc8bc --- /dev/null +++ b/api/laboratory/runtime/index.html @@ -0,0 +1,95 @@ + + + + + runtime + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

runtime

+
+

Packages

+
+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-blocking-io-call/index.html b/api/laboratory/runtime/io.mehow.laboratory/-blocking-io-call/index.html new file mode 100644 index 000000000..7be085c9c --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-blocking-io-call/index.html @@ -0,0 +1,80 @@ + + + + + BlockingIoCall + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

BlockingIoCall

+

Opt-in annotation denoting that the used function can potentially block a calling thread with I/O operations.

+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/clear.html b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/clear.html new file mode 100644 index 000000000..97b8a417d --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/clear.html @@ -0,0 +1,76 @@ + + + + + clear + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

clear

+
+
fun clear(): Boolean

Removes all stored feature flag options. Warning – this call can block the calling thread.

Return

true if the option was set successfully, false otherwise.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/experiment-is.html b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/experiment-is.html new file mode 100644 index 000000000..880ba5d90 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/experiment-is.html @@ -0,0 +1,76 @@ + + + + + experimentIs + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

experimentIs

+
+
fun <T : Feature<out T>> experimentIs(option: T): Boolean

Checks if a Feature is set to the input option. Warning – this call can block the calling thread.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/experiment.html b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/experiment.html new file mode 100644 index 000000000..cb44fcf11 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/experiment.html @@ -0,0 +1,76 @@ + + + + + experiment + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

experiment

+
+
inline fun <T : Feature<out T>> experiment(): T
fun <T : Feature<out T>> experiment(feature: Class<out T>): T

Returns the current option of the input Feature. Warning – this call can block the calling thread.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/index.html b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/index.html new file mode 100644 index 000000000..a57f885a2 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/index.html @@ -0,0 +1,160 @@ + + + + + BlockingLaboratory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

BlockingLaboratory

+

A blocking equivalent of Laboratory.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun clear(): Boolean

Removes all stored feature flag options. Warning – this call can block the calling thread.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
inline fun <T : Feature<out T>> experiment(): T
fun <T : Feature<out T>> experiment(feature: Class<out T>): T

Returns the current option of the input Feature. Warning – this call can block the calling thread.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun <T : Feature<out T>> experimentIs(option: T): Boolean

Checks if a Feature is set to the input option. Warning – this call can block the calling thread.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun <T : Feature<*>> setOption(option: T): Boolean

Sets a Feature to have the input option. Warning – this call can block the calling thread.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun <T : Feature<*>> setOptions(vararg options: T): Boolean
fun <T : Feature<*>> setOptions(options: Collection<T>): Boolean

Sets Features to have the input options. If options contains more than one option for the same feature flag, the last one should be applied. Warning – this call can block the calling thread.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/set-option.html b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/set-option.html new file mode 100644 index 000000000..14e35078a --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/set-option.html @@ -0,0 +1,76 @@ + + + + + setOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

setOption

+
+
fun <T : Feature<*>> setOption(option: T): Boolean

Sets a Feature to have the input option. Warning – this call can block the calling thread.

Return

true if the option was set successfully, false otherwise.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/set-options.html b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/set-options.html new file mode 100644 index 000000000..3101aa0ed --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-blocking-laboratory/set-options.html @@ -0,0 +1,76 @@ + + + + + setOptions + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

setOptions

+
+
fun <T : Feature<*>> setOptions(vararg options: T): Boolean
fun <T : Feature<*>> setOptions(options: Collection<T>): Boolean

Sets Features to have the input options. If options contains more than one option for the same feature flag, the last one should be applied. Warning – this call can block the calling thread.

Return

true if the option was set successfully, false otherwise.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/-companion/index.html b/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/-companion/index.html new file mode 100644 index 000000000..b24cba9ee --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/-companion/index.html @@ -0,0 +1,80 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/create.html b/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/create.html new file mode 100644 index 000000000..e9a363603 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/create.html @@ -0,0 +1,76 @@ + + + + + create + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

create

+
+
abstract fun <T : Feature<out T>> create(feature: T): Feature<*>?

Returns override for a default option or null if there should be no override.

Warning – returned default option must be of the same type as feature. Otherwise it will throw an exception.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/index.html b/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/index.html new file mode 100644 index 000000000..bfcdc09ab --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/index.html @@ -0,0 +1,134 @@ + + + + + DefaultOptionFactory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

DefaultOptionFactory

+

Factory that allows to override default feature flag option used by Laboratory.

See also

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract fun <T : Feature<out T>> create(feature: T): Feature<*>?

Returns override for a default option or null if there should be no override.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open operator fun plus(factory: DefaultOptionFactory): DefaultOptionFactory

Creates a new DefaultOptionFactory that will first look for a default value in this factory and then in the other factory.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/plus.html b/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/plus.html new file mode 100644 index 000000000..f6152d4b1 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-default-option-factory/plus.html @@ -0,0 +1,76 @@ + + + + + plus + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

plus

+
+
open operator fun plus(factory: DefaultOptionFactory): DefaultOptionFactory

Creates a new DefaultOptionFactory that will first look for a default value in this factory and then in the other factory.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/-companion/index.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/-companion/index.html new file mode 100644 index 000000000..b2fb17f50 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/-companion/index.html @@ -0,0 +1,80 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/create.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/create.html new file mode 100644 index 000000000..0c9b70711 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/create.html @@ -0,0 +1,76 @@ + + + + + create + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

create

+
+
abstract fun create(): Set<Class<out Feature<*>>>

Returns set of all available feature flags.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/index.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/index.html new file mode 100644 index 000000000..927707930 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/index.html @@ -0,0 +1,134 @@ + + + + + FeatureFactory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureFactory

+
interface FeatureFactory

Factory that should provide all available feature flags. There shouldn't be any need to use it in a regular application code. Its main purpose is for QA inspection module.

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract fun create(): Set<Class<out Feature<*>>>

Returns set of all available feature flags.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open operator fun plus(factory: FeatureFactory): FeatureFactory

Creates a new FeatureFactory that will return a combined set of this factory and the other factory.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/plus.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/plus.html new file mode 100644 index 000000000..9c7cd946e --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-factory/plus.html @@ -0,0 +1,76 @@ + + + + + plus + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

plus

+
+
open operator fun plus(factory: FeatureFactory): FeatureFactory

Creates a new FeatureFactory that will return a combined set of this factory and the other factory.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/in-memory.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/in-memory.html new file mode 100644 index 000000000..9cad52171 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/in-memory.html @@ -0,0 +1,76 @@ + + + + + inMemory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

inMemory

+
+

Creates FeatureStorage that saves feature flags in app's memory.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/index.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/index.html new file mode 100644 index 000000000..c5a2569bc --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/index.html @@ -0,0 +1,115 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Creates FeatureStorage that saves feature flags in app's memory.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
fun sourced(localSource: FeatureStorage, remoteSources: Map<String, FeatureStorage>): FeatureStorage

Creates FeatureStorage that is aware of different sources for feature flag values. For example, the following code will be able to produce values for local, Firebase and Aws sources, and will automatically switch reads based on currently selected sources for feature flags.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/sourced.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/sourced.html new file mode 100644 index 000000000..a4e25ba7d --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/-companion/sourced.html @@ -0,0 +1,76 @@ + + + + + sourced + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

sourced

+
+
fun sourced(localSource: FeatureStorage, remoteSources: Map<String, FeatureStorage>): FeatureStorage

Creates FeatureStorage that is aware of different sources for feature flag values. For example, the following code will be able to produce values for local, Firebase and Aws sources, and will automatically switch reads based on currently selected sources for feature flags.

FeatureStorage.sourced(
localSource = FeatureStorage.inMemory(),
remoteSources = mapOf(
"Firebase" to FeatureStorage.inMemory(),
"Aws" to FeatureStorage.inMemory(),
),
)

In order to connect remote sources with sources of feature flag sources they need to match their names. If you use Gradle plugin, you should not use this method as a more specialised factory method will be generated for you, that will make sure that all remote sources are configured.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/clear.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/clear.html new file mode 100644 index 000000000..aee8dd204 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/clear.html @@ -0,0 +1,76 @@ + + + + + clear + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

clear

+
+
abstract suspend fun clear(): Boolean

Removes all stored feature flag options.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/get-feature-name.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/get-feature-name.html new file mode 100644 index 000000000..fa2d7d69e --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/get-feature-name.html @@ -0,0 +1,76 @@ + + + + + getFeatureName + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

getFeatureName

+
+
abstract suspend fun getFeatureName(feature: Class<out Feature<*>>): String?

Returns the current value of a selected feature flag name. If feature flag is not available, it should return null.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/index.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/index.html new file mode 100644 index 000000000..357613f3a --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/index.html @@ -0,0 +1,179 @@ + + + + + FeatureStorage + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureStorage

+
interface FeatureStorage

Persistence mechanism for feature flags.

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract suspend fun clear(): Boolean

Removes all stored feature flag options.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract suspend fun getFeatureName(feature: Class<out Feature<*>>): String?

Returns the current value of a selected feature flag name. If feature flag is not available, it should return null.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract fun observeFeatureName(feature: Class<out Feature<*>>): Flow<String?>

Observes changes to currently selected feature flag name. If feature flag is not available, it should emit null.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open suspend fun setOption(option: Feature<*>): Boolean

Sets a Feature to have the input option.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract suspend fun setOptions(vararg options: Feature<*>): Boolean
open suspend fun setOptions(options: Collection<Feature<*>>): Boolean

Sets Features to have the input options. If options contains more than one value for the same feature flag, the last one should be applied.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/observe-feature-name.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/observe-feature-name.html new file mode 100644 index 000000000..599e9f688 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/observe-feature-name.html @@ -0,0 +1,76 @@ + + + + + observeFeatureName + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

observeFeatureName

+
+
abstract fun observeFeatureName(feature: Class<out Feature<*>>): Flow<String?>

Observes changes to currently selected feature flag name. If feature flag is not available, it should emit null.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/set-option.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/set-option.html new file mode 100644 index 000000000..143c1dfa1 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/set-option.html @@ -0,0 +1,76 @@ + + + + + setOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

setOption

+
+
open suspend fun setOption(option: Feature<*>): Boolean

Sets a Feature to have the input option.

Return

true if the value was set successfully, false otherwise.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/set-options.html b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/set-options.html new file mode 100644 index 000000000..b06e9cba1 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature-storage/set-options.html @@ -0,0 +1,76 @@ + + + + + setOptions + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

setOptions

+
+
abstract suspend fun setOptions(vararg options: Feature<*>): Boolean
open suspend fun setOptions(options: Collection<Feature<*>>): Boolean

Sets Features to have the input options. If options contains more than one value for the same feature flag, the last one should be applied.

Return

true if the value was set successfully, false otherwise.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature/default-option.html b/api/laboratory/runtime/io.mehow.laboratory/-feature/default-option.html new file mode 100644 index 000000000..a29672781 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature/default-option.html @@ -0,0 +1,76 @@ + + + + + defaultOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

defaultOption

+
+
abstract val defaultOption: T

Determines which option is a default for this feature flag.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature/description.html b/api/laboratory/runtime/io.mehow.laboratory/-feature/description.html new file mode 100644 index 000000000..b00c1b220 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature/description.html @@ -0,0 +1,76 @@ + + + + + description + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

description

+
+

Description of the feature flag that can be used for more contextual information. Markdown formatted links will be picked up by the QA module and represented as hyperlinks.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature/index.html b/api/laboratory/runtime/io.mehow.laboratory/-feature/index.html new file mode 100644 index 000000000..ab9656dd5 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature/index.html @@ -0,0 +1,179 @@ + + + + + Feature + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Feature

+
interface Feature<T : Feature<T>, Enum<T>> : Comparable<T>

A feature flag that has one active option. Options are selected by interaction of this interface with Laboratory. Feature flag is a enum that implements this interface.

Warning: Enum values cannot individually override any functions. Otherwise serialization, and consequentially discovery of a selection option, will not work as it is based on a class name.

+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract val defaultOption: T

Determines which option is a default for this feature flag.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Description of the feature flag that can be used for more contextual information. Markdown formatted links will be picked up by the QA module and represented as hyperlinks.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract val name: String

A name of an option that should uniquely identify it within this feature flag.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open val source: Class<out Feature<*>>?

Source of feature flag values. When null it is assumed that the feature flag has only local source of values. Source is also a feature flag, which means it can be controlled by Laboratory as well. By convention, if this property is not null, one of the source values should be Local. For example, the following code will result in a flag that can be controlled by local, Firebase or Aws source.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Option of another feature flag that controls value of this child flag. When supervisor feature flag has an option different from this value then the child does not produce values other than the default one. Option can still be set via Laboratory but it will not be exposed as long as a feature flag is not supervised.

+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract operator fun compareTo(other: T): Int
+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature/name.html b/api/laboratory/runtime/io.mehow.laboratory/-feature/name.html new file mode 100644 index 000000000..50f49f17e --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature/name.html @@ -0,0 +1,76 @@ + + + + + name + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

name

+
+
abstract val name: String

A name of an option that should uniquely identify it within this feature flag.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature/source.html b/api/laboratory/runtime/io.mehow.laboratory/-feature/source.html new file mode 100644 index 000000000..b273d0f4f --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature/source.html @@ -0,0 +1,76 @@ + + + + + source + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

source

+
+
open val source: Class<out Feature<*>>?

Source of feature flag values. When null it is assumed that the feature flag has only local source of values. Source is also a feature flag, which means it can be controlled by Laboratory as well. By convention, if this property is not null, one of the source values should be Local. For example, the following code will result in a flag that can be controlled by local, Firebase or Aws source.

enum class SomeFeature : Feature<SomeFeature> {
FirstValue,
SecondValue,
;

override val defaultOption get() = FirstValue

override val source = Source::class.java

enum class Source : Feature<Source> {
Local,
Firebase,
Aws,
;

override val defaultOption get() = Local
}
}
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-feature/supervisor-option.html b/api/laboratory/runtime/io.mehow.laboratory/-feature/supervisor-option.html new file mode 100644 index 000000000..f85205680 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-feature/supervisor-option.html @@ -0,0 +1,76 @@ + + + + + supervisorOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

supervisorOption

+
+

Option of another feature flag that controls value of this child flag. When supervisor feature flag has an option different from this value then the child does not produce values other than the default one. Option can still be set via Laboratory but it will not be exposed as long as a feature flag is not supervised.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/build.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/build.html new file mode 100644 index 000000000..892afd61a --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/build.html @@ -0,0 +1,76 @@ + + + + + build + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

build

+
+
abstract fun build(): Laboratory

Creates a new Laboratory with provided parameters.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/default-option-factory.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/default-option-factory.html new file mode 100644 index 000000000..651232092 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/default-option-factory.html @@ -0,0 +1,76 @@ + + + + + defaultOptionFactory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

defaultOptionFactory

+
+

Sets a factory that can provide default options override.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/index.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/index.html new file mode 100644 index 000000000..e5af0cb55 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-building-step/index.html @@ -0,0 +1,115 @@ + + + + + BuildingStep + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

BuildingStep

+
interface BuildingStep

The final step of a fluent builder that can set optional parameters.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract fun build(): Laboratory

Creates a new Laboratory with provided parameters.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets a factory that can provide default options override.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/builder.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/builder.html new file mode 100644 index 000000000..abc13d278 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/builder.html @@ -0,0 +1,76 @@ + + + + + builder + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

builder

+
+

Creates a builder that allows to customize Laboratory.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/create.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/create.html new file mode 100644 index 000000000..46b915ada --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/create.html @@ -0,0 +1,76 @@ + + + + + create + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

create

+
+

Creates Laboratory with a provided storage.

Parameters

storage

FeatureStorage delegate that will persist all feature flags.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/in-memory.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/in-memory.html new file mode 100644 index 000000000..92b60caa3 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/in-memory.html @@ -0,0 +1,76 @@ + + + + + inMemory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

inMemory

+
+

Creates Laboratory with an in-memory persistence mechanism.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/index.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/index.html new file mode 100644 index 000000000..5e5965119 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-companion/index.html @@ -0,0 +1,130 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Creates a builder that allows to customize Laboratory.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Creates Laboratory with a provided storage.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Creates Laboratory with an in-memory persistence mechanism.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-feature-storage-step/feature-storage.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-feature-storage-step/feature-storage.html new file mode 100644 index 000000000..bb2dadbf1 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-feature-storage-step/feature-storage.html @@ -0,0 +1,76 @@ + + + + + featureStorage + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

featureStorage

+
+

Sets a feature storage that will be used by Laboratory.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-feature-storage-step/index.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-feature-storage-step/index.html new file mode 100644 index 000000000..42577d72b --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/-feature-storage-step/index.html @@ -0,0 +1,100 @@ + + + + + FeatureStorageStep + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

FeatureStorageStep

+

A step of a fluent builder that requires FeatureStorage to proceed.

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Sets a feature storage that will be used by Laboratory.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/blocking.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/blocking.html new file mode 100644 index 000000000..bf779667f --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/blocking.html @@ -0,0 +1,76 @@ + + + + + blocking + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

blocking

+
+

An entry point for blocking API.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/clear.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/clear.html new file mode 100644 index 000000000..8560dfdf6 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/clear.html @@ -0,0 +1,76 @@ + + + + + clear + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

clear

+
+
suspend fun clear(): Boolean

Removes all stored feature flag options.

Return

true if the option was set successfully, false otherwise.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/experiment-is.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/experiment-is.html new file mode 100644 index 000000000..afd958e6d --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/experiment-is.html @@ -0,0 +1,76 @@ + + + + + experimentIs + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

experimentIs

+
+
suspend fun <T : Feature<out T>> experimentIs(option: T): Boolean

Checks if a Feature is set to the input option.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/experiment.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/experiment.html new file mode 100644 index 000000000..05594f0d8 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/experiment.html @@ -0,0 +1,76 @@ + + + + + experiment + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

experiment

+
+
inline suspend fun <T : Feature<out T>> experiment(): T
suspend fun <T : Feature<out T>> experiment(feature: Class<out T>): T

Returns the current option of the input Feature.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/index.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/index.html new file mode 100644 index 000000000..c3bf2a366 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/index.html @@ -0,0 +1,239 @@ + + + + + Laboratory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Laboratory

+

High-level API for interaction with feature flags. It allows to read and write their options.

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
interface BuildingStep

The final step of a fluent builder that can set optional parameters.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

A step of a fluent builder that requires FeatureStorage to proceed.

+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

An entry point for blocking API.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
suspend fun clear(): Boolean

Removes all stored feature flag options.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
inline suspend fun <T : Feature<out T>> experiment(): T
suspend fun <T : Feature<out T>> experiment(feature: Class<out T>): T

Returns the current option of the input Feature.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
suspend fun <T : Feature<out T>> experimentIs(option: T): Boolean

Checks if a Feature is set to the input option.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
inline fun <T : Feature<out T>> observe(): Flow<T>
fun <T : Feature<out T>> observe(feature: Class<out T>): Flow<T>

Observes any changes to the input Feature.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
suspend fun <T : Feature<*>> setOption(option: T): Boolean

Sets a Feature to have the input option.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
suspend fun <T : Feature<*>> setOptions(vararg options: T): Boolean
suspend fun <T : Feature<*>> setOptions(options: Collection<T>): Boolean

Sets Features to have the input options. If options contains more than one option for the same feature flag, the last one should be applied.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/observe.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/observe.html new file mode 100644 index 000000000..c12410a77 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/observe.html @@ -0,0 +1,76 @@ + + + + + observe + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

observe

+
+
inline fun <T : Feature<out T>> observe(): Flow<T>
fun <T : Feature<out T>> observe(feature: Class<out T>): Flow<T>

Observes any changes to the input Feature.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/set-option.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/set-option.html new file mode 100644 index 000000000..0ebe8a5b6 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/set-option.html @@ -0,0 +1,76 @@ + + + + + setOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

setOption

+
+
suspend fun <T : Feature<*>> setOption(option: T): Boolean

Sets a Feature to have the input option.

Return

true if the option was set successfully, false otherwise.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-laboratory/set-options.html b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/set-options.html new file mode 100644 index 000000000..81b06f406 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-laboratory/set-options.html @@ -0,0 +1,76 @@ + + + + + setOptions + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

setOptions

+
+
suspend fun <T : Feature<*>> setOptions(vararg options: T): Boolean
suspend fun <T : Feature<*>> setOptions(options: Collection<T>): Boolean

Sets Features to have the input options. If options contains more than one option for the same feature flag, the last one should be applied.

Return

true if the option was set successfully, false otherwise.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-option-factory/-companion/index.html b/api/laboratory/runtime/io.mehow.laboratory/-option-factory/-companion/index.html new file mode 100644 index 000000000..5bb2162e8 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-option-factory/-companion/index.html @@ -0,0 +1,80 @@ + + + + + Companion + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Companion

+
object Companion
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-option-factory/create.html b/api/laboratory/runtime/io.mehow.laboratory/-option-factory/create.html new file mode 100644 index 000000000..b95355efd --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-option-factory/create.html @@ -0,0 +1,76 @@ + + + + + create + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

create

+
+
abstract fun create(key: String, name: String): Feature<*>?

Returns a feature matching class name and option name or null if no match is found.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-option-factory/index.html b/api/laboratory/runtime/io.mehow.laboratory/-option-factory/index.html new file mode 100644 index 000000000..df3d436c2 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-option-factory/index.html @@ -0,0 +1,134 @@ + + + + + OptionFactory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

OptionFactory

+
interface OptionFactory

Factory that returns a matching option.

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
object Companion
+
+
+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
abstract fun create(key: String, name: String): Feature<*>?

Returns a feature matching class name and option name or null if no match is found.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
open operator fun plus(factory: OptionFactory): OptionFactory

Creates a new OptionFactory that will first look for an option in this factory and then in the other factory.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/-option-factory/plus.html b/api/laboratory/runtime/io.mehow.laboratory/-option-factory/plus.html new file mode 100644 index 000000000..8a6437eaf --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/-option-factory/plus.html @@ -0,0 +1,76 @@ + + + + + plus + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

plus

+
+
open operator fun plus(factory: OptionFactory): OptionFactory

Creates a new OptionFactory that will first look for an option in this factory and then in the other factory.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/default-option.html b/api/laboratory/runtime/io.mehow.laboratory/default-option.html new file mode 100644 index 000000000..df4823292 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/default-option.html @@ -0,0 +1,76 @@ + + + + + defaultOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

defaultOption

+
+
val <T : Feature<out T>> Class<out T>.defaultOption: T

Default option of a feature flag.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/description.html b/api/laboratory/runtime/io.mehow.laboratory/description.html new file mode 100644 index 000000000..4c5d1058e --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/description.html @@ -0,0 +1,76 @@ + + + + + description + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

description

+
+

Description of a feature flag.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/index.html b/api/laboratory/runtime/io.mehow.laboratory/index.html new file mode 100644 index 000000000..891d77143 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/index.html @@ -0,0 +1,283 @@ + + + + + io.mehow.laboratory + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Package-level declarations

+
+
+
+
+
+

Types

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+

Opt-in annotation denoting that the used function can potentially block a calling thread with I/O operations.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

A blocking equivalent of Laboratory.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Factory that allows to override default feature flag option used by Laboratory.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
interface Feature<T : Feature<T>, Enum<T>> : Comparable<T>

A feature flag that has one active option. Options are selected by interaction of this interface with Laboratory. Feature flag is a enum that implements this interface.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
interface FeatureFactory

Factory that should provide all available feature flags. There shouldn't be any need to use it in a regular application code. Its main purpose is for QA inspection module.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
interface FeatureStorage

Persistence mechanism for feature flags.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

High-level API for interaction with feature flags. It allows to read and write their options.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
interface OptionFactory

Factory that returns a matching option.

+
+
+
+
+
+
+
+

Properties

+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+
val <T : Feature<out T>> Class<out T>.defaultOption: T

Default option of a feature flag.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Description of a feature flag.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val <T : Feature<out T>> Class<out T>.options: Array<out T>

All available options of a feature flag.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+
val Class<out Feature<*>>.source: Class<out Feature<*>>?

Source of feature flag values.

+
+
+
+
+ +
+
+
+ + +
Link copied to clipboard
+
+
+
+

Supervisor of a feature flag.

+
+
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/options.html b/api/laboratory/runtime/io.mehow.laboratory/options.html new file mode 100644 index 000000000..c072c08cb --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/options.html @@ -0,0 +1,76 @@ + + + + + options + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

options

+
+
val <T : Feature<out T>> Class<out T>.options: Array<out T>

All available options of a feature flag.

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/source.html b/api/laboratory/runtime/io.mehow.laboratory/source.html new file mode 100644 index 000000000..fe24e41d3 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/source.html @@ -0,0 +1,76 @@ + + + + + source + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

source

+
+
val Class<out Feature<*>>.source: Class<out Feature<*>>?

Source of feature flag values.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/io.mehow.laboratory/supervisor-option.html b/api/laboratory/runtime/io.mehow.laboratory/supervisor-option.html new file mode 100644 index 000000000..2af0b3792 --- /dev/null +++ b/api/laboratory/runtime/io.mehow.laboratory/supervisor-option.html @@ -0,0 +1,76 @@ + + + + + supervisorOption + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

supervisorOption

+
+

Supervisor of a feature flag.

See also

+
+ +
+
+
+ + + diff --git a/api/laboratory/runtime/navigation.html b/api/laboratory/runtime/navigation.html new file mode 100644 index 000000000..09bd18bdc --- /dev/null +++ b/api/laboratory/runtime/navigation.html @@ -0,0 +1,397 @@ +
+
+ + +
+
+
+ generator +
+
+ +
+ +
+ + + + + +
+ +
+
+ +
+
+ Public +
+
+
+
+ Internal +
+
+
+
+
+
+ + +
+
+
+ inspector +
+
+ +
+ +
+
+ Selector +
+
+
+
+ Regular +
+
+
+
+ Bottom +
+
+
+
+ +
+
+ Selector +
+
+
+
+ Show +
+
+
+ +
+
+
+ Hide +
+
+
+
+ +
+
+ Companion +
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+ +
+
+ +
+
+ Limited +
+
+
+
+ Unlimited +
+
+
+
+
+
+
+
+
+ runtime +
+
+ +
+ +
+ +
+ +
+
+ +
+
+ Companion +
+
+
+
+ +
+
+
+ Feature +
+
+
+ +
+
+ Companion +
+
+
+
+ +
+
+ Companion +
+
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+
+ +
+
+ Companion +
+
+
+
+
+ options +
+
+
+
+ source +
+
+ +
+
+
+ + +
+
diff --git a/api/laboratory/shared-preferences/index.html b/api/laboratory/shared-preferences/index.html new file mode 100644 index 000000000..2cde3dbd0 --- /dev/null +++ b/api/laboratory/shared-preferences/index.html @@ -0,0 +1,95 @@ + + + + + shared-preferences + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

shared-preferences

+
+

Packages

+
+
+
+
+
+ + +
Link copied to clipboard
+
+
+
+ +
+
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/shared-preferences/io.mehow.laboratory.sharedpreferences/index.html b/api/laboratory/shared-preferences/io.mehow.laboratory.sharedpreferences/index.html new file mode 100644 index 000000000..43a658a4f --- /dev/null +++ b/api/laboratory/shared-preferences/io.mehow.laboratory.sharedpreferences/index.html @@ -0,0 +1,99 @@ + + + + + io.mehow.laboratory.sharedpreferences + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

Package-level declarations

+
+
+
+
+
+

Functions

+
+
+
+
+ + +
Link copied to clipboard
+
+ +
+
+
+
+
+
+
+ +
+
+
+ + + diff --git a/api/laboratory/shared-preferences/io.mehow.laboratory.sharedpreferences/shared-preferences.html b/api/laboratory/shared-preferences/io.mehow.laboratory.sharedpreferences/shared-preferences.html new file mode 100644 index 000000000..4d2933dae --- /dev/null +++ b/api/laboratory/shared-preferences/io.mehow.laboratory.sharedpreferences/shared-preferences.html @@ -0,0 +1,76 @@ + + + + + sharedPreferences + + + + + + + + + + + + + + + + + +
+ +
+ +
+
+ +
+

sharedPreferences

+
+ +
+ +
+
+
+ + + diff --git a/api/laboratory/shared-preferences/navigation.html b/api/laboratory/shared-preferences/navigation.html new file mode 100644 index 000000000..09bd18bdc --- /dev/null +++ b/api/laboratory/shared-preferences/navigation.html @@ -0,0 +1,397 @@ +
+
+ + +
+
+
+ generator +
+
+ +
+ +
+ + + + + +
+ +
+
+ +
+
+ Public +
+
+
+
+ Internal +
+
+
+
+
+
+ + +
+
+
+ inspector +
+
+ +
+ +
+
+ Selector +
+
+
+
+ Regular +
+
+
+
+ Bottom +
+
+
+
+ +
+
+ Selector +
+
+
+
+ Show +
+
+
+ +
+
+
+ Hide +
+
+
+
+ +
+
+ Companion +
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+ +
+
+ +
+
+ Limited +
+
+
+
+ Unlimited +
+
+
+
+
+
+
+
+
+ runtime +
+
+ +
+ +
+ +
+ +
+
+ +
+
+ Companion +
+
+
+
+ +
+
+
+ Feature +
+
+
+ +
+
+ Companion +
+
+
+
+ +
+
+ Companion +
+
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+
+ +
+
+ Companion +
+
+
+
+
+ options +
+
+
+
+ source +
+
+ +
+
+
+ + +
+
diff --git a/api/navigation.html b/api/navigation.html new file mode 100644 index 000000000..a97245bbb --- /dev/null +++ b/api/navigation.html @@ -0,0 +1,397 @@ +
+
+ + +
+
+
+ generator +
+
+ +
+ +
+ + + + + +
+ +
+
+ +
+
+ Public +
+
+
+
+ Internal +
+
+
+
+
+
+ + +
+
+
+ inspector +
+
+ +
+ +
+
+ Selector +
+
+
+
+ Regular +
+
+
+
+ Bottom +
+
+
+
+ +
+
+ Selector +
+
+
+
+ Show +
+
+
+ +
+
+
+ Hide +
+
+
+
+ +
+
+ Companion +
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+ +
+
+ +
+
+ Limited +
+
+
+
+ Unlimited +
+
+
+
+
+
+
+
+
+ runtime +
+
+ +
+ +
+ +
+ +
+
+ +
+
+ Companion +
+
+
+
+ +
+
+
+ Feature +
+
+
+ +
+
+ Companion +
+
+
+
+ +
+
+ Companion +
+
+
+
+ +
+ +
+
+
+ Companion +
+
+ +
+
+ +
+
+ Companion +
+
+
+
+
+ options +
+
+
+
+ source +
+
+ +
+
+
+ + +
+
diff --git a/api/package-list b/api/package-list new file mode 100644 index 000000000..d2c671ed3 --- /dev/null +++ b/api/package-list @@ -0,0 +1,15 @@ +$dokka.format:html-v1 +$dokka.linkExtension:html + +module:data-store +io.mehow.laboratory.datastore +module:generator +io.mehow.laboratory.generator +module:gradle-plugin +io.mehow.laboratory.gradle +module:inspector +io.mehow.laboratory.inspector +module:runtime +io.mehow.laboratory +module:shared-preferences +io.mehow.laboratory.sharedpreferences diff --git a/api/scripts/clipboard.js b/api/scripts/clipboard.js new file mode 100644 index 000000000..7a4f33c59 --- /dev/null +++ b/api/scripts/clipboard.js @@ -0,0 +1,56 @@ +/* + * Copyright 2014-2023 JetBrains s.r.o. Use of this source code is governed by the Apache 2.0 license. + */ + +window.addEventListener('load', () => { + document.querySelectorAll('span.copy-icon').forEach(element => { + element.addEventListener('click', (el) => copyElementsContentToClipboard(element)); + }) + + document.querySelectorAll('span.anchor-icon').forEach(element => { + element.addEventListener('click', (el) => { + if(element.hasAttribute('pointing-to')){ + const location = hrefWithoutCurrentlyUsedAnchor() + '#' + element.getAttribute('pointing-to') + copyTextToClipboard(element, location) + } + }); + }) +}) + +const copyElementsContentToClipboard = (element) => { + const selection = window.getSelection(); + const range = document.createRange(); + range.selectNodeContents(element.parentNode.parentNode); + selection.removeAllRanges(); + selection.addRange(range); + + copyAndShowPopup(element, () => selection.removeAllRanges()) +} + +const copyTextToClipboard = (element, text) => { + var textarea = document.createElement("textarea"); + textarea.textContent = text; + textarea.style.position = "fixed"; + document.body.appendChild(textarea); + textarea.select(); + + copyAndShowPopup(element, () => document.body.removeChild(textarea)) +} + +const copyAndShowPopup = (element, after) => { + try { + document.execCommand('copy'); + element.nextElementSibling.classList.add('active-popup'); + setTimeout(() => { + element.nextElementSibling.classList.remove('active-popup'); + }, 1200); + } catch (e) { + console.error('Failed to write to clipboard:', e) + } + finally { + if(after) after() + } +} + +const hrefWithoutCurrentlyUsedAnchor = () => window.location.href.split('#')[0] + diff --git a/api/scripts/main.js b/api/scripts/main.js new file mode 100644 index 000000000..ba6c34739 --- /dev/null +++ b/api/scripts/main.js @@ -0,0 +1,44 @@ +(()=>{var e={8527:e=>{e.exports=''},5570:e=>{e.exports=''},107:e=>{e.exports=''},7224:e=>{e.exports=''},538:e=>{e.exports=''},1924:(e,n,t)=>{"use strict";var r=t(210),o=t(5559),i=o(r("String.prototype.indexOf"));e.exports=function(e,n){var t=r(e,!!n);return"function"==typeof t&&i(e,".prototype.")>-1?o(t):t}},5559:(e,n,t)=>{"use strict";var r=t(8612),o=t(210),i=o("%Function.prototype.apply%"),a=o("%Function.prototype.call%"),l=o("%Reflect.apply%",!0)||r.call(a,i),c=o("%Object.getOwnPropertyDescriptor%",!0),u=o("%Object.defineProperty%",!0),s=o("%Math.max%");if(u)try{u({},"a",{value:1})}catch(e){u=null}e.exports=function(e){var n=l(r,a,arguments);if(c&&u){var t=c(n,"length");t.configurable&&u(n,"length",{value:1+s(0,e.length-(arguments.length-1))})}return n};var f=function(){return l(r,i,arguments)};u?u(e.exports,"apply",{value:f}):e.exports.apply=f},4184:(e,n)=>{var t; +/*! + Copyright (c) 2018 Jed Watson. + Licensed under the MIT License (MIT), see + http://jedwatson.github.io/classnames +*/!function(){"use strict";var r={}.hasOwnProperty;function o(){for(var e=[],n=0;n{"use strict";e.exports=function(e,n){var t=this,r=t.constructor;return t.options=Object.assign({storeInstancesGlobally:!0},n||{}),t.callbacks={},t.directMap={},t.sequenceLevels={},t.resetTimer=null,t.ignoreNextKeyup=!1,t.ignoreNextKeypress=!1,t.nextExpectedAction=!1,t.element=e,t.addEvents(),t.options.storeInstancesGlobally&&r.instances.push(t),t},e.exports.prototype.bind=t(2207),e.exports.prototype.bindMultiple=t(3396),e.exports.prototype.unbind=t(9208),e.exports.prototype.trigger=t(9855),e.exports.prototype.reset=t(6214),e.exports.prototype.stopCallback=t(3450),e.exports.prototype.handleKey=t(3067),e.exports.prototype.addEvents=t(718),e.exports.prototype.bindSingle=t(8763),e.exports.prototype.getKeyInfo=t(5825),e.exports.prototype.pickBestAction=t(8608),e.exports.prototype.getReverseMap=t(3956),e.exports.prototype.getMatches=t(3373),e.exports.prototype.resetSequences=t(3346),e.exports.prototype.fireCallback=t(2684),e.exports.prototype.bindSequence=t(7103),e.exports.prototype.resetSequenceTimer=t(7309),e.exports.prototype.detach=t(7554),e.exports.instances=[],e.exports.reset=t(1822),e.exports.REVERSE_MAP=null},718:(e,n,t)=>{"use strict";e.exports=function(){var e=this,n=t(4323),r=e.element;e.eventHandler=t(9646).bind(e),n(r,"keypress",e.eventHandler),n(r,"keydown",e.eventHandler),n(r,"keyup",e.eventHandler)}},2207:e=>{"use strict";e.exports=function(e,n,t){return e=e instanceof Array?e:[e],this.bindMultiple(e,n,t),this}},3396:e=>{"use strict";e.exports=function(e,n,t){for(var r=0;r{"use strict";e.exports=function(e,n,r,o){var i=this;function a(n){return function(){i.nextExpectedAction=n,++i.sequenceLevels[e],i.resetSequenceTimer()}}function l(n){var a;i.fireCallback(r,n,e),"keyup"!==o&&(a=t(6770),i.ignoreNextKeyup=a(n)),setTimeout((function(){i.resetSequences()}),10)}i.sequenceLevels[e]=0;for(var c=0;c{"use strict";e.exports=function(e,n,t,r,o){var i=this;i.directMap[e+":"+t]=n;var a,l=(e=e.replace(/\s+/g," ")).split(" ");l.length>1?i.bindSequence(e,l,n,t):(a=i.getKeyInfo(e,t),i.callbacks[a.key]=i.callbacks[a.key]||[],i.getMatches(a.key,a.modifiers,{type:a.action},r,e,o),i.callbacks[a.key][r?"unshift":"push"]({callback:n,modifiers:a.modifiers,action:a.action,seq:r,level:o,combo:e}))}},7554:(e,n,t)=>{var r=t(4323).off;e.exports=function(){var e=this,n=e.element;r(n,"keypress",e.eventHandler),r(n,"keydown",e.eventHandler),r(n,"keyup",e.eventHandler)}},4323:e=>{function n(e,n,t,r){return!e.addEventListener&&(n="on"+n),(e.addEventListener||e.attachEvent).call(e,n,t,r),t}e.exports=n,e.exports.on=n,e.exports.off=function(e,n,t,r){return!e.removeEventListener&&(n="on"+n),(e.removeEventListener||e.detachEvent).call(e,n,t,r),t}},2684:(e,n,t)=>{"use strict";e.exports=function(e,n,r,o){this.stopCallback(n,n.target||n.srcElement,r,o)||!1===e(n,r)&&(t(1350)(n),t(6103)(n))}},5825:(e,n,t)=>{"use strict";e.exports=function(e,n){var r,o,i,a,l,c,u=[];for(r=t(4520)(e),a=t(7549),l=t(5355),c=t(8581),i=0;i{"use strict";e.exports=function(e,n,r,o,i,a){var l,c,u,s,f=this,p=[],d=r.type;"keypress"!==d||r.code&&"Arrow"===r.code.slice(0,5)||(f.callbacks["any-character"]||[]).forEach((function(e){p.push(e)}));if(!f.callbacks[e])return p;for(u=t(8581),"keyup"===d&&u(e)&&(n=[e]),l=0;l{"use strict";e.exports=function(){var e,n=this.constructor;if(!n.REVERSE_MAP)for(var r in n.REVERSE_MAP={},e=t(4766))r>95&&r<112||e.hasOwnProperty(r)&&(n.REVERSE_MAP[e[r]]=r);return n.REVERSE_MAP}},3067:(e,n,t)=>{"use strict";e.exports=function(e,n,r){var o,i,a,l,c=this,u={},s=0,f=!1;for(o=c.getMatches(e,n,r),i=0;i{"use strict";e.exports=function(e){var n,r=this;"number"!=typeof e.which&&(e.which=e.keyCode);var o=t(6770)(e);void 0!==o&&("keyup"!==e.type||r.ignoreNextKeyup!==o?(n=t(4610),r.handleKey(o,n(e),e)):r.ignoreNextKeyup=!1)}},5532:e=>{"use strict";e.exports=function(e,n){return e.sort().join(",")===n.sort().join(",")}},8608:e=>{"use strict";e.exports=function(e,n,t){return t||(t=this.getReverseMap()[e]?"keydown":"keypress"),"keypress"===t&&n.length&&(t="keydown"),t}},6214:e=>{"use strict";e.exports=function(){return this.callbacks={},this.directMap={},this}},7309:e=>{"use strict";e.exports=function(){var e=this;clearTimeout(e.resetTimer),e.resetTimer=setTimeout((function(){e.resetSequences()}),1e3)}},3346:e=>{"use strict";e.exports=function(e){var n=this;e=e||{};var t,r=!1;for(t in n.sequenceLevels)e[t]?r=!0:n.sequenceLevels[t]=0;r||(n.nextExpectedAction=!1)}},3450:e=>{"use strict";e.exports=function(e,n){if((" "+n.className+" ").indexOf(" combokeys ")>-1)return!1;var t=n.tagName.toLowerCase();return"input"===t||"select"===t||"textarea"===t||n.isContentEditable}},9855:e=>{"use strict";e.exports=function(e,n){return this.directMap[e+":"+n]&&this.directMap[e+":"+n]({},e),this}},9208:e=>{"use strict";e.exports=function(e,n){return this.bind(e,(function(){}),n)}},1822:e=>{"use strict";e.exports=function(){this.instances.forEach((function(e){e.reset()}))}},6770:(e,n,t)=>{"use strict";e.exports=function(e){var n,r;if(n=t(4766),r=t(5295),"keypress"===e.type){var o=String.fromCharCode(e.which);return e.shiftKey||(o=o.toLowerCase()),o}return void 0!==n[e.which]?n[e.which]:void 0!==r[e.which]?r[e.which]:String.fromCharCode(e.which).toLowerCase()}},4610:e=>{"use strict";e.exports=function(e){var n=[];return e.shiftKey&&n.push("shift"),e.altKey&&n.push("alt"),e.ctrlKey&&n.push("ctrl"),e.metaKey&&n.push("meta"),n}},8581:e=>{"use strict";e.exports=function(e){return"shift"===e||"ctrl"===e||"alt"===e||"meta"===e}},4520:e=>{"use strict";e.exports=function(e){return"+"===e?["+"]:e.split("+")}},1350:e=>{"use strict";e.exports=function(e){e.preventDefault?e.preventDefault():e.returnValue=!1}},5355:e=>{"use strict";e.exports={"~":"`","!":"1","@":"2","#":"3",$:"4","%":"5","^":"6","&":"7","*":"8","(":"9",")":"0",_:"-","+":"=",":":";",'"':"'","<":",",">":".","?":"/","|":"\\"}},7549:e=>{"use strict";e.exports={option:"alt",command:"meta",return:"enter",escape:"esc",mod:/Mac|iPod|iPhone|iPad/.test(navigator.platform)?"meta":"ctrl"}},5295:e=>{"use strict";e.exports={106:"*",107:"plus",109:"minus",110:".",111:"/",186:";",187:"=",188:",",189:"-",190:".",191:"/",192:"`",219:"[",220:"\\",221:"]",222:"'"}},4766:e=>{"use strict";e.exports={8:"backspace",9:"tab",13:"enter",16:"shift",17:"ctrl",18:"alt",20:"capslock",27:"esc",32:"space",33:"pageup",34:"pagedown",35:"end",36:"home",37:"left",38:"up",39:"right",40:"down",45:"ins",46:"del",91:"meta",93:"meta",173:"minus",187:"plus",189:"minus",224:"meta"};for(var n=1;n<20;++n)e.exports[111+n]="f"+n;for(n=0;n<=9;++n)e.exports[n+96]=n},6103:e=>{"use strict";e.exports=function(e){e.stopPropagation?e.stopPropagation():e.cancelBubble=!0}},3362:()=>{var e;!function(){var e=Math.PI,n=2*e,t=e/180,r=document.createElement("div");document.head.appendChild(r);var o=self.ConicGradient=function(e){o.all.push(this),e=e||{},this.canvas=document.createElement("canvas"),this.context=this.canvas.getContext("2d"),this.repeating=!!e.repeating,this.size=e.size||Math.max(innerWidth,innerHeight),this.canvas.width=this.canvas.height=this.size;var n=e.stops;this.stops=(n||"").split(/\s*,(?![^(]*\))\s*/),this.from=0;for(var t=0;t0){var i=this.stops[0].clone();i.pos=0,this.stops.unshift(i)}if(void 0===this.stops[this.stops.length-1].pos)this.stops[this.stops.length-1].pos=1;else if(!this.repeating&&this.stops[this.stops.length-1].pos<1){var a=this.stops[this.stops.length-1].clone();a.pos=1,this.stops.push(a)}if(this.stops.forEach((function(e,n){if(void 0===e.pos){for(var t=n+1;this[t];t++)if(void 0!==this[t].pos){e.pos=this[n-1].pos+(this[t].pos-this[n-1].pos)/(t-n+1);break}}else n>0&&(e.pos=Math.max(e.pos,this[n-1].pos))}),this.stops),this.repeating){var l=(n=this.stops.slice())[n.length-1].pos-n[0].pos;for(t=0;this.stops[this.stops.length-1].pos<1&&t<1e4;t++)for(var c=0;c'},get png(){return this.canvas.toDataURL()},get r(){return Math.sqrt(2)*this.size/2},paint:function(){var e,n,r,o=this.context,i=this.r,a=this.size/2,l=0,c=this.stops[l];o.translate(this.size/2,this.size/2),o.rotate(-90*t),o.rotate(this.from*t),o.translate(-this.size/2,-this.size/2);for(var u=0;u<360;){if(u/360+1e-5>=c.pos){do{e=c,l++,c=this.stops[l]}while(c&&c!=e&&c.pos===e.pos);if(!c)break;var s=e.color+""==c.color+""&&e!=c;n=e.color.map((function(e,n){return c.color[n]-e}))}r=(u/360-e.pos)/(c.pos-e.pos);var f=s?c.color:n.map((function(n,t){var o=n*r+e.color[t];return t<3?255&o:o}));if(o.fillStyle="rgba("+f.join(",")+")",o.beginPath(),o.moveTo(a,a),s)var p=360*(c.pos-e.pos);else p=.5;var d=u*t,h=(d=Math.min(360*t,d))+p*t;h=Math.min(360*t,h+.02),o.arc(a,a,i,d,h),o.closePath(),o.fill(),u+=p}}},o.ColorStop=function(e,t){if(this.gradient=e,t){var r=t.match(/^(.+?)(?:\s+([\d.]+)(%|deg|turn|grad|rad)?)?(?:\s+([\d.]+)(%|deg|turn|grad|rad)?)?\s*$/);if(this.color=o.ColorStop.colorToRGBA(r[1]),r[2]){var i=r[3];"%"==i||"0"===r[2]&&!i?this.pos=r[2]/100:"turn"==i?this.pos=+r[2]:"deg"==i?this.pos=r[2]/360:"grad"==i?this.pos=r[2]/400:"rad"==i&&(this.pos=r[2]/n)}r[4]&&(this.next=new o.ColorStop(e,r[1]+" "+r[4]+r[5]))}},o.ColorStop.prototype={clone:function(){var e=new o.ColorStop(this.gradient);return e.color=this.color,e.pos=this.pos,e},toString:function(){return"rgba("+this.color.join(", ")+") "+100*this.pos+"%"}},o.ColorStop.colorToRGBA=function(e){if(!Array.isArray(e)&&-1==e.indexOf("from")){r.style.color=e;var n=getComputedStyle(r).color.match(/rgba?\(([\d.]+), ([\d.]+), ([\d.]+)(?:, ([\d.]+))?\)/);return n&&(n.shift(),(n=n.map((function(e){return+e})))[3]=isNaN(n[3])?1:n[3]),n||[0,0,0,0]}return e}}(),self.StyleFix&&((e=document.createElement("p")).style.backgroundImage="conic-gradient(white, black)",e.style.backgroundImage=PrefixFree.prefix+"conic-gradient(white, black)",e.style.backgroundImage||StyleFix.register((function(e,n){return e.indexOf("conic-gradient")>-1&&(e=e.replace(/(?:repeating-)?conic-gradient\(\s*((?:\([^()]+\)|[^;()}])+?)\)/g,(function(e,n){return new ConicGradient({stops:n,repeating:e.indexOf("repeating-")>-1})}))),e})))},9662:(e,n,t)=>{var r=t(7854),o=t(614),i=t(6330),a=r.TypeError;e.exports=function(e){if(o(e))return e;throw a(i(e)+" is not a function")}},9483:(e,n,t)=>{var r=t(7854),o=t(4411),i=t(6330),a=r.TypeError;e.exports=function(e){if(o(e))return e;throw a(i(e)+" is not a constructor")}},6077:(e,n,t)=>{var r=t(7854),o=t(614),i=r.String,a=r.TypeError;e.exports=function(e){if("object"==typeof e||o(e))return e;throw a("Can't set "+i(e)+" as a prototype")}},1223:(e,n,t)=>{var r=t(5112),o=t(30),i=t(3070),a=r("unscopables"),l=Array.prototype;null==l[a]&&i.f(l,a,{configurable:!0,value:o(null)}),e.exports=function(e){l[a][e]=!0}},1530:(e,n,t)=>{"use strict";var r=t(8710).charAt;e.exports=function(e,n,t){return n+(t?r(e,n).length:1)}},5787:(e,n,t)=>{var r=t(7854),o=t(7976),i=r.TypeError;e.exports=function(e,n){if(o(n,e))return e;throw i("Incorrect invocation")}},9670:(e,n,t)=>{var r=t(7854),o=t(111),i=r.String,a=r.TypeError;e.exports=function(e){if(o(e))return e;throw a(i(e)+" is not an object")}},7556:(e,n,t)=>{var r=t(7293);e.exports=r((function(){if("function"==typeof ArrayBuffer){var e=new ArrayBuffer(8);Object.isExtensible(e)&&Object.defineProperty(e,"a",{value:8})}}))},8533:(e,n,t)=>{"use strict";var r=t(2092).forEach,o=t(9341)("forEach");e.exports=o?[].forEach:function(e){return r(this,e,arguments.length>1?arguments[1]:void 0)}},8457:(e,n,t)=>{"use strict";var r=t(7854),o=t(9974),i=t(6916),a=t(7908),l=t(3411),c=t(7659),u=t(4411),s=t(6244),f=t(6135),p=t(8554),d=t(1246),h=r.Array;e.exports=function(e){var n=a(e),t=u(this),r=arguments.length,g=r>1?arguments[1]:void 0,v=void 0!==g;v&&(g=o(g,r>2?arguments[2]:void 0));var A,b,m,y,E,_,C=d(n),w=0;if(!C||this==h&&c(C))for(A=s(n),b=t?new this(A):h(A);A>w;w++)_=v?g(n[w],w):n[w],f(b,w,_);else for(E=(y=p(n,C)).next,b=t?new this:[];!(m=i(E,y)).done;w++)_=v?l(y,g,[m.value,w],!0):m.value,f(b,w,_);return b.length=w,b}},1318:(e,n,t)=>{var r=t(5656),o=t(1400),i=t(6244),a=function(e){return function(n,t,a){var l,c=r(n),u=i(c),s=o(a,u);if(e&&t!=t){for(;u>s;)if((l=c[s++])!=l)return!0}else for(;u>s;s++)if((e||s in c)&&c[s]===t)return e||s||0;return!e&&-1}};e.exports={includes:a(!0),indexOf:a(!1)}},2092:(e,n,t)=>{var r=t(9974),o=t(1702),i=t(8361),a=t(7908),l=t(6244),c=t(5417),u=o([].push),s=function(e){var n=1==e,t=2==e,o=3==e,s=4==e,f=6==e,p=7==e,d=5==e||f;return function(h,g,v,A){for(var b,m,y=a(h),E=i(y),_=r(g,v),C=l(E),w=0,x=A||c,k=n?x(h,C):t||p?x(h,0):void 0;C>w;w++)if((d||w in E)&&(m=_(b=E[w],w,y),e))if(n)k[w]=m;else if(m)switch(e){case 3:return!0;case 5:return b;case 6:return w;case 2:u(k,b)}else switch(e){case 4:return!1;case 7:u(k,b)}return f?-1:o||s?s:k}};e.exports={forEach:s(0),map:s(1),filter:s(2),some:s(3),every:s(4),find:s(5),findIndex:s(6),filterReject:s(7)}},1194:(e,n,t)=>{var r=t(7293),o=t(5112),i=t(7392),a=o("species");e.exports=function(e){return i>=51||!r((function(){var n=[];return(n.constructor={})[a]=function(){return{foo:1}},1!==n[e](Boolean).foo}))}},9341:(e,n,t)=>{"use strict";var r=t(7293);e.exports=function(e,n){var t=[][e];return!!t&&r((function(){t.call(null,n||function(){throw 1},1)}))}},3671:(e,n,t)=>{var r=t(7854),o=t(9662),i=t(7908),a=t(8361),l=t(6244),c=r.TypeError,u=function(e){return function(n,t,r,u){o(t);var s=i(n),f=a(s),p=l(s),d=e?p-1:0,h=e?-1:1;if(r<2)for(;;){if(d in f){u=f[d],d+=h;break}if(d+=h,e?d<0:p<=d)throw c("Reduce of empty array with no initial value")}for(;e?d>=0:p>d;d+=h)d in f&&(u=t(u,f[d],d,s));return u}};e.exports={left:u(!1),right:u(!0)}},206:(e,n,t)=>{var r=t(1702);e.exports=r([].slice)},4362:(e,n,t)=>{var r=t(206),o=Math.floor,i=function(e,n){var t=e.length,c=o(t/2);return t<8?a(e,n):l(e,i(r(e,0,c),n),i(r(e,c),n),n)},a=function(e,n){for(var t,r,o=e.length,i=1;i0;)e[r]=e[--r];r!==i++&&(e[r]=t)}return e},l=function(e,n,t,r){for(var o=n.length,i=t.length,a=0,l=0;a{var r=t(7854),o=t(3157),i=t(4411),a=t(111),l=t(5112)("species"),c=r.Array;e.exports=function(e){var n;return o(e)&&(n=e.constructor,(i(n)&&(n===c||o(n.prototype))||a(n)&&null===(n=n[l]))&&(n=void 0)),void 0===n?c:n}},5417:(e,n,t)=>{var r=t(7475);e.exports=function(e,n){return new(r(e))(0===n?0:n)}},3411:(e,n,t)=>{var r=t(9670),o=t(9212);e.exports=function(e,n,t,i){try{return i?n(r(t)[0],t[1]):n(t)}catch(n){o(e,"throw",n)}}},7072:(e,n,t)=>{var r=t(5112)("iterator"),o=!1;try{var i=0,a={next:function(){return{done:!!i++}},return:function(){o=!0}};a[r]=function(){return this},Array.from(a,(function(){throw 2}))}catch(e){}e.exports=function(e,n){if(!n&&!o)return!1;var t=!1;try{var i={};i[r]=function(){return{next:function(){return{done:t=!0}}}},e(i)}catch(e){}return t}},4326:(e,n,t)=>{var r=t(1702),o=r({}.toString),i=r("".slice);e.exports=function(e){return i(o(e),8,-1)}},648:(e,n,t)=>{var r=t(7854),o=t(1694),i=t(614),a=t(4326),l=t(5112)("toStringTag"),c=r.Object,u="Arguments"==a(function(){return arguments}());e.exports=o?a:function(e){var n,t,r;return void 0===e?"Undefined":null===e?"Null":"string"==typeof(t=function(e,n){try{return e[n]}catch(e){}}(n=c(e),l))?t:u?a(n):"Object"==(r=a(n))&&i(n.callee)?"Arguments":r}},5631:(e,n,t)=>{"use strict";var r=t(3070).f,o=t(30),i=t(2248),a=t(9974),l=t(5787),c=t(408),u=t(654),s=t(6340),f=t(9781),p=t(2423).fastKey,d=t(9909),h=d.set,g=d.getterFor;e.exports={getConstructor:function(e,n,t,u){var s=e((function(e,r){l(e,d),h(e,{type:n,index:o(null),first:void 0,last:void 0,size:0}),f||(e.size=0),null!=r&&c(r,e[u],{that:e,AS_ENTRIES:t})})),d=s.prototype,v=g(n),A=function(e,n,t){var r,o,i=v(e),a=b(e,n);return a?a.value=t:(i.last=a={index:o=p(n,!0),key:n,value:t,previous:r=i.last,next:void 0,removed:!1},i.first||(i.first=a),r&&(r.next=a),f?i.size++:e.size++,"F"!==o&&(i.index[o]=a)),e},b=function(e,n){var t,r=v(e),o=p(n);if("F"!==o)return r.index[o];for(t=r.first;t;t=t.next)if(t.key==n)return t};return i(d,{clear:function(){for(var e=v(this),n=e.index,t=e.first;t;)t.removed=!0,t.previous&&(t.previous=t.previous.next=void 0),delete n[t.index],t=t.next;e.first=e.last=void 0,f?e.size=0:this.size=0},delete:function(e){var n=this,t=v(n),r=b(n,e);if(r){var o=r.next,i=r.previous;delete t.index[r.index],r.removed=!0,i&&(i.next=o),o&&(o.previous=i),t.first==r&&(t.first=o),t.last==r&&(t.last=i),f?t.size--:n.size--}return!!r},forEach:function(e){for(var n,t=v(this),r=a(e,arguments.length>1?arguments[1]:void 0);n=n?n.next:t.first;)for(r(n.value,n.key,this);n&&n.removed;)n=n.previous},has:function(e){return!!b(this,e)}}),i(d,t?{get:function(e){var n=b(this,e);return n&&n.value},set:function(e,n){return A(this,0===e?0:e,n)}}:{add:function(e){return A(this,e=0===e?0:e,e)}}),f&&r(d,"size",{get:function(){return v(this).size}}),s},setStrong:function(e,n,t){var r=n+" Iterator",o=g(n),i=g(r);u(e,n,(function(e,n){h(this,{type:r,target:e,state:o(e),kind:n,last:void 0})}),(function(){for(var e=i(this),n=e.kind,t=e.last;t&&t.removed;)t=t.previous;return e.target&&(e.last=t=t?t.next:e.state.first)?"keys"==n?{value:t.key,done:!1}:"values"==n?{value:t.value,done:!1}:{value:[t.key,t.value],done:!1}:(e.target=void 0,{value:void 0,done:!0})}),t?"entries":"values",!t,!0),s(n)}}},9320:(e,n,t)=>{"use strict";var r=t(1702),o=t(2248),i=t(2423).getWeakData,a=t(9670),l=t(111),c=t(5787),u=t(408),s=t(2092),f=t(2597),p=t(9909),d=p.set,h=p.getterFor,g=s.find,v=s.findIndex,A=r([].splice),b=0,m=function(e){return e.frozen||(e.frozen=new y)},y=function(){this.entries=[]},E=function(e,n){return g(e.entries,(function(e){return e[0]===n}))};y.prototype={get:function(e){var n=E(this,e);if(n)return n[1]},has:function(e){return!!E(this,e)},set:function(e,n){var t=E(this,e);t?t[1]=n:this.entries.push([e,n])},delete:function(e){var n=v(this.entries,(function(n){return n[0]===e}));return~n&&A(this.entries,n,1),!!~n}},e.exports={getConstructor:function(e,n,t,r){var s=e((function(e,o){c(e,p),d(e,{type:n,id:b++,frozen:void 0}),null!=o&&u(o,e[r],{that:e,AS_ENTRIES:t})})),p=s.prototype,g=h(n),v=function(e,n,t){var r=g(e),o=i(a(n),!0);return!0===o?m(r).set(n,t):o[r.id]=t,e};return o(p,{delete:function(e){var n=g(this);if(!l(e))return!1;var t=i(e);return!0===t?m(n).delete(e):t&&f(t,n.id)&&delete t[n.id]},has:function(e){var n=g(this);if(!l(e))return!1;var t=i(e);return!0===t?m(n).has(e):t&&f(t,n.id)}}),o(p,t?{get:function(e){var n=g(this);if(l(e)){var t=i(e);return!0===t?m(n).get(e):t?t[n.id]:void 0}},set:function(e,n){return v(this,e,n)}}:{add:function(e){return v(this,e,!0)}}),s}}},7710:(e,n,t)=>{"use strict";var r=t(2109),o=t(7854),i=t(1702),a=t(4705),l=t(1320),c=t(2423),u=t(408),s=t(5787),f=t(614),p=t(111),d=t(7293),h=t(7072),g=t(8003),v=t(9587);e.exports=function(e,n,t){var A=-1!==e.indexOf("Map"),b=-1!==e.indexOf("Weak"),m=A?"set":"add",y=o[e],E=y&&y.prototype,_=y,C={},w=function(e){var n=i(E[e]);l(E,e,"add"==e?function(e){return n(this,0===e?0:e),this}:"delete"==e?function(e){return!(b&&!p(e))&&n(this,0===e?0:e)}:"get"==e?function(e){return b&&!p(e)?void 0:n(this,0===e?0:e)}:"has"==e?function(e){return!(b&&!p(e))&&n(this,0===e?0:e)}:function(e,t){return n(this,0===e?0:e,t),this})};if(a(e,!f(y)||!(b||E.forEach&&!d((function(){(new y).entries().next()})))))_=t.getConstructor(n,e,A,m),c.enable();else if(a(e,!0)){var x=new _,k=x[m](b?{}:-0,1)!=x,S=d((function(){x.has(1)})),O=h((function(e){new y(e)})),B=!b&&d((function(){for(var e=new y,n=5;n--;)e[m](n,n);return!e.has(-0)}));O||((_=n((function(e,n){s(e,E);var t=v(new y,e,_);return null!=n&&u(n,t[m],{that:t,AS_ENTRIES:A}),t}))).prototype=E,E.constructor=_),(S||B)&&(w("delete"),w("has"),A&&w("get")),(B||k)&&w(m),b&&E.clear&&delete E.clear}return C[e]=_,r({global:!0,forced:_!=y},C),g(_,e),b||t.setStrong(_,e,A),_}},9920:(e,n,t)=>{var r=t(2597),o=t(3887),i=t(1236),a=t(3070);e.exports=function(e,n){for(var t=o(n),l=a.f,c=i.f,u=0;u{var r=t(5112)("match");e.exports=function(e){var n=/./;try{"/./"[e](n)}catch(t){try{return n[r]=!1,"/./"[e](n)}catch(e){}}return!1}},8544:(e,n,t)=>{var r=t(7293);e.exports=!r((function(){function e(){}return e.prototype.constructor=null,Object.getPrototypeOf(new e)!==e.prototype}))},4230:(e,n,t)=>{var r=t(1702),o=t(4488),i=t(1340),a=/"/g,l=r("".replace);e.exports=function(e,n,t,r){var c=i(o(e)),u="<"+n;return""!==t&&(u+=" "+t+'="'+l(i(r),a,""")+'"'),u+">"+c+""}},4994:(e,n,t)=>{"use strict";var r=t(3383).IteratorPrototype,o=t(30),i=t(9114),a=t(8003),l=t(7497),c=function(){return this};e.exports=function(e,n,t){var u=n+" Iterator";return e.prototype=o(r,{next:i(1,t)}),a(e,u,!1,!0),l[u]=c,e}},8880:(e,n,t)=>{var r=t(9781),o=t(3070),i=t(9114);e.exports=r?function(e,n,t){return o.f(e,n,i(1,t))}:function(e,n,t){return e[n]=t,e}},9114:e=>{e.exports=function(e,n){return{enumerable:!(1&e),configurable:!(2&e),writable:!(4&e),value:n}}},6135:(e,n,t)=>{"use strict";var r=t(4948),o=t(3070),i=t(9114);e.exports=function(e,n,t){var a=r(n);a in e?o.f(e,a,i(0,t)):e[a]=t}},8709:(e,n,t)=>{"use strict";var r=t(7854),o=t(9670),i=t(2140),a=r.TypeError;e.exports=function(e){if(o(this),"string"===e||"default"===e)e="string";else if("number"!==e)throw a("Incorrect hint");return i(this,e)}},654:(e,n,t)=>{"use strict";var r=t(2109),o=t(6916),i=t(1913),a=t(6530),l=t(614),c=t(4994),u=t(9518),s=t(7674),f=t(8003),p=t(8880),d=t(1320),h=t(5112),g=t(7497),v=t(3383),A=a.PROPER,b=a.CONFIGURABLE,m=v.IteratorPrototype,y=v.BUGGY_SAFARI_ITERATORS,E=h("iterator"),_="keys",C="values",w="entries",x=function(){return this};e.exports=function(e,n,t,a,h,v,k){c(t,n,a);var S,O,B,I=function(e){if(e===h&&R)return R;if(!y&&e in j)return j[e];switch(e){case _:case C:case w:return function(){return new t(this,e)}}return function(){return new t(this)}},T=n+" Iterator",P=!1,j=e.prototype,z=j[E]||j["@@iterator"]||h&&j[h],R=!y&&z||I(h),M="Array"==n&&j.entries||z;if(M&&(S=u(M.call(new e)))!==Object.prototype&&S.next&&(i||u(S)===m||(s?s(S,m):l(S[E])||d(S,E,x)),f(S,T,!0,!0),i&&(g[T]=x)),A&&h==C&&z&&z.name!==C&&(!i&&b?p(j,"name",C):(P=!0,R=function(){return o(z,this)})),h)if(O={values:I(C),keys:v?R:I(_),entries:I(w)},k)for(B in O)(y||P||!(B in j))&&d(j,B,O[B]);else r({target:n,proto:!0,forced:y||P},O);return i&&!k||j[E]===R||d(j,E,R,{name:h}),g[n]=R,O}},7235:(e,n,t)=>{var r=t(857),o=t(2597),i=t(6061),a=t(3070).f;e.exports=function(e){var n=r.Symbol||(r.Symbol={});o(n,e)||a(n,e,{value:i.f(e)})}},9781:(e,n,t)=>{var r=t(7293);e.exports=!r((function(){return 7!=Object.defineProperty({},1,{get:function(){return 7}})[1]}))},317:(e,n,t)=>{var r=t(7854),o=t(111),i=r.document,a=o(i)&&o(i.createElement);e.exports=function(e){return a?i.createElement(e):{}}},8324:e=>{e.exports={CSSRuleList:0,CSSStyleDeclaration:0,CSSValueList:0,ClientRectList:0,DOMRectList:0,DOMStringList:0,DOMTokenList:1,DataTransferItemList:0,FileList:0,HTMLAllCollection:0,HTMLCollection:0,HTMLFormElement:0,HTMLSelectElement:0,MediaList:0,MimeTypeArray:0,NamedNodeMap:0,NodeList:1,PaintRequestList:0,Plugin:0,PluginArray:0,SVGLengthList:0,SVGNumberList:0,SVGPathSegList:0,SVGPointList:0,SVGStringList:0,SVGTransformList:0,SourceBufferList:0,StyleSheetList:0,TextTrackCueList:0,TextTrackList:0,TouchList:0}},8509:(e,n,t)=>{var r=t(317)("span").classList,o=r&&r.constructor&&r.constructor.prototype;e.exports=o===Object.prototype?void 0:o},8886:(e,n,t)=>{var r=t(8113).match(/firefox\/(\d+)/i);e.exports=!!r&&+r[1]},256:(e,n,t)=>{var r=t(8113);e.exports=/MSIE|Trident/.test(r)},5268:(e,n,t)=>{var r=t(4326),o=t(7854);e.exports="process"==r(o.process)},8113:(e,n,t)=>{var r=t(5005);e.exports=r("navigator","userAgent")||""},7392:(e,n,t)=>{var r,o,i=t(7854),a=t(8113),l=i.process,c=i.Deno,u=l&&l.versions||c&&c.version,s=u&&u.v8;s&&(o=(r=s.split("."))[0]>0&&r[0]<4?1:+(r[0]+r[1])),!o&&a&&(!(r=a.match(/Edge\/(\d+)/))||r[1]>=74)&&(r=a.match(/Chrome\/(\d+)/))&&(o=+r[1]),e.exports=o},8008:(e,n,t)=>{var r=t(8113).match(/AppleWebKit\/(\d+)\./);e.exports=!!r&&+r[1]},748:e=>{e.exports=["constructor","hasOwnProperty","isPrototypeOf","propertyIsEnumerable","toLocaleString","toString","valueOf"]},2109:(e,n,t)=>{var r=t(7854),o=t(1236).f,i=t(8880),a=t(1320),l=t(3505),c=t(9920),u=t(4705);e.exports=function(e,n){var t,s,f,p,d,h=e.target,g=e.global,v=e.stat;if(t=g?r:v?r[h]||l(h,{}):(r[h]||{}).prototype)for(s in n){if(p=n[s],f=e.noTargetGet?(d=o(t,s))&&d.value:t[s],!u(g?s:h+(v?".":"#")+s,e.forced)&&void 0!==f){if(typeof p==typeof f)continue;c(p,f)}(e.sham||f&&f.sham)&&i(p,"sham",!0),a(t,s,p,e)}}},7293:e=>{e.exports=function(e){try{return!!e()}catch(e){return!0}}},7007:(e,n,t)=>{"use strict";t(4916);var r=t(1702),o=t(1320),i=t(2261),a=t(7293),l=t(5112),c=t(8880),u=l("species"),s=RegExp.prototype;e.exports=function(e,n,t,f){var p=l(e),d=!a((function(){var n={};return n[p]=function(){return 7},7!=""[e](n)})),h=d&&!a((function(){var n=!1,t=/a/;return"split"===e&&((t={}).constructor={},t.constructor[u]=function(){return t},t.flags="",t[p]=/./[p]),t.exec=function(){return n=!0,null},t[p](""),!n}));if(!d||!h||t){var g=r(/./[p]),v=n(p,""[e],(function(e,n,t,o,a){var l=r(e),c=n.exec;return c===i||c===s.exec?d&&!a?{done:!0,value:g(n,t,o)}:{done:!0,value:l(t,n,o)}:{done:!1}}));o(String.prototype,e,v[0]),o(s,p,v[1])}f&&c(s[p],"sham",!0)}},6677:(e,n,t)=>{var r=t(7293);e.exports=!r((function(){return Object.isExtensible(Object.preventExtensions({}))}))},2104:e=>{var n=Function.prototype,t=n.apply,r=n.bind,o=n.call;e.exports="object"==typeof Reflect&&Reflect.apply||(r?o.bind(t):function(){return o.apply(t,arguments)})},9974:(e,n,t)=>{var r=t(1702),o=t(9662),i=r(r.bind);e.exports=function(e,n){return o(e),void 0===n?e:i?i(e,n):function(){return e.apply(n,arguments)}}},7065:(e,n,t)=>{"use strict";var r=t(7854),o=t(1702),i=t(9662),a=t(111),l=t(2597),c=t(206),u=r.Function,s=o([].concat),f=o([].join),p={},d=function(e,n,t){if(!l(p,n)){for(var r=[],o=0;o{var n=Function.prototype.call;e.exports=n.bind?n.bind(n):function(){return n.apply(n,arguments)}},6530:(e,n,t)=>{var r=t(9781),o=t(2597),i=Function.prototype,a=r&&Object.getOwnPropertyDescriptor,l=o(i,"name"),c=l&&"something"===function(){}.name,u=l&&(!r||r&&a(i,"name").configurable);e.exports={EXISTS:l,PROPER:c,CONFIGURABLE:u}},1702:e=>{var n=Function.prototype,t=n.bind,r=n.call,o=t&&t.bind(r);e.exports=t?function(e){return e&&o(r,e)}:function(e){return e&&function(){return r.apply(e,arguments)}}},5005:(e,n,t)=>{var r=t(7854),o=t(614),i=function(e){return o(e)?e:void 0};e.exports=function(e,n){return arguments.length<2?i(r[e]):r[e]&&r[e][n]}},1246:(e,n,t)=>{var r=t(648),o=t(8173),i=t(7497),a=t(5112)("iterator");e.exports=function(e){if(null!=e)return o(e,a)||o(e,"@@iterator")||i[r(e)]}},8554:(e,n,t)=>{var r=t(7854),o=t(6916),i=t(9662),a=t(9670),l=t(6330),c=t(1246),u=r.TypeError;e.exports=function(e,n){var t=arguments.length<2?c(e):n;if(i(t))return a(o(t,e));throw u(l(e)+" is not iterable")}},8173:(e,n,t)=>{var r=t(9662);e.exports=function(e,n){var t=e[n];return null==t?void 0:r(t)}},647:(e,n,t)=>{var r=t(1702),o=t(7908),i=Math.floor,a=r("".charAt),l=r("".replace),c=r("".slice),u=/\$([$&'`]|\d{1,2}|<[^>]*>)/g,s=/\$([$&'`]|\d{1,2})/g;e.exports=function(e,n,t,r,f,p){var d=t+e.length,h=r.length,g=s;return void 0!==f&&(f=o(f),g=u),l(p,g,(function(o,l){var u;switch(a(l,0)){case"$":return"$";case"&":return e;case"`":return c(n,0,t);case"'":return c(n,d);case"<":u=f[c(l,1,-1)];break;default:var s=+l;if(0===s)return o;if(s>h){var p=i(s/10);return 0===p?o:p<=h?void 0===r[p-1]?a(l,1):r[p-1]+a(l,1):o}u=r[s-1]}return void 0===u?"":u}))}},7854:(e,n,t)=>{var r=function(e){return e&&e.Math==Math&&e};e.exports=r("object"==typeof globalThis&&globalThis)||r("object"==typeof window&&window)||r("object"==typeof self&&self)||r("object"==typeof t.g&&t.g)||function(){return this}()||Function("return this")()},2597:(e,n,t)=>{var r=t(1702),o=t(7908),i=r({}.hasOwnProperty);e.exports=Object.hasOwn||function(e,n){return i(o(e),n)}},3501:e=>{e.exports={}},490:(e,n,t)=>{var r=t(5005);e.exports=r("document","documentElement")},4664:(e,n,t)=>{var r=t(9781),o=t(7293),i=t(317);e.exports=!r&&!o((function(){return 7!=Object.defineProperty(i("div"),"a",{get:function(){return 7}}).a}))},8361:(e,n,t)=>{var r=t(7854),o=t(1702),i=t(7293),a=t(4326),l=r.Object,c=o("".split);e.exports=i((function(){return!l("z").propertyIsEnumerable(0)}))?function(e){return"String"==a(e)?c(e,""):l(e)}:l},9587:(e,n,t)=>{var r=t(614),o=t(111),i=t(7674);e.exports=function(e,n,t){var a,l;return i&&r(a=n.constructor)&&a!==t&&o(l=a.prototype)&&l!==t.prototype&&i(e,l),e}},2788:(e,n,t)=>{var r=t(1702),o=t(614),i=t(5465),a=r(Function.toString);o(i.inspectSource)||(i.inspectSource=function(e){return a(e)}),e.exports=i.inspectSource},2423:(e,n,t)=>{var r=t(2109),o=t(1702),i=t(3501),a=t(111),l=t(2597),c=t(3070).f,u=t(8006),s=t(1156),f=t(2050),p=t(9711),d=t(6677),h=!1,g=p("meta"),v=0,A=function(e){c(e,g,{value:{objectID:"O"+v++,weakData:{}}})},b=e.exports={enable:function(){b.enable=function(){},h=!0;var e=u.f,n=o([].splice),t={};t[g]=1,e(t).length&&(u.f=function(t){for(var r=e(t),o=0,i=r.length;o{var r,o,i,a=t(8536),l=t(7854),c=t(1702),u=t(111),s=t(8880),f=t(2597),p=t(5465),d=t(6200),h=t(3501),g="Object already initialized",v=l.TypeError,A=l.WeakMap;if(a||p.state){var b=p.state||(p.state=new A),m=c(b.get),y=c(b.has),E=c(b.set);r=function(e,n){if(y(b,e))throw new v(g);return n.facade=e,E(b,e,n),n},o=function(e){return m(b,e)||{}},i=function(e){return y(b,e)}}else{var _=d("state");h[_]=!0,r=function(e,n){if(f(e,_))throw new v(g);return n.facade=e,s(e,_,n),n},o=function(e){return f(e,_)?e[_]:{}},i=function(e){return f(e,_)}}e.exports={set:r,get:o,has:i,enforce:function(e){return i(e)?o(e):r(e,{})},getterFor:function(e){return function(n){var t;if(!u(n)||(t=o(n)).type!==e)throw v("Incompatible receiver, "+e+" required");return t}}}},7659:(e,n,t)=>{var r=t(5112),o=t(7497),i=r("iterator"),a=Array.prototype;e.exports=function(e){return void 0!==e&&(o.Array===e||a[i]===e)}},3157:(e,n,t)=>{var r=t(4326);e.exports=Array.isArray||function(e){return"Array"==r(e)}},614:e=>{e.exports=function(e){return"function"==typeof e}},4411:(e,n,t)=>{var r=t(1702),o=t(7293),i=t(614),a=t(648),l=t(5005),c=t(2788),u=function(){},s=[],f=l("Reflect","construct"),p=/^\s*(?:class|function)\b/,d=r(p.exec),h=!p.exec(u),g=function(e){if(!i(e))return!1;try{return f(u,s,e),!0}catch(e){return!1}};e.exports=!f||o((function(){var e;return g(g.call)||!g(Object)||!g((function(){e=!0}))||e}))?function(e){if(!i(e))return!1;switch(a(e)){case"AsyncFunction":case"GeneratorFunction":case"AsyncGeneratorFunction":return!1}return h||!!d(p,c(e))}:g},4705:(e,n,t)=>{var r=t(7293),o=t(614),i=/#|\.prototype\./,a=function(e,n){var t=c[l(e)];return t==s||t!=u&&(o(n)?r(n):!!n)},l=a.normalize=function(e){return String(e).replace(i,".").toLowerCase()},c=a.data={},u=a.NATIVE="N",s=a.POLYFILL="P";e.exports=a},111:(e,n,t)=>{var r=t(614);e.exports=function(e){return"object"==typeof e?null!==e:r(e)}},1913:e=>{e.exports=!1},7850:(e,n,t)=>{var r=t(111),o=t(4326),i=t(5112)("match");e.exports=function(e){var n;return r(e)&&(void 0!==(n=e[i])?!!n:"RegExp"==o(e))}},2190:(e,n,t)=>{var r=t(7854),o=t(5005),i=t(614),a=t(7976),l=t(3307),c=r.Object;e.exports=l?function(e){return"symbol"==typeof e}:function(e){var n=o("Symbol");return i(n)&&a(n.prototype,c(e))}},408:(e,n,t)=>{var r=t(7854),o=t(9974),i=t(6916),a=t(9670),l=t(6330),c=t(7659),u=t(6244),s=t(7976),f=t(8554),p=t(1246),d=t(9212),h=r.TypeError,g=function(e,n){this.stopped=e,this.result=n},v=g.prototype;e.exports=function(e,n,t){var r,A,b,m,y,E,_,C=t&&t.that,w=!(!t||!t.AS_ENTRIES),x=!(!t||!t.IS_ITERATOR),k=!(!t||!t.INTERRUPTED),S=o(n,C),O=function(e){return r&&d(r,"normal",e),new g(!0,e)},B=function(e){return w?(a(e),k?S(e[0],e[1],O):S(e[0],e[1])):k?S(e,O):S(e)};if(x)r=e;else{if(!(A=p(e)))throw h(l(e)+" is not iterable");if(c(A)){for(b=0,m=u(e);m>b;b++)if((y=B(e[b]))&&s(v,y))return y;return new g(!1)}r=f(e,A)}for(E=r.next;!(_=i(E,r)).done;){try{y=B(_.value)}catch(e){d(r,"throw",e)}if("object"==typeof y&&y&&s(v,y))return y}return new g(!1)}},9212:(e,n,t)=>{var r=t(6916),o=t(9670),i=t(8173);e.exports=function(e,n,t){var a,l;o(e);try{if(!(a=i(e,"return"))){if("throw"===n)throw t;return t}a=r(a,e)}catch(e){l=!0,a=e}if("throw"===n)throw t;if(l)throw a;return o(a),t}},3383:(e,n,t)=>{"use strict";var r,o,i,a=t(7293),l=t(614),c=t(30),u=t(9518),s=t(1320),f=t(5112),p=t(1913),d=f("iterator"),h=!1;[].keys&&("next"in(i=[].keys())?(o=u(u(i)))!==Object.prototype&&(r=o):h=!0),null==r||a((function(){var e={};return r[d].call(e)!==e}))?r={}:p&&(r=c(r)),l(r[d])||s(r,d,(function(){return this})),e.exports={IteratorPrototype:r,BUGGY_SAFARI_ITERATORS:h}},7497:e=>{e.exports={}},6244:(e,n,t)=>{var r=t(7466);e.exports=function(e){return r(e.length)}},133:(e,n,t)=>{var r=t(7392),o=t(7293);e.exports=!!Object.getOwnPropertySymbols&&!o((function(){var e=Symbol();return!String(e)||!(Object(e)instanceof Symbol)||!Symbol.sham&&r&&r<41}))},8536:(e,n,t)=>{var r=t(7854),o=t(614),i=t(2788),a=r.WeakMap;e.exports=o(a)&&/native code/.test(i(a))},3929:(e,n,t)=>{var r=t(7854),o=t(7850),i=r.TypeError;e.exports=function(e){if(o(e))throw i("The method doesn't accept regular expressions");return e}},1574:(e,n,t)=>{"use strict";var r=t(9781),o=t(1702),i=t(6916),a=t(7293),l=t(1956),c=t(5181),u=t(5296),s=t(7908),f=t(8361),p=Object.assign,d=Object.defineProperty,h=o([].concat);e.exports=!p||a((function(){if(r&&1!==p({b:1},p(d({},"a",{enumerable:!0,get:function(){d(this,"b",{value:3,enumerable:!1})}}),{b:2})).b)return!0;var e={},n={},t=Symbol(),o="abcdefghijklmnopqrst";return e[t]=7,o.split("").forEach((function(e){n[e]=e})),7!=p({},e)[t]||l(p({},n)).join("")!=o}))?function(e,n){for(var t=s(e),o=arguments.length,a=1,p=c.f,d=u.f;o>a;)for(var g,v=f(arguments[a++]),A=p?h(l(v),p(v)):l(v),b=A.length,m=0;b>m;)g=A[m++],r&&!i(d,v,g)||(t[g]=v[g]);return t}:p},30:(e,n,t)=>{var r,o=t(9670),i=t(6048),a=t(748),l=t(3501),c=t(490),u=t(317),s=t(6200),f=s("IE_PROTO"),p=function(){},d=function(e){return" + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Changelog

+

All notable changes to this project will be documented in this document.

+

The format is based on Keep a Changelog, +and this project adheres to Semantic Versioning.

+

Unreleased

+

Changed

+
    +
  • Upgrade to Kotlin 1.9.24.
  • +
  • Upgrade to Coroutines 1.8.1.
  • +
  • Upgrade to Gradle 8.7.
  • +
  • Upgrade to AGP to 8.4.0.
  • +
  • Upgrade to Wire 4.9.9.
  • +
  • Upgrade to KotlinPoet 1.16.0.
  • +
  • Upgrade to DataStore 1.1.1.
  • +
  • Upgrade to ViewPager2 1.3.2.
  • +
  • Upgrade to ViewModel-ktx 2.8.0.
  • +
  • Upgrade to Fragment-ktx 1.7.1.
  • +
  • Upgrade to RecyclerView 1.3.2.
  • +
  • Upgrade to Material 1.12.0.
  • +
  • Upgrade to Hyperion 0.9.38.
  • +
  • Downgrade target and source compatibilities versions to Java 11.
  • +
  • Change compile and target SDK to 34.
  • +
+

1.1.0 - 2023-06-13

+

Changed

+
    +
  • Upgrade to Kotlin 1.8.21.
  • +
  • Upgrade to Coroutines 1.6.4.
  • +
  • Upgrade to Gradle 8.1.1.
  • +
  • Upgrade to Wire 4.7.0.
  • +
  • Upgrade to KotlinPoet 1.14.2.
  • +
  • Upgrade to Hyperion 0.9.37.
  • +
  • Upgrade to AppCompat 1.6.1.
  • +
  • Upgrade to ViewModel-ktx 2.6.1.
  • +
  • Upgrade to Fragment-ktx 1.5.7.
  • +
  • Upgrade to RecyclerView 1.3.0.
  • +
  • Upgrade to Material 1.9.0.
  • +
  • Upgrade target and source compatibilities versions to Java 17.
  • +
  • Change compile and target SDK to 33.
  • +
+

1.0.3 - 2022-10-01

+

Fixed

+
    +
  • Generating feature flags and related classes to empty Kotlin source sets in Kotlin 1.7.20.
  • +
+

1.0.2 - 2022-09-29

+

Fixed

+
    +
  • Fixed IllegalArgumentException: Did not find Kotlin source set after upgrading to Kotlin 1.7.20.
  • +
+

1.0.1 - 2022-06-21

+

Added

+ +

Removed

+
    +
  • CoreKtx dependency.
  • +
+

1.0.0 - 2021-02-06

+

Added

+
    +
  • setOptions(options) overload which accepts collection instead of varargs.
  • +
+

Removed

+
    +
  • ConstraintLayout dependency.
  • +
  • DynamicAnimation dependency.
  • +
+

1.0.0-rc2 - 2021-12-28

+

Changed

+
    +
  • SharedPreferencesFeatureStorage no marked as experimental due to coroutines.
  • +
  • Upgrade to Kotlin 1.6.10.
  • +
  • Upgrade to Coroutines 1.6.0.
  • +
  • Upgrade to Wire 4.0.1.
  • +
+

Fixed

+
    +
  • Handle usage of deprecated features in a generated OptionFactory.
  • +
+

Removed

+
    +
  • Builders for generator models. Models are now created via constructors and throw if data is invalid.
  • +
  • GenerationFailure interface.
  • +
  • Arrow dependency.
  • +
+

1.0.0-rc1 - 2021-12-22

+

Added

+
    +
  • Multi-module setup no longer includes other modules implicitly. Instead each module needs to be included via dependency function in Gradle. +
    laboratory {
    +  featureFactory()
    +
    +  // Before, these were included implicitly.
    +  dependency(project(":module-a"))
    +  dependency(project(":module-b"))
    +}
    +
  • +
+

Changed

+
    +
  • Upgrade Android target and compile SDK to 31.
  • +
  • Upgrade to LifecycleViewmodelKtx 2.4.0.
  • +
  • Upgrade to KotlinPoet 1.10.2.
  • +
  • Upgrade to Wire 4.0.0.
  • +
  • Upgrade to Kotlin 1.6.0.
  • +
  • Upgrade to ConstraintLayout 2.1.2.
  • +
  • Upgrade to FragmentKtx 1.4.0.
  • +
  • Upgrade to AppCompat 1.4.0.
  • +
+

Removed

+
    +
  • Groovy DSL introduced in 0.9.0 for adding feature flags.
  • +
  • projectFilter properties from Gradle plugin. Use explicit dependencies instead.
  • +
  • Deprecated API.
  • +
+

Fixed

+
    +
  • Overrides of sources in DefaultOptionFactory are now respected by Laboratory - #220.
  • +
+

0.14.0 - 2021-10-11

+

Added

+
    +
  • Better integration with remote sources, like Firebase, via OptionFactory interface. It creates feature options based on a feature key and an option name.
  • +
  • Code generation of option factory via Gradle plugin.
  • +
+

Changed

+
    +
  • Make Feature and other related classes covariant.
  • +
  • FeatureStorage functions are no longer parameterized over Feature. They accept raw class type instead.
  • +
  • Generator and Gradle plugin no longer validate package names, duplicates and other things that are checked by compiler.
  • +
  • Model builders accept now ClassName in constructor.
  • +
  • Mark SharedPreferencesFeatureStorage with ExperimentalCoroutinesApi annotation.
  • +
  • Upgrade to Kotlin 1.5.31.
  • +
  • Upgrade to Material 1.4.0.
  • +
  • Upgrade to CoreKtx 1.6.0.
  • +
  • Upgrade to DataStore 1.0.0.
  • +
  • Upgrade to AGP 4.2.2.
  • +
  • Upgrade to Hyperion 0.9.34.
  • +
  • Upgrade to FragmentKtx 1.3.6.
  • +
  • Upgrade to AppCompat 1.3.1.
  • +
  • Upgrade to ConstraintLayout 2.1.1.
  • +
  • Upgrade to ArrowKt 1.0.0.
  • +
  • Upgrade to Coroutines 1.5.2.
  • +
  • Upgrade to KotlinPoet 1.10.1.
  • +
+

Deprecated

+
    +
  • FeatureStorage.Companion.sharedPreferences(Context) function. Use overload that accepts SharedPreferences instead.
  • +
  • FeatureStorage.Companion.dataStore(() -> File) function. Use overload that accepts DataStore instead.
  • +
  • FeatureStorage.Companion.dataStore(Context, String) function. Use overload that accepts DataStore instead.
  • +
  • generate() methods on generation models. Use prepare() and operate on FileSpec directly instead.
  • +
+

Removed

+
    +
  • Dependency on Kyrie.
  • +
  • Dependency on JCenter.
  • +
+

0.13.1 - 2021-06-27

+

Changed

+
    +
  • Upgrade to Kotlin 1.5.20.
  • +
  • Upgrade to RecyclerView 1.2.1.
  • +
  • Upgrade to FragmentKtx 1.3.5.
  • +
  • Upgrade to DataStore 1.0.0-beta02.
  • +
  • Upgrade to KotlinPoet 1.9.0.
  • +
  • Upgrade to CoreKtx 1.5.0.
  • +
  • Upgrade to AppCompat 1.3.0.
  • +
+

0.13.0 - 2021-05-17

+

Changed

+
    +
  • Drop deprecated @JvmDefault and switch to JVM default modes.
  • +
  • Upgrade to Kotlin 1.5.0.
  • +
  • Upgrade to Coroutines 1.5.0.
  • +
  • Upgrade to AGP 4.2.1.
  • +
  • Upgrade to KotlinPoet 1.8.0.
  • +
  • Upgrade to RecyclerView 1.2.0.
  • +
  • Upgrade to Hyperion 0.9.32.
  • +
  • Upgrade to FragmentKtx 1.3.3.
  • +
  • Upgrade to DataStore 1.0.0-beta01.
  • +
+

0.12.1 - 2021-03-28

+

Added

+
    +
  • Indication that an option is a supervisor. If an option supervises features it has an eye icon next to it. List of supervised features is available after long pressing a chip.
  • +
  • Navigation from supervised feature to supervisor.
  • +
  • Navigation from supervisor to supervised feature.
  • +
  • Amount of offscreen feature sections in inspector can be controlled with LaboratoryActivity.Configuration.OffscreenSectionsBehavior. Default is unlimited.
  • +
+

Changed

+
    +
  • Upgrade to Kotlin 1.4.32.
  • +
  • Upgrade to LifecycleViewmodelKtx 2.3.1.
  • +
  • Upgrade to FragmentKtx 1.3.2.
  • +
  • Upgrade to Wire 3.7.0.
  • +
+

0.12.0 - 2021-03-21

+

Added

+
    +
  • Gradle plugin generates sourcedBuilder() extension function for SourcedFeatureStorage that returns custom builder with steps for each source. This makes changes to sources compile time safe.
  • +
  • Show feature’s supervisor option in inspector – #95.
  • +
+

Changed

+
    +
  • Upgrade to Coroutines 1.4.3.
  • +
  • Upgrade to AGP 4.1.3.
  • +
+

Deprecated

+
    +
  • sourcedGenerated() extension function generated by Gradle plugin.
  • +
+

0.11.0 - 2021-03-11

+

Changed

+
    +
  • Use proto3 for FeatureFlags definition.
  • +
  • Upgrade to DataStore 1.0.0-alpha08.
  • +
  • Upgrade to Kotlin 1.4.31.
  • +
  • Upgrade to Wire 3.6.1.
  • +
  • Upgrade to FragmentKtx 1.3.1.
  • +
+

0.10.0 - 2021-02-18

+

Added

+
    +
  • Parent–child relationship to Feature. This relationship is controlled with a Feature.supervisorOption property. Whenever supervisor has its option different from this value then the supervised feature flag cannot return any other option than a default one. Option can still be set via Laboratory but it will not be exposed as long as a feature flag is not supervised. This relationship is recursive meaning that grandparents control grandchildren indirectly.
  • +
  • Code generation of supervisor options via Gradle plugin.
  • +
+

Changed

+
    +
  • Gradle plugin no longer changes implicit package name multiple times. Only last value that was set is applied in configuration.
  • +
  • Upgrade to DataStore 1.0.0-alpha06.
  • +
  • Upgrade to AGP 4.1.2.
  • +
  • Upgrade to Kotlin 1.4.30.
  • +
  • Upgrade to Wire 3.6.0.
  • +
  • Upgrade to Material 1.3.0.
  • +
  • Upgrade to FragmentKtx 1.3.0.
  • +
  • Upgrade to LifecycleViewmodelKtx 2.3.0.
  • +
  • Upgrade to Hyperion 0.9.31.
  • +
+

Fixed

+
    +
  • Search icon not animating on Android below SDK 24.
  • +
+

Deprecated

+
    +
  • DataStore custom builder and builder factory methods. Factory method that accepts DataStore directly should be used instead.
  • +
+

0.9.7 - 2020-12-15

+

Changed

+
    +
  • DeprecationLevel.Hidden is no longer deprecated. It was a mistake to deprecate it at all since it could work from the start.
  • +
+

0.9.6 - 2020-12-15

+

Added

+
    +
  • FeatureFactory can be now appended to another with plus operator.
  • +
  • DefaultOptionFactory can be now appended to another with plus operator.
  • +
+

Changed

+
    +
  • Use description as feature flag’s KDoc content.
  • +
  • Upgrade Kotlin to 1.4.21.
  • +
+

Deprecated

+
    +
  • Using DeprecationLevel.Hidden is temporarily treated as an error until the compiler issue is fixed.
  • +
+

Fixed

+
    +
  • Make updates to the in-memory Laboratory atomic.
  • +
+

0.9.5 - 2020-12-03

+

Added

+
    +
  • Builder pattern for LaboratoryActivity.Configuration construction.
  • +
  • Visual representation of deprecated feature flags in the QA module.
  • +
  • Visual representation of deprecated feature flags can be configured via LaboratoryActivity.Configuration builder with deprecationPhenotypeSelector() and deprecationAlignmentSelector() functions.
  • +
  • Consumer ProGuard rules to laboratory-inspector to keep @Deprecated annotation.
  • +
  • QA module displays clickable hyperlinks from a feature flag description if it contains Markdown formatted links.
  • +
+

Changed

+
    +
  • Upgrade to DataStore 1.0.0-alpha05.
  • +
+

Deprecated

+
    +
  • LaboratoryActivity.Configuration() constructor. Use LaboratoryActivity.Configuration.create() or LaboratoryActivity.Configuration.builder() instead.
  • +
+

Fixed

+
    +
  • Warning and error level deprecation on generated feature flags is now correctly suppressed.
  • +
+

0.9.4 - 2020-11-27

+

Added

+
    +
  • Kyrie 0.2.1 to laboratory-inspector.
  • +
  • DynamicAnimation 1.0.0 to laboratory-inspector.
  • +
+

Changed

+
    +
  • Animation of search feature in inspector. It no longer makes ugly visibility transitions.
  • +
  • Upgrade to Coroutines 1.4.2.
  • +
+

0.9.3 - 2020-11-23

+

Added

+
    +
  • Feature flags filtering to the QA module. Features are filtered by their name, options or source options.
  • +
  • ConstraintLayout 2.0.4 to laboratory-inspector.
  • +
+

Changed

+
    +
  • Inspector tabs are now scrollable instead of fixed.
  • +
  • Upgrade to Kotlin 1.4.20.
  • +
+

Fixed

+
    +
  • Shared preferences based FeatureStorage dispatches now changes to feature flag observers when clear() method is used. This fixes an issue with the QA module where it did not update the UI after resetting feature flags if shared preferences where used for feature flags persistence.
  • +
  • Preserve feature flags preview adapter scroll position on configuration changes.
  • +
  • External feature factories are no longer filtered out when added with the configure() function.
  • +
+

0.9.2 - 2020-11-18

+

Added

+
    +
  • BlockingLaboratory class that can read and write feature flags via blocking API.
  • +
  • blocking() function to Laboratory class that is an entry point to the blocking API.
  • +
  • Deprecation of feature flags from the Gradle plugin with deprecated(message, level) method. level argument is optional and a warning level is used by default.
  • +
+

Changed

+
    +
  • Upgrade to DataStore 1.0.0-alpha04.
  • +
+

Deprecated

+
    +
  • All blocking functions on the Laboratory class. BlockingLaboratory available via blocking() function should be used instead.
  • +
+

0.9.1 - 2020-11-12

+

Added

+
    +
  • Builder pattern for Laboratory construction.
  • +
  • DefaultOptionFactory that can substitute default options for feature flags read by Laboratory.
  • +
  • clear() function to FeatureStorage and Laboratory.
  • +
+

Changed

+
    +
  • Upgrade to DataStore 1.0.0-alpha03.
  • +
+

Deprecated

+
    +
  • Laboratory(storage) constructor. Use Laboratory.create(storage) or Laboratory.builder() instead.
  • +
+

0.9.0 - 2020-11-11

+

Added

+
    +
  • Groovy DSL for adding feature flags via Gradle plugin. This is equivalent to feature("SomeFeatureFlag") function. +
    laboratory {
    +  SomeFeatureFlag {
    +    withDefaultOption("Enabled")
    +    withOption("Disabled")
    +  }
    +}
    +
  • +
  • options extension to Class<Feature<T>> that returns all available feature flag options.
  • +
  • defaultOption extension to Class<Feature<T>> that returns a default option of a feature flag.
  • +
  • source extension to Class<Feature<*>> that returns a feature flag source if available.
  • +
  • description extension to Class<Feature<*>> that returns a feature flag description if available.
  • +
  • withOption() and withDefaultOption() to Gradle plugin for adding options to feature flags.
  • +
  • defaultOption property to Feature interface.
  • +
  • setOption() and setOptions() functions to Laboratory and FeatureStorage.
  • +
+

Changed

+
    +
  • excludeProjects plugin functions are now called projectFilter and the condition is reversed. Previously they removed projects that matched a condition. Now they allow projects that match it.
  • +
  • sourcedWith property on Feature is now named source.
  • +
  • Upgrade to Coroutines 1.4.1.
  • +
+

Deprecated

+
    +
  • withValue() and withDefaultValue() functions in Gradle plugin. withOption() and withDefaultOption() should be used instead.
  • +
  • setFeature() and setFeatures() functions. setOption() and setOptions() should be used instead.
  • +
+

Removed

+
    +
  • ProjectFilter from laboratory-gradle-plugin in favour of java.util.function.Predicate.
  • +
  • configure() overload which accepts sources factory as a separate argument.
  • +
  • isDefaultValue from Feature interface. defaultOption should be used instead.
  • +
+

Fixed

+
    +
  • Moved generateSourcedFeatureStorage task to a correct tasks group.
  • +
+

0.8.0 - 2020-10-28

+

Added

+
    +
  • KDoc documentation.
  • +
+

Changed

+
    +
  • Renamed feature/features argument in setFeature() and setFeatures() methods to value/values respectively.
  • +
  • Elevation is no longer an attribute in the IoMehowLaboratory.Theme and a regular resource is used instead. This makes sure that when an Activity theme is overridden externally it won’t crash for an unknown attribute.
  • +
  • Flatten Hyperion button to visually match other items.
  • +
  • Upgrade to Coroutines 1.4.0.
  • +
  • Upgrade to Wire 3.5.0.
  • +
+

Removed

+
    +
  • generateFactory property from sourcedFeatureStorage() method in Gradle plugin. It was added to the public API by a mistake and wasn’t responsible for anything.
  • +
  • Wire dependency from the library-shared-preferences artifact. It was added by a mistake.
  • +
  • BuildConfig classes from Android library modules.
  • +
+

0.7.0 - 2020-10-22

+

Changed

+
    +
  • Changelog format follows now Keep a Changelog format. Format is applied retroactively to this file.
  • +
  • R8 rules are now a part of META-INF of the laboratory artifact.
  • +
  • SharedPreferencesFeatureStorage is now internal.
  • +
  • Gradle plugin no longer has a runtime dependency on Android Gradle Plugin.
  • +
  • laboratory-generator generates source code compatible with the explicit API mode.
  • +
  • Set compile SDK to 30.
  • +
  • Upgrade to KotlinPoet 1.7.2.
  • +
  • Upgrade to Hyperion 0.9.30.
  • +
  • Upgrade to DataStore 1.0.0-alpha02.
  • +
+

0.6.2 - 2020-10-12

+

Added

+
    +
  • FeatureStorage extensions for creation of SharedPreferences based FeatureStorage.
  • +
  • FeatureStorage extensions for creation of DataStore based FeatureStorage.
  • +
  • Hyperion plugin can be ordered in the debug menu by overriding io_mehow_laboratory_plugin_id resource.
  • +
+

Deprecated

+
    +
  • SharedPreferenceFeatureStorage soon will become internal.
  • +
+

Changed

+
    +
  • DataStoreFeatureStorage is now internal. It is not considered a breaking change as DataStore is in the alpha stage.
  • +
+

0.6.1 - 2020-10-12

+

Fixed

+
    +
  • Hyperion plugin layout where button was on the wrong side of the debug menu.
  • +
+

0.6.0 - 2020-10-12

+

Added

+
    +
  • Feature can have now description. It can be used to add more contextual data to feature flags.
  • +
  • LaboratoryActivity observes changes to feature flags instead of loading them every time the screen is opened.
  • +
  • LaboratoryActivity displays feature flag sources next to them and allows users to select a source from a drop down menu.
  • +
  • Remote feature flag values are displayed in LaboratoryActivity if a source is not local.
  • +
  • When a remote source is used for a feature flag a value cannot be changed from LaboratoryActivity.
  • +
  • LaboratoryActivity displays feature flag descriptions if they are present.
  • +
  • LaboratoryActivity can reset feature flag values to their default state from an item in the action bar.
  • +
  • Laboratory.experimentIs() and Laboratory.experimentIsBlocking() functions that allow to check if a feature flag has particular value.
  • +
  • ViewPager2 1.0.0 dependency to laboratory-inspector.
  • +
  • RecyclerView 1.1.0 dependency to laboratory-inspector.
  • +
+

Changed

+
    +
  • LaboratoryActivity requires now a Laboratory instance for initialization. This Laboratory should share FeatureStorage with instances of Laboratory used in the application.
  • +
+

0.5.0 - 2020-10-08

+

Changed

+
    +
  • fallback nomenclature to default. This affects Gradle plugin withFallbackValue() and withFallbackSources() functions as well as isFallbackValue property on the Feature interface.
  • +
+

0.4.0 - 2020-10-08

+

Changed

+
    +
  • Name of the generated sourced FeatureStorage extension function is now sourcedGenerated() in order to align it with the generated feature factory extension function name.
  • +
+

0.3.0 - 2020-10-08

+

Added

+
    +
  • Feature flags can have multiple sources. Source is also a feature flag and is optional. If no source is available it is assumed that only a local source is controlled.
  • +
  • FeatureStorage that connects feature flags with their sources. It is available via FeatureStorage.sourced() extension function. Feature flag sources are uniquely identified only by their value names.
  • +
  • Feature flag sources can be set from the Gradle plugin with withSource("Name") and withFallbackSource("Name") functions in feature() blocks. Any source that has the name “Local” (or a variant of it) is filtered out.
  • +
  • Gradle plugin has a new sourcedStorage() function. It is responsible for generating a customized FeatureStorage that is aware of all available feature flag sources.
  • +
  • Gradle plugin has a new featureSourceFactory() function. It works similarly to featureFactory() function with a difference that it collects only feature flag sources.
  • +
  • LaboratoryActivity is now configurable with the configure() function.
  • +
  • LaboratoryActivity can display different sets of feature flags on separate tabs.
  • +
  • FragmentKtx 1.2.5 dependency to laboratory-inspector.
  • +
  • ViewModelKtx 2.2.0 dependency to laboratory-inspector.
  • +
+

Changed

+
    +
  • LaboratoryActivity.initialize() function is renamed to configure().
  • +
  • Gradle plugin factory() function is renamed to featureFactory().
  • +
+

0.2.1 - 2020-10-02

+

Added

+
    +
  • Laboratory exposes a blocking way of reading and writing feature flags. It requires an opt-in BlockingIoCall annotation.
  • +
+

Changed

+
    +
  • laboratory-android artifact is now laboratory-shared-preferences artifact.
  • +
  • laboratory-shared-preferences artifact (old laboratory-android) is no longer automatically applied by Gradle plugin in Android modules.
  • +
  • Upgrade to Kotlin 1.4.10.
  • +
  • Upgrade to CoreKtx 1.3.2.
  • +
  • Upgrade to Wire 3.4.0.
  • +
  • Upgrade to KotlinPoet 1.6.0.
  • +
+

0.2.0 - 2020-09-05

+

Added

+
    +
  • Laboratory.observe() function to observe feature flag changes via Flow.
  • +
  • Support for DataStore with the laboratory-data-store artifact.
  • +
  • Laboratory and FeatureStorage return a boolean information whether writes are successful.
  • +
  • Feature interface that is used to define feature flags.
  • +
  • Wire 3.2.2 dependency to laboratory-data-store.
  • +
+

Changed

+
    +
  • Kotlin standard library is now part of the public API.
  • +
  • Laboratory and FeatureStorage expose their API via suspend functions.
  • +
  • Gradle plugin requires exactly one feature flag value to be added with withFallbackValue("Name") function.
  • +
  • Upgrade to Kotlin 1.4.0.
  • +
  • Upgrade to Material 1.2.1.
  • +
  • Upgrade to Hyperion 0.9.29.
  • +
+

Removed

+
    +
  • @Feature annotation. Feature flags should implement the Feature interface.
  • +
+

0.1.0 - 2020-08-03

+
    +
  • Initial release.
  • +
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/css/site.css b/css/site.css new file mode 100644 index 000000000..7590b496d --- /dev/null +++ b/css/site.css @@ -0,0 +1,10 @@ +.md-typeset h1, .md-typeset h2, .md-typeset h3, .md-typeset h4 { + line-height: normal; + font-weight: bold; + color: #353535; +} + +.center { + display: block; + margin: 0 auto; +} diff --git a/gradle-plugin/index.html b/gradle-plugin/index.html new file mode 100644 index 000000000..aea7b023e --- /dev/null +++ b/gradle-plugin/index.html @@ -0,0 +1,1148 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + Gradle plugin - Laboratory + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Gradle plugin

+

Gradle plugin’s main job is to make your life easier when creating and managing feature flags. It generates features, feature factories, and customized sourced feature storage. Plugin, additionally, verifies things that cannot be represented by the API. For example, it checks if a feature flag has exactly one default option defined.

+

Under the hood, the Gradle plugin uses KotlinPoet to generate compact source files.

+
+

Info

+

The Gradle plugin automatically adds the laboratory artifact to dependencies.

+
+
+

Tip

+

The best way to understand the Gradle plugin is to check the samples. It uses most of the Gradle plugin features that most of the applications need.

+
+

Feature flags

+

Feature flags are added to the generation process with a feature() function, which uses the generateFeatureFlags Gradle task. Here is a sample configuration.

+
+

Tip

+

Check the sample with demo configuration.

+
+
apply plugin: "io.mehow.laboratory"
+
+laboratory {
+  packageName = "io.mehow.laboratory.sample"
+
+  feature("Authentication") {
+    description = "Type of authentication when opening the app"
+
+    withOption("None")
+    withOption("Fingerprint")
+    withDefaultOption("Retina")
+  }
+
+  feature("LocationTracking") {
+    packageName = "io.mehow.laboratory.location"
+
+    isPublic = false
+
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+
+    withDefaultSource("Firebase")
+    withSource("Aws")
+  }
+}
+
+

This setup creates two feature flags. Authentication and LocationTracking with options taken from the feature(name) { } block. Key things that might not be that obvious.

+
    +
  • Feature flag source visibility is inherited from a feature’s visibility.
  • +
  • If a feature flag defines a remote source, a Local source is automatically added as an option. Any custom Local sources will be filtered out.
  • +
  • If all sources are added with withSource() function, Local source will be used as a default one.
  • +
+
package io.mehow.laboratory.sample
+
+import io.mehow.laboratory.Feature
+import kotlin.Boolean
+import kotlin.String
+
+public enum class Authentication : Feature<Authentication> {
+  Password,
+  Fingerprint,
+  Retina,
+  ;
+
+  public override val defaultOption get() = Retina
+
+  public override val description: String = "Type of authentication when opening the app"
+}
+
+
package io.mehow.laboratory.location
+
+import io.mehow.laboratory.Feature
+import java.lang.Class
+import kotlin.Boolean
+import kotlin.Suppress
+
+internal enum class LocationTracking : LocationTracking<Authentication> {
+  Enabled,
+  Disabled,
+  ;
+
+  public override val defaultOption get() = Disabled
+
+  public override val source = Source::class.java
+
+  internal enum class Source : Feature<Source> {
+    Local,
+    Firebase,
+    Aws,
+    ;
+
+    public override val defaultOption get() = Firebase
+  }
+}
+
+

Supervision

+

Gradle plugin supports generation of supervised feature flags.

+
+

Tip

+

Check the sample with demo configuration.

+
+
laboratory {
+  feature("ChristmasTheme") {
+    withDefaultOption("Disabled")
+
+    withOption("Enabled") { enabledChristmas ->
+      enabledChristmas.feature("Greeting") { greeting ->
+        greeting.withDefaultOption("Hello")
+        greeting.withOption("HoHoHo")
+      }
+
+      enabledChristmas.feature("Background") { background ->
+        background.withDefaultOption("White")
+        background.withOption("Reindeer")
+        background.withOption("Snowman")
+      }
+    }
+  }
+}
+
+

This configuration generates the code below.

+
enum class ChristmasTheme : Feature<ChristmasTheme> {
+  Enabled,
+  Disabled,
+  ;
+
+  public override val defaultOption get() = Disabled
+}
+
+enum class Greeting : Feature<Greeting> {
+  Hello,
+  HoHoHo,
+  ;
+
+  public override val defaultOption get() = Hello
+
+  public override val supervisorOption get() = ChristmasTheme.Enabled
+}
+
+enum class Background : Feature<Background> {
+  White,
+  Reindeer,
+  Snowman,
+  ;
+
+  public override val defaultOption get() = White
+
+  public override val supervisorOption get() = ChristmasTheme.Enabled
+}
+
+

DSL for supervised feature flags is recursive allowing to nest them in withOption() and withDefaultOption() functions.

+

Feature flags storage

+

If your feature flags use multiple sources, you can configure the Gradle plugin to generate for you a quality of life extension function that returns a custom FeatureStorage builder.

+
apply plugin: "io.mehow.laboratory"
+
+laboratory {
+  packageName = "io.mehow.laboratory.sample"
+
+  sourcedStorage()
+
+  feature("FeatureA") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+
+    withSource("Azure")
+    withSource("Firebase")
+  }
+
+  feature("FeatureB") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+
+    withSource("Azure")
+    withSource("Aws")
+  }
+
+  feature("FeatureC") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+
+    withSource("Heroku")
+  }
+
+  feature("FeatureD") {
+    withDefaultOption("Enabled")
+    withOption("Disabled")
+  }
+}
+
+

sourcedBuilder() function uses generateSourcedFeatureStorage Gradle task that generates the code below.

+
package io.mehow.laboratory.sample
+
+import io.mehow.laboratory.FeatureStorage
+import io.mehow.laboratory.FeatureStorage.Companion.sourced
+import kotlin.String
+import kotlin.collections.Map
+import kotlin.collections.emptyMap
+import kotlin.collections.plus
+import kotlin.to
+
+internal fun FeatureStorage.Companion.sourcedBuilder(localSource: FeatureStorage): AwsStep =
+    Builder(localSource, emptyMap())
+
+internal interface AwsStep {
+  public fun awsSource(source: FeatureStorage): AzureStep
+}
+
+internal interface AzureStep {
+  public fun azureSource(source: FeatureStorage): FirebaseStep
+}
+
+internal interface FirebaseStep {
+  public fun firebaseSource(source: FeatureStorage): HerokuStep
+}
+
+internal interface HerokuStep {
+  public fun herokuSource(source: FeatureStorage): BuildingStep
+}
+
+internal interface BuildingStep {
+  public fun build(): FeatureStorage
+}
+
+private data class Builder(
+  private val localSource: FeatureStorage,
+  private val remoteSources: Map<String, FeatureStorage>
+) : AwsStep, AzureStep, FirebaseStep, HerokuStep, BuildingStep {
+  public override fun awsSourceSource(source: FeatureStorage): AzureStep = copy(
+    remoteSources = remoteSources + ("Firebase" to source)
+  )
+
+  public override fun azureSource(source: FeatureStorage): FirebaseStep = copy(
+    remoteSources = remoteSources + ("Azure" to source)
+  )
+
+  public override fun firebaseSource(source: FeatureStorage): HerokuStep = copy(
+    remoteSources = remoteSources + ("Firebase" to source)
+  )
+
+  public override fun herokuSource(source: FeatureStorage): BuildingStep = copy(
+    remoteSources = remoteSources + ("Heroku" to source)
+  )
+
+  public override fun build(): FeatureStorage = sourced(localSource, remoteSources)
+}
+
+

Feature flags factory

+

The generation of feature flags factory is useful if you use the QA module.

+
+

Tip

+

Check the samples with demo configurations.

+
+
apply plugin: "io.mehow.laboratory"
+
+laboratory {
+  packageName = "io.mehow.laboratory.sample"
+
+  featureFactory()
+
+  feature("FeatureA") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+  }
+
+  feature("FeatureB") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+  }
+
+  feature("FeatureC") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+  }
+}
+
+

featureFactory() uses generateFeatureFactory Gradle task that generates the code below. Class.forname() is used for lookup instead of the direct reference to classes because there is no guarantee that feature flags are directly available in the module that generates the factory if feature flags come, for example, as transitive dependencies of other modules.

+
package io.mehow.laboratory.sample
+
+import io.mehow.laboratory.Feature
+import io.mehow.laboratory.FeatureFactory
+import java.lang.Class
+import kotlin.Suppress
+import kotlin.collections.Set
+import kotlin.collections.setOf
+
+internal fun FeatureFactory.Companion.featureGenerated(): FeatureFactory = GeneratedFeatureFactory
+
+private object GeneratedFeatureFactory : FeatureFactory {
+  @Suppress("UNCHECKED_CAST")
+  override fun create(): Set<Class<out Feature<*>>> = setOf(
+    Class.forName("io.mehow.laboratory.sample.FeatureA"),
+    Class.forName("io.mehow.laboratory.sample.FeatureB"),
+    Class.forName("io.mehow.laboratory.sample.FeatureC")
+  ) as Set<Class<Feature<*>>>
+}
+
+

Feature flag sources factory

+

If you want to group all feature flag sources similar to feature flags, you can use featureSourceFactory() function that collects them.

+
laboratory {
+  packageName = "io.mehow.laboratory.sample"
+
+  featureSourceFactory()
+
+  feature("FeatureA") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+
+    withSource(Remote)
+  }
+
+  feature("FeatureB") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+
+    withSource(Remote)
+  }
+}
+
+

This uses the generateFeatureSourceFactory Gradle task that generates the code below.

+
package io.mehow.laboratory.sample
+
+import io.mehow.laboratory.Feature
+import io.mehow.laboratory.FeatureFactory
+import java.lang.Class
+import kotlin.Suppress
+import kotlin.collections.Set
+import kotlin.collections.setOf
+
+internal fun FeatureFactory.Companion.featureSourceGenerated(): FeatureFactory =
+    GeneratedFeatureSourceFactory
+
+private object GeneratedFeatureSourceFactory : FeatureFactory {
+  @Suppress("UNCHECKED_CAST")
+  override fun create(): Set<Class<out Feature<*>>> = setOf(
+    Class.forName("io.mehow.laboratory.sample.FeatureA${'$'}Source"),
+    Class.forName("io.mehow.laboratory.sample.FeatureB${'$'}Source")
+  ) as Set<Class<Feature<*>>>
+}
+
+

Feature flag option factory

+

The generation of an option factory is useful when you want to control local feature flag options remotely. Option factory aggregates all feature flags and recognizes them either by a fully qualified class name or an optional key property on a feature flag. Keys must be unique and cannot match fully qualified class names of other feature flags.

+

+
apply plugin: "io.mehow.laboratory"
+
+laboratory {
+  packageName = "io.mehow.laboratory.sample"
+
+  optionFactory()
+
+  feature("FeatureA") {
+    key = "FeatureA"
+
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+  }
+
+  feature("FeatureB") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+  }
+
+  feature("FeatureC") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+  }
+}
+
+

This uses the generateOptionFactory Gradle task that generates the code below.

+
package io.mehow.laboratory.sample
+
+import io.mehow.laboratory.Feature
+import io.mehow.laboratory.OptionFactory
+
+internal fun OptionFactory.Companion.generated(): OptionFactory = GeneratedOptionFactory
+
+private object GeneratedOptionFactory : OptionFactory {
+  override fun create(key: String, name: String): Feature<*>? = when (key) {
+    "FeatureA" -> when (name) {
+      "Enabled" -> FeatureA.Enabled
+      "Disabled" -> FeatureA.Disabled
+      else -> null
+    }
+    "io.mehow.laboratory.sample.FeatureB" -> when (name) {
+      "Enabled" -> FeatureB.Enabled
+      "Disabled" -> FeatureB.Disabled
+      else -> null
+    }
+    "io.mehow.laboratory.sample.FeatureC" -> when (name) {
+      "Enabled" -> FeatureC.Enabled
+      "Disabled" -> FeatureC.Disabled
+      else -> null
+    }
+    else -> null
+  }
+}
+
+

Multi-module support

+

The Gradle plugin was written with support for multi-module projects in mind.

+
+

Tip

+

Check the sample with demo configuration.

+
+
.
+├─ module-a
+│  └─ build.gradle
+├─ module-b
+│  └─ build.gradle
+├─ module-app
+│  └─ build.gradle
+├─ build.gradle
+└─ settings.gradle
+
+

A Laboratory setup for a Gradle project like above could look like this. Configuration of the Android Gradle plugin or any other dependencies is omitted for brevity.

+
// module-a
+plugins {
+  id "org.jetbrains.kotlin.jvm"
+  id "io.mehow.laboratory"
+}
+
+laboratory {
+  packageName = "com.sample.a"
+
+  feature("Authentication") {
+    withDefaultOption("Password")
+    withOption("Fingerprint")
+    withOption("Retina")
+    withOption("Face")
+
+    withSource("Firebase")
+    withSource("Aws")
+  }
+
+  feature("AllowScreenshots") {
+    withOption("Enabled")
+    withDefaultOption("Disabled")
+  }
+}
+
+
// module-b
+plugins {
+  id "org.jetbrains.kotlin.jvm"
+  id "io.mehow.laboratory"
+}
+
+laboratory {
+  packageName = "com.sample.b"
+
+  feature("DistanceAlgorithm") {
+    isPublic = false
+
+    withDefaultOption("Euclidean")
+    withOption("Jaccard")
+    withOption("Cosine")
+    withOption("Edit")
+    withOption("Hamming")
+
+    withSource("Firebase")
+    withDefaultSource("Azure")
+  }
+}
+
+dependencies {
+  implementation project(":module-a")
+}
+
+
// module-app
+plugins {
+  id "com.android.application"
+  id "org.jetbrains.kotlin.android"
+  id "io.mehow.laboratory"
+}
+
+laboratory {
+  packageName = "com.sample"
+  sourcedStorage()
+  featureFactory()
+
+  dependency(project(":module-a"))
+  dependency(project(":module-b"))
+}
+
+dependencies {
+  implementation project(":module-b")
+}
+
+

This setup shows that each module can define its feature flags that do not have to be exposed outside. In this scenario, module-app is responsible only for gluing together all feature flags so that Laboratory instances are aware of feature flag sources and the QA module. It should then deliver the correct Laboratory to modules via dependency injection. In order to include feature flags during generation of factories, their modules need to be added with dependency function.

+

Full configuration

+

Below is the full configuration of the Gradle plugins.

+
laboratory {
+  // Sets namespace of generated features and factories. Empty by default.
+  packageName = "io.mehow.sample"
+
+  // Informs plugin to create 'enum class SomeFeature' during the generation period.
+  feature("SomeFeature") {
+    // Used for option factory lookup. No value by default.
+    key = "SomeFeatureKey"
+
+    // Overrides globally declared namespace. No value by default.
+    packageName = "io.mehow.sample.feature"
+
+    // Adds a description to this feature that can be used for more context.
+    description = "Feature description"
+
+    // Sets the visibility of a feature flag to be either 'public' or 'internal'. 'true' by default.
+    isPublic = false
+
+    // Deprecates a feature flag. `DeprecationLevel` argument is optional and uses `DeprecationLevel.Warning` by default.
+    // Add the class to the import list in your Gradle script to avoid typing the whole package name.
+    deprecated("Deprecation message", io.mehow.laboratory.gradle.DeprecationLevel.Hidden)
+
+    // Informs plugin to add 'ValueA' option to the generated feature flag and set it as a default option.
+    // Exactly one of the feature options must be set with this function.
+    withDefaultOption("ValueA")
+
+    // Informs plugin to add 'ValueB' option to the generated feature flag.
+    withOption("ValueB")
+
+    // Informs plugin to add 'Firebase' option to the list of sources controlling this flag.
+    // Adding any source automatically adds the 'Local' option to the source enum.
+    // Any custom 'Local' sources are ignored by the plugin.
+    withSource("Firebase")
+
+    // Informs plugin to add 'Aws' option to the list of sources controlling this flag and to set a default option.
+    // At most, one of the source options can be set with this function.
+    // By default, 'Local' sources are considered to be default options.
+    withDefaultSource("Aws")
+
+    // Same as `withDefaultOption(option)` without lambda except that it generates supervised feature flags
+    // defined in the lambda.
+    withDefaultOption("Option") { option ->
+      option.feature("SupervisedFeature") {
+        // recursive feature generation
+      }
+    }
+
+    // Same as `withOption(option)` without lambda except that it generates supervised feature flags
+    // defined in the lambda.
+    withOption("Option") { option ->
+      option.feature("SupervisedFeature") {
+        // recursive feature generation
+      }
+    }
+  }
+
+  // Configures feature flags storage. Useful when feature flags have multiple sources.
+  sourcedStorage {
+    // Overrides globally declared namespace. No value by default.
+    packageName = "io.mehow.sample.storage"
+
+    // Sets visibility of a storage extension function to be either 'public' or 'internal'. 'false' by default.
+    isPublic = true
+  }
+
+  // Configures option factory. Useful for integration with remote service such as Firebase.
+  optionFactory {
+    // Overrides globally declared namespace. No value by default.
+    packageName = "io.mehow.sample.factory"
+
+    // Sets visibility of a factory extension function to be either 'public' or 'internal'. 'false' by default.
+    isPublic = true
+  }
+
+  // Configures feature flags factory. Useful for the QA module configuration.
+  featureFactory {
+    // Overrides globally declared namespace. No value by default.
+    packageName = "io.mehow.sample.factory"
+
+    // Sets visibility of a factory extension function to be either 'public' or 'internal'. 'false' by default.
+    isPublic = true
+  }
+
+  // Configures feature flag sources factory.
+  featureSourceFactory {
+    // Overrides globally declared namespace. No value by default.
+    packageName = "io.mehow.sample.factory"
+
+    // Sets visibility of a factory extension function to be either 'public' or 'internal'. 'false' by default.
+    isPublic = true
+  }
+
+  // Includes feature flags that are used for generation of feature factories, sourced storage and option factory.
+  dependency(project(":some-project"))
+}
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/images/hyperion_screenshot.jpg b/images/hyperion_screenshot.jpg new file mode 100644 index 000000000..1b57a6780 Binary files /dev/null and b/images/hyperion_screenshot.jpg differ diff --git a/images/inspector_screenshot.jpg b/images/inspector_screenshot.jpg new file mode 100644 index 000000000..62a34ab26 Binary files /dev/null and b/images/inspector_screenshot.jpg differ diff --git a/images/laboratory_logo.ico b/images/laboratory_logo.ico new file mode 100644 index 000000000..91ff177b4 Binary files /dev/null and b/images/laboratory_logo.ico differ diff --git a/images/laboratory_logo.svg b/images/laboratory_logo.svg new file mode 100644 index 000000000..79da7f9e4 --- /dev/null +++ b/images/laboratory_logo.svg @@ -0,0 +1,103 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/images/laboratory_logo_menu.svg b/images/laboratory_logo_menu.svg new file mode 100644 index 000000000..6a94769d6 --- /dev/null +++ b/images/laboratory_logo_menu.svg @@ -0,0 +1,6 @@ + + + diff --git a/index.html b/index.html new file mode 100644 index 000000000..745106342 --- /dev/null +++ b/index.html @@ -0,0 +1,602 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + Laboratory + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Laboratory ⚗️

+

Laboratory

+

A feature flags management library for multi-module Kotlin Android projects. Laboratory offers:

+
    +
  • Encapsulation: Different feature flags can freely live in separate Gradle modules without being exposed outside.
  • +
  • Type safety: Feature flags are represented with concrete types instead of booleans or grouped enums.
  • +
  • A/B/n testing: Feature flags don’t have to be constrained to provide only a binary choice. They can have as many states as you’d like.
  • +
  • Multiple sources: Feature flags can have different sources used for their current options. For example, you can have a feature flag that takes its option either from a local source or from any number of remote sources like, for instance, Firebase or Azure.
  • +
  • QA integration: Laboratory offers great QA capabilities and easy integration with popular tools. It comes with an out-of-the-box Hyperion plugin.
  • +
  • Persistence ignorance: Laboratory does not care how you want to store your feature flags. It provides implementations for most common scenarios, but you can always use an implementation for your custom storage mechanism.
  • +
  • Testing support: The in-memory implementation can be used as a drop-in substitute for Laboratory instances in tests.
  • +
  • Coroutines support: Changes to feature flags can be observed via Flow. Options reads and writes are made with suspend functions, but you can always opt-in to a blocking equivalent of I/O functions.
  • +
+

TLDR

+

First, you need to define your feature flags.

+
enum class AuthType : Feature<AuthType> {
+  None,
+  Fingerprint,
+  Retina,
+  Face;
+
+  public override val defaultOption get() = Fingerprint
+}
+
+

Once you have your feature flags defined, you can start using them in the application.

+
suspend fun main() {
+  // A high-level API for interaction with feature flags
+  val laboratory = Laboratory.inMemory()
+
+  // Set AuthType option to Fingerprint
+  val success = laboratory.setOption(AuthType.Fingerprint)
+
+  // Check what is the current option of AuthType
+  val currentAuthType = laboratory.experiment<AuthType>()
+
+  // Check if the current option of AuthType is equal to Face
+  val isFaceAuth = laboratory.experimentIs(AuthType.Face)
+
+  // Observe changes to the AuthType feature flag
+  laboratory.observe<AuthType>()
+      .onEach { option -> println("AuthType: $option") }
+      .launchIn(GlobalScope)
+}
+
+

Requirements

+

Laboratory requires default methods generation. You can do this by adding a compiler flag in a build.gradle file.

+
android {
+  kotlinOptions {
+    freeCompilerArgs += [
+        "-Xjvm-default=all",
+    ]
+  }
+}
+
+

R8

+

Laboratory ships with R8 rules and doesn’t require any extra configuration.

+

Get Laboratory

+

Laboratory is published to Maven Central Repository.

+
repositories {
+  mavenCentral()
+}
+
+dependencies {
+  implementation "io.mehow.laboratory:laboratory:1.1.0"
+}
+
+

Snapshots of the development version are available on Sonatype’s snapshots repository.

+

Here is the list of all available artifacts that Laboratory library provides.

+
    +
  • io.mehow.laboratory:laboratory:1.1.0: Core of the library. Defines classes and interfaces that you can interact with from your application code. It also provides R8 rules.
  • +
  • io.mehow.laboratory:laboratory-shared-preferences:1.1.0: Provides implementation of FeatureStorage based on SharedPreferences.
  • +
  • io.mehow.laboratory:laboratory-data-store:1.1.0: Provides implementation of FeatureStorage based on Jetpack DataStore.
  • +
  • io.mehow.laboratory:laboratory-inspector:1.1.0: QA module that allows users to preview all features and change them at runtime from one place.
  • +
  • io.mehow.laboratory:laboratory-hyperion-plugin:1.1.0: QA module that integrates laboratory-inspector with Hyperion.
  • +
  • io.mehow.laboratory:laboratory-gradle-plugin:1.1.0: Gradle plugin for feature flags generation and other quality of life improvements. It is highly recommended to use it instead of manual class management.
  • +
+

License

+
Copyright 2020 Michał Sikora
+
+Licensed under the Apache License, Version 2.0 (the "License");
+you may not use this file except in compliance with the License.
+You may obtain a copy of the License at
+
+   http://www.apache.org/licenses/LICENSE-2.0
+
+Unless required by applicable law or agreed to in writing, software
+distributed under the License is distributed on an "AS IS" BASIS,
+WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+See the License for the specific language governing permissions and
+limitations under the License.
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/qa-module/index.html b/qa-module/index.html new file mode 100644 index 000000000..55e79277c --- /dev/null +++ b/qa-module/index.html @@ -0,0 +1,642 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + QA module - Laboratory + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

QA module

+

It is very often desirable to have the option of configuring feature flag options at runtime. Laboratory addresses this problem with its QA modules.

+

Inspector

+

Feature flags inspection is available through the laboratory-inspector artifact. LaboratoryActivity is an Activity that enables inspection and modifications of feature flags.

+

Inspector

+

Inspector displays feature flags as cards and their options on chips. Active options of feature flags are marked with a highlight color. A local option of a feature flag can be changed by tapping on a chip. Chips that do not use Local sources cannot have their options changed. If a feature flag has multiple sources available, they can be switched from a drop down menu.

+

Feature flags (including sources) can be reset to their default options with a button in an action bar.

+

Configuration

+

Before LaboratoryActivity can be started, it has to be configured with an instance of Laboratory and at least one instance of FeatureFactory. FeatureFactory is an interface that should gather feature flags that are logically grouped together. Logical grouping can be different for each application, but in most cases, all feature flags in the project belong to a single unit. Scenarios, when you might want to split feature flags, are for example:

+
    +
  • Feature flags that do not belong to your project and are exposed to you from an external library.
  • +
  • Abundance of feature flags and a need to increase the readability of the inspector interface by separating feature flags into custom categories.
  • +
+
+

Tip

+

A lot of the boilerplate code presented here can be generated with the Gradle plugin. It is highly recommended to rely on the plugin instead of handwriting the code.

+
+
val sourcedFeatureStorage = FeatureStorage.sourced(
+  localSource = FeatureStorage.inMemory(),
+  remoteSources = mapOf(
+    "Firebase" to FeatureStorage.inMemory(),
+    "Aws" to FeatureStorage.inMemory(),
+    "Azure" to FeatureStorage.inMemory(),
+  ),
+)
+val laboratory = Laboratory.create(sourcedFeatureStorage)
+
+LaboratoryActivity.configure(
+  laboratory = laboratory,
+  featureFactory = CustomFeatureFactory,
+)
+LaboratoryActivity.start(context)
+
+object CustomFeatureFactory : FeatureFactory {
+  override fun create(): Set<Class<out Feature<*>>> = setOf(
+    AllowScreenshots::class.java,
+    Authentication::class.java,
+    PowerSource::class.java,
+    DistanceAlgorithm::class.java,
+    LogType::class.java,
+  )
+}
+
+enum class AllowScreenshots : Feature<AllowScreenshots> {
+  Enabled,
+  Disabled;
+
+  public override val defaultOption get() = Disabled
+
+  override val description: String = "Enables or disables screenshots during a video chat"
+}
+
+enum class Authentication : Feature<Authentication> {
+  Password,
+  Fingerprint,
+  Retina,
+  Face;
+
+  public override val defaultOption get() = Password
+
+  override val source = Source::class.java
+
+  enum class Source : Feature<Source> {
+    Local,
+    Firebase,
+    Aws;
+
+    public override val defaultOption get() = Local
+  }
+}
+
+enum class DistanceAlgorithm : Feature<DistanceAlgorithm> {
+  Euclidean,
+  Jaccard,
+  Cosine,
+  Edit,
+  Hamming;
+
+  public override val defaultOption get() = Euclidean
+
+  @Suppress("UNCHECKED_CAST")
+  override val source: Class<Feature<*>> = Source::class.java as Class<Feature<*>>
+
+  override val description: String = "Algorithm used for destination distance calculations"
+
+  enum class Source : Feature<Source> {
+    Local,
+    Firebase,
+    Azure;
+
+    public override val defaultOption get() = Azure
+  }
+}
+
+enum class LogType : Feature<LogType> {
+  Verbose,
+  Debug,
+  Info,
+  Warning,
+  Error;
+
+  public override val defaultOption get() = Info
+}
+
+enum class PowerSource : Feature<PowerSource> {
+  Coal,
+  Wind,
+  Solar,
+  Nuclear,
+  ColdFusion;
+
+  public override val defaultOption get() = Solar
+
+  @Suppress("UNCHECKED_CAST")
+  override val source: Class<Feature<*>> = Source::class.java as Class<Feature<*>>
+
+  enum class Source : Feature<Source> {
+    Local,
+    Firebase;
+
+    public override val defaultOption get() = Firebase
+  }
+}
+
+

Deprecation

+

You can configure how deprecated feature flags will be represented in the QA module. To do this you need to pass additional parameters to the Configuration builder.

+
val configuration = LaboratoryActivity.Configuration.builder()
+    .laboratory(laboratory)
+    .featureFactories(mapOf("Features" to featureFactory))
+    .deprecationPhenotypeSelector { deprecationLevel -> DeprecationPhenotype.Strikethrough }
+    .deprecationAlignmentSelector { deprecationLevel -> DeprecationAlignment.Bottom }
+    .build()
+LaboratoryActivity.configure(configuration)
+
+

Hyperion

+

If you use Hyperion you can easily integrate Laboratory by adding the laboratory-hyperion-plugin artifact to your dependencies. This will put an item in Hyperion’s debug menu.

+

Hyperion

+

If you’d like to position the Laboratory menu item in a different place on the menu, you can override the string id resource.

+
<?xml version="1.0" encoding="utf-8"?>
+<resources>
+  <string name="io_mehow_laboratory_plugin_id" translatable="false">!Laboratory</string>
+</resources>
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/releasing/index.html b/releasing/index.html new file mode 100644 index 000000000..ae8fb18e8 --- /dev/null +++ b/releasing/index.html @@ -0,0 +1,500 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + Releasing - Laboratory + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

Releasing

+

Versioning

+
    +
  1. Run the prepare release script and bump the desirable version part.
  2. +
  3. If there are no errors git push && git push --tags.
  4. +
  5. Wait for the CI server to upload the artifacts.
  6. +
  7. Visit Sonatype Nexus and promote the artifacts.
  8. +
+

Documentation updates

+

Website documentation lives under /docs directory and is deployed with MkDocs using Material Theme. A new site is built and published for the latest commits on the trunk branch.

+

If you want to test the website locally before pushing changes, you need to follow these steps.

+

Make sure you have Python 3 and pip installed.

+
$ python --version
+Python 3.8.5
+
+$ pip --version
+pip 20.2.4
+
+

Install MkDocs, Material Theme and MkDocs Video.

+
$ pip install mkdocs mkdocs-material mkdocs-video
+$ mkdocs --version
+mkdocs, version 1.1.2
+
+

Navigate to the library directory and run the site locally.

+
$ mkdocs serve
+INFO    -  Building documentation...
+INFO    -  Cleaning site directory
+INFO    -  Documentation built in 0.73 seconds
+[I 201026 22:51:56 server:335] Serving on http://127.0.0.1:8000
+INFO    -  Serving on http://127.0.0.1:8000
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file diff --git a/requirements.txt b/requirements.txt new file mode 100644 index 000000000..95af4e40e --- /dev/null +++ b/requirements.txt @@ -0,0 +1 @@ +mkdocs-video diff --git a/search/search_index.json b/search/search_index.json new file mode 100644 index 000000000..0d849f421 --- /dev/null +++ b/search/search_index.json @@ -0,0 +1 @@ +{"config":{"lang":["en"],"separator":"[\\s\\-]+","pipeline":["stopWordFilter"]},"docs":[{"location":"","title":"Quick start","text":""},{"location":"#laboratory","title":"Laboratory \u2697\ufe0f","text":"

A feature flags management library for multi-module Kotlin Android projects. Laboratory offers:

  • Encapsulation: Different feature flags can freely live in separate Gradle modules without being exposed outside.
  • Type safety: Feature flags are represented with concrete types instead of booleans or grouped enums.
  • A/B/n testing: Feature flags don\u2019t have to be constrained to provide only a binary choice. They can have as many states as you\u2019d like.
  • Multiple sources: Feature flags can have different sources used for their current options. For example, you can have a feature flag that takes its option either from a local source or from any number of remote sources like, for instance, Firebase or Azure.
  • QA integration: Laboratory offers great QA capabilities and easy integration with popular tools. It comes with an out-of-the-box Hyperion plugin.
  • Persistence ignorance: Laboratory does not care how you want to store your feature flags. It provides implementations for most common scenarios, but you can always use an implementation for your custom storage mechanism.
  • Testing support: The in-memory implementation can be used as a drop-in substitute for Laboratory instances in tests.
  • Coroutines support: Changes to feature flags can be observed via Flow. Options reads and writes are made with suspend functions, but you can always opt-in to a blocking equivalent of I/O functions.
"},{"location":"#tldr","title":"TLDR","text":"

First, you need to define your feature flags.

enum class AuthType : Feature<AuthType> {\nNone,\nFingerprint,\nRetina,\nFace;\n\npublic override val defaultOption get() = Fingerprint\n}\n

Once you have your feature flags defined, you can start using them in the application.

suspend fun main() {\n// A high-level API for interaction with feature flags\nval laboratory = Laboratory.inMemory()\n\n// Set AuthType option to Fingerprint\nval success = laboratory.setOption(AuthType.Fingerprint)\n\n// Check what is the current option of AuthType\nval currentAuthType = laboratory.experiment<AuthType>()\n\n// Check if the current option of AuthType is equal to Face\nval isFaceAuth = laboratory.experimentIs(AuthType.Face)\n\n// Observe changes to the AuthType feature flag\nlaboratory.observe<AuthType>()\n.onEach { option -> println(\"AuthType: $option\") }\n.launchIn(GlobalScope)\n}\n
"},{"location":"#requirements","title":"Requirements","text":"

Laboratory requires default methods generation. You can do this by adding a compiler flag in a build.gradle file.

android {\nkotlinOptions {\nfreeCompilerArgs += [\n\"-Xjvm-default=all\",\n]\n}\n}\n
"},{"location":"#r8","title":"R8","text":"

Laboratory ships with R8 rules and doesn\u2019t require any extra configuration.

"},{"location":"#get-laboratory","title":"Get Laboratory","text":"

Laboratory is published to Maven Central Repository.

repositories {\nmavenCentral()\n}\n\ndependencies {\nimplementation \"io.mehow.laboratory:laboratory:1.1.0\"\n}\n

Snapshots of the development version are available on Sonatype\u2019s snapshots repository.

Here is the list of all available artifacts that Laboratory library provides.

  • io.mehow.laboratory:laboratory:1.1.0: Core of the library. Defines classes and interfaces that you can interact with from your application code. It also provides R8 rules.
  • io.mehow.laboratory:laboratory-shared-preferences:1.1.0: Provides implementation of FeatureStorage based on SharedPreferences.
  • io.mehow.laboratory:laboratory-data-store:1.1.0: Provides implementation of FeatureStorage based on Jetpack DataStore.
  • io.mehow.laboratory:laboratory-inspector:1.1.0: QA module that allows users to preview all features and change them at runtime from one place.
  • io.mehow.laboratory:laboratory-hyperion-plugin:1.1.0: QA module that integrates laboratory-inspector with Hyperion.
  • io.mehow.laboratory:laboratory-gradle-plugin:1.1.0: Gradle plugin for feature flags generation and other quality of life improvements. It is highly recommended to use it instead of manual class management.
"},{"location":"#license","title":"License","text":"
Copyright 2020 Micha\u0142 Sikora\n\nLicensed under the Apache License, Version 2.0 (the \"License\");\nyou may not use this file except in compliance with the License.\nYou may obtain a copy of the License at\n\n   http://www.apache.org/licenses/LICENSE-2.0\n\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS,\nWITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.\nSee the License for the specific language governing permissions and\nlimitations under the License.\n
"},{"location":"changelog/","title":"Changelog","text":""},{"location":"changelog/#changelog","title":"Changelog","text":"

All notable changes to this project will be documented in this document.

The format is based on Keep a Changelog, and this project adheres to Semantic Versioning.

"},{"location":"changelog/#unreleased","title":"Unreleased","text":""},{"location":"changelog/#changed","title":"Changed","text":"
  • Upgrade to Kotlin 1.9.24.
  • Upgrade to Coroutines 1.8.1.
  • Upgrade to Gradle 8.7.
  • Upgrade to AGP to 8.4.0.
  • Upgrade to Wire 4.9.9.
  • Upgrade to KotlinPoet 1.16.0.
  • Upgrade to DataStore 1.1.1.
  • Upgrade to ViewPager2 1.3.2.
  • Upgrade to ViewModel-ktx 2.8.0.
  • Upgrade to Fragment-ktx 1.7.1.
  • Upgrade to RecyclerView 1.3.2.
  • Upgrade to Material 1.12.0.
  • Upgrade to Hyperion 0.9.38.
  • Downgrade target and source compatibilities versions to Java 11.
  • Change compile and target SDK to 34.
"},{"location":"changelog/#110-2023-06-13","title":"1.1.0 - 2023-06-13","text":""},{"location":"changelog/#changed_1","title":"Changed","text":"
  • Upgrade to Kotlin 1.8.21.
  • Upgrade to Coroutines 1.6.4.
  • Upgrade to Gradle 8.1.1.
  • Upgrade to Wire 4.7.0.
  • Upgrade to KotlinPoet 1.14.2.
  • Upgrade to Hyperion 0.9.37.
  • Upgrade to AppCompat 1.6.1.
  • Upgrade to ViewModel-ktx 2.6.1.
  • Upgrade to Fragment-ktx 1.5.7.
  • Upgrade to RecyclerView 1.3.0.
  • Upgrade to Material 1.9.0.
  • Upgrade target and source compatibilities versions to Java 17.
  • Change compile and target SDK to 33.
"},{"location":"changelog/#103-2022-10-01","title":"1.0.3 - 2022-10-01","text":""},{"location":"changelog/#fixed","title":"Fixed","text":"
  • Generating feature flags and related classes to empty Kotlin source sets in Kotlin 1.7.20.
"},{"location":"changelog/#102-2022-09-29","title":"1.0.2 - 2022-09-29","text":""},{"location":"changelog/#fixed_1","title":"Fixed","text":"
  • Fixed IllegalArgumentException: Did not find Kotlin source set after upgrading to Kotlin 1.7.20.
"},{"location":"changelog/#101-2022-06-21","title":"1.0.1 - 2022-06-21","text":""},{"location":"changelog/#added","title":"Added","text":"
  • Gradle configuration cache support.
"},{"location":"changelog/#removed","title":"Removed","text":"
  • CoreKtx dependency.
"},{"location":"changelog/#100-2021-02-06","title":"1.0.0 - 2021-02-06","text":""},{"location":"changelog/#added_1","title":"Added","text":"
  • setOptions(options) overload which accepts collection instead of varargs.
"},{"location":"changelog/#removed_1","title":"Removed","text":"
  • ConstraintLayout dependency.
  • DynamicAnimation dependency.
"},{"location":"changelog/#100-rc2-2021-12-28","title":"1.0.0-rc2 - 2021-12-28","text":""},{"location":"changelog/#changed_2","title":"Changed","text":"
  • SharedPreferencesFeatureStorage no marked as experimental due to coroutines.
  • Upgrade to Kotlin 1.6.10.
  • Upgrade to Coroutines 1.6.0.
  • Upgrade to Wire 4.0.1.
"},{"location":"changelog/#fixed_2","title":"Fixed","text":"
  • Handle usage of deprecated features in a generated OptionFactory.
"},{"location":"changelog/#removed_2","title":"Removed","text":"
  • Builders for generator models. Models are now created via constructors and throw if data is invalid.
  • GenerationFailure interface.
  • Arrow dependency.
"},{"location":"changelog/#100-rc1-2021-12-22","title":"1.0.0-rc1 - 2021-12-22","text":""},{"location":"changelog/#added_2","title":"Added","text":"
  • Multi-module setup no longer includes other modules implicitly. Instead each module needs to be included via dependency function in Gradle.
    laboratory {\nfeatureFactory()\n\n// Before, these were included implicitly.\ndependency(project(\":module-a\"))\ndependency(project(\":module-b\"))\n}\n
"},{"location":"changelog/#changed_3","title":"Changed","text":"
  • Upgrade Android target and compile SDK to 31.
  • Upgrade to LifecycleViewmodelKtx 2.4.0.
  • Upgrade to KotlinPoet 1.10.2.
  • Upgrade to Wire 4.0.0.
  • Upgrade to Kotlin 1.6.0.
  • Upgrade to ConstraintLayout 2.1.2.
  • Upgrade to FragmentKtx 1.4.0.
  • Upgrade to AppCompat 1.4.0.
"},{"location":"changelog/#removed_3","title":"Removed","text":"
  • Groovy DSL introduced in 0.9.0 for adding feature flags.
  • projectFilter properties from Gradle plugin. Use explicit dependencies instead.
  • Deprecated API.
"},{"location":"changelog/#fixed_3","title":"Fixed","text":"
  • Overrides of sources in DefaultOptionFactory are now respected by Laboratory - #220.
"},{"location":"changelog/#0140-2021-10-11","title":"0.14.0 - 2021-10-11","text":""},{"location":"changelog/#added_3","title":"Added","text":"
  • Better integration with remote sources, like Firebase, via OptionFactory interface. It creates feature options based on a feature key and an option name.
  • Code generation of option factory via Gradle plugin.
"},{"location":"changelog/#changed_4","title":"Changed","text":"
  • Make Feature and other related classes covariant.
  • FeatureStorage functions are no longer parameterized over Feature. They accept raw class type instead.
  • Generator and Gradle plugin no longer validate package names, duplicates and other things that are checked by compiler.
  • Model builders accept now ClassName in constructor.
  • Mark SharedPreferencesFeatureStorage with ExperimentalCoroutinesApi annotation.
  • Upgrade to Kotlin 1.5.31.
  • Upgrade to Material 1.4.0.
  • Upgrade to CoreKtx 1.6.0.
  • Upgrade to DataStore 1.0.0.
  • Upgrade to AGP 4.2.2.
  • Upgrade to Hyperion 0.9.34.
  • Upgrade to FragmentKtx 1.3.6.
  • Upgrade to AppCompat 1.3.1.
  • Upgrade to ConstraintLayout 2.1.1.
  • Upgrade to ArrowKt 1.0.0.
  • Upgrade to Coroutines 1.5.2.
  • Upgrade to KotlinPoet 1.10.1.
"},{"location":"changelog/#deprecated","title":"Deprecated","text":"
  • FeatureStorage.Companion.sharedPreferences(Context) function. Use overload that accepts SharedPreferences instead.
  • FeatureStorage.Companion.dataStore(() -> File) function. Use overload that accepts DataStore instead.
  • FeatureStorage.Companion.dataStore(Context, String) function. Use overload that accepts DataStore instead.
  • generate() methods on generation models. Use prepare() and operate on FileSpec directly instead.
"},{"location":"changelog/#removed_4","title":"Removed","text":"
  • Dependency on Kyrie.
  • Dependency on JCenter.
"},{"location":"changelog/#0131-2021-06-27","title":"0.13.1 - 2021-06-27","text":""},{"location":"changelog/#changed_5","title":"Changed","text":"
  • Upgrade to Kotlin 1.5.20.
  • Upgrade to RecyclerView 1.2.1.
  • Upgrade to FragmentKtx 1.3.5.
  • Upgrade to DataStore 1.0.0-beta02.
  • Upgrade to KotlinPoet 1.9.0.
  • Upgrade to CoreKtx 1.5.0.
  • Upgrade to AppCompat 1.3.0.
"},{"location":"changelog/#0130-2021-05-17","title":"0.13.0 - 2021-05-17","text":""},{"location":"changelog/#changed_6","title":"Changed","text":"
  • Drop deprecated @JvmDefault and switch to JVM default modes.
  • Upgrade to Kotlin 1.5.0.
  • Upgrade to Coroutines 1.5.0.
  • Upgrade to AGP 4.2.1.
  • Upgrade to KotlinPoet 1.8.0.
  • Upgrade to RecyclerView 1.2.0.
  • Upgrade to Hyperion 0.9.32.
  • Upgrade to FragmentKtx 1.3.3.
  • Upgrade to DataStore 1.0.0-beta01.
"},{"location":"changelog/#0121-2021-03-28","title":"0.12.1 - 2021-03-28","text":""},{"location":"changelog/#added_4","title":"Added","text":"
  • Indication that an option is a supervisor. If an option supervises features it has an eye icon next to it. List of supervised features is available after long pressing a chip.
  • Navigation from supervised feature to supervisor.
  • Navigation from supervisor to supervised feature.
  • Amount of offscreen feature sections in inspector can be controlled with LaboratoryActivity.Configuration.OffscreenSectionsBehavior. Default is unlimited.
"},{"location":"changelog/#changed_7","title":"Changed","text":"
  • Upgrade to Kotlin 1.4.32.
  • Upgrade to LifecycleViewmodelKtx 2.3.1.
  • Upgrade to FragmentKtx 1.3.2.
  • Upgrade to Wire 3.7.0.
"},{"location":"changelog/#0120-2021-03-21","title":"0.12.0 - 2021-03-21","text":""},{"location":"changelog/#added_5","title":"Added","text":"
  • Gradle plugin generates sourcedBuilder() extension function for SourcedFeatureStorage that returns custom builder with steps for each source. This makes changes to sources compile time safe.
  • Show feature\u2019s supervisor option in inspector \u2013 #95.
"},{"location":"changelog/#changed_8","title":"Changed","text":"
  • Upgrade to Coroutines 1.4.3.
  • Upgrade to AGP 4.1.3.
"},{"location":"changelog/#deprecated_1","title":"Deprecated","text":"
  • sourcedGenerated() extension function generated by Gradle plugin.
"},{"location":"changelog/#0110-2021-03-11","title":"0.11.0 - 2021-03-11","text":""},{"location":"changelog/#changed_9","title":"Changed","text":"
  • Use proto3 for FeatureFlags definition.
  • Upgrade to DataStore 1.0.0-alpha08.
  • Upgrade to Kotlin 1.4.31.
  • Upgrade to Wire 3.6.1.
  • Upgrade to FragmentKtx 1.3.1.
"},{"location":"changelog/#0100-2021-02-18","title":"0.10.0 - 2021-02-18","text":""},{"location":"changelog/#added_6","title":"Added","text":"
  • Parent\u2013child relationship to Feature. This relationship is controlled with a Feature.supervisorOption property. Whenever supervisor has its option different from this value then the supervised feature flag cannot return any other option than a default one. Option can still be set via Laboratory but it will not be exposed as long as a feature flag is not supervised. This relationship is recursive meaning that grandparents control grandchildren indirectly.
  • Code generation of supervisor options via Gradle plugin.
"},{"location":"changelog/#changed_10","title":"Changed","text":"
  • Gradle plugin no longer changes implicit package name multiple times. Only last value that was set is applied in configuration.
  • Upgrade to DataStore 1.0.0-alpha06.
  • Upgrade to AGP 4.1.2.
  • Upgrade to Kotlin 1.4.30.
  • Upgrade to Wire 3.6.0.
  • Upgrade to Material 1.3.0.
  • Upgrade to FragmentKtx 1.3.0.
  • Upgrade to LifecycleViewmodelKtx 2.3.0.
  • Upgrade to Hyperion 0.9.31.
"},{"location":"changelog/#fixed_4","title":"Fixed","text":"
  • Search icon not animating on Android below SDK 24.
"},{"location":"changelog/#deprecated_2","title":"Deprecated","text":"
  • DataStore custom builder and builder factory methods. Factory method that accepts DataStore directly should be used instead.
"},{"location":"changelog/#097-2020-12-15","title":"0.9.7 - 2020-12-15","text":""},{"location":"changelog/#changed_11","title":"Changed","text":"
  • DeprecationLevel.Hidden is no longer deprecated. It was a mistake to deprecate it at all since it could work from the start.
"},{"location":"changelog/#096-2020-12-15","title":"0.9.6 - 2020-12-15","text":""},{"location":"changelog/#added_7","title":"Added","text":"
  • FeatureFactory can be now appended to another with plus operator.
  • DefaultOptionFactory can be now appended to another with plus operator.
"},{"location":"changelog/#changed_12","title":"Changed","text":"
  • Use description as feature flag\u2019s KDoc content.
  • Upgrade Kotlin to 1.4.21.
"},{"location":"changelog/#deprecated_3","title":"Deprecated","text":"
  • Using DeprecationLevel.Hidden is temporarily treated as an error until the compiler issue is fixed.
"},{"location":"changelog/#fixed_5","title":"Fixed","text":"
  • Make updates to the in-memory Laboratory atomic.
"},{"location":"changelog/#095-2020-12-03","title":"0.9.5 - 2020-12-03","text":""},{"location":"changelog/#added_8","title":"Added","text":"
  • Builder pattern for LaboratoryActivity.Configuration construction.
  • Visual representation of deprecated feature flags in the QA module.
  • Visual representation of deprecated feature flags can be configured via LaboratoryActivity.Configuration builder with deprecationPhenotypeSelector() and deprecationAlignmentSelector() functions.
  • Consumer ProGuard rules to laboratory-inspector to keep @Deprecated annotation.
  • QA module displays clickable hyperlinks from a feature flag description if it contains Markdown formatted links.
"},{"location":"changelog/#changed_13","title":"Changed","text":"
  • Upgrade to DataStore 1.0.0-alpha05.
"},{"location":"changelog/#deprecated_4","title":"Deprecated","text":"
  • LaboratoryActivity.Configuration() constructor. Use LaboratoryActivity.Configuration.create() or LaboratoryActivity.Configuration.builder() instead.
"},{"location":"changelog/#fixed_6","title":"Fixed","text":"
  • Warning and error level deprecation on generated feature flags is now correctly suppressed.
"},{"location":"changelog/#094-2020-11-27","title":"0.9.4 - 2020-11-27","text":""},{"location":"changelog/#added_9","title":"Added","text":"
  • Kyrie 0.2.1 to laboratory-inspector.
  • DynamicAnimation 1.0.0 to laboratory-inspector.
"},{"location":"changelog/#changed_14","title":"Changed","text":"
  • Animation of search feature in inspector. It no longer makes ugly visibility transitions.
  • Upgrade to Coroutines 1.4.2.
"},{"location":"changelog/#093-2020-11-23","title":"0.9.3 - 2020-11-23","text":""},{"location":"changelog/#added_10","title":"Added","text":"
  • Feature flags filtering to the QA module. Features are filtered by their name, options or source options.
  • ConstraintLayout 2.0.4 to laboratory-inspector.
"},{"location":"changelog/#changed_15","title":"Changed","text":"
  • Inspector tabs are now scrollable instead of fixed.
  • Upgrade to Kotlin 1.4.20.
"},{"location":"changelog/#fixed_7","title":"Fixed","text":"
  • Shared preferences based FeatureStorage dispatches now changes to feature flag observers when clear() method is used. This fixes an issue with the QA module where it did not update the UI after resetting feature flags if shared preferences where used for feature flags persistence.
  • Preserve feature flags preview adapter scroll position on configuration changes.
  • External feature factories are no longer filtered out when added with the configure() function.
"},{"location":"changelog/#092-2020-11-18","title":"0.9.2 - 2020-11-18","text":""},{"location":"changelog/#added_11","title":"Added","text":"
  • BlockingLaboratory class that can read and write feature flags via blocking API.
  • blocking() function to Laboratory class that is an entry point to the blocking API.
  • Deprecation of feature flags from the Gradle plugin with deprecated(message, level) method. level argument is optional and a warning level is used by default.
"},{"location":"changelog/#changed_16","title":"Changed","text":"
  • Upgrade to DataStore 1.0.0-alpha04.
"},{"location":"changelog/#deprecated_5","title":"Deprecated","text":"
  • All blocking functions on the Laboratory class. BlockingLaboratory available via blocking() function should be used instead.
"},{"location":"changelog/#091-2020-11-12","title":"0.9.1 - 2020-11-12","text":""},{"location":"changelog/#added_12","title":"Added","text":"
  • Builder pattern for Laboratory construction.
  • DefaultOptionFactory that can substitute default options for feature flags read by Laboratory.
  • clear() function to FeatureStorage and Laboratory.
"},{"location":"changelog/#changed_17","title":"Changed","text":"
  • Upgrade to DataStore 1.0.0-alpha03.
"},{"location":"changelog/#deprecated_6","title":"Deprecated","text":"
  • Laboratory(storage) constructor. Use Laboratory.create(storage) or Laboratory.builder() instead.
"},{"location":"changelog/#090-2020-11-11","title":"0.9.0 - 2020-11-11","text":""},{"location":"changelog/#added_13","title":"Added","text":"
  • Groovy DSL for adding feature flags via Gradle plugin. This is equivalent to feature(\"SomeFeatureFlag\") function.
    laboratory {\nSomeFeatureFlag {\nwithDefaultOption(\"Enabled\")\nwithOption(\"Disabled\")\n}\n}\n
  • options extension to Class<Feature<T>> that returns all available feature flag options.
  • defaultOption extension to Class<Feature<T>> that returns a default option of a feature flag.
  • source extension to Class<Feature<*>> that returns a feature flag source if available.
  • description extension to Class<Feature<*>> that returns a feature flag description if available.
  • withOption() and withDefaultOption() to Gradle plugin for adding options to feature flags.
  • defaultOption property to Feature interface.
  • setOption() and setOptions() functions to Laboratory and FeatureStorage.
"},{"location":"changelog/#changed_18","title":"Changed","text":"
  • excludeProjects plugin functions are now called projectFilter and the condition is reversed. Previously they removed projects that matched a condition. Now they allow projects that match it.
  • sourcedWith property on Feature is now named source.
  • Upgrade to Coroutines 1.4.1.
"},{"location":"changelog/#deprecated_7","title":"Deprecated","text":"
  • withValue() and withDefaultValue() functions in Gradle plugin. withOption() and withDefaultOption() should be used instead.
  • setFeature() and setFeatures() functions. setOption() and setOptions() should be used instead.
"},{"location":"changelog/#removed_5","title":"Removed","text":"
  • ProjectFilter from laboratory-gradle-plugin in favour of java.util.function.Predicate.
  • configure() overload which accepts sources factory as a separate argument.
  • isDefaultValue from Feature interface. defaultOption should be used instead.
"},{"location":"changelog/#fixed_8","title":"Fixed","text":"
  • Moved generateSourcedFeatureStorage task to a correct tasks group.
"},{"location":"changelog/#080-2020-10-28","title":"0.8.0 - 2020-10-28","text":""},{"location":"changelog/#added_14","title":"Added","text":"
  • KDoc documentation.
"},{"location":"changelog/#changed_19","title":"Changed","text":"
  • Renamed feature/features argument in setFeature() and setFeatures() methods to value/values respectively.
  • Elevation is no longer an attribute in the IoMehowLaboratory.Theme and a regular resource is used instead. This makes sure that when an Activity theme is overridden externally it won\u2019t crash for an unknown attribute.
  • Flatten Hyperion button to visually match other items.
  • Upgrade to Coroutines 1.4.0.
  • Upgrade to Wire 3.5.0.
"},{"location":"changelog/#removed_6","title":"Removed","text":"
  • generateFactory property from sourcedFeatureStorage() method in Gradle plugin. It was added to the public API by a mistake and wasn\u2019t responsible for anything.
  • Wire dependency from the library-shared-preferences artifact. It was added by a mistake.
  • BuildConfig classes from Android library modules.
"},{"location":"changelog/#070-2020-10-22","title":"0.7.0 - 2020-10-22","text":""},{"location":"changelog/#changed_20","title":"Changed","text":"
  • Changelog format follows now Keep a Changelog format. Format is applied retroactively to this file.
  • R8 rules are now a part of META-INF of the laboratory artifact.
  • SharedPreferencesFeatureStorage is now internal.
  • Gradle plugin no longer has a runtime dependency on Android Gradle Plugin.
  • laboratory-generator generates source code compatible with the explicit API mode.
  • Set compile SDK to 30.
  • Upgrade to KotlinPoet 1.7.2.
  • Upgrade to Hyperion 0.9.30.
  • Upgrade to DataStore 1.0.0-alpha02.
"},{"location":"changelog/#062-2020-10-12","title":"0.6.2 - 2020-10-12","text":""},{"location":"changelog/#added_15","title":"Added","text":"
  • FeatureStorage extensions for creation of SharedPreferences based FeatureStorage.
  • FeatureStorage extensions for creation of DataStore based FeatureStorage.
  • Hyperion plugin can be ordered in the debug menu by overriding io_mehow_laboratory_plugin_id resource.
"},{"location":"changelog/#deprecated_8","title":"Deprecated","text":"
  • SharedPreferenceFeatureStorage soon will become internal.
"},{"location":"changelog/#changed_21","title":"Changed","text":"
  • DataStoreFeatureStorage is now internal. It is not considered a breaking change as DataStore is in the alpha stage.
"},{"location":"changelog/#061-2020-10-12","title":"0.6.1 - 2020-10-12","text":""},{"location":"changelog/#fixed_9","title":"Fixed","text":"
  • Hyperion plugin layout where button was on the wrong side of the debug menu.
"},{"location":"changelog/#060-2020-10-12","title":"0.6.0 - 2020-10-12","text":""},{"location":"changelog/#added_16","title":"Added","text":"
  • Feature can have now description. It can be used to add more contextual data to feature flags.
  • LaboratoryActivity observes changes to feature flags instead of loading them every time the screen is opened.
  • LaboratoryActivity displays feature flag sources next to them and allows users to select a source from a drop down menu.
  • Remote feature flag values are displayed in LaboratoryActivity if a source is not local.
  • When a remote source is used for a feature flag a value cannot be changed from LaboratoryActivity.
  • LaboratoryActivity displays feature flag descriptions if they are present.
  • LaboratoryActivity can reset feature flag values to their default state from an item in the action bar.
  • Laboratory.experimentIs() and Laboratory.experimentIsBlocking() functions that allow to check if a feature flag has particular value.
  • ViewPager2 1.0.0 dependency to laboratory-inspector.
  • RecyclerView 1.1.0 dependency to laboratory-inspector.
"},{"location":"changelog/#changed_22","title":"Changed","text":"
  • LaboratoryActivity requires now a Laboratory instance for initialization. This Laboratory should share FeatureStorage with instances of Laboratory used in the application.
"},{"location":"changelog/#050-2020-10-08","title":"0.5.0 - 2020-10-08","text":""},{"location":"changelog/#changed_23","title":"Changed","text":"
  • fallback nomenclature to default. This affects Gradle plugin withFallbackValue() and withFallbackSources() functions as well as isFallbackValue property on the Feature interface.
"},{"location":"changelog/#040-2020-10-08","title":"0.4.0 - 2020-10-08","text":""},{"location":"changelog/#changed_24","title":"Changed","text":"
  • Name of the generated sourced FeatureStorage extension function is now sourcedGenerated() in order to align it with the generated feature factory extension function name.
"},{"location":"changelog/#030-2020-10-08","title":"0.3.0 - 2020-10-08","text":""},{"location":"changelog/#added_17","title":"Added","text":"
  • Feature flags can have multiple sources. Source is also a feature flag and is optional. If no source is available it is assumed that only a local source is controlled.
  • FeatureStorage that connects feature flags with their sources. It is available via FeatureStorage.sourced() extension function. Feature flag sources are uniquely identified only by their value names.
  • Feature flag sources can be set from the Gradle plugin with withSource(\"Name\") and withFallbackSource(\"Name\") functions in feature() blocks. Any source that has the name \u201cLocal\u201d (or a variant of it) is filtered out.
  • Gradle plugin has a new sourcedStorage() function. It is responsible for generating a customized FeatureStorage that is aware of all available feature flag sources.
  • Gradle plugin has a new featureSourceFactory() function. It works similarly to featureFactory() function with a difference that it collects only feature flag sources.
  • LaboratoryActivity is now configurable with the configure() function.
  • LaboratoryActivity can display different sets of feature flags on separate tabs.
  • FragmentKtx 1.2.5 dependency to laboratory-inspector.
  • ViewModelKtx 2.2.0 dependency to laboratory-inspector.
"},{"location":"changelog/#changed_25","title":"Changed","text":"
  • LaboratoryActivity.initialize() function is renamed to configure().
  • Gradle plugin factory() function is renamed to featureFactory().
"},{"location":"changelog/#021-2020-10-02","title":"0.2.1 - 2020-10-02","text":""},{"location":"changelog/#added_18","title":"Added","text":"
  • Laboratory exposes a blocking way of reading and writing feature flags. It requires an opt-in BlockingIoCall annotation.
"},{"location":"changelog/#changed_26","title":"Changed","text":"
  • laboratory-android artifact is now laboratory-shared-preferences artifact.
  • laboratory-shared-preferences artifact (old laboratory-android) is no longer automatically applied by Gradle plugin in Android modules.
  • Upgrade to Kotlin 1.4.10.
  • Upgrade to CoreKtx 1.3.2.
  • Upgrade to Wire 3.4.0.
  • Upgrade to KotlinPoet 1.6.0.
"},{"location":"changelog/#020-2020-09-05","title":"0.2.0 - 2020-09-05","text":""},{"location":"changelog/#added_19","title":"Added","text":"
  • Laboratory.observe() function to observe feature flag changes via Flow.
  • Support for DataStore with the laboratory-data-store artifact.
  • Laboratory and FeatureStorage return a boolean information whether writes are successful.
  • Feature interface that is used to define feature flags.
  • Wire 3.2.2 dependency to laboratory-data-store.
"},{"location":"changelog/#changed_27","title":"Changed","text":"
  • Kotlin standard library is now part of the public API.
  • Laboratory and FeatureStorage expose their API via suspend functions.
  • Gradle plugin requires exactly one feature flag value to be added with withFallbackValue(\"Name\") function.
  • Upgrade to Kotlin 1.4.0.
  • Upgrade to Material 1.2.1.
  • Upgrade to Hyperion 0.9.29.
"},{"location":"changelog/#removed_7","title":"Removed","text":"
  • @Feature annotation. Feature flags should implement the Feature interface.
"},{"location":"changelog/#010-2020-08-03","title":"0.1.0 - 2020-08-03","text":"
  • Initial release.
"},{"location":"gradle-plugin/","title":"Gradle plugin","text":""},{"location":"gradle-plugin/#gradle-plugin","title":"Gradle plugin","text":"

Gradle plugin\u2019s main job is to make your life easier when creating and managing feature flags. It generates features, feature factories, and customized sourced feature storage. Plugin, additionally, verifies things that cannot be represented by the API. For example, it checks if a feature flag has exactly one default option defined.

Under the hood, the Gradle plugin uses KotlinPoet to generate compact source files.

Info

The Gradle plugin automatically adds the laboratory artifact to dependencies.

Tip

The best way to understand the Gradle plugin is to check the samples. It uses most of the Gradle plugin features that most of the applications need.

"},{"location":"gradle-plugin/#feature-flags","title":"Feature flags","text":"

Feature flags are added to the generation process with a feature() function, which uses the generateFeatureFlags Gradle task. Here is a sample configuration.

Tip

Check the sample with demo configuration.

apply plugin: \"io.mehow.laboratory\"\n\nlaboratory {\npackageName = \"io.mehow.laboratory.sample\"\n\nfeature(\"Authentication\") {\ndescription = \"Type of authentication when opening the app\"\n\nwithOption(\"None\")\nwithOption(\"Fingerprint\")\nwithDefaultOption(\"Retina\")\n}\n\nfeature(\"LocationTracking\") {\npackageName = \"io.mehow.laboratory.location\"\n\nisPublic = false\n\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n\nwithDefaultSource(\"Firebase\")\nwithSource(\"Aws\")\n}\n}\n

This setup creates two feature flags. Authentication and LocationTracking with options taken from the feature(name) { } block. Key things that might not be that obvious.

  • Feature flag source visibility is inherited from a feature\u2019s visibility.
  • If a feature flag defines a remote source, a Local source is automatically added as an option. Any custom Local sources will be filtered out.
  • If all sources are added with withSource() function, Local source will be used as a default one.
package io.mehow.laboratory.sample\n\nimport io.mehow.laboratory.Feature\nimport kotlin.Boolean\nimport kotlin.String\n\npublic enum class Authentication : Feature<Authentication> {\nPassword,\nFingerprint,\nRetina,\n;\n\npublic override val defaultOption get() = Retina\n\npublic override val description: String = \"Type of authentication when opening the app\"\n}\n
package io.mehow.laboratory.location\n\nimport io.mehow.laboratory.Feature\nimport java.lang.Class\nimport kotlin.Boolean\nimport kotlin.Suppress\n\ninternal enum class LocationTracking : LocationTracking<Authentication> {\nEnabled,\nDisabled,\n;\n\npublic override val defaultOption get() = Disabled\n\npublic override val source = Source::class.java\n\ninternal enum class Source : Feature<Source> {\nLocal,\nFirebase,\nAws,\n;\n\npublic override val defaultOption get() = Firebase\n}\n}\n
"},{"location":"gradle-plugin/#supervision","title":"Supervision","text":"

Gradle plugin supports generation of supervised feature flags.

Tip

Check the sample with demo configuration.

laboratory {\nfeature(\"ChristmasTheme\") {\nwithDefaultOption(\"Disabled\")\n\nwithOption(\"Enabled\") { enabledChristmas ->\nenabledChristmas.feature(\"Greeting\") { greeting ->\ngreeting.withDefaultOption(\"Hello\")\ngreeting.withOption(\"HoHoHo\")\n}\n\nenabledChristmas.feature(\"Background\") { background ->\nbackground.withDefaultOption(\"White\")\nbackground.withOption(\"Reindeer\")\nbackground.withOption(\"Snowman\")\n}\n}\n}\n}\n

This configuration generates the code below.

enum class ChristmasTheme : Feature<ChristmasTheme> {\nEnabled,\nDisabled,\n;\n\npublic override val defaultOption get() = Disabled\n}\n\nenum class Greeting : Feature<Greeting> {\nHello,\nHoHoHo,\n;\n\npublic override val defaultOption get() = Hello\n\npublic override val supervisorOption get() = ChristmasTheme.Enabled\n}\n\nenum class Background : Feature<Background> {\nWhite,\nReindeer,\nSnowman,\n;\n\npublic override val defaultOption get() = White\n\npublic override val supervisorOption get() = ChristmasTheme.Enabled\n}\n

DSL for supervised feature flags is recursive allowing to nest them in withOption() and withDefaultOption() functions.

"},{"location":"gradle-plugin/#feature-flags-storage","title":"Feature flags storage","text":"

If your feature flags use multiple sources, you can configure the Gradle plugin to generate for you a quality of life extension function that returns a custom FeatureStorage builder.

apply plugin: \"io.mehow.laboratory\"\n\nlaboratory {\npackageName = \"io.mehow.laboratory.sample\"\n\nsourcedStorage()\n\nfeature(\"FeatureA\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n\nwithSource(\"Azure\")\nwithSource(\"Firebase\")\n}\n\nfeature(\"FeatureB\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n\nwithSource(\"Azure\")\nwithSource(\"Aws\")\n}\n\nfeature(\"FeatureC\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n\nwithSource(\"Heroku\")\n}\n\nfeature(\"FeatureD\") {\nwithDefaultOption(\"Enabled\")\nwithOption(\"Disabled\")\n}\n}\n

sourcedBuilder() function uses generateSourcedFeatureStorage Gradle task that generates the code below.

package io.mehow.laboratory.sample\n\nimport io.mehow.laboratory.FeatureStorage\nimport io.mehow.laboratory.FeatureStorage.Companion.sourced\nimport kotlin.String\nimport kotlin.collections.Map\nimport kotlin.collections.emptyMap\nimport kotlin.collections.plus\nimport kotlin.to\n\ninternal fun FeatureStorage.Companion.sourcedBuilder(localSource: FeatureStorage): AwsStep =\nBuilder(localSource, emptyMap())\n\ninternal interface AwsStep {\npublic fun awsSource(source: FeatureStorage): AzureStep\n}\n\ninternal interface AzureStep {\npublic fun azureSource(source: FeatureStorage): FirebaseStep\n}\n\ninternal interface FirebaseStep {\npublic fun firebaseSource(source: FeatureStorage): HerokuStep\n}\n\ninternal interface HerokuStep {\npublic fun herokuSource(source: FeatureStorage): BuildingStep\n}\n\ninternal interface BuildingStep {\npublic fun build(): FeatureStorage\n}\n\nprivate data class Builder(\nprivate val localSource: FeatureStorage,\nprivate val remoteSources: Map<String, FeatureStorage>\n) : AwsStep, AzureStep, FirebaseStep, HerokuStep, BuildingStep {\npublic override fun awsSourceSource(source: FeatureStorage): AzureStep = copy(\nremoteSources = remoteSources + (\"Firebase\" to source)\n)\n\npublic override fun azureSource(source: FeatureStorage): FirebaseStep = copy(\nremoteSources = remoteSources + (\"Azure\" to source)\n)\n\npublic override fun firebaseSource(source: FeatureStorage): HerokuStep = copy(\nremoteSources = remoteSources + (\"Firebase\" to source)\n)\n\npublic override fun herokuSource(source: FeatureStorage): BuildingStep = copy(\nremoteSources = remoteSources + (\"Heroku\" to source)\n)\n\npublic override fun build(): FeatureStorage = sourced(localSource, remoteSources)\n}\n
"},{"location":"gradle-plugin/#feature-flags-factory","title":"Feature flags factory","text":"

The generation of feature flags factory is useful if you use the QA module.

Tip

Check the samples with demo configurations.

apply plugin: \"io.mehow.laboratory\"\n\nlaboratory {\npackageName = \"io.mehow.laboratory.sample\"\n\nfeatureFactory()\n\nfeature(\"FeatureA\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n}\n\nfeature(\"FeatureB\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n}\n\nfeature(\"FeatureC\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n}\n}\n

featureFactory() uses generateFeatureFactory Gradle task that generates the code below. Class.forname() is used for lookup instead of the direct reference to classes because there is no guarantee that feature flags are directly available in the module that generates the factory if feature flags come, for example, as transitive dependencies of other modules.

package io.mehow.laboratory.sample\n\nimport io.mehow.laboratory.Feature\nimport io.mehow.laboratory.FeatureFactory\nimport java.lang.Class\nimport kotlin.Suppress\nimport kotlin.collections.Set\nimport kotlin.collections.setOf\n\ninternal fun FeatureFactory.Companion.featureGenerated(): FeatureFactory = GeneratedFeatureFactory\n\nprivate object GeneratedFeatureFactory : FeatureFactory {\n@Suppress(\"UNCHECKED_CAST\")\noverride fun create(): Set<Class<out Feature<*>>> = setOf(\nClass.forName(\"io.mehow.laboratory.sample.FeatureA\"),\nClass.forName(\"io.mehow.laboratory.sample.FeatureB\"),\nClass.forName(\"io.mehow.laboratory.sample.FeatureC\")\n) as Set<Class<Feature<*>>>\n}\n
"},{"location":"gradle-plugin/#feature-flag-sources-factory","title":"Feature flag sources factory","text":"

If you want to group all feature flag sources similar to feature flags, you can use featureSourceFactory() function that collects them.

laboratory {\npackageName = \"io.mehow.laboratory.sample\"\n\nfeatureSourceFactory()\n\nfeature(\"FeatureA\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n\nwithSource(Remote)\n}\n\nfeature(\"FeatureB\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n\nwithSource(Remote)\n}\n}\n

This uses the generateFeatureSourceFactory Gradle task that generates the code below.

package io.mehow.laboratory.sample\n\nimport io.mehow.laboratory.Feature\nimport io.mehow.laboratory.FeatureFactory\nimport java.lang.Class\nimport kotlin.Suppress\nimport kotlin.collections.Set\nimport kotlin.collections.setOf\n\ninternal fun FeatureFactory.Companion.featureSourceGenerated(): FeatureFactory =\nGeneratedFeatureSourceFactory\n\nprivate object GeneratedFeatureSourceFactory : FeatureFactory {\n@Suppress(\"UNCHECKED_CAST\")\noverride fun create(): Set<Class<out Feature<*>>> = setOf(\nClass.forName(\"io.mehow.laboratory.sample.FeatureA${'$'}Source\"),\nClass.forName(\"io.mehow.laboratory.sample.FeatureB${'$'}Source\")\n) as Set<Class<Feature<*>>>\n}\n
"},{"location":"gradle-plugin/#feature-flag-option-factory","title":"Feature flag option factory","text":"

The generation of an option factory is useful when you want to control local feature flag options remotely. Option factory aggregates all feature flags and recognizes them either by a fully qualified class name or an optional key property on a feature flag. Keys must be unique and cannot match fully qualified class names of other feature flags.

apply plugin: \"io.mehow.laboratory\"\n\nlaboratory {\npackageName = \"io.mehow.laboratory.sample\"\n\noptionFactory()\n\nfeature(\"FeatureA\") {\nkey = \"FeatureA\"\n\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n}\n\nfeature(\"FeatureB\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n}\n\nfeature(\"FeatureC\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n}\n}\n

This uses the generateOptionFactory Gradle task that generates the code below.

package io.mehow.laboratory.sample\n\nimport io.mehow.laboratory.Feature\nimport io.mehow.laboratory.OptionFactory\n\ninternal fun OptionFactory.Companion.generated(): OptionFactory = GeneratedOptionFactory\n\nprivate object GeneratedOptionFactory : OptionFactory {\noverride fun create(key: String, name: String): Feature<*>? = when (key) {\n\"FeatureA\" -> when (name) {\n\"Enabled\" -> FeatureA.Enabled\n\"Disabled\" -> FeatureA.Disabled\nelse -> null\n}\n\"io.mehow.laboratory.sample.FeatureB\" -> when (name) {\n\"Enabled\" -> FeatureB.Enabled\n\"Disabled\" -> FeatureB.Disabled\nelse -> null\n}\n\"io.mehow.laboratory.sample.FeatureC\" -> when (name) {\n\"Enabled\" -> FeatureC.Enabled\n\"Disabled\" -> FeatureC.Disabled\nelse -> null\n}\nelse -> null\n}\n}\n
"},{"location":"gradle-plugin/#multi-module-support","title":"Multi-module support","text":"

The Gradle plugin was written with support for multi-module projects in mind.

Tip

Check the sample with demo configuration.

.\n\u251c\u2500 module-a\n\u2502  \u2514\u2500 build.gradle\n\u251c\u2500 module-b\n\u2502  \u2514\u2500 build.gradle\n\u251c\u2500 module-app\n\u2502  \u2514\u2500 build.gradle\n\u251c\u2500 build.gradle\n\u2514\u2500 settings.gradle\n

A Laboratory setup for a Gradle project like above could look like this. Configuration of the Android Gradle plugin or any other dependencies is omitted for brevity.

// module-a\nplugins {\nid \"org.jetbrains.kotlin.jvm\"\nid \"io.mehow.laboratory\"\n}\n\nlaboratory {\npackageName = \"com.sample.a\"\n\nfeature(\"Authentication\") {\nwithDefaultOption(\"Password\")\nwithOption(\"Fingerprint\")\nwithOption(\"Retina\")\nwithOption(\"Face\")\n\nwithSource(\"Firebase\")\nwithSource(\"Aws\")\n}\n\nfeature(\"AllowScreenshots\") {\nwithOption(\"Enabled\")\nwithDefaultOption(\"Disabled\")\n}\n}\n
// module-b\nplugins {\nid \"org.jetbrains.kotlin.jvm\"\nid \"io.mehow.laboratory\"\n}\n\nlaboratory {\npackageName = \"com.sample.b\"\n\nfeature(\"DistanceAlgorithm\") {\nisPublic = false\n\nwithDefaultOption(\"Euclidean\")\nwithOption(\"Jaccard\")\nwithOption(\"Cosine\")\nwithOption(\"Edit\")\nwithOption(\"Hamming\")\n\nwithSource(\"Firebase\")\nwithDefaultSource(\"Azure\")\n}\n}\n\ndependencies {\nimplementation project(\":module-a\")\n}\n
// module-app\nplugins {\nid \"com.android.application\"\nid \"org.jetbrains.kotlin.android\"\nid \"io.mehow.laboratory\"\n}\n\nlaboratory {\npackageName = \"com.sample\"\nsourcedStorage()\nfeatureFactory()\n\ndependency(project(\":module-a\"))\ndependency(project(\":module-b\"))\n}\n\ndependencies {\nimplementation project(\":module-b\")\n}\n

This setup shows that each module can define its feature flags that do not have to be exposed outside. In this scenario, module-app is responsible only for gluing together all feature flags so that Laboratory instances are aware of feature flag sources and the QA module. It should then deliver the correct Laboratory to modules via dependency injection. In order to include feature flags during generation of factories, their modules need to be added with dependency function.

"},{"location":"gradle-plugin/#full-configuration","title":"Full configuration","text":"

Below is the full configuration of the Gradle plugins.

laboratory {\n// Sets namespace of generated features and factories. Empty by default.\npackageName = \"io.mehow.sample\"\n\n// Informs plugin to create 'enum class SomeFeature' during the generation period.\nfeature(\"SomeFeature\") {\n// Used for option factory lookup. No value by default.\nkey = \"SomeFeatureKey\"\n\n// Overrides globally declared namespace. No value by default.\npackageName = \"io.mehow.sample.feature\"\n\n// Adds a description to this feature that can be used for more context.\ndescription = \"Feature description\"\n\n// Sets the visibility of a feature flag to be either 'public' or 'internal'. 'true' by default.\nisPublic = false\n\n// Deprecates a feature flag. `DeprecationLevel` argument is optional and uses `DeprecationLevel.Warning` by default.\n// Add the class to the import list in your Gradle script to avoid typing the whole package name.\ndeprecated(\"Deprecation message\", io.mehow.laboratory.gradle.DeprecationLevel.Hidden)\n\n// Informs plugin to add 'ValueA' option to the generated feature flag and set it as a default option.\n// Exactly one of the feature options must be set with this function.\nwithDefaultOption(\"ValueA\")\n\n// Informs plugin to add 'ValueB' option to the generated feature flag.\nwithOption(\"ValueB\")\n\n// Informs plugin to add 'Firebase' option to the list of sources controlling this flag.\n// Adding any source automatically adds the 'Local' option to the source enum.\n// Any custom 'Local' sources are ignored by the plugin.\nwithSource(\"Firebase\")\n\n// Informs plugin to add 'Aws' option to the list of sources controlling this flag and to set a default option.\n// At most, one of the source options can be set with this function.\n// By default, 'Local' sources are considered to be default options.\nwithDefaultSource(\"Aws\")\n\n// Same as `withDefaultOption(option)` without lambda except that it generates supervised feature flags\n// defined in the lambda.\nwithDefaultOption(\"Option\") { option ->\noption.feature(\"SupervisedFeature\") {\n// recursive feature generation\n}\n}\n\n// Same as `withOption(option)` without lambda except that it generates supervised feature flags\n// defined in the lambda.\nwithOption(\"Option\") { option ->\noption.feature(\"SupervisedFeature\") {\n// recursive feature generation\n}\n}\n}\n\n// Configures feature flags storage. Useful when feature flags have multiple sources.\nsourcedStorage {\n// Overrides globally declared namespace. No value by default.\npackageName = \"io.mehow.sample.storage\"\n\n// Sets visibility of a storage extension function to be either 'public' or 'internal'. 'false' by default.\nisPublic = true\n}\n\n// Configures option factory. Useful for integration with remote service such as Firebase.\noptionFactory {\n// Overrides globally declared namespace. No value by default.\npackageName = \"io.mehow.sample.factory\"\n\n// Sets visibility of a factory extension function to be either 'public' or 'internal'. 'false' by default.\nisPublic = true\n}\n\n// Configures feature flags factory. Useful for the QA module configuration.\nfeatureFactory {\n// Overrides globally declared namespace. No value by default.\npackageName = \"io.mehow.sample.factory\"\n\n// Sets visibility of a factory extension function to be either 'public' or 'internal'. 'false' by default.\nisPublic = true\n}\n\n// Configures feature flag sources factory.\nfeatureSourceFactory {\n// Overrides globally declared namespace. No value by default.\npackageName = \"io.mehow.sample.factory\"\n\n// Sets visibility of a factory extension function to be either 'public' or 'internal'. 'false' by default.\nisPublic = true\n}\n\n// Includes feature flags that are used for generation of feature factories, sourced storage and option factory.\ndependency(project(\":some-project\"))\n}\n
"},{"location":"qa-module/","title":"QA module","text":""},{"location":"qa-module/#qa-module","title":"QA module","text":"

It is very often desirable to have the option of configuring feature flag options at runtime. Laboratory addresses this problem with its QA modules.

"},{"location":"qa-module/#inspector","title":"Inspector","text":"

Feature flags inspection is available through the laboratory-inspector artifact. LaboratoryActivity is an Activity that enables inspection and modifications of feature flags.

Inspector displays feature flags as cards and their options on chips. Active options of feature flags are marked with a highlight color. A local option of a feature flag can be changed by tapping on a chip. Chips that do not use Local sources cannot have their options changed. If a feature flag has multiple sources available, they can be switched from a drop down menu.

Feature flags (including sources) can be reset to their default options with a button in an action bar.

"},{"location":"qa-module/#configuration","title":"Configuration","text":"

Before LaboratoryActivity can be started, it has to be configured with an instance of Laboratory and at least one instance of FeatureFactory. FeatureFactory is an interface that should gather feature flags that are logically grouped together. Logical grouping can be different for each application, but in most cases, all feature flags in the project belong to a single unit. Scenarios, when you might want to split feature flags, are for example:

  • Feature flags that do not belong to your project and are exposed to you from an external library.
  • Abundance of feature flags and a need to increase the readability of the inspector interface by separating feature flags into custom categories.

Tip

A lot of the boilerplate code presented here can be generated with the Gradle plugin. It is highly recommended to rely on the plugin instead of handwriting the code.

val sourcedFeatureStorage = FeatureStorage.sourced(\nlocalSource = FeatureStorage.inMemory(),\nremoteSources = mapOf(\n\"Firebase\" to FeatureStorage.inMemory(),\n\"Aws\" to FeatureStorage.inMemory(),\n\"Azure\" to FeatureStorage.inMemory(),\n),\n)\nval laboratory = Laboratory.create(sourcedFeatureStorage)\n\nLaboratoryActivity.configure(\nlaboratory = laboratory,\nfeatureFactory = CustomFeatureFactory,\n)\nLaboratoryActivity.start(context)\n\nobject CustomFeatureFactory : FeatureFactory {\noverride fun create(): Set<Class<out Feature<*>>> = setOf(\nAllowScreenshots::class.java,\nAuthentication::class.java,\nPowerSource::class.java,\nDistanceAlgorithm::class.java,\nLogType::class.java,\n)\n}\n\nenum class AllowScreenshots : Feature<AllowScreenshots> {\nEnabled,\nDisabled;\n\npublic override val defaultOption get() = Disabled\n\noverride val description: String = \"Enables or disables screenshots during a video chat\"\n}\n\nenum class Authentication : Feature<Authentication> {\nPassword,\nFingerprint,\nRetina,\nFace;\n\npublic override val defaultOption get() = Password\n\noverride val source = Source::class.java\n\nenum class Source : Feature<Source> {\nLocal,\nFirebase,\nAws;\n\npublic override val defaultOption get() = Local\n}\n}\n\nenum class DistanceAlgorithm : Feature<DistanceAlgorithm> {\nEuclidean,\nJaccard,\nCosine,\nEdit,\nHamming;\n\npublic override val defaultOption get() = Euclidean\n\n@Suppress(\"UNCHECKED_CAST\")\noverride val source: Class<Feature<*>> = Source::class.java as Class<Feature<*>>\n\noverride val description: String = \"Algorithm used for destination distance calculations\"\n\nenum class Source : Feature<Source> {\nLocal,\nFirebase,\nAzure;\n\npublic override val defaultOption get() = Azure\n}\n}\n\nenum class LogType : Feature<LogType> {\nVerbose,\nDebug,\nInfo,\nWarning,\nError;\n\npublic override val defaultOption get() = Info\n}\n\nenum class PowerSource : Feature<PowerSource> {\nCoal,\nWind,\nSolar,\nNuclear,\nColdFusion;\n\npublic override val defaultOption get() = Solar\n\n@Suppress(\"UNCHECKED_CAST\")\noverride val source: Class<Feature<*>> = Source::class.java as Class<Feature<*>>\n\nenum class Source : Feature<Source> {\nLocal,\nFirebase;\n\npublic override val defaultOption get() = Firebase\n}\n}\n
"},{"location":"qa-module/#deprecation","title":"Deprecation","text":"

You can configure how deprecated feature flags will be represented in the QA module. To do this you need to pass additional parameters to the Configuration builder.

val configuration = LaboratoryActivity.Configuration.builder()\n.laboratory(laboratory)\n.featureFactories(mapOf(\"Features\" to featureFactory))\n.deprecationPhenotypeSelector { deprecationLevel -> DeprecationPhenotype.Strikethrough }\n.deprecationAlignmentSelector { deprecationLevel -> DeprecationAlignment.Bottom }\n.build()\nLaboratoryActivity.configure(configuration)\n
"},{"location":"qa-module/#hyperion","title":"Hyperion","text":"

If you use Hyperion you can easily integrate Laboratory by adding the laboratory-hyperion-plugin artifact to your dependencies. This will put an item in Hyperion\u2019s debug menu.

If you\u2019d like to position the Laboratory menu item in a different place on the menu, you can override the string id resource.

<?xml version=\"1.0\" encoding=\"utf-8\"?>\n<resources>\n<string name=\"io_mehow_laboratory_plugin_id\" translatable=\"false\">!Laboratory</string>\n</resources>\n
"},{"location":"releasing/","title":"Releasing","text":""},{"location":"releasing/#releasing","title":"Releasing","text":""},{"location":"releasing/#versioning","title":"Versioning","text":"
  1. Run the prepare release script and bump the desirable version part.
  2. If there are no errors git push && git push --tags.
  3. Wait for the CI server to upload the artifacts.
  4. Visit Sonatype Nexus and promote the artifacts.
"},{"location":"releasing/#documentation-updates","title":"Documentation updates","text":"

Website documentation lives under /docs directory and is deployed with MkDocs using Material Theme. A new site is built and published for the latest commits on the trunk branch.

If you want to test the website locally before pushing changes, you need to follow these steps.

Make sure you have Python 3 and pip installed.

$ python --version\nPython 3.8.5\n\n$ pip --version\npip 20.2.4\n

Install MkDocs, Material Theme and MkDocs Video.

$ pip install mkdocs mkdocs-material mkdocs-video\n$ mkdocs --version\nmkdocs, version 1.1.2\n

Navigate to the library directory and run the site locally.

$ mkdocs serve\nINFO    -  Building documentation...\nINFO    -  Cleaning site directory\nINFO    -  Documentation built in 0.73 seconds\n[I 201026 22:51:56 server:335] Serving on http://127.0.0.1:8000\nINFO    -  Serving on http://127.0.0.1:8000\n
"},{"location":"user-guide/","title":"User guide","text":""},{"location":"user-guide/#user-guide","title":"User guide","text":""},{"location":"user-guide/#features","title":"Features","text":"

Feature flags are nothing more than enums that implement the Feature interface. It allows us to define a default option, remote sources that can provide different options and descriptions for some human-readable metadata.

Danger

Feature enums must have at least one option. Defining an enum like below will make Laboratory throw an exception when used to read an option.

enum class SomeFeature : Feature<SomeFeature>\n

Tip

Check the samples to learn by example.

"},{"location":"user-guide/#io","title":"I/O","text":"

Laboratory is nothing more than a high-level API over the FeatureStorage interface responsible for persisting feature flags. All implementations that are provided by this library rely on a feature flag package name and an enum name.

Warning

Because the persistence mechanism relies on package names and enum names, you should be careful when refactoring feature flags already available on production. Changing these options may result in a perception of unsaved feature flags.

Because FeatureStorage is an interface that is meant to be used with I/O operations, it exposes only suspend functions. Laboratory, on the other hand, allows you to opt-into blocking equivalents of read and write functions. You can selectively do this by applying the @BlockingIoCall annotation or globally by adding a compiler flag.

android {\nkotlinOptions {\nfreeCompilerArgs += [\n\"-Xopt-in=io.mehow.laboratory.BlockingIoCall\",\n]\n}\n}\n

In either case, a design that relies on non-blocking function calls is preferable.

"},{"location":"user-guide/#sources","title":"Sources","text":"

Feature flags, by default, have only a single source for their options. By convention, it is considered to be a local source. However, you might need to have different data sources for feature flags, depending on some runtime conditions or a build variant. For example, you might want to use a local source during debugging and rely on some remote services on production.

Let\u2019s say that you want to have a feature flag that has three sources. One local, and two remote ones.

Info

Notice that a feature flag source is also a feature flag. This allows us to change feature flag sources via Laboratory as well.

enum class PowerType : Feature<PowerType> {\nCoal,\nWind,\nSolar;\n\npublic override val defaultOption get() = Solar\n\n@Suppress(\"UNCHECKED_CAST\")\noverride val source = Source::class.java as Class<Feature<*>>\n\nenum class Source : Feature<Source> {\nLocal,\nFirebase,\nAzure;\n\npublic override val defaultOption get() = Firebase\n}\n}\n

If you define multiple sources for a feature flag, you should add a Local option to them. This allows changing feature flag options at runtime from the QA module.

This feature flag definition allows configuring Laboratory in a way that it is capable of recognizing that PowerType has different option providers and that the default provider is Firebase.

Because the Laboratory only delegates its work to FeatureStorage, it is FeatureStorage that needs to understand how to connect feature flags with their sources. This is possible with a special implementation of this interface that is available as an extension function.

val sourcedFeatureStorage = FeatureStorage.sourced(\nlocalSource = FeatureStorage.inMemory(),\nremoteSources = mapOf(\n\"Firebase\" to FeatureStorage.inMemory(),\n\"Azure\" to FeatureStorage.inMemory(),\n),\n)\n

sourcedFeatureStorage delegates persistence mechanism to three different storage and is responsible for coordinating a selected source and a current feature flag option.

One error-prone thing is that sourcedFeatureStorage relies on strings and source names to use the correct storage. The reason for this is that two different feature flags might share sources partially.

Tip

Using Gradle plugin allows you to avoid this issue with the generation of a custom FeatureStorage that is always up-to-date.

enum class PowerType : Feature<PowerType> {\nCoal,\nWind,\nSolar;\n\npublic override val defaultOption get() = Solar\n\n@Suppress(\"UNCHECKED_CAST\")\noverride val source = Source::class.java as Class<Feature<*>>\n\nenum class Source : Feature<Source> {\nLocal,\nFirebase,\nAzure;\n\npublic override val defaultOption get() = Firebase\n}\n}\n\nenum class Theme : Feature<PowerType> {\nNight,\nDay,\nChristmas;\n\npublic override val defaultOption get() = Night\n\n@Suppress(\"UNCHECKED_CAST\")\noverride val source = Source::class.java as Class<Feature<*>>\n\nenum class Source : Feature<Source> {\nLocal,\nAzure;\n\npublic override val defaultOption get() = Local\n}\n}\n

In this case, Theme and PowerType feature flags share Azure source, but Firebase applies only to the PowerType flag.

// Create laboratory that understands sourced features\nval laboratory = Laboratory.create(sourcedFeatureStorage)\n\n// Check option of PowerType in Firebase FeatureStorage\nval powerTypeFirebaseValue = laboratory.experiment<PowerType>()\n\n// Check option of Theme in local FeatureStorage\nval themeLocalValue = laboratory.experiment<Theme>()\n\n// Set source of Theme source to Azure (PowerType is still unaffected and uses Firebase)\nval success = laboratory.setOption(Theme.Source.Azure)\n\n// Check option of Theme in Azure FeatureStorage\nval themeAzureValue = laboratory.experiment<Theme>()\n

Info

The implementation of sourcedFeatureStorage provided by the library saves data only in localSource.

To propagate remote feature flag options on updates, they need to be connected to a remote source.

enum class ShowAds : Feature<ShowAds> {\nEnabled,\nDisabled;\n\npublic override val defaultOption get() = Disabled\n\n@Suppress(\"UNCHECKED_CAST\")\noverride val source = Source::class.java as Class<Feature<*>>\n\nenum class Source : Feature<Source> {\nLocal,\nRemote;\n\npublic override val defaultOption get() = Remote\n}\n}\n\nval firebaseStorage = FeatureStorage.inMemory()\nval sourcedFeatureStorage = FeatureStorage.sourced(\nlocalSource = FeatureStorage.inMemory(),\nremoteSources = mapOf(\"Remote\" to firebaseStorage),\n)\n\n// During application initialisation\nval laboratory = Laboratory.create(sourcedFeatureStorage)\nremoteService.observeShowAdsFlag()\n// Some custom mapping between a service option and a feature flag\n.map { showAds: Boolean ->\nval showAdsFlag = if (showAds) ShowAds.Enabled else ShowAds.Disabled\nlaboratory.setOption(showAdsFlag)\n}\n// Scope should last for the lifetime of an application\n.launchIn(GlobalScope)\n
"},{"location":"user-guide/#default-options-override","title":"Default options override","text":"

Whenever Laboratory reads an option for a feature flag, it falls back to a default option declared on a said flag. However, there might be cases when you\u2019d like to change the default behavior. One example might be having features enabled by default in your debug builds and disabled on production. Or you might use feature flags for configuration, and you\u2019d like to have a different configuration per build variant. Laboratory enables this with default options overrides.

enum class ShowAds : Feature<ShowAds> {\nEnabled,\nDisabled;\n\npublic override val defaultOption get() = Disabled\n}\n\nobject DebugDefaultOptionFactory : DefaultOptionFactory {\noverride fun <T : Feature<T>> create(feature: T): Feature<*>? = when(feature) {\nis ShowAds -> ShowAds.Enabled\nelse -> null\n}\n}\n\nval laboratory = Laboratory.builder()\n.featureStorage(FeatureStorage.inMemory())\n.defaultOptionFactory(DebugDefaultOptionFactory)\n.build()\n\n// Uses default option declared in DebugDefaultOptionFactory\nlaboratory.experimentIs(ShowAds.Enabled)\n

You can be even more creative and, for example, enable all feature flags in your debug builds, which have an option Enabled.

class DebugDefaultOptionFactory : DefaultOptionFactory {\noverride fun <T : Feature<T>> create(feature: T): Feature<*>? {\nreturn feature.options.associateBy { it.name }[\"Enabled\"]\n}\n\nprivate val <T : Feature<T>> T.options get() = javaClass.options\n}\n
"},{"location":"user-guide/#feature-flag-supervision","title":"Feature flag supervision","text":"

Feature flags can be supervised using FeatureFlag.supervisorOption property. Whenever supervisor has its option different from the value in this property then the supervised feature flag cannot return any other option than a default one. Option can still be set via Laboratory but it will not be exposed as long as a feature flag is not supervised. This relationship is recursive meaning that grandparents control grandchildren indirectly.

enum class ChristmasTheme : Feature<ChristmasTheme> {\nEnabled,\nDisabled,\n;\n\npublic override val defaultOption get() = Disabled\n}\n\nenum class Greeting : Feature<Greeting> {\nHello,\nHoHoHo,\n;\n\npublic override val defaultOption get() = Hello\n\npublic override val supervisorOption get() = ChristmasTheme.Enabled\n}\n\nenum class Background : Feature<Background> {\nWhite,\nReindeer,\nSnowman,\n;\n\npublic override val defaultOption get() = White\n\npublic override val supervisorOption get() = ChristmasTheme.Enabled\n}\n\nval laboratory = Laboratory.inMemory()\n\nlaboratory.setOptions(Greeting.HoHoHo, Background.Reindeer)\n\nlaboratory.experimentIs(Greeting.HoHoHo) // false\nlaboratory.experimentIs(Background.Reindeer) // false\n\nlaboratory.setOption(ChristmasTheme.Enabled)\n\nlaboratory.experimentIs(Greeting.HoHoHo) // true\nlaboratory.experimentIs(Background.Reindeer) // true\n
"},{"location":"user-guide/#listening-to-remote-change","title":"Listening to remote change","text":"

Feature flags can be synced with a remote source with a help of OptionFactory. Below is a sample setup using Firebase.

enum class ChristmasTheme : Feature<ChristmasTheme> {\nEnabled,\nDisabled,\n;\n\npublic val override val defaultOption get() = Disabled\n}\n\nenum class ShowAds : Feature<ShowAds> {\nEnabled,\nDisabled;\n\npublic override val defaultOption get() = Disabled\n}\n\nobject CustomOptionFactory : OptionFactory {\nprivate val optionMapping = mapOf<String, (String) -> Feature<*>?>(\n\"ChristmasTheme\" to { name -> ChristmasTheme::class.java.options.firstOrNull { it.name == name } },\n\"ShowAds\" to { name -> ShowAds::class.java.options.firstOrNull { it.name == name } },\n)\n\noverride fun create(key: String, name: String) = optionMapping[key]?.invoke(name)\n}\n\nclass App : Application {\noverride fun onCreate() {\nval firebaseStorage = FeatureStorage.inMemory()\n// Get a reference to a node where feature flags are kept\nval database = FirebaseDatabase.getInstance().reference.child(\"featureFlags\")\n\nval featureFlagListener = object : ValueEventListener {\noverride fun onDataChange(snapshot: DataSnapshot) {\nval newOptions = (snapshot.value as? Map<*, *>)\n.orEmpty()\n.mapNotNull { (key, value) ->\nval stringKey = key as? String ?: return@mapNotNull null\nval stringValue = value as? String ?: return@mapNotNull null\nCustomOptionFactory.create(stringKey, stringValue)\n}\n// Be cautious with using GlobalScope.\nGlobalScope.launch { firebaseStorage.setOptions(newOptions) }\n}\n\noverride fun onCancelled(error: DatabaseError) = Unit\n}\n\ndatabase.child(\"featureFlags\").addValueEventListener(featureFlagListener)\n}\n}\n
"}]} \ No newline at end of file diff --git a/sitemap.xml b/sitemap.xml new file mode 100644 index 000000000..04d0d7d16 --- /dev/null +++ b/sitemap.xml @@ -0,0 +1,33 @@ + + + + https://mehow.io/laboratory/ + 2024-05-16 + daily + + + https://mehow.io/laboratory/changelog/ + 2024-05-16 + daily + + + https://mehow.io/laboratory/gradle-plugin/ + 2024-05-16 + daily + + + https://mehow.io/laboratory/qa-module/ + 2024-05-16 + daily + + + https://mehow.io/laboratory/releasing/ + 2024-05-16 + daily + + + https://mehow.io/laboratory/user-guide/ + 2024-05-16 + daily + + \ No newline at end of file diff --git a/sitemap.xml.gz b/sitemap.xml.gz new file mode 100644 index 000000000..51453785d Binary files /dev/null and b/sitemap.xml.gz differ diff --git a/user-guide/index.html b/user-guide/index.html new file mode 100644 index 000000000..c5d8444bd --- /dev/null +++ b/user-guide/index.html @@ -0,0 +1,819 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + User guide - Laboratory + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
+ +
+ + + + +
+ + +
+ +
+ + + + + + +
+
+ + + +
+
+
+ + + + +
+
+
+ + + +
+
+
+ + + +
+
+
+ + + +
+
+ + + + + + + + +

User guide

+

Features

+

Feature flags are nothing more than enums that implement the Feature interface. It allows us to define a default option, remote sources that can provide different options and descriptions for some human-readable metadata.

+
+

Danger

+

Feature enums must have at least one option. Defining an enum like below will make Laboratory throw an exception when used to read an option.

+
+
enum class SomeFeature : Feature<SomeFeature>
+
+
+

Tip

+

Check the samples to learn by example.

+
+

I/O

+

Laboratory is nothing more than a high-level API over the FeatureStorage interface responsible for persisting feature flags. All implementations that are provided by this library rely on a feature flag package name and an enum name.

+
+

Warning

+

Because the persistence mechanism relies on package names and enum names, you should be careful when refactoring feature flags already available on production. Changing these options may result in a perception of unsaved feature flags.

+
+

Because FeatureStorage is an interface that is meant to be used with I/O operations, it exposes only suspend functions. Laboratory, on the other hand, allows you to opt-into blocking equivalents of read and write functions. You can selectively do this by applying the @BlockingIoCall annotation or globally by adding a compiler flag.

+
android {
+  kotlinOptions {
+    freeCompilerArgs += [
+        "-Xopt-in=io.mehow.laboratory.BlockingIoCall",
+    ]
+  }
+}
+
+

In either case, a design that relies on non-blocking function calls is preferable.

+

Sources

+

Feature flags, by default, have only a single source for their options. By convention, it is considered to be a local source. However, you might need to have different data sources for feature flags, depending on some runtime conditions or a build variant. For example, you might want to use a local source during debugging and rely on some remote services on production.

+

Let’s say that you want to have a feature flag that has three sources. One local, and two remote ones.

+
+

Info

+

Notice that a feature flag source is also a feature flag. This allows us to change feature flag sources via Laboratory as well.

+
+
enum class PowerType : Feature<PowerType> {
+  Coal,
+  Wind,
+  Solar;
+
+  public override val defaultOption get() = Solar
+
+  @Suppress("UNCHECKED_CAST")
+  override val source = Source::class.java as Class<Feature<*>>
+
+  enum class Source : Feature<Source> {
+    Local,
+    Firebase,
+    Azure;
+
+    public override val defaultOption get() = Firebase
+  }
+}
+
+

If you define multiple sources for a feature flag, you should add a Local option to them. This allows changing feature flag options at runtime from the QA module.

+

This feature flag definition allows configuring Laboratory in a way that it is capable of recognizing that PowerType has different option providers and that the default provider is Firebase.

+

Because the Laboratory only delegates its work to FeatureStorage, it is FeatureStorage that needs to understand how to connect feature flags with their sources. This is possible with a special implementation of this interface that is available as an extension function.

+
val sourcedFeatureStorage = FeatureStorage.sourced(
+  localSource = FeatureStorage.inMemory(),
+  remoteSources = mapOf(
+    "Firebase" to FeatureStorage.inMemory(),
+    "Azure" to FeatureStorage.inMemory(),
+  ),
+)
+
+

sourcedFeatureStorage delegates persistence mechanism to three different storage and is responsible for coordinating a selected source and a current feature flag option.

+

One error-prone thing is that sourcedFeatureStorage relies on strings and source names to use the correct storage. The reason for this is that two different feature flags might share sources partially.

+
+

Tip

+

Using Gradle plugin allows you to avoid this issue with the generation of a custom FeatureStorage that is always up-to-date.

+
+
enum class PowerType : Feature<PowerType> {
+  Coal,
+  Wind,
+  Solar;
+
+  public override val defaultOption get() = Solar
+
+  @Suppress("UNCHECKED_CAST")
+  override val source = Source::class.java as Class<Feature<*>>
+
+  enum class Source : Feature<Source> {
+    Local,
+    Firebase,
+    Azure;
+
+    public override val defaultOption get() = Firebase
+  }
+}
+
+enum class Theme : Feature<PowerType> {
+  Night,
+  Day,
+  Christmas;
+
+  public override val defaultOption get() = Night
+
+  @Suppress("UNCHECKED_CAST")
+  override val source = Source::class.java as Class<Feature<*>>
+
+  enum class Source : Feature<Source> {
+    Local,
+    Azure;
+
+    public override val defaultOption get() = Local
+  }
+}
+
+

In this case, Theme and PowerType feature flags share Azure source, but Firebase applies only to the PowerType flag.

+
// Create laboratory that understands sourced features
+val laboratory = Laboratory.create(sourcedFeatureStorage)
+
+// Check option of PowerType in Firebase FeatureStorage
+val powerTypeFirebaseValue = laboratory.experiment<PowerType>()
+
+// Check option of Theme in local FeatureStorage
+val themeLocalValue = laboratory.experiment<Theme>()
+
+// Set source of Theme source to Azure (PowerType is still unaffected and uses Firebase)
+val success = laboratory.setOption(Theme.Source.Azure)
+
+// Check option of Theme in Azure FeatureStorage
+val themeAzureValue = laboratory.experiment<Theme>()
+
+
+

Info

+

The implementation of sourcedFeatureStorage provided by the library saves data only in localSource.

+
+

To propagate remote feature flag options on updates, they need to be connected to a remote source.

+
enum class ShowAds : Feature<ShowAds> {
+  Enabled,
+  Disabled;
+
+  public override val defaultOption get() = Disabled
+
+  @Suppress("UNCHECKED_CAST")
+  override val source = Source::class.java as Class<Feature<*>>
+
+  enum class Source : Feature<Source> {
+    Local,
+    Remote;
+
+    public override val defaultOption get() = Remote
+  }
+}
+
+val firebaseStorage = FeatureStorage.inMemory()
+val sourcedFeatureStorage = FeatureStorage.sourced(
+  localSource = FeatureStorage.inMemory(),
+  remoteSources = mapOf("Remote" to firebaseStorage),
+)
+
+// During application initialisation
+val laboratory = Laboratory.create(sourcedFeatureStorage)
+remoteService.observeShowAdsFlag()
+    // Some custom mapping between a service option and a feature flag
+    .map { showAds: Boolean ->
+      val showAdsFlag = if (showAds) ShowAds.Enabled else ShowAds.Disabled
+      laboratory.setOption(showAdsFlag)
+    }
+    // Scope should last for the lifetime of an application
+    .launchIn(GlobalScope)
+
+

Default options override

+

Whenever Laboratory reads an option for a feature flag, it falls back to a default option declared on a said flag. However, there might be cases when you’d like to change the default behavior. One example might be having features enabled by default in your debug builds and disabled on production. Or you might use feature flags for configuration, and you’d like to have a different configuration per build variant. Laboratory enables this with default options overrides.

+
enum class ShowAds : Feature<ShowAds> {
+  Enabled,
+  Disabled;
+
+  public override val defaultOption get() = Disabled
+}
+
+object DebugDefaultOptionFactory : DefaultOptionFactory {
+  override fun <T : Feature<T>> create(feature: T): Feature<*>? = when(feature) {
+    is ShowAds -> ShowAds.Enabled
+    else -> null
+  }
+}
+
+val laboratory = Laboratory.builder()
+    .featureStorage(FeatureStorage.inMemory())
+    .defaultOptionFactory(DebugDefaultOptionFactory)
+    .build()
+
+// Uses default option declared in DebugDefaultOptionFactory
+laboratory.experimentIs(ShowAds.Enabled)
+
+

You can be even more creative and, for example, enable all feature flags in your debug builds, which have an option Enabled.

+
class DebugDefaultOptionFactory : DefaultOptionFactory {
+  override fun <T : Feature<T>> create(feature: T): Feature<*>? {
+    return feature.options.associateBy { it.name }["Enabled"]
+  }
+
+  private val <T : Feature<T>> T.options get() = javaClass.options
+}
+
+

Feature flag supervision

+

Feature flags can be supervised using FeatureFlag.supervisorOption property. Whenever supervisor has its option different from the value in this property then the supervised feature flag cannot return any other option than a default one. Option can still be set via Laboratory but it will not be exposed as long as a feature flag is not supervised. This relationship is recursive meaning that grandparents control grandchildren indirectly.

+
enum class ChristmasTheme : Feature<ChristmasTheme> {
+  Enabled,
+  Disabled,
+  ;
+
+  public override val defaultOption get() = Disabled
+}
+
+enum class Greeting : Feature<Greeting> {
+  Hello,
+  HoHoHo,
+  ;
+
+  public override val defaultOption get() = Hello
+
+  public override val supervisorOption get() = ChristmasTheme.Enabled
+}
+
+enum class Background : Feature<Background> {
+  White,
+  Reindeer,
+  Snowman,
+  ;
+
+  public override val defaultOption get() = White
+
+  public override val supervisorOption get() = ChristmasTheme.Enabled
+}
+
+val laboratory = Laboratory.inMemory()
+
+laboratory.setOptions(Greeting.HoHoHo, Background.Reindeer)
+
+laboratory.experimentIs(Greeting.HoHoHo) // false
+laboratory.experimentIs(Background.Reindeer) // false
+
+laboratory.setOption(ChristmasTheme.Enabled)
+
+laboratory.experimentIs(Greeting.HoHoHo) // true
+laboratory.experimentIs(Background.Reindeer) // true
+
+

Listening to remote change

+

Feature flags can be synced with a remote source with a help of OptionFactory. Below is a sample setup using Firebase.

+
enum class ChristmasTheme : Feature<ChristmasTheme> {
+  Enabled,
+  Disabled,
+  ;
+
+  public val override val defaultOption get() = Disabled
+}
+
+enum class ShowAds : Feature<ShowAds> {
+  Enabled,
+  Disabled;
+
+  public override val defaultOption get() = Disabled
+}
+
+object CustomOptionFactory : OptionFactory {
+  private val optionMapping = mapOf<String, (String) -> Feature<*>?>(
+    "ChristmasTheme" to { name -> ChristmasTheme::class.java.options.firstOrNull { it.name == name } },
+    "ShowAds" to { name -> ShowAds::class.java.options.firstOrNull { it.name == name } },
+  )
+
+  override fun create(key: String, name: String) = optionMapping[key]?.invoke(name)
+}
+
+class App : Application {
+  override fun onCreate() {
+    val firebaseStorage = FeatureStorage.inMemory()
+    // Get a reference to a node where feature flags are kept
+    val database = FirebaseDatabase.getInstance().reference.child("featureFlags")
+
+    val featureFlagListener = object : ValueEventListener {
+      override fun onDataChange(snapshot: DataSnapshot) {
+        val newOptions = (snapshot.value as? Map<*, *>)
+            .orEmpty()
+            .mapNotNull { (key, value) ->
+              val stringKey = key as? String ?: return@mapNotNull null
+              val stringValue = value as? String ?: return@mapNotNull null
+              CustomOptionFactory.create(stringKey, stringValue)
+            }
+        // Be cautious with using GlobalScope.
+        GlobalScope.launch { firebaseStorage.setOptions(newOptions) }
+      }
+
+      override fun onCancelled(error: DatabaseError) = Unit
+    }
+
+    database.child("featureFlags").addValueEventListener(featureFlagListener)
+  }
+}
+
+ + + + + + +
+
+ + +
+ +
+ + + +
+
+
+
+ + + + + + + + + \ No newline at end of file