File: ConfigBuilder.php

package info (click to toggle)
mediawiki 1%3A1.43.3%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 417,464 kB
  • sloc: php: 1,062,949; javascript: 664,290; sql: 9,714; python: 5,458; xml: 3,489; sh: 1,131; makefile: 64
file content (73 lines) | stat: -rw-r--r-- 2,016 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<?php

namespace MediaWiki\Settings\Config;

use MediaWiki\Config\Config;
use MediaWiki\Settings\SettingsBuilderException;

/**
 * Builder for Config objects.
 *
 * @unstable
 */
interface ConfigBuilder {

	/**
	 * Set the configuration $key to $value.
	 *
	 * @param string $key
	 * @param mixed $value
	 * @param MergeStrategy|null $mergeStrategy strategy for merging array config values.
	 * @return ConfigBuilder
	 */
	public function set( string $key, $value, ?MergeStrategy $mergeStrategy = null ): ConfigBuilder;

	/**
	 * Set all values in the array.
	 *
	 * @param array $values
	 * @param MergeStrategy[] $mergeStrategies The merge strategies indexed by config key
	 * @return ConfigBuilder
	 */
	public function setMulti( array $values, array $mergeStrategies = [] ): ConfigBuilder;

	/**
	 * Set the default for the configuration $key to $defaultValue.
	 *
	 * If the $key is already set, non-array $defaultValue will be ignored,
	 * for array $defaultValue the existing value will be merged into it as
	 * if the default was already there when the existing value was set.
	 *
	 * @param string $key
	 * @param mixed $defaultValue
	 * @param MergeStrategy|null $mergeStrategy strategy for merging array config values.
	 * @return ConfigBuilder
	 */
	public function setDefault( string $key, $defaultValue, ?MergeStrategy $mergeStrategy = null ): ConfigBuilder;

	/**
	 * Set defaults in a batch.
	 *
	 * @param array $defaults The default values
	 * @param MergeStrategy[] $mergeStrategies The merge strategies indexed by config key
	 * @return ConfigBuilder
	 * @throws SettingsBuilderException if a merge strategy is not provided and
	 *   the value is not an array.
	 */
	public function setMultiDefault( array $defaults, array $mergeStrategies ): ConfigBuilder;

	/**
	 * Get the current value for $key.
	 *
	 * @param string $key
	 * @return mixed
	 */
	public function get( string $key );

	/**
	 * Build the resulting Config object.
	 *
	 * @return Config
	 */
	public function build(): Config;
}