Skip to content
This repository has been archived by the owner on Oct 15, 2024. It is now read-only.

Commit

Permalink
doc: clarify why no array
Browse files Browse the repository at this point in the history
  • Loading branch information
Markus Raab committed Oct 7, 2016
1 parent 5424aaf commit 8348e4c
Showing 1 changed file with 31 additions and 21 deletions.
52 changes: 31 additions & 21 deletions doc/decisions/plugin_variants.md
Original file line number Diff line number Diff line change
Expand Up @@ -54,11 +54,23 @@ are:

## Decision

Provide a function `int genconf (KeySet * ks, Key * errorKey)` where `ks`
contains a list of all variants with the essential configuration
and the changed parts of the contract as subkeys.

E.g. for augeas:
1. Provide a function `int genconf (KeySet * ks, Key * errorKey)` where `ks`
is filled with a list of all variants with the essential configuration (subkeys `config`)
and the changed parts of the contract (subkeys `infos`).
2. Keys defined in `system/elektra/plugins/variants` have the same content,
but take precedence. If a variant with the same name is defined, only `config` or `infos`
from `genconf` are considered if they are not mentioned in `system/elektra/plugins/variants`.
If the keys `config` or `infos` are present, it will be overwritten (deleted),
if only subkeys thereof are present, it will be enhanced.
3. Empty `config` and `infos` mean:
- `config`: The "default variant" (without any parameter) should be also available
(has useful functionality)
- `infos`: It is not possible to determine the changes of the contract,
the user need to instantiate the plugin and enquiry the contract.

### Example

`genconf` for augeas yields:
```
access
access/config
Expand All @@ -68,33 +80,31 @@ access/infos/format = access
aliases
aliases/config
aliases/config/lens = Aliases.lns
aliases/config/path = /etc/aliases
aliases/infos
aliases/infos/format = aliases
```

Which would enlist `augeas#access`

E.g. for python:
`genconf` for python yields:
```
configparser/config
configparser/config/script = python_configparser.py
```

the user specifies:
```
system/elektra/plugins/variants/access
system/elektra/plugins/variants/aliases/infos/status = 10000
system/elektra/plugins/variants/configparser
system/elektra/plugins/variants/configparser/config
system/elektra/plugins/variants/configparser/config/script = mybetter_configparser.py
```

The same keys can be enhanced or overwritten in
`system/elektra/plugins/variants`.

The keys defined in `system/elektra/plugins/variants` have precedence.


The absence of parts mean:
- `config`: The default variant (given no parameter), if it makes sense
(has useful functionality)
- `infos`: It is not possible to determine the changes of the contract,
the user need to instantiate the plugin and enquiry the contract.
- `config` and `infos`: To manually suppress a plugin variant to not
enlist it and do not try to instantiate it.
then the plugin variant:

1. `access` is not available (`system/elektra/plugins/variants/access` overrides `genconf`)
2. `aliases` as defined from `genconf`, but with changes in contract (`infos/status`)
3. `configparser` is completely redefined (result from `genconf` will not be considered)


## Argument
Expand Down

0 comments on commit 8348e4c

Please sign in to comment.