On Sat, Mar 21, 2015 at 10:06 PM, David Nalesnik <david.nales...@gmail.com>
wrote:

> Hi Abraham,
>
> On Sat, Mar 21, 2015 at 9:13 PM, tisimst <tisimst.lilyp...@gmail.com>
> wrote:
>
>> David,
>>
>>
[...]


> This works perfectly when there are NO rests, but I get this error when
>> there is a rest in the NoteColumn:
>>
>> In procedure ly:grob-array->list in expression (ly:grob-array->list
>> (ly:grob-object grob #)): Wrong type argument in position 1 (expecting
>> Grob_array): ()
>>
>>
>>
> Glad I could help!
>
> If there's a rest, then the note-heads array will be empty.  To make this
> work, just add a check that the note-heads list isn't the empty list '().
>
>
 Oh, shoot!  It's past my bedtime...

The error happens because you're applying ly:grob-array->list to that
grob-array which is empty when there's a rest.  So the check has to be
before the conversion to a list:

#(define (flipnotes grob)
   (let ((notes (ly:grob-object grob 'note-heads)))
     (if (ly:grob-array? notes)
         (for-each
          (lambda (note)
            (let* (;(pitch (ly:event-property (event-cause note) 'pitch))
;; don't need this
                   (stem (ly:grob-object note 'stem))
                   (dir (ly:grob-property stem 'direction))
                   (offset (ly:grob-relative-coordinate note grob X)))
              (if (eq? dir DOWN)
                  (if (and (< offset 0.1) (> offset -0.1))
                      (ly:grob-set-property! note 'rotation '(180 0 0))
                      (ly:grob-set-property! note 'rotation '(0 0 0)))
                  (if (and (< offset 0.1) (> offset -0.1))
                      (ly:grob-set-property! note 'rotation '(0 0 0))
                      (ly:grob-set-property! note 'rotation '(180 0 0)))
                  )
              ))
          (ly:grob-array->list notes))
         ; alternate return?

         )))


--David
_______________________________________________
lilypond-user mailing list
lilypond-user@gnu.org
https://lists.gnu.org/mailman/listinfo/lilypond-user

Reply via email to