On Sun, 18 Jan 2015 19:34:24 -0800, Kieren MacMillan <kieren_macmil...@sympatico.ca> wrote:
This does have the variable reedPlayer storing written pitches, where we recommend storing concert pitchesI would much rather code in concert pitches.
What I was suggesting, and what I put into the example, had all the typed input in concert pitch. By saying "reedPlayer stores written pitches", I meant only that the \transpose{...} operations, to tell LilyPond which notes should be printed at which transposition, were included in the variable reedPlayer.
Still, I think I must be missing something fundamental… It really seems to me that \addInstrumentDefinition already has [almost?] everything we need: the shortInstrumentName is there, the clef is there (in case a change is needed), the cue name is there, the transposition is there, etc. So what is stopping us from making something very similar to the OP’s original code Do The Right Thing™?
LilyPond has the information, but it takes some work to teach her to consistently use it differently than she does now, and differently than the original poster still wants her to. You could try the attached modification (to avoid transposition of cues) of Jan-Peter's method. LilyPond transposes your input by 'instrumentTransposition when generating cue notes, so leave instrumentTransposition at its default. Instead, the attached engraver uses a new property 'printTransposition to shift your concert-pitch input to printed pitches. Key-signature changes are not always appropriate, but you can type \key\default to reprint the current key-signature and have it transposed for the instrument. (This second *-Transposition setting would be confusing to new users of LilyPond, so any real patch would require re-writing some internals of LilyPond so we can select the desired behavior using just the old 'instrumentTransposition to describe the instrument pitch.) part = { g'4 b' d'' fis'' R1 \instrumentSwitch "cl Bflat" \bar"||"\key\default g'4 b' d'' fis'' R1 \instrumentSwitch "flute" \bar"||"\key\default g'4 b' d'' fis'' R1 } global = { \key g\major s1*4 } \new Staff \with { \printTransposition } \new Voice << \global \part >>
\version "2.18.2" % vim: filetype=lilypond: % Substitute for \key\default that works with midi{} reprintKey = \applyContext #(lambda (c) (define (same-scale-step? a b) (= (car a) (car b))) (let* ((pitch-alist (delete-duplicates! (append (ly:context-property c 'keyAlterations) major) same-scale-step?)) (tonic (ly:context-property c 'tonic (ly:make-pitch 0 0 0))) (sev (ly:make-stream-event `(key-change-event) `((pitch-alist . ,pitch-alist) (tonic . ,tonic))))) (ly:broadcast (ly:context-event-source c) sev))) % from "scm/define-context-properties.scm" #(define (translator-property-description symbol type? description) (if (not (and (symbol? symbol) (procedure? type?) (string? description))) (throw 'init-format-error)) (if (not (equal? #f (object-property symbol 'translation-doc))) (ly:error (_ "symbol ~S redefined" symbol))) (set-object-property! symbol 'translation-type? type?) (set-object-property! symbol 'translation-doc description) (set! all-translation-properties (cons symbol all-translation-properties)) symbol) #(translator-property-description 'printTransposition ly:pitch? "transposition for printing with autoTransposeEngraver") % adapted from Jan-Peter Voigt's autoTransposeEngraver at openlilylib printTranspositionEngraver = #(lambda (context) (let ((old-pitch-alist major) (old-transp (ly:make-pitch 1 0 0))) (make-engraver (listeners ((melodic-event engraver ev) (let ((transp (ly:context-property context 'printTransposition)) (pitch (ly:event-property ev 'pitch))) (if (and (ly:pitch? pitch) (ly:pitch? transp)) (ly:event-set-property! ev 'pitch (ly:pitch-diff pitch transp))))) ((key-change-event engraver ev) (let ((transp (ly:context-property context 'printTransposition)) (tonic (ly:event-property ev 'tonic (ly:context-property context 'tonic ;for \key\default (ly:make-pitch 1 0 0)))) (pitch-alist (ly:event-property ev 'pitch-alist old-pitch-alist))) (if (ly:pitch? transp) (begin (ly:event-set-property! ev 'tonic (ly:pitch-diff tonic transp)) (set! pitch-alist (ly:transpose-key-alist pitch-alist (ly:pitch-diff old-transp transp))) (ly:event-set-property! ev 'pitch-alist pitch-alist) (set! old-transp transp))) (set! old-pitch-alist pitch-alist))))))) printTransposition = \with { \remove Key_engraver \consists \printTranspositionEngraver \consists Key_engraver } % =================================================== \addInstrumentDefinition #"cl Bflat" #`( (printTransposition . ,(ly:make-pitch -1 6 FLAT)) (shortInstrumentName . "Cl. in Bb") (clefGlyph . "clefs.G") (middleCPosition . -6) (clefPosition . -2) (instrumentCueName . ,(make-bold-markup "Cl. in Bb")) (midiInstrument . "clarinet") ) \addInstrumentDefinition #"flute" #`( (printTransposition . ,(ly:make-pitch 0 0 0)) (shortInstrumentName . "Flute") (clefGlyph . "clefs.G") (middleCPosition . -6) (clefPosition . -2) (instrumentCueName . ,(make-bold-markup "Flute")) (midiInstrument . "flute") ) part = { g'4 b' d'' fis'' R1 g'4 b' d'' fis'' R1 g'4 b' d'' fis'' R1 } arrangement = { s1*2 \instrumentSwitch "cl Bflat" \bar"||"\reprintKey s1*2 \instrumentSwitch "flute" \bar"||"\reprintKey s1*2 } global = { \key g\major s1*4 } \new Staff \with { \printTransposition } \new Voice << \global \arrangement \part >>
_______________________________________________ lilypond-user mailing list lilypond-user@gnu.org https://lists.gnu.org/mailman/listinfo/lilypond-user