The Tutorial section already gives an introduction to .fms files. The following examples summarize the syntax of `.fms' files and introduce extra features designed to make these files more flexible and easier to edit.
|  |   | 
Figure 6.1: Comments
The syntax for setting and parameter assignments is pretty flexible. You can use a ‘=’, ‘:’ or nothing at all between the setting/parameter id and its assigned value. To append to a list or replace entries in a mapping from strings to values, use a plus sign (i.e., use ‘+=’, ‘+:’ or ‘+’).
Strings can be surrounded by single or double quotes. If there are no characters that could be confused with the string's surrounding context (e.g., ‘,’, ‘)’, ‘=’, etc.) then quotes aren't necessary. A double quote inside a double-quoted string is specified with ‘\"’, a single quote inside a single-quoted string is specified with ‘\'’, and a space in an unquoted string is specified with ‘\ ’. Also, a tab character is specifed with ‘\t’ and a newline with ‘\n’.
Lists are enclosed in ‘(’ and ‘)’. Object definitions are enclosed in ‘<’ and ‘>’. Lists can optionally contain commas to separate elements. Setting/value pairs in object definitions can also be delimited by commas to assist readability. If a list is described in the documentation as a “mapping” from strings to values, then the string/value pairs can also be specified as assignments (i.e., using ‘=’ or ‘:’) and delimited by commas.
Floating point numbers always have a decimal point in them while integers, rationals and mixed numbers don't.
The example below demonstrates the variety of options described above.
|  |   | 
Figure 6.2: Syntax
Many parameters and symbols have abbreviations, as shown below.
| dyns = yes part <id p1 inst "oboe"> // measures time 0 dur 3 measure <> time 0 dur 3 meas <> time 0 dur 3 mea <> time 0 dur 3 me <> time 0 dur 3 e <> time 0 dur 3 || // note event parameters part p1 voice 1 note time 0 grace 0 duration 1/2 pitch 59 dynamic 1 ; note time 0 duration 1 pitch 60 dynamic 1 ; mark [.]; par p1 voi 1 not tim 2 gra 0 dur 1/2 pit 59 dyn 1 ; not tim 2 dur 1 pit 60 dyn 1 ; mar [.]; pa p1 vo 1 no ti 4 gr 0 du 1/2 pi 59 dy 1 ; no ti 4 du 1 pi 60 dy 1; ma [.]; a p1 v 1 n t 6 g 0 d 1/2 p 59 y 1 ; n t 6 d 1 p 60 y 1; m [.]; rest tim 7 dur 1 ; res tim 8 dur 1 ; re tim 9 dur 1 ; r tim 10 dur 1 ; |   | 
Figure 6.3: Abbreviations
Note events are created by specifying the values of parameters, settings and marks and “entering” the note with a ‘;’. 
One note event is created for each ‘;’ encountered in the file. 
To specify a rest or mark event, include the symbol rest or mark before the ‘;’ (the symbol note is also valid but unnecessary).
   
| time 0 dur 1/2 pitch 60; time + dur 1/2 pitch 62; time + dur 1/2 pitch 64; time + dur 1/2 pitch 65; time + dur 1/2 pitch 67; time + dur 1/2 rest [ferm]; time + dur 1/2 pitch 65 ; time + dur 1/2 pitch 64 ; time + dur 1/2 pitch 62 ; time + dur 1/2 pitch 60 ; mark time 3 dur 2 [.]; |   | 
Figure 6.4: Note Events
Marks are specified by enclosing the mark symbol within a ‘[’ and ‘]’. If the mark requires an argument, it is also included within the brackets and separated from the mark symbol by a space or comma.
|  |   | 
Figure 6.5: Marks
When the values of the following parameters are set, they “stick” until the next time they are set in the file:
time, duration, pitch, part, voice, dynamic and grace. 
When FOMUS encounters a ‘;’, a note event is constructed from these arguments in whatever current states they are in. 
This allows you to represent constructs such as chords and melodies more efficiently and in a style that's easier to read
than when all parameters are specified for each individual note.
   
|  |   | 
Figure 6.6: Sticky Values
grace behaves in a special manner.  Whenever time is set to some value, grace is “reset” (i.e., the next note
isn't a grace note until another grace value is encountered).  As long as time isn't given a value, grace behaves
in a sticky manner like all of the other arguments.
   
|  |   | 
Figure 6.7: Sticky Grace Values
Marks don't behave stickily. The entire set of marks must be specified for each individual note. Setting assignments are also not sticky—like marks, they must appear in each individual note. If you need to specify marks and settings for large groups of notes, define a region (see below for an example).
A ‘+’ following the time parameter is an instruction to increment the time by the last duration value. 
‘+’ can also be used to increment “grace time” in the same way.
   
| duration 1 time 0 pitch 60; duration 1/2 time + pitch 61; time + pitch 60; time + pitch 59; time + pitch 60; duration 1/3 time + pitch 61; time + pitch 62; time + pitch 61; time + pitch 60; time + pitch 59; time + pitch 58; time + pitch 59; time + pitch 60; time + time 6 duration 1/4 grace 0 pitch 70; grace + pitch 66; grace + pitch 62; time 6 duration 1 pitch 63; |   | 
Figure 6.8: Time Increments
A ‘+’ following the duration parameter is an instruction to set the duration of the note so that it ends where the next note begins
in the same voice.  A ‘-’ following a duration parameter is an instruction to end the note at the given time, and place the onset
at the end time of the previous note in the same voice.
   
| time 0 duration + pitch 60; time 1 duration + pitch 66; time 1+1/2 duration + pitch 59; time 3 duration + pitch 62; time 3+1/2 duration + pitch 64; time 5 duration + pitch 61; time 6 duration 1/2 pitch 69; time 8 duration 1/2 pitch 60; time 9 duration - pitch 66; time 9+1/2 duration - pitch 59; time 11 duration - pitch 62; time 11+1/2 duration - pitch 64; time 13 duration - pitch 61; time 14 duration - pitch 69; |   | 
Figure 6.9: Time Extensions
‘{’ and ‘}’ are used to surround a group of entries and modify them in some way. 
A region beginning with ‘time +4 {’, for example, increments all of the time values in the region by 4. 
For time, grace duration and dyn, any one of ‘+’, ‘-’, ‘*’ and ‘/’ can be used (i.e., times, durations and dynamics
can be scaled using ‘*’ and ‘/’ as well as incremented using ‘+’ and ‘-’). 
It's important to note that if you scale time with a region specification like ‘time *2 {’ or ‘time /2 {’,
this only scales time values, not duration values.  For example, ‘time *2 {’ should usually be accompanied by ‘dur *2 {’
to produce the effect you probably want. 
pitch may be modified with ‘+’ or ‘-’ but not scaled like time and dur.
   
voice can be altered by specifying a voice or list of voices to add or subtract from all of the enclosed note events. 
For example, voice +2 { means voice 2 is an additional choice for all enclosed note events (2 is added to each event's list of voices) while
‘voice -2 {’ means voice 2 is never a choice regardless of what is specified in each note event (2 is removed from each event's list of voices). 
‘voice 2 {’ means simply set all enclosed events to voice 2. 
Mark regions can also be defined, and behave in a manner similar to voice regions. 
For example, ‘[.] {’ or ‘+[.] {’ means a staccato mark is added to all enclosed note events while
‘-[.] {’ means staccato marks are removed from all enclosed note events regardless of whether or not they are specified in individual notes.
   
|  |   | 
Figure 6.10: Regions
Some of the regions in the example above are nested.  When numerical values like time or pitch are being modified, the effects accumulate. 
When lists of things (like voices or marks) are being modified inner regions take precendence over the outer ones. 
Regions can also overlap.  To specify which ‘{’ belongs to which ‘}’ you must attach matching tag strings to them
(e.g., ‘a{’ would match ‘}a’ and ‘foo{’ would match ‘}foo’). 
Also, a region extending to the end of the file can be defined with an alternate syntax using ‘..’ or ‘...’
instead of ‘{’ (e.g., ‘time +1 ...’).
   
|  |   | 
Figure 6.11: Nested and Overlapping Regions
Settings can also be specified for groups of notes using regions.  In the following example staff is set to 1
for the first four note entries and 2 for the next four.  The ‘time 0’ is necessary to tell FOMUS that the following
‘staff = 1’ is not a score-level setting (which must appear before anything else in the file) but a note event setting (see Settings (File)).
   
|  |   | 
Figure 6.12: Settings in Regions
Notes and durations can be specified symbolically using strings in .fms files. 
A pitch symbol begins with a note letter followed optionally by one or two accidentals (the second accidental is a microtone adjustment) and
an octave number (middle C is ‘c4’).  If the octave number is omitted, the pitch closest to the last specified pitch is used. 
It is important to note that by specifying pitches this way you are not specifying notation (i.e., ‘cs4’ could turn out to be a C-sharp, D-flat or
B-doublesharp in the score regardless of the ‘s’ in the symbol), they are only a convenient way of representing numeric values.  To actually force FOMUS
to use a sharp, you would have to use the acc setting.
   
Duration symbols consist of a base string (e.g., ‘q’ signifies a quarter note, ‘e’ signifies an eighth note, etc.), a dot or double-dot symbol, and an optional
tuplet modifier (e.g., ‘t’ multiplies the value by 2/3, ‘q’ multiplies the value by 4/5, etc.).  The symbol may also be followed by a tie
(the ‘+’, ‘_’ or ‘~’ characters can be used) and another duration symbol, in which case the two duration values are added together. 
Like pitch symbols, rhythmic symbols map strictly to FOMUS time values and don't necessarily signify the rhythmic spelling of the note. 
For example, the default symbol ‘s’ specifies a sixteenth note only when the beat setting is set to 1/4 (1 beat equals 1 quarter note—see setBeat). 
If you change the value of beat to 1/8, ‘s’ outputs a 32nd note instead since it still represents 1/4 of a beat. 
(The reason for this discrepancy is that, under some conditions, it would be impossible for FOMUS to determine proper event times and durations
if logical values are mixed with notation symbols.)
   
| quartertones = yes time 0 duration s pitch c3; // octave is given only on first note time + duration e pitch dn; // d natural time + duration q pitch ef; time + duration h pitch fs; time + duration w pitch gb; time + duration e. pitch f#; // dot modifiers time + duration q. pitch e-; time + duration h. pitch d+; // tuplet modifiers time 20 duration qt pitch cns4; // one quartertone sharp (natural-sharp) time + duration qt pitch cnf; time + duration qt pitch bff; // three quartertones flat (flat-flat) time 24 duration q+s pitch css; |   | 
Figure 6.13: Pitch and Duration Symbols
The settings note-symbols, note-accs, note-microtones and note-octaves contain all of the information for parsing notes while
dur-symbols, dur-dots, dur-tie and tuplet-symbols contain information for parsing durations. 
Look up the values of these settings to see all of the options available for constructing symbols, or customize them if the default values are insufficient. 
The following example shows how to do this:
   
|  |   | 
Figure 6.14: Custom Pitch and Duration Symbols
These settings also affect the appearance of symbols printed by the online documentation.
To include another file, use the include instruction shown in the example below. 
Files may be included at any location, and can be in any format that FOMUS recognizes (e.g., a MIDI file).
   
| // include the comments example at the beginning of this section include "comments.fms" time: 4 dur: 1+1/2 pitch: 30; |   | 
Figure 6.15: Including the Comments Example
Macros are text strings that can be inserted at any arbitrary location in the file. 
They are defined with the macro keyword followed by a string that specifies the name of the macro,
a list of positional parameters, and finally a string that represents the macro body or replacement text.  The ‘@’ character followed by the
name of a parameter indicates that the appropriate argument is inserted at this location.  Once the macro is defined, it may be invoked using the macro name
followed by a list of arguments.  The number of arguments must match the number of parameters in the macro definition.
   
|  |   | 
Figure 6.16: Macros
All arguments are passed as strings. Since FOMUS executes macros by simply replacing text in the file, you can pass absolutely anything as an argument. Complex arguments with spaces, commas and other confusing characters can be passed by enclosing them in quotes. Also, you must be careful not give a macro the same name as a part, setting or event parameter to avoid potential conflicts.