1 # XML Generator 2 3 This set of tools is used to transform files written in the pseudo language 4 (referred to as "Extended Domain Description") into XML parameter-framework 5 Settings files. The extension of such files are usually `.edd` or `.pfw`. 6 7 ## EDD Syntax 8 9 ### Introduction 10 11 The Extended Domain Description (EDD) has been designed to help describing 12 multiple and complex PFW settings. It is a recursive structured language with 13 tabulation indentation (inspired from python). 14 15 It has several advantages : 16 17 - Easy to write 18 - Easy to read 19 - Nearly twice as compact as it's equivalent in XML 20 - Less merge conflicts and easy solving 21 - Can be split in multiple files 22 - Intuitive syntax and comprehension when you know the PFW concepts 23 24 But has a couple of drawbacks: 25 26 - it is not supported natively by the PFW. It needs to be compiled into XML. 27 - it supports only tabulation indentation 28 29 ### Concepts 30 31 The EDD adds a couple of concepts over the PFW ones in order to extend the 32 concepts used in the Settings files. 33 34 #### DomainGroup 35 A domain group can contain other domain groups and domains. Those inner domains 36 will be prefixed with the name of the domain group. 37 38 *The tag for domain groups is `domainGroup`.* 39 40 *Example* 41 42 ``` 43 domainGroup: Codec 44 45 domain: Flow 46 conf: Unmute 47 /Audio/codec/playback/master_mute = 0 48 conf: Mute 49 /Audio/codec/playback/master_mute = 1 50 51 domainGroup: Configure 52 RoutageState Includes Configure 53 54 domain: IHF 55 [...] 56 ``` 57 58 will create the domains : 59 60 - Codec.Flow (containing the Unmute and Mute configurations) 61 - Codec.Configure.IHF (The `RoutageState Includes Configure` rule will apply to 62 all configurations inside the `Codec.Configure.*` domains) 63 64 #### ConfigurationGroup 65 A configuration group can contain other configuration groups and 66 configurations. Those inner configurations will be prefixed with the name of 67 the configuration group. 68 69 *The tag for configuration groups is `confGroup`.* 70 71 *Example* 72 73 ``` 74 domain: ExternalDSP 75 76 conf: TTY 77 [...] 78 79 confGroup: CsvCall 80 Mode Is InCsvCall 81 82 confGroup: Output 83 conf: IHF 84 [...] 85 conf: Earpiece 86 [...] 87 ``` 88 89 will create the following configurations in the `ExternalDSP` domain: 90 91 - TTY 92 - CsvCall.Output.IHF 93 - CsvCall.Outout.Earpiece 94 95 As with domainGroup, the `Mode Is InCsvCall` rule applies to all 96 `CsvCall.Output.*` configurations in the `ExternalDSP` domain. 97 98 #### ConfigurationType 99 A configuration type is the specialization concept. When defining a 100 configuration type, any configuration in the containing domain (or domain 101 group) with the same name will inherit the configuration type rule. 102 103 *The tag for configuration types is `confType`.* 104 105 *Example* 106 107 ``` 108 domain: ExternalDSP 109 confType: Bind 110 Mode Is InCsvCall 111 112 confGroup: Modem 113 114 conf: Bind 115 BandRinging is Modem 116 [...] 117 conf: Unbind 118 [...] 119 ``` 120 121 will create the following configurations in the `ExternalDSP` domain: 122 123 - Modem.Bind (applicable if `Mode Is InCsvCall` and `BandRinging is Modem`) 124 - Modem.Unbind (no rule, i.e. applicable by default) 125 126 #### Component 127 A component can be used to factorize parameter names in configurations. 128 129 *The tag for components is `component`.* 130 131 ``` 132 domain: Foo 133 conf: Bar 134 component: /System/some_element 135 parameter1 = "egg" 136 parameter2 = "spam" 137 /System/another_element/parameter3 = 42 138 ``` 139 140 will create a domain Foo containing a configuration Bar (no rule, i.e. 141 applicable by default) that will set these 3 parameters: 142 143 - `/System/some_element/parameter1` to "egg" 144 - `/System/some_element/parameter2` to "spam" 145 - `/System/another_element/parameter3` to 42 146 147 ## Preprocessor 148 149 The xmlGenerator uses m4 to preprocess the files before parsing them. You may 150 use any macro implemented by m4, such as `define` and `include`. This is 151 deprecated and we do not recommend using it. 152 153 ## Style 154 155 Here are a few recommendations to follow when writing Settings using EDD: 156 157 ### Rules 158 159 - if you need to modify a rule, do not hesitate to rework it globally. 160 - keep rule depth under 3-4. 161 - factorize the rules, taking 3 minute to write a Karnaugh map is worth it. 162 - comment, comment, comment ! 163 164 ### Enum Parameters 165 166 When setting an enum parameter value, use its lexical space, not its numerical 167 space. E.g. don't write 168 169 /Subsystem/frequency = 5 170 171 Write instead: 172 173 /Subsystem/frequency = f48kHz 174 175 ### String Parameters 176 177 In an EDD file, string parameters may not contain newlines. Apart from that, 178 all characters are supported. Also, leading spaces are ignored. Do *not* 179 surround a string parameter's value with quotes. Don't write: 180 181 /Subsystem/string_parameter = "some string value" 182 183 Write instead: 184 185 /Subsystem/string_parameter = some string value 186 187 ## XML Generation 188 189 Once a `.edd` file is ready to be tested, it is possible to generate the 190 corresponding XML file. 191 192 ### domainGenerator.py 193 194 This python tool is self-documented: you may run `domainGenerator.py -h` to get 195 its full usage. 196 197 It prints the resulting XML on the standard output. Its syntax is: 198 199 domainGenerator.py [-h] --toplevel-config TOPLEVEL_CONFIG_FILE 200 --criteria CRITERIA_FILE 201 [--initial-settings XML_SETTINGS_FILE] 202 [--add-domains XML_DOMAIN_FILE [XML_DOMAIN_FILE ...]] 203 [--add-edds EDD_FILE [EDD_FILE ...]] 204 [--schemas-dir SCHEMAS_DIR] 205 [--validate] [--verbose] 206 207 *Explanation:* 208 209 - The "top-level configuration file" is the same as the one provided by the 210 parameter-framework client to instantiate it. The plugins referenced in that 211 file are not used. 212 - The "criteria file" lists all criteria and possible values used in the EDD 213 files. 214 - The initial settings file is an XML file containing a single 215 `<ConfigurableDomains>` (plural) tag; it may not overlap with the other 216 sources below. It will be imported into the settings. 217 - Domain files are XML files, each containing a single `<ConfigurableDomain>` 218 (singular) tag. They all will be imported in the order of the command line 219 into the settings. 220 - EDD files are all the files in EDD syntax you want to add to your Settings. 221 - The optional `--schemas-dir` argument lets you change the directory 222 containing the XML Schemas in the context of the XML generation only (see the 223 `--validate` option). 224 - The optional `--validate` option check the validity of all XML files involved 225 in the process. 226 227 *Regarding XML Domain files and EDD files:* 228 229 In theory, the order doesn't matter but since files are parsed in the order of 230 the command line, you'll get different (although equivalent) files if you 231 change the order, which makes it more difficult to compare versions. 232 233 234 *The "criteria file" must look something like this:* 235 236 ``` 237 ExclusiveCriterion Criterion1Name : Criterion1Value1 Criterion1Value2 238 InclusiveCriterion Criterion2Name : Criterion2Value1 Criterion2Value2 239 ``` 240 241 I.e. One criterion by line, starting by its kind, then its name, followed by a 242 semicolon and then all possible values separated by spaces. 243 244 #### How it works 245 TODO 246