5743.3.7
by Vincent Ladeuil
Add some documentation about option and sections. |
1 |
Configuring Bazaar |
2 |
================== |
|
3 |
||
6332.1.2
by Vincent Ladeuil
Add a contents directive and fold the initial remarks about config option in the right section. |
4 |
.. contents:: |
5 |
:depth: 2 |
|
6 |
||
5743.12.10
by Vincent Ladeuil
Add documentation. |
7 |
|
6332.1.1
by Martin Pool
Attempted developer documentation of configuration |
8 |
The short story |
9 |
--------------- |
|
10 |
||
11 |
As a Bazaar developer there are three things you need to know about |
|
12 |
configuration. |
|
13 |
||
6332.1.3
by Vincent Ladeuil
Better tweaks (the value is not a property of the option). |
14 |
1. Get a value. |
15 |
||
16 |
You construct or get a reference to a ConfigStack subclass that's relevant |
|
17 |
to the context where you want to look up a value. For instance, given a |
|
18 |
branch:: |
|
6332.1.1
by Martin Pool
Attempted developer documentation of configuration |
19 |
|
20 |
print branch.get_config_stack().get('log_format') |
|
21 |
||
22 |
This will look up the stack through all relevant configuration sources. |
|
23 |
The value returned is of the type declared for that Option and if nothing |
|
24 |
is specifically declared you will get the default for that option. |
|
25 |
||
6332.1.3
by Vincent Ladeuil
Better tweaks (the value is not a property of the option). |
26 |
2. Add a new option. |
27 |
||
28 |
You add a new ``Option`` to the ``option_registry``, either inside |
|
29 |
``bzrlib/config.py`` or during initialization of your plugin. New plugins |
|
30 |
should have systematic hierarchical names so that related values are grouped |
|
31 |
together:: |
|
6332.1.1
by Martin Pool
Attempted developer documentation of configuration |
32 |
|
33 |
option_registry.register( |
|
34 |
Option('dirstate.fdatasync', default=True, |
|
35 |
from_unicode=bool_from_store, |
|
36 |
help="Flush dirstate changes onto physical disk? ....")) |
|
37 |
||
6332.1.3
by Vincent Ladeuil
Better tweaks (the value is not a property of the option). |
38 |
|
39 |
3. Old and new configuration code. |
|
40 |
||
41 |
There is (as of late 2011) some older and some newer configuration code. The |
|
42 |
old code has specific methods for various checks or uses classes like |
|
43 |
``GlobalConfig``. Don't add to to it; try to remove it. |
|
6332.1.1
by Martin Pool
Attempted developer documentation of configuration |
44 |
|
5743.12.10
by Vincent Ladeuil
Add documentation. |
45 |
Option |
46 |
------ |
|
47 |
||
48 |
The Option object is used to define its properties: |
|
49 |
||
50 |
* name: a name: a valid python identifier (even if it's not used as an |
|
51 |
identifier in python itself). This is also used to register the option. |
|
52 |
||
6332.1.2
by Vincent Ladeuil
Add a contents directive and fold the initial remarks about config option in the right section. |
53 |
* from_unicode: a callable accepting a unicode string and returning a |
54 |
suitable value for the option. If the string cannot be coerced it should |
|
55 |
return None. |
|
56 |
||
5743.12.10
by Vincent Ladeuil
Add documentation. |
57 |
* default: the default value that Stack.get() should return if no |
58 |
value can be found for the option. |
|
59 |
||
6082.2.1
by Vincent Ladeuil
Implement default values from environment for config options |
60 |
* default_from_env: a list of environment variables. The first variable set |
61 |
will provide a default value overriding 'default' which remains the |
|
6082.2.2
by Vincent Ladeuil
Fix typos. |
62 |
default value if *no* environment variable is set. |
6082.2.1
by Vincent Ladeuil
Implement default values from environment for config options |
63 |
|
6056.2.4
by Vincent Ladeuil
Option help is now part of the object itself. |
64 |
* help: a doc string describing the option, the first line should be a |
65 |
summary and can be followed by a blank line and a more detailed |
|
6332.1.3
by Vincent Ladeuil
Better tweaks (the value is not a property of the option). |
66 |
explanation. This will be displayed to the user with:: |
67 |
||
68 |
bzr help <option name> |
|
6059.1.1
by Vincent Ladeuil
Implement from_unicode to convert config option values from store. |
69 |
|
6059.1.5
by Vincent Ladeuil
Handle invalid config option values. |
70 |
* invalid: the action to be taken when an invalid value is encountered in a |
71 |
store (during a Stack.get()). |
|
72 |
||
6332.1.3
by Vincent Ladeuil
Better tweaks (the value is not a property of the option). |
73 |
The value of an option is a unicode string or ``None`` if it's not |
74 |
defined. By using ``from_unicode`` you can turn this string into a more |
|
75 |
appropriate representation (a list of unicode strings for example). |
|
76 |
||
5743.3.7
by Vincent Ladeuil
Add some documentation about option and sections. |
77 |
Sections |
78 |
-------- |
|
79 |
||
80 |
Options are grouped into sections which share some properties with the well |
|
81 |
known dict objects: |
|
82 |
||
5743.12.10
by Vincent Ladeuil
Add documentation. |
83 |
* the key is the name, |
84 |
* you can get, set and remove an option, |
|
85 |
* the value is a unicode string. |
|
5743.3.7
by Vincent Ladeuil
Add some documentation about option and sections. |
86 |
|
5743.3.10
by Vincent Ladeuil
Fix typos mentioned in reviews. |
87 |
MutableSection is needed to set or remove an option, ReadOnlySection should |
5743.3.7
by Vincent Ladeuil
Add some documentation about option and sections. |
88 |
be used otherwise. |
89 |
||
6082.5.24
by Vincent Ladeuil
More documentation about local section options. |
90 |
|
5743.4.16
by Vincent Ladeuil
Some doc for the stores. |
91 |
Stores |
92 |
------ |
|
93 |
||
5743.4.25
by Vincent Ladeuil
Address review comments by jelmer and poolie. |
94 |
Options can be persistent in which case they are saved into Stores. |
5743.4.16
by Vincent Ladeuil
Some doc for the stores. |
95 |
|
96 |
``config.Store`` defines the abstract interface that all stores should |
|
97 |
implement. |
|
98 |
||
5743.4.25
by Vincent Ladeuil
Address review comments by jelmer and poolie. |
99 |
This object doesn't provide direct access to the options, it only provides |
100 |
access to Sections. This is deliberate to ensure that sections can be |
|
101 |
properly shared by reusing the same underlying objects. Accessing options |
|
102 |
should be done via the ``Section`` objects. |
|
5743.4.16
by Vincent Ladeuil
Some doc for the stores. |
103 |
|
104 |
A ``Store`` can contain one or more sections, each section is uniquely |
|
105 |
identified by a unicode string. |
|
106 |
||
107 |
``config.ConfigObjStore`` is an implementation that use ``ConfigObj``. |
|
108 |
||
109 |
Depending on the object it is associated with (or not) a ``Store`` also needs |
|
110 |
to implement a locking mechanism. ``LockableConfigObjStore`` implements such a |
|
111 |
mechanism for ``ConfigObj`` based stores. |
|
5743.5.6
by Vincent Ladeuil
Mention that the test framework ought to support adding new stores. |
112 |
|
113 |
Classes are provided for the usual Bazaar configuration files and could be |
|
114 |
used as examples to define new ones if needed. The associated tests provides a |
|
115 |
basis for new classes which only need to register themselves in the right |
|
116 |
places to inherit from the existing basic tests and add their own specific |
|
117 |
ones. |
|
5743.2.29
by Vincent Ladeuil
Add doc for the section matchers. |
118 |
|
119 |
Filtering sections |
|
120 |
------------------ |
|
121 |
||
122 |
For some contexts, only some sections from a given store will apply. Defining |
|
6082.5.24
by Vincent Ladeuil
More documentation about local section options. |
123 |
which is what the ``SectionMatcher`` objects are about. |
5743.2.29
by Vincent Ladeuil
Add doc for the section matchers. |
124 |
|
125 |
The main constraint here is that a ``SectionMatcher`` should delay the loading |
|
126 |
of the associated store as long as possible. The constructor should collect |
|
127 |
all data needed for the selection and uses it while processing the sections in |
|
128 |
``get_sections``. |
|
129 |
||
6123.7.1
by Vincent Ladeuil
Provide config.IdMatcher for config files defining secion names as unique ids |
130 |
Only ``ReadOnlySection`` objects are manipulated here but a |
131 |
``SectionMatcher`` can return dedicated ``Section`` objects to provide |
|
132 |
additional context (the ``LocationSection`` add an ``extra_path`` attribute |
|
133 |
to implement the ``appendpath`` policy for example). If no sections match, |
|
134 |
an empty list is returned. |
|
5743.2.29
by Vincent Ladeuil
Add doc for the section matchers. |
135 |
|
6082.5.24
by Vincent Ladeuil
More documentation about local section options. |
136 |
Options local to a section can also be defined for special purposes and be |
137 |
handled by ``Section.get()``. One such option is ``relpath`` which is |
|
138 |
defined in ``LocationSection`` as an alternative to the ``appendpath`` |
|
139 |
policy. |
|
140 |
||
6082.5.25
by Vincent Ladeuil
Add ``basename`` as a section local option |
141 |
For ``appendpath``, the ``LocationSection`` will carry ``extra_path`` as the |
142 |
relative path between the section name and the location used. ``relpath`` |
|
143 |
will be available as a ``Section`` local option with the same |
|
144 |
value. ``basename`` will carry the location base name and be available as a |
|
145 |
local option with the same name. Note that such options can only be expanded |
|
146 |
inside the section that defines them. |
|
5743.1.24
by Vincent Ladeuil
Some generic doc about stacks. |
147 |
|
6123.7.1
by Vincent Ladeuil
Provide config.IdMatcher for config files defining secion names as unique ids |
148 |
Specific section matchers can be implemented by overriding ``get_sections`` |
149 |
or just ``match``. |
|
150 |
||
151 |
``bzrlib`` provides: |
|
152 |
||
153 |
* ``LocationMatcher(store, location)``: To select all sections that match |
|
154 |
``location``. |
|
155 |
||
6123.7.2
by Vincent Ladeuil
Rename IdMatcher to NameMatcher. |
156 |
* ``NameMatcher(store, unique_id)``: To select a single section matching |
6123.7.1
by Vincent Ladeuil
Provide config.IdMatcher for config files defining secion names as unique ids |
157 |
``unique_id``. |
158 |
||
5743.1.24
by Vincent Ladeuil
Some generic doc about stacks. |
159 |
Stacks |
160 |
------ |
|
161 |
||
6332.1.3
by Vincent Ladeuil
Better tweaks (the value is not a property of the option). |
162 |
An option can take different values depending on the context it is |
163 |
used. This can involve configuration files, options from the command line, |
|
5743.1.24
by Vincent Ladeuil
Some generic doc about stacks. |
164 |
default values in bzrlib and then some. |
165 |
||
166 |
Such a context is implemented by creating a list of ``Section`` stacked upon |
|
167 |
each other. A ``Stack`` can then be asked for an option value and returns the |
|
168 |
first definition found. |
|
169 |
||
170 |
This provides a great flexibility to decide priorities between sections when |
|
171 |
the stack is defined without to worry about them in the code itself. |
|
172 |
||
173 |
A stack also defines a mutable section (which can be None) to handle |
|
174 |
modifications. |
|
175 |
||
176 |
Many sections (or even stores) are aimed at providing default values for an |
|
177 |
option but these sections shouldn't be modified lightly as modifying an option |
|
178 |
used for different contexts will indeed be seen by all these contexts. |
|
179 |
||
5743.1.35
by Vincent Ladeuil
Address some review comments from jelmer and poolie. |
180 |
Default values in configuration files are defined by users. Developers |
5743.1.24
by Vincent Ladeuil
Some generic doc about stacks. |
181 |
shouldn't have to modify them, as such, no mechanism nor heuristics are used |
5743.1.35
by Vincent Ladeuil
Address some review comments from jelmer and poolie. |
182 |
to find which section (or sections) should be modified. |
5743.1.24
by Vincent Ladeuil
Some generic doc about stacks. |
183 |
|
5743.1.35
by Vincent Ladeuil
Address some review comments from jelmer and poolie. |
184 |
A ``Stack`` defines a mutable section when there is no ambiguity. If there |
185 |
is one, then the *user* should be able to decide and in this case a new |
|
186 |
``Stack`` can be created cheaply. |
|
5743.1.24
by Vincent Ladeuil
Some generic doc about stacks. |
187 |
|
5743.6.5
by Vincent Ladeuil
Complement the stacks doc. |
188 |
Different stacks can be created for different purposes, the existing |
5743.6.16
by Vincent Ladeuil
Fix typo. |
189 |
``GlobalStack``, ``LocationStack`` and ``BranchStack`` can be used as basis |
5743.6.5
by Vincent Ladeuil
Complement the stacks doc. |
190 |
or examples. These classes are the only ones that should be used in code, |
191 |
``Stores`` can be used to build them but shouldn't be used otherwise, ditto |
|
192 |
for sections. Again, the associated tests could and should be used against the |
|
193 |
created stacks. |