-
Notifications
You must be signed in to change notification settings - Fork 1
/
BOSS Userlist Syntax.html
362 lines (302 loc) · 18.2 KB
/
BOSS Userlist Syntax.html
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
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
<!DOCTYPE html>
<meta charset="utf-8">
<title>BOSS Userlist Syntax</title>
<link rel="icon" type="image/ico" href="icon.ico">
<link rel="stylesheet" href="css/readme.css">
<link rel="stylesheet" href="css/readme_aux.css">
<link rel="stylesheet" href="css/navigation.css">
<nav>
<header>
<h1><a href="index.html">BOSS</a></h1>
</header>
<a href="BOSS Readme.html">Readme</a>
<a href="BOSS Masterlist Syntax.html">Master List Syntax</a>
<a href="#" class="current">User List Syntax</a>
<a href="BOSS Version History.html">Version History</a>
<h2>Version 2.3.1</h2>
</nav>
<article>
<h1>Userlist Syntax</h1>
<h2>Contents</h2>
<ol id="contents">
<li><a href="#intro">Introduction</a>
<li><a href="#start">Getting Started</a>
<li><a href="#basics">Basic Rules</a>
<ol>
<li><a href="#basics-add">Sorting An Unknown Plugin</a>
<li><a href="#basics-override">Changing A Recognised Plugin's Position</a>
<li><a href="#basics-message">Editing A Plugin's BOSS Log Messages & Bash Tag Suggestions</a>
</ol>
<li><a href="#syntax">Rule Syntax</a>
<ol>
<li><a href="#syntax-rule">The Rule Line</a>
<li><a href="#syntax-sort">The Sort Line</a>
<li><a href="#syntax-message">The Message Line</a>
<li><a href="#syntax-examples">Examples</a>
</ol>
<li><a href="#notes">Further Notes</a>
<li><a href="#messages">The BOSS Message Format</a>
<li><a href="#license">License</a>
</ol>
<h2 id="intro">Introduction</h2>
<figure>
<img alt="userlist" src="images/Userlist.png">
<figcaption>An example userlist containing some user rules, as viewed in Notepad.</figcaption>
</figure>
<p>As mentioned in <a href="BOSS%20Readme.html#gui-urm">The User Rules Manager</a>, user rules can be used to customise BOSS's sorting of plugins and the messages attached to them. To recap, user rules can do the following:
<ol>
<li><i>Sort plugins relative to other plugins.</i> You can both override the positions of plugins BOSS recognises and sort plugins that are unrecognised.
<li><i>Sort groups of plugins relative to other groups of plugins.</i> BOSS's masterlist generally lists plugins in thematic groups, which you can override the relative positioning of. You can't create new groups though. Groups are marked out by the
<code>\BeginGroup\: <var>Group Name</var></code> and <code>\EndGroup\\</code>, or <code>BEGINGROUP: <var>Group Name</var></code> and <code>ENDGROUP</code>, lines.
<li><i>Insert plugins into the top or bottom of groups of plugins.</i>
<li><i>Edit the messages BOSS attaches to plugins.</i> You can add to or replace messages with your own. See <a href="#messages">The BOSS Message Format</a> below for more details on the message types and syntax.
</ol>
<p><strong>Note:</strong> This section contains some examples of user rules written for Oblivion mod plugins, but user rules will work for any of the games BOSS supports, not just Oblivion. In addition, when <q>your game's master file</q> is mentioned, this refers to Morrowind.esm, Oblivion.esm, Nehrim.esm, Skyrim.esm, Fallout3.esm or FalloutNV.esm for Morrowind, Oblivion, Nehrim, Skyrim, Fallout 3 or Fallout: New Vegas respectively.
<h2 id="start">Getting Started</h2>
<p>The userlist is the file which contains your user rules for sorting plugins and editing plugins' messages. It is found at <code>BOSS\[GAME]\userlist.txt</code>, where <code>[GAME]</code> is one of <code>Morrowind</code>, <code>Oblivion</code>, <code>Nehrim</code>, <code>Skyrim</code>, <code>Fallout 3</code> or <code>Fallout New Vegas</code>, depending on the game the userlist is for. A blank userlist is automatically created for a game when BOSS is first run for that game.
<p>Within this file, which you can edit in Notepad or any other text editor, you list your rule definitions. The rule definition syntax is simple and concise, and is explained in the <a href="#syntax">Rule Syntax</a> section below.
<p>When BOSS is run, it will read your userlist, checking the syntax of the rules it finds, and then attempt to apply the rules found if no syntax errors were encountered. It will display the rules it finds in the <q>User Rules</q> section of your BOSS Log, along with whether they were applied or not, and if not, why.
<p>If the parser finds a syntax error in your userlist, either grammatical or contextual, it will stop parsing and discard any rules it has found before printing an error message detailing what was expected and where. For some grammatical errors, the expected item may not provide much useful meaning - in these cases look at where the error was found and determine the exact cause of the problem yourself. See the <a href="BOSS%20Readme.html#trouble-error">Error Messages</a> section in the main readme for a full list of possible contextuaal syntax errors.
<p><b>Rule application does not alter your masterlist.txt or userlist.txt.</b> This means that if you want to undo the application of a rule, all you need to do is disable it and re-run BOSS.
<h2 id="basics">Basic Rules</h2>
<p>This section gives the syntax required to write some basic rules. A full description of the syntax is found in the <a href="#syntax">Rule Syntax</a> section.
<h3 id="basics-add">Sorting An Unknown Plugin</h3>
<p>To sort a plugin that is not in the masterlist after another plugin:
<code class="box">ADD: <var>[RULE PLUGIN]</var>
AFTER: <var>[SORT PLUGIN]</var>
</code>
<p>To sort it before another plugin:
<code class="box">ADD: <var>[RULE PLUGIN]</var>
BEFORE: <var>[SORT PLUGIN]</var>
</code>
<p>The <em>rule plugin</em> is the plugin you want to add, and the <em>sort plugin</em> is the plugin you want to sort it relative to.
<p>Examples:
<code class="box">ADD: Plugin1.esp
AFTER: AFK_Weye.esp
ADD: Plugin2.esp
BEFORE: AFK_Weye.esp
</code>
<p>This gives a load order of:
<blockquote>
...<br>
Plugin2.esp<br>
AFK_Weye.esp<br>
Plugin1.esp<br>
...
</blockquote>
<h3 id="basics-override">Changing A Recognised Plugin's Position</h3>
<p>To sort a plugin that is already in the masterlist after another plugin:
<code class="box">OVERRIDE: <var>[RULE PLUGIN]</var>
AFTER: <var>[SORT PLUGIN]</var>
</code>
<p>To sort it before another plugin:
<code class="box">OVERRIDE: <var>[RULE PLUGIN]</var>
BEFORE: <var>[SORT PLUGIN]</var>
</code>
<p>The <em>rule plugin</em> is the plugin you want to sort, and the <em>sort plugin</em> is the plugin you want to sort it relative to.
<p>Example:
<code class="box">OVERRIDE: bgBalancingEVCore.esp
AFTER: Unofficial Oblivion Patch.esp
</code>
<p>This gives a load order of:
<blockquote>
...<br>
Unofficial Oblivion Patch.esp<br>
bgBalancingEVCore.esp<br>
...
</blockquote>
<h3 id="basics-message">Editing A Plugin's BOSS Log Messages & Bash Tag Suggestions</h3>
<p>To add a message to a plugin for display in the BOSS Log:
<code class="box">FOR: <var>[RULE PLUGIN]</var>
APPEND: <var>[MESSAGE OBJECT]</var>
</code>
<p>To replace the messages attached to a plugin for display in the BOSS Log:
<code class="box">FOR: <var>[RULE PLUGIN]</var>
REPLACE: <var>[MESSAGE OBJECT]</var>
</code>
<p>The <em>rule plugin</em> is the plugin you want to add the message to. The <em>message object</em> is the formatted BOSS message that you want to attach. See the <a href="#messages">The BOSS Message Format</a> section later on in this readme if you are unfamiliar with BOSS message formatting.
<p>An example:
<code class="box">FOR: Unofficial Oblivion Patch.esp
REPLACE: SAY: Replaced!
FOR: bgMagicEV.esp
APPEND: TAG: {{BASH: Names, Delev, Relev}}
</code>
<p>This will print in the BOSS Log:
<blockquote>
...<br><br>
Unofficial Oblivion Patch.esp
<ul>
<li>Note: Replaced!
</ul>
...<br><br>
bgMagicEV.esp
<ul>
<li>Bashed Patch tag suggestion: {{BASH: Names, Delev, Relev}}
</ul>
...
</blockquote>
<h2 id="syntax">Rule Syntax</h2>
<p>User rules have a specific structure and syntax which your rules must follow to be applied. The information below provides the details on this structure and syntax.
<h3 id="syntax-rule">The Rule Line</h3>
<p>Every rule begins with a <em>rule line</em>, which defines what basic type of rule it is and what plugin it is applied to. It has the structure:
<code class="box"><var>[RULE KEYWORD]</var>: <var>[RULE OBJECT]</var></code>
<p>This is the <em>rule line</em>. The <em>rule keyword</em> can be one of:
<ul>
<li><dfn>ADD</dfn>: This tells BOSS that the rule sorts a plugin that is not in the
masterlist. The rule may also add and/or edit messages attached to that plugin.
<li><dfn>OVERRIDE</dfn>: This tells BOSS that the rule overrides the current position of a plugin or group in the masterlist with a new position.
The rule may also add and/or edit messages attached to that plugin.
<li><dfn>FOR</dfn>: This tells BOSS that the rule adds and/or edits the messages attached to a plugin, but does not sort it.
</ul>
<p>The <em>rule object</em> is the plugin or group that the rule is applied to. If the rule keyword is ADD or FOR, the rule object must be a plugin.
<p>When you define groups, the names of those groups are used as they appear in the masterlist. For example,
if you wanted to reference the group of plugins that begins with <code>\BeginGroup\: Supreme Magicka</code>, you would put it in the rule as <code>Supreme Magicka</code>.
<p>There is one more keyword that can be used on the rule line. <code>DISABLE</code> can be put before the rule keyword to prevent the rule from being applied. For example:
<code class="box">DISABLE ADD: MyMod.esp
AFTER: Unofficial Oblivion Patch.esp
</code>
<p>Would result in MyMod.esp not being sorted after Unofficial Oblivon Patch.esp. The <code>DISABLE</code> keyword should be used instead of silent comments to stop a rule being applied because the latter makes the rule invisible to the GUI's User Rule Manager whereas the former does not.
<h3 id="syntax-sort">The Sort Line</h3>
<p>If a rule's rule keyword is ADD or OVERRIDE, it can sort plugins and should include a <em>sort line</em> directly below the rule line. If the rule keyword is FOR, the rule <b>must not</b> include a sort line. A rule may only contain one sort line. The sort line has the structure:
<code class="box"><var>[SORT KEYWORD]</var>: <var>[SORT OBJECT]</var></code>
<p>The <em>sort keyword</em> can be one of:
<ul>
<li><dfn>BEFORE</dfn>: This states that the rule object is to load immediately before the sort object.
<li><dfn>AFTER</dfn>: This states that the rule object is to load immediately after the sort object.
<li><dfn>TOP</dfn>: This states that the rule plugin is to be inserted into the top of the sort group. The rule plugin will then load before everything else in the sort group.
<li><dfn>BOTTOM</dfn>: This states that the rule plugin is to be inserted into the bottom of the sort group. The rule plugin will then load after everything else in the sort group.
</ul>
<p>When using the BEFORE or AFTER sort keywords, the <em>sort object</em> is the plugin or group that you wish the rule object
to be positioned relative to. Plugins must be sorted relative to other plugins, and groups must be sorted relative to groups. You cannot sort plugins relative to groups, or vice versa. You also cannot sort your game's master file, sort other plugins before it, or sort groups before the "ESMs" group.
<p>When using the TOP or BOTTOM sort keywords, the <em>sort object</em> is the <b>group</b> that you wish to insert the rule plugin into. You cannot insert groups into anything, plugins into plugins, or insert anything into the top of the <q>ESMs</q> group.
<h3 id="syntax-message">The Message Line</h3>
<p>If a rule's rule keyword is FOR, it should include at least one <em>message line</em>. A rule with a rule keyword of ADD or OVERRIDE can also include message lines, if they sort a plugin. Message lines have the structure:
<code class="box"><var>[MESSAGE KEYWORD]</var>: <var>[MESSAGE OBJECT]</var></code>
<p>The <em>message keyword</em> can be one of:
<ul>
<li><dfn>APPEND</dfn>: This states that the message is to be appended to the list of messages attached to the rule plugin.
<li><dfn>REPLACE</dfn>: This states that the message is to replace any existing message or messages attached to the rule plugin. You may only have up to one <code>REPLACE</code> message line per rule, and if used it must be the first message line.
</ul>
<p>The <em>message object</em> is the message, complete with keyword, that you wish to attach to the plugin defined by the rule object. You cannot attach messages to groups.
<p>You may have multiple message lines in a rule (but only the first may use the <code>REPLACE</code> message keyword), to add multiple messages to a plugin, or to override an existing set of messages with a new set.
<h3 id="syntax-examples">Examples</h3>
<p>Here is the contents of an example userlist:
<code class="box">ADD: MyPluginToAdd.esp
AFTER: LoadAfterThis.esm
APPEND: SAY: Adding a general message.
APPEND: REQ: OOO
OVERRIDE: MyPluginToOverride.esp
BEFORE: LoadBeforeThis.esp
OVERRIDE: L.A.M.E.
BEFORE: Supreme Magicka
FOR: bgBalancingEVOptionalNPCDiversity, Vanilla.esp
REPLACE: SAY: This is a replacement message.
APPEND: TAG: {{BASH:NpcFaces,NoMerge}}
</code>
<p>This is the equivalent of the masterlist having:
<blockquote>
...<br>
LoadAfterThis.esm<br>
MyPluginToAdd.esp<br>
SAY: Adding a general message.<br>
REQ: OOO<br>
...<br>
MyPluginToOverride.esp<br>
LoadBeforeThis.esp<br>
...<br>
bgBalancingEVOptionalNPCDiversity, Vanilla.esp<br>
SAY: This is a replacement message.<br>
TAG: {{BASH:NpcFaces,NoMerge}}<br>
...
</blockquote>
<p>Which would give in the BOSS Log:
<blockquote>
...<br>
LoadAfterThis.esm<br>
MyPluginToAdd.esp
<ul>
<li>Note: Adding a general message.
<li>Requires: OOO
</ul>
...<br >
MyPluginToOverride.esp<br>
LoadBeforeThis.esp<br>
...<br>
bgBalancingEVOptionalNPCDiversity, Vanilla.esp
<ul>
<li> Note: This is a replacement message.
<li> Bash Tag Suggestion(s): {{BASH:NpcFaces,NoMerge}}
</ul>
...
</blockquote>
<p>The rule sorting the two groups L.A.M.E. and Supreme Magicka simply moves the L.A.M.E. group from its current position to before the Supreme Magicka group.
<h2 id="notes">Further Notes</h2>
<p>While the <a href="#syntax">Rule Definition Syntax</a> section gave you most of the rules of defining rules, here are some further general notes on defining rules that may not be evident:
<ol>
<li>Blank lines or lines beginning with <code>//</code> in your userlist will be ignored by BOSS. You can use blank lines to improve the formatting of your userlist, and use the <code>//</code> line start to provide comments. <strong>Using the GUI's User Rules Manager strips all comments from your userlist.</strong>
<ul>
<li>You can also begin lines with <code>\</code> instead of <code>//</code> to have the same effect, and comment out multiple lines by enclosing them between <code>/*</code> and <code>*/</code>.
<li>It is better to use the <code>DISABLE</code> keyword to disable rules, as this means that they are still visible to the GUI's User Rule Manager without being applied, though their syntax is still checked.
</ul>
<li>User rules are case-insensitive. The only exception is the message object, which will retain its case when displayed in the BOSS Log.
<li>If a rule's rule plugin is not installed in your Data folder, the rule will be skipped.
<li>Plugins ghosted by Wrye Bash are treated no differently from non-ghosted plugins, but they must be referenced without their ".ghost" extension.
<li>The group "ESMs" must always load first. You cannot sort this group or sort another group before it.
<li>The game's master file must always load first. You cannot sort it, sort another plugin before it, or insert another plugin into the top of the "ESMs" group.
<li>You cannot sort a plugin relative to another plugin that is not in the masterlist and has not been sorted by a previous rule.
<li>You cannot include conditionals in any messages added through user rules. While BOSS will not display any errors, the message will be added as if it were a note with no conditional.
<li>You cannot sort mods or groups relative to themselves.
<li>You cannot sort a non-master plugin before a master, or a master after a non-master plugin. Masters are commonly <code>.esm</code> files, and non-master plugins are commonly <code>.esp</code> files, but whether a plugin is a master or not is actually decided by a variable in the file, not the file extension. See <a href="BOSS%20Readme.html#appendix-c">False-Flagged Plugins</a> of the main readme for more information.
<li>
<p><b>Rules are applied in the order they are listed</b>. This means you can have several rules sorting different rule objects relative to the same sort object, or have rules sorting rule objects relative to sort objects that were sorted in previous rules.
For example:
<code class="box">ADD: LoadBeforeThis.esp
AFTER: RTT.esp
ADD: Plugin1.esp
BEFORE: LoadBeforeThis.esp
OVERRIDE: xulAspenWood.esp
AFTER: Plugin1.esp
ADD: Plugin2.esp
BEFORE: RTT.esp
</code>
<p>which will order the plugins as:
<blockquote>Plugin2.esp<br>
RTT.esp<br>
Plugin1.esp<br>
xulAspenWood.esp<br>
LoadBeforeThis.esp
</blockquote>
<p>Take care when writing such rules though, as a small difference in the order of the rules in your userlist can have a very large difference on the resulting load order.
</ol>
<h2 id="messages">The BOSS Message Format</h2>
<p>Each of the four message types that can be added via the userlist begins with a <em>message keyword</em>. The keyword is then followed by the message itself. The message is just a standard line of text. In addition, Bash Tag suggestion messages must include the suggested Bash Tags in a comma-separated list beginning with <code>{{BASH:</code> and ending with <code>}}</code>.
<p>The message types and keywords are listed in the table below:
<table>
<thead>
<tr>
<th><b>Message Type</b>
<th><b>Keyword</b>
<th>Example
<tbody>
<tr>
<td>Bash Tag Suggestion
<td>TAG:
<td><code>TAG: {{BASH: Names, Graphics}} to prevent changes being lost when using overhauls.</code>
<tr>
<td>General Message
<td>SAY:
<td><code>SAY: This message was added in a user rule.</code>
<tr>
<td>Installation Requirement
<td>REQ:
<td><code>REQ: This mod requires another.</code>
<tr>
<td>Specific Incompatibility
<td>INC:
<td><code>INC: This mod is incompatible with other mods that do the same thing.</code>
</table>
<h2 id="license">License</h2>
<p>This document is part of the BOSS documentation.<br>
Copyright (C) 2009-2012 BOSS Development Team.<br>
See the file <q>BOSS ReadMe.html</q> for copying conditions.
</article>