X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=scm%2Fdefine-music-properties.scm;h=6150a2ad040027a81ba6bc5fb1f9dba14c99b0c6;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=fde1f61f617ef512a751f88b64be4988c943e20f;hpb=30c8b1685f2d51aa08b7987f085d26e0d6df6854;p=lilypond.git diff --git a/scm/define-music-properties.scm b/scm/define-music-properties.scm index fde1f61f61..6150a2ad04 100644 --- a/scm/define-music-properties.scm +++ b/scm/define-music-properties.scm @@ -1,101 +1,188 @@ ;;;; music-property-description.scm -- part of generated backend documentation ;;;; ;;;; source file of the GNU LilyPond music typesetter -;;;; -;;;; (c) 1998--2003 Han-Wen Nienhuys +;;;; +;;;; (c) 1998--2008 Han-Wen Nienhuys ;;;; Jan Nieuwenhuizen +(define (music-property-description symbol type? description) + (if (not (equal? #f (object-property symbol 'music-doc))) + (ly:error (_ "symbol ~S redefined") symbol)) + (set-object-property! symbol 'music-type? type?) + (set-object-property! symbol 'music-doc description) + symbol) + +(define-public all-music-properties + (map + (lambda (x) (apply music-property-description x)) + `( + (X-offset ,number? + "Offset of resulting grob; only used for balloon texts.") + (Y-offset ,number? + "Offset of resulting grob; only used for balloon texts.") -(define-public all-music-properties '()) + (alteration ,number? "Alteration for figured bass.") + (absolute-octave ,integer? + "The absolute octave for a octave check note.") + (articulations ,ly:music-list? + "Articulation events specifically for this note.") + (articulation-type ,string? "Key for script definitions alist. -(define (music-property-description symbol type? description) - (if (not (equal? #f (object-property symbol 'music-doc))) - (begin - (ly:warn (string-append "Redefining " (symbol->string symbol) "\n")) - (exit 2) - )) - (set-object-property! symbol 'music-type? type?) - (set-object-property! symbol 'music-doc description) - (set! all-music-properties (cons symbol all-music-properties)) - ) - - - -(music-property-description 'iterator-ctor procedure? "Function to construct music-event-iterator object for this Music") -(music-property-description 'duration ly:duration? "Duration of this note/lyric.") -(music-property-description 'metronome-count number? "How many beats in a minute?") -(music-property-description 'span-type string? "What kind of spanner should be created? - -TODO: consider making type into symbol") -(music-property-description 'articulations music-list? - "Articulation events specifically for this note.") -(music-property-description 'articulation-type string? "key for script definitions alist. - -TODO: consider making type into symbol ") -(music-property-description 'associated-context string? "Name of the Voice context associated with this \\newaddlyrics section") -(music-property-description 'bass boolean? "Set if this note is a bass note in a chord") -(music-property-description 'cautionary boolean? "If set, this alteration needs cautionary accidental") -(music-property-description 'change-to-id string? "name of the context to change to ") -(music-property-description 'change-to-type symbol? "type of the context to change to.") -(music-property-description 'compress-procedure procedure? "compress this music expression. Argument 1: the music, arg 2: factor") -(music-property-description 'context-id string? "name of context") -(music-property-description 'context-type symbol? "type of context") -(music-property-description 'denominator integer? "denominator in a time signature") -(music-property-description 'digit integer? "digit for fingering") -(music-property-description 'direction ly:dir? "Print this up or down?") -(music-property-description 'tags list? "List of symbols that for denoting extra details, -eg. @code{\\tag #'part ...} could tag a piece of music as only being active in a part.") - - -(music-property-description 'text-type symbol? "Particular type of text script (eg. finger, dynamic).") -(music-property-description 'tempo-unit ly:duration? "The unit for the metronome count.") -(music-property-description 'tonic ly:pitch? "Base of the scale") -(music-property-description 'element ly:music? "The single child of a Music_wrapper music object, or the body of a repeat.") -(music-property-description 'elements music-list? "A list of elements for sequential of simultaneous music, or the alternatives of repeated music. ") -(music-property-description 'force-accidental boolean? "If set, a cautionary accidental should always be printed on this note") -(music-property-description 'grob-property symbol? "The symbol of the grob property to set. ") -(music-property-description 'grob-value scheme? "The value of the grob property to set") -(music-property-description 'inversion boolean? "If set, this chord note is inverted.") -(music-property-description 'label markup? "label of a mark.") -(music-property-description 'last-pitch ly:pitch? "The last pitch after relativization.") -(music-property-description 'length procedure? "How to compute the duration of this music") -(music-property-description 'internal-class-name string? "C++ class to use for this Music object") -(music-property-description 'name symbol? "Name of this music object") -(music-property-description 'numerator integer? "numerator of a time signature") -(music-property-description 'once boolean? "Apply this operation only during one time step?") -(music-property-description 'octavation integer? - "This pitch was octavated by how many octaves? +TODO: Consider making type into symbol.") + (augmented ,boolean? "This figure is for an augmented figured bass +(with @code{+} sign).") + (augmented-slash ,boolean? "This figure is for an augmented figured bass +(back-slashed number).") + (associated-context ,string? "Name of the Voice context associated with +this @code{\\newaddlyrics} section.") + + (bass ,boolean? "Set if this note is a bass note in a chord.") + (bracket-start ,boolean? "Start a bracket here. + +TODO: Use SpanEvents?") + (bracket-stop ,boolean? "Stop a bracket here.") + (break-penalty ,number? "Penalty for line break hint.") + (break-permission ,symbol? + "Whether to allow, forbid or force a line break.") + + (cautionary ,boolean? "If set, this alteration needs a +cautionary accidental.") + (change-to-id ,string? "Name of the context to change to.") + (change-to-type ,symbol? "Type of the context to change to.") + (compress-procedure ,procedure? "Compress this music expression. +Arg@tie{}1: the music, arg@tie{}2: factor.") + (context-id ,string? "Name of context.") + (context-type ,symbol? "Type of context.") + (create-new ,boolean? "Create a fresh context.") + + (delta-step ,number? "How much should a fall change pitch?") + (descend-only ,boolean? "If set, this @code{\\context} only descends +in the context tree.") + (denominator ,integer? "Denominator in a time signature.") + (digit ,integer? "Digit for fingering.") + (diminished ,boolean? "This bass figure should be slashed.") + (direction ,ly:dir? "Print this up or down?") + (drum-type ,symbol? "Which percussion instrument to play this note on.") + (duration ,ly:duration? "Duration of this note or lyric.") + + (error-found ,boolean? + "If true, a parsing error was found in this expression.") + (element ,ly:music? "The single child of a Music_wrapper music object, +or the body of a repeat.") + (elements ,ly:music-list? "A list of elements for sequential of +simultaneous music, or the alternatives of repeated music.") + (elements-callback ,procedure? "Return a list of children, for use by +a sequential iterator. Takes a single music parameter.") + (expected-beam-count ,integer? "Expected number of non-tremolo beams +in a tremolo repeat.") + + (figure ,integer? "A bass figure.") + (force-accidental ,boolean? "If set, a cautionary accidental should +always be printed on this note.") + + (grob-property ,symbol? "The symbol of the grob property to set.") + (grob-property-path ,list? "A list of symbols, locating a nested grob +property, e.g., @code{(beamed-lengths details)}.") + (grob-value ,scheme? "The value of the grob property to set.") + + (input-tag ,scheme? "Arbitrary marker to relate input and output.") + (inversion ,boolean? "If set, this chord note is inverted.") + (iterator-ctor ,procedure? "Function to construct a +@code{music-event-iterator} object for this music.") + + (label ,markup? "Label of a mark.") + (last-pitch ,ly:pitch? "The last pitch after relativization.") + (length ,ly:moment? "The duration of this music.") + (length-callback ,procedure? "How to compute the duration of this music. +This property can only be defined as initializer in +@file{scm/@/define-music-types.scm}.") + (line-break-permission ,symbol? "When the music is at top-level, +whether to allow, forbid or force a line break.") + + (metronome-count ,number? "How many beats in a minute?") + + (name ,symbol? "Name of this music object.") + (no-continuation ,boolean? "If set, disallow continuation lines.") + (numerator ,integer? "Numerator of a time signature.") + + (once ,boolean? "Apply this operation only during one time step?") + (octavation ,integer? "This pitch was octavated by how many octaves? For chord inversions, this is negative.") -(music-property-description 'origin ly:input-location? "where was this piece of music defined?") -(music-property-description 'penalty number? "Penalty for break hint.") -(music-property-description 'pitch ly:pitch? "the pitch of this note") -(music-property-description 'pitch-alist list? "list of pitches jointly forming the scale of a key signature") -(music-property-description 'pop-first boolean? "Do a revert before we try to do a override on some grob property.") -(music-property-description 'procedure procedure? - "The function to run with \\applycontext. It must take a single argument, being the context.") -(music-property-description 'property-operations list? - "Do these operations for instantiating the context.") -(music-property-description 'predicate procedure? "the predicate of a \\outputproperty") -(music-property-description 'type symbol? "The type of this music object. Determines iteration in some cases.") -(music-property-description 'types list? "The types of this music object. Determines iteration in some cases.") -(music-property-description 'repeat-count integer? "do a @code{\repeat} how ofen?") -(music-property-description 'span-direction ly:dir? "Does this start or stop a spanner?") - -(music-property-description 'start-moment-function procedure? "Function to compute the negative length of -starting grace notes.") -(music-property-description 'string-number integer? "The number of the string in a String_number_req") -(music-property-description 'symbol symbol? "Grob name to perform an override/revert on.") -(music-property-description 'text markup? "markup expression to be printed") -;; markup? -(music-property-description 'tremolo-type integer? "") -(music-property-description 'value scheme? "Assignment value for a -translation property") -(music-property-description 'what symbol? "What to change for auto-change. FIXME, naming") - -(music-property-description 'figure string? "a `figure' (which may be -a string) for figured bass") -(music-property-description 'alteration number? "alteration for figured bass") -(music-property-description 'bracket-start boolean? "start a bracket -here. TODO: use span requests?") -(music-property-description 'bracket-stop boolean? "stop a bracket here.") + (origin ,ly:input-location? "Where was this piece of music defined?") + + (page-break-permission ,symbol? "When the music is at top-level, +whether to allow, forbid or force a page break.") + (page-label ,symbol? "The label of a page marker.") + (page-marker ,boolean? "If true, and the music expression is found at +top-level, a page marker object is instanciated instead of a score.") + (page-turn-permission ,symbol? "When the music is at top-level, +whether to allow, forbid or force a page turn.") + (part-combine-status ,symbol? "Change to what kind of state? +Options are @code{solo1}, @code{solo2} and @code{unisono}.") + (parenthesize ,boolean? "Enclose resulting objects in parentheses?") + (pitch ,ly:pitch? "The pitch of this note.") + (pitch-alist ,list? "A list of pitches jointly forming the scale +of a key signature.") + (pop-first ,boolean? "Do a revert before we try to do a override +on some grob property.") + (prob-property ,symbol? "The symbol of the prob property to set.") + (procedure ,procedure? "The function to run with @code{\\applycontext}. +It must take a single argument, being the context.") + (property-operations ,list? "Do these operations for instantiating +the context.") + + (quoted-events ,vector? "A vector of with @code{moment} and +@code{event-list} entries.") + (quoted-music-name ,string? "The name of the voice to quote.") + (quoted-voice-direction ,ly:dir? "Should the quoted voice be up-stem +or down-stem?") + (quoted-context-type ,symbol? "The name of the context to +direct quotes to, e.g., @code{Voice}.") + (quoted-context-id ,string? "The ID of the context to direct quotes to, +e.g., @code{cue}.") + (quoted-transposition ,ly:pitch? "The pitch used for the quote, +overriding @code{\\transposition}.") + + (repeat-count ,integer? "Do a @code{\\repeat} how often?") + + (span-direction ,ly:dir? "Does this start or stop a spanner?") + (span-type ,string? "What kind of spanner should be created? + +TODO: Consider making type into symbol.") + (split-list ,list? "Splitting moments for part combiner.") + (start-callback ,procedure? "Function to compute the negative length +of starting grace notes. This property can only be defined as initializer +in @file{scm/@/define-music-types.scm}.") + (string-number ,integer? "The number of the string in +a @code{StringNumberEvent.}") + (symbol ,symbol? "Grob name to perform an override or revert on.") + + (tags ,list? "List of symbols that for denoting extra details, e.g., +@code{\\tag #'part @dots{}} could tag a piece of music as only being active +in a part.") + (text-type ,symbol? + "Particular type of text script (e.g., finger, dynamic).") + (text ,markup? "Markup expression to be printed.") + (tempo-unit ,ly:duration? "The unit for the metronome count.") + (to-relative-callback ,procedure? "How to transform a piece of music +to relative pitches.") + (tonic ,ly:pitch? "Base of the scale.") + (tremolo-type ,integer? "Speed of tremolo, e.g., 16 for @code{c4:16}.") + (trill-pitch ,ly:pitch? "Pitch of other note of the trill.") + (type ,symbol? "The type of this music object. +Determines iteration in some cases.") + (types ,list? "The types of this music object; determines by what +engraver this music expression is processed.") + (tweaks ,list? "An alist of properties to override in the backend +for the grob made of this event.") + + (untransposable ,boolean? "If set, this music is not transposed.") + + (value ,scheme? "Assignment value for a translation property.") + (void ,boolean? "If this property is @code{#t}, then the +music expression is to be discarded by the toplevel music handler.") + + (what ,symbol? "What to change for auto-change. +FIXME: Naming.") + )))