LilyPond-Ruby 0.1.1 → 0.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/etc/fonts/conf.d/10-hinting-slight.conf +15 -0
- data/etc/fonts/conf.d/10-scale-bitmap-fonts.conf +83 -0
- data/etc/fonts/conf.d/11-lcdfilter-default.conf +17 -0
- data/etc/fonts/conf.d/20-unhint-small-vera.conf +49 -0
- data/etc/fonts/conf.d/30-metric-aliases.conf +637 -0
- data/etc/fonts/conf.d/40-nonlatin.conf +332 -0
- data/etc/fonts/conf.d/45-generic.conf +136 -0
- data/etc/fonts/conf.d/45-latin.conf +301 -0
- data/etc/fonts/conf.d/48-spacing.conf +16 -0
- data/etc/fonts/conf.d/49-sansserif.conf +22 -0
- data/etc/fonts/conf.d/50-user.conf +16 -0
- data/etc/fonts/conf.d/51-local.conf +7 -0
- data/etc/fonts/conf.d/60-generic.conf +64 -0
- data/etc/fonts/conf.d/60-latin.conf +88 -0
- data/etc/fonts/conf.d/65-fonts-persian.conf +418 -0
- data/etc/fonts/conf.d/65-nonlatin.conf +228 -0
- data/etc/fonts/conf.d/69-unifont.conf +28 -0
- data/etc/fonts/conf.d/80-delicious.conf +19 -0
- data/etc/fonts/conf.d/90-synthetic.conf +64 -0
- data/etc/fonts/conf.d/README +23 -0
- data/etc/fonts/fonts.conf +101 -0
- data/etc/relocate/fontconfig.reloc +2 -0
- data/etc/relocate/guile.reloc +2 -0
- data/etc/relocate/libexec.reloc +1 -0
- data/lib/guile/2.2/ccache/ice-9/and-let-star.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/arrays.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/atomic.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/binary-ports.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/boot-9.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/buffered-input.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/calling.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/channel.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/command-line.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/common-list.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/control.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/curried-definitions.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/debug.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/deprecated.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/documentation.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/eval-string.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/eval.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/expect.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/fdes-finalizers.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/format.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/ftw.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/futures.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/gap-buffer.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/getopt-long.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/hash-table.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/hcons.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/history.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/i18n.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/iconv.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/lineio.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/list.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/local-eval.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/ls.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/mapping.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/match.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/networking.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/null.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/occam-channel.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/optargs.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/peg/cache.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/peg/codegen.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/peg/simplify-tree.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/peg/string-peg.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/peg/using-parsers.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/peg.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/poe.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/poll.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/popen.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/ports.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/posix.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/pretty-print.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/psyntax-pp.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/q.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/r5rs.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/rdelim.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/receive.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/regex.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/runq.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/rw.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/safe-r5rs.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/safe.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/sandbox.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/save-stack.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/scm-style-repl.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/serialize.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/session.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/slib.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/stack-catch.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/streams.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/string-fun.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/suspendable-ports.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/syncase.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/textual-ports.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/threads.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/time.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/top-repl.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/unicode.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/vlist.go +0 -0
- data/lib/guile/2.2/ccache/ice-9/weak-vector.go +0 -0
- data/lib/guile/2.2/ccache/language/brainfuck/compile-scheme.go +0 -0
- data/lib/guile/2.2/ccache/language/brainfuck/compile-tree-il.go +0 -0
- data/lib/guile/2.2/ccache/language/brainfuck/parse.go +0 -0
- data/lib/guile/2.2/ccache/language/brainfuck/spec.go +0 -0
- data/lib/guile/2.2/ccache/language/bytecode/spec.go +0 -0
- data/lib/guile/2.2/ccache/language/bytecode.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/closure-conversion.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/compile-bytecode.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/constructors.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/contification.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/cse.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/dce.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/effects-analysis.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/elide-values.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/handle-interrupts.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/intmap.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/intset.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/licm.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/optimize.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/peel-loops.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/primitives.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/prune-bailouts.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/prune-top-level-scopes.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/reify-primitives.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/renumber.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/rotate-loops.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/self-references.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/simplify.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/slot-allocation.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/spec.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/specialize-numbers.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/specialize-primcalls.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/split-rec.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/type-checks.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/type-fold.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/types.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/utils.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/verify.go +0 -0
- data/lib/guile/2.2/ccache/language/cps/with-cps.go +0 -0
- data/lib/guile/2.2/ccache/language/cps.go +0 -0
- data/lib/guile/2.2/ccache/language/ecmascript/array.go +0 -0
- data/lib/guile/2.2/ccache/language/ecmascript/base.go +0 -0
- data/lib/guile/2.2/ccache/language/ecmascript/compile-tree-il.go +0 -0
- data/lib/guile/2.2/ccache/language/ecmascript/function.go +0 -0
- data/lib/guile/2.2/ccache/language/ecmascript/impl.go +0 -0
- data/lib/guile/2.2/ccache/language/ecmascript/parse.go +0 -0
- data/lib/guile/2.2/ccache/language/ecmascript/spec.go +0 -0
- data/lib/guile/2.2/ccache/language/ecmascript/tokenize.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/bindings.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/boot.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/compile-tree-il.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/falias.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/lexer.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/parser.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/runtime/function-slot.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/runtime/value-slot.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/runtime.go +0 -0
- data/lib/guile/2.2/ccache/language/elisp/spec.go +0 -0
- data/lib/guile/2.2/ccache/language/scheme/compile-tree-il.go +0 -0
- data/lib/guile/2.2/ccache/language/scheme/decompile-tree-il.go +0 -0
- data/lib/guile/2.2/ccache/language/scheme/spec.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/analyze.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/canonicalize.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/compile-cps.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/debug.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/effects.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/fix-letrec.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/optimize.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/peval.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/primitives.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il/spec.go +0 -0
- data/lib/guile/2.2/ccache/language/tree-il.go +0 -0
- data/lib/guile/2.2/ccache/language/value/spec.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops/accessors.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops/active-slot.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops/composite-slot.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops/describe.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops/internal.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops/save.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops/simple.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops/stklos.go +0 -0
- data/lib/guile/2.2/ccache/oop/goops.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/arithmetic/bitwise.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/arithmetic/fixnums.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/arithmetic/flonums.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/base.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/bytevectors.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/conditions.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/control.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/enums.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/eval.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/exceptions.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/files.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/hashtables.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/io/ports.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/io/simple.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/lists.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/mutable-pairs.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/mutable-strings.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/programs.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/r5rs.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/records/inspection.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/records/procedural.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/records/syntactic.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/sorting.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/syntax-case.go +0 -0
- data/lib/guile/2.2/ccache/rnrs/unicode.go +0 -0
- data/lib/guile/2.2/ccache/rnrs.go +0 -0
- data/lib/guile/2.2/ccache/scripts/api-diff.go +0 -0
- data/lib/guile/2.2/ccache/scripts/autofrisk.go +0 -0
- data/lib/guile/2.2/ccache/scripts/compile.go +0 -0
- data/lib/guile/2.2/ccache/scripts/disassemble.go +0 -0
- data/lib/guile/2.2/ccache/scripts/display-commentary.go +0 -0
- data/lib/guile/2.2/ccache/scripts/doc-snarf.go +0 -0
- data/lib/guile/2.2/ccache/scripts/frisk.go +0 -0
- data/lib/guile/2.2/ccache/scripts/generate-autoload.go +0 -0
- data/lib/guile/2.2/ccache/scripts/help.go +0 -0
- data/lib/guile/2.2/ccache/scripts/lint.go +0 -0
- data/lib/guile/2.2/ccache/scripts/list.go +0 -0
- data/lib/guile/2.2/ccache/scripts/punify.go +0 -0
- data/lib/guile/2.2/ccache/scripts/read-rfc822.go +0 -0
- data/lib/guile/2.2/ccache/scripts/read-scheme-source.go +0 -0
- data/lib/guile/2.2/ccache/scripts/read-text-outline.go +0 -0
- data/lib/guile/2.2/ccache/scripts/scan-api.go +0 -0
- data/lib/guile/2.2/ccache/scripts/snarf-check-and-output-texi.go +0 -0
- data/lib/guile/2.2/ccache/scripts/snarf-guile-m4-docs.go +0 -0
- data/lib/guile/2.2/ccache/scripts/summarize-guile-TODO.go +0 -0
- data/lib/guile/2.2/ccache/scripts/use2dot.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-1.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-10.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-11.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-111.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-13.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-14.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-16.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-17.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-18.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-19.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-2.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-26.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-27.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-28.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-31.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-34.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-35.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-37.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-38.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-39.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-4/gnu.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-4.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-41.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-42.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-43.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-45.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-6.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-60.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-64.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-67.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-69.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-71.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-8.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-88.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-9/gnu.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-9.go +0 -0
- data/lib/guile/2.2/ccache/srfi/srfi-98.go +0 -0
- data/lib/guile/2.2/ccache/statprof.go +0 -0
- data/lib/guile/2.2/ccache/sxml/apply-templates.go +0 -0
- data/lib/guile/2.2/ccache/sxml/fold.go +0 -0
- data/lib/guile/2.2/ccache/sxml/match.go +0 -0
- data/lib/guile/2.2/ccache/sxml/simple.go +0 -0
- data/lib/guile/2.2/ccache/sxml/ssax/input-parse.go +0 -0
- data/lib/guile/2.2/ccache/sxml/ssax.go +0 -0
- data/lib/guile/2.2/ccache/sxml/transform.go +0 -0
- data/lib/guile/2.2/ccache/sxml/xpath.go +0 -0
- data/lib/guile/2.2/ccache/system/base/ck.go +0 -0
- data/lib/guile/2.2/ccache/system/base/compile.go +0 -0
- data/lib/guile/2.2/ccache/system/base/lalr.go +0 -0
- data/lib/guile/2.2/ccache/system/base/language.go +0 -0
- data/lib/guile/2.2/ccache/system/base/message.go +0 -0
- data/lib/guile/2.2/ccache/system/base/pmatch.go +0 -0
- data/lib/guile/2.2/ccache/system/base/syntax.go +0 -0
- data/lib/guile/2.2/ccache/system/base/target.go +0 -0
- data/lib/guile/2.2/ccache/system/base/types.go +0 -0
- data/lib/guile/2.2/ccache/system/foreign-object.go +0 -0
- data/lib/guile/2.2/ccache/system/foreign.go +0 -0
- data/lib/guile/2.2/ccache/system/repl/command.go +0 -0
- data/lib/guile/2.2/ccache/system/repl/common.go +0 -0
- data/lib/guile/2.2/ccache/system/repl/coop-server.go +0 -0
- data/lib/guile/2.2/ccache/system/repl/debug.go +0 -0
- data/lib/guile/2.2/ccache/system/repl/error-handling.go +0 -0
- data/lib/guile/2.2/ccache/system/repl/repl.go +0 -0
- data/lib/guile/2.2/ccache/system/repl/server.go +0 -0
- data/lib/guile/2.2/ccache/system/syntax.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/assembler.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/coverage.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/debug.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/disassembler.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/dwarf.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/elf.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/frame.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/inspect.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/linker.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/loader.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/program.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/trace.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/trap-state.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/traps.go +0 -0
- data/lib/guile/2.2/ccache/system/vm/vm.go +0 -0
- data/lib/guile/2.2/ccache/system/xref.go +0 -0
- data/lib/guile/2.2/ccache/texinfo/docbook.go +0 -0
- data/lib/guile/2.2/ccache/texinfo/html.go +0 -0
- data/lib/guile/2.2/ccache/texinfo/indexing.go +0 -0
- data/lib/guile/2.2/ccache/texinfo/plain-text.go +0 -0
- data/lib/guile/2.2/ccache/texinfo/reflection.go +0 -0
- data/lib/guile/2.2/ccache/texinfo/serialize.go +0 -0
- data/lib/guile/2.2/ccache/texinfo/string-utils.go +0 -0
- data/lib/guile/2.2/ccache/texinfo.go +0 -0
- data/lib/guile/2.2/ccache/web/client.go +0 -0
- data/lib/guile/2.2/ccache/web/http.go +0 -0
- data/lib/guile/2.2/ccache/web/request.go +0 -0
- data/lib/guile/2.2/ccache/web/response.go +0 -0
- data/lib/guile/2.2/ccache/web/server/http.go +0 -0
- data/lib/guile/2.2/ccache/web/server.go +0 -0
- data/lib/guile/2.2/ccache/web/uri.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/accreg.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/auto-beam.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/autochange.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/backend-library.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/bar-line.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/breath.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/c++.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/chord-entry.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/chord-ignatzek-names.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/chord-name.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/clip-region.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/color.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/curried-definitions.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-context-properties.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-event-classes.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-grob-interfaces.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-grob-properties.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-grobs.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-markup-commands.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-music-callbacks.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-music-display-methods.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-music-properties.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-music-types.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-note-names.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-stencil-commands.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/define-woodwind-diagrams.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/display-lily.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/display-woodwind-diagrams.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/file-cache.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/flag-styles.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/font-encodings.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/font.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/framework-cairo.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/framework-ps.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/framework-svg.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/fret-diagrams.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/graphviz.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/harp-pedals.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/layout-beam.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/layout-slur.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/lily-library.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/lily.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/ly-syntax-constructors.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/markup-macros.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/markup.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/midi.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/modal-transforms.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/music-functions.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/output-lib.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/output-ps.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/output-svg.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/page.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/paper-system.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/paper.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/parser-clef.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/parser-ly-from-scheme.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/part-combiner.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/predefined-fretboards.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/ps-to-png.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/scheme-engravers.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/scheme-performers.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/script.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/skyline.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/song-util.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/song.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/stencil.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/tablature.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/time-signature-settings.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/time-signature.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/titling.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/to-xml.go +0 -0
- data/lib/lilypond/2.24.1/ccache/lily/translation-functions.go +0 -0
- data/share/emacs/site-lisp/lilypond-font-lock.el +208 -0
- data/share/emacs/site-lisp/lilypond-indent.el +605 -0
- data/share/emacs/site-lisp/lilypond-init.el +21 -0
- data/share/emacs/site-lisp/lilypond-mode.el +1204 -0
- data/share/emacs/site-lisp/lilypond-song.el +556 -0
- data/share/emacs/site-lisp/lilypond-what-beat.el +279 -0
- data/share/emacs/site-lisp/lilypond-words.el +1428 -0
- data/share/guile/2.2/guile-procedures.txt +8860 -0
- data/share/guile/2.2/ice-9/and-let-star.scm +73 -0
- data/share/guile/2.2/ice-9/arrays.scm +70 -0
- data/share/guile/2.2/ice-9/atomic.scm +38 -0
- data/share/guile/2.2/ice-9/binary-ports.scm +53 -0
- data/share/guile/2.2/ice-9/boot-9.scm +4131 -0
- data/share/guile/2.2/ice-9/buffered-input.scm +109 -0
- data/share/guile/2.2/ice-9/calling.scm +326 -0
- data/share/guile/2.2/ice-9/channel.scm +170 -0
- data/share/guile/2.2/ice-9/command-line.scm +477 -0
- data/share/guile/2.2/ice-9/common-list.scm +278 -0
- data/share/guile/2.2/ice-9/control.scm +110 -0
- data/share/guile/2.2/ice-9/curried-definitions.scm +57 -0
- data/share/guile/2.2/ice-9/debug.scm +25 -0
- data/share/guile/2.2/ice-9/deprecated.scm +93 -0
- data/share/guile/2.2/ice-9/documentation.scm +203 -0
- data/share/guile/2.2/ice-9/eval-string.scm +90 -0
- data/share/guile/2.2/ice-9/eval.scm +723 -0
- data/share/guile/2.2/ice-9/expect.scm +171 -0
- data/share/guile/2.2/ice-9/fdes-finalizers.scm +25 -0
- data/share/guile/2.2/ice-9/format.scm +1626 -0
- data/share/guile/2.2/ice-9/ftw.scm +564 -0
- data/share/guile/2.2/ice-9/futures.scm +308 -0
- data/share/guile/2.2/ice-9/gap-buffer.scm +283 -0
- data/share/guile/2.2/ice-9/getopt-long.scm +371 -0
- data/share/guile/2.2/ice-9/hash-table.scm +45 -0
- data/share/guile/2.2/ice-9/hcons.scm +80 -0
- data/share/guile/2.2/ice-9/history.scm +65 -0
- data/share/guile/2.2/ice-9/i18n.scm +531 -0
- data/share/guile/2.2/ice-9/iconv.scm +95 -0
- data/share/guile/2.2/ice-9/lineio.scm +115 -0
- data/share/guile/2.2/ice-9/list.scm +36 -0
- data/share/guile/2.2/ice-9/local-eval.scm +261 -0
- data/share/guile/2.2/ice-9/ls.scm +94 -0
- data/share/guile/2.2/ice-9/mapping.scm +118 -0
- data/share/guile/2.2/ice-9/match.scm +59 -0
- data/share/guile/2.2/ice-9/match.upstream.scm +917 -0
- data/share/guile/2.2/ice-9/networking.scm +94 -0
- data/share/guile/2.2/ice-9/null.scm +34 -0
- data/share/guile/2.2/ice-9/occam-channel.scm +261 -0
- data/share/guile/2.2/ice-9/optargs.scm +381 -0
- data/share/guile/2.2/ice-9/peg/cache.scm +45 -0
- data/share/guile/2.2/ice-9/peg/codegen.scm +359 -0
- data/share/guile/2.2/ice-9/peg/simplify-tree.scm +97 -0
- data/share/guile/2.2/ice-9/peg/string-peg.scm +273 -0
- data/share/guile/2.2/ice-9/peg/using-parsers.scm +116 -0
- data/share/guile/2.2/ice-9/peg.scm +42 -0
- data/share/guile/2.2/ice-9/poe.scm +116 -0
- data/share/guile/2.2/ice-9/poll.scm +172 -0
- data/share/guile/2.2/ice-9/popen.scm +178 -0
- data/share/guile/2.2/ice-9/ports.scm +566 -0
- data/share/guile/2.2/ice-9/posix.scm +75 -0
- data/share/guile/2.2/ice-9/pretty-print.scm +483 -0
- data/share/guile/2.2/ice-9/psyntax-pp.scm +3542 -0
- data/share/guile/2.2/ice-9/psyntax.scm +3326 -0
- data/share/guile/2.2/ice-9/q.scm +153 -0
- data/share/guile/2.2/ice-9/quasisyntax.scm +136 -0
- data/share/guile/2.2/ice-9/r5rs.scm +45 -0
- data/share/guile/2.2/ice-9/r6rs-libraries.scm +242 -0
- data/share/guile/2.2/ice-9/rdelim.scm +208 -0
- data/share/guile/2.2/ice-9/receive.scm +26 -0
- data/share/guile/2.2/ice-9/regex.scm +229 -0
- data/share/guile/2.2/ice-9/runq.scm +241 -0
- data/share/guile/2.2/ice-9/rw.scm +27 -0
- data/share/guile/2.2/ice-9/safe-r5rs.scm +145 -0
- data/share/guile/2.2/ice-9/safe.scm +34 -0
- data/share/guile/2.2/ice-9/sandbox.scm +1399 -0
- data/share/guile/2.2/ice-9/save-stack.scm +58 -0
- data/share/guile/2.2/ice-9/scm-style-repl.scm +279 -0
- data/share/guile/2.2/ice-9/serialize.scm +114 -0
- data/share/guile/2.2/ice-9/session.scm +530 -0
- data/share/guile/2.2/ice-9/slib.scm +33 -0
- data/share/guile/2.2/ice-9/stack-catch.scm +47 -0
- data/share/guile/2.2/ice-9/streams.scm +168 -0
- data/share/guile/2.2/ice-9/string-fun.scm +280 -0
- data/share/guile/2.2/ice-9/suspendable-ports.scm +788 -0
- data/share/guile/2.2/ice-9/syncase.scm +37 -0
- data/share/guile/2.2/ice-9/textual-ports.scm +70 -0
- data/share/guile/2.2/ice-9/threads.scm +392 -0
- data/share/guile/2.2/ice-9/time.scm +58 -0
- data/share/guile/2.2/ice-9/top-repl.scm +78 -0
- data/share/guile/2.2/ice-9/unicode.scm +26 -0
- data/share/guile/2.2/ice-9/vlist.scm +595 -0
- data/share/guile/2.2/ice-9/weak-vector.scm +31 -0
- data/share/guile/2.2/language/brainfuck/compile-scheme.scm +123 -0
- data/share/guile/2.2/language/brainfuck/compile-tree-il.scm +184 -0
- data/share/guile/2.2/language/brainfuck/parse.scm +95 -0
- data/share/guile/2.2/language/brainfuck/spec.scm +43 -0
- data/share/guile/2.2/language/bytecode/spec.scm +42 -0
- data/share/guile/2.2/language/bytecode.scm +104 -0
- data/share/guile/2.2/language/cps/closure-conversion.scm +848 -0
- data/share/guile/2.2/language/cps/compile-bytecode.scm +610 -0
- data/share/guile/2.2/language/cps/constructors.scm +106 -0
- data/share/guile/2.2/language/cps/contification.scm +448 -0
- data/share/guile/2.2/language/cps/cse.scm +414 -0
- data/share/guile/2.2/language/cps/dce.scm +363 -0
- data/share/guile/2.2/language/cps/effects-analysis.scm +597 -0
- data/share/guile/2.2/language/cps/elide-values.scm +88 -0
- data/share/guile/2.2/language/cps/handle-interrupts.scm +69 -0
- data/share/guile/2.2/language/cps/intmap.scm +765 -0
- data/share/guile/2.2/language/cps/intset.scm +830 -0
- data/share/guile/2.2/language/cps/licm.scm +308 -0
- data/share/guile/2.2/language/cps/optimize.scm +135 -0
- data/share/guile/2.2/language/cps/peel-loops.scm +287 -0
- data/share/guile/2.2/language/cps/primitives.scm +141 -0
- data/share/guile/2.2/language/cps/prune-bailouts.scm +86 -0
- data/share/guile/2.2/language/cps/prune-top-level-scopes.scm +63 -0
- data/share/guile/2.2/language/cps/reify-primitives.scm +179 -0
- data/share/guile/2.2/language/cps/renumber.scm +217 -0
- data/share/guile/2.2/language/cps/rotate-loops.scm +239 -0
- data/share/guile/2.2/language/cps/self-references.scm +79 -0
- data/share/guile/2.2/language/cps/simplify.scm +274 -0
- data/share/guile/2.2/language/cps/slot-allocation.scm +1058 -0
- data/share/guile/2.2/language/cps/spec.scm +51 -0
- data/share/guile/2.2/language/cps/specialize-numbers.scm +724 -0
- data/share/guile/2.2/language/cps/specialize-primcalls.scm +87 -0
- data/share/guile/2.2/language/cps/split-rec.scm +174 -0
- data/share/guile/2.2/language/cps/type-checks.scm +72 -0
- data/share/guile/2.2/language/cps/type-fold.scm +455 -0
- data/share/guile/2.2/language/cps/types.scm +1826 -0
- data/share/guile/2.2/language/cps/utils.scm +550 -0
- data/share/guile/2.2/language/cps/verify.scm +304 -0
- data/share/guile/2.2/language/cps/with-cps.scm +145 -0
- data/share/guile/2.2/language/cps.scm +358 -0
- data/share/guile/2.2/language/ecmascript/array.scm +121 -0
- data/share/guile/2.2/language/ecmascript/base.scm +251 -0
- data/share/guile/2.2/language/ecmascript/compile-tree-il.scm +576 -0
- data/share/guile/2.2/language/ecmascript/function.scm +78 -0
- data/share/guile/2.2/language/ecmascript/impl.scm +169 -0
- data/share/guile/2.2/language/ecmascript/parse.scm +352 -0
- data/share/guile/2.2/language/ecmascript/spec.scm +37 -0
- data/share/guile/2.2/language/ecmascript/tokenize.scm +513 -0
- data/share/guile/2.2/language/elisp/bindings.scm +107 -0
- data/share/guile/2.2/language/elisp/boot.el +617 -0
- data/share/guile/2.2/language/elisp/compile-tree-il.scm +812 -0
- data/share/guile/2.2/language/elisp/falias.scm +47 -0
- data/share/guile/2.2/language/elisp/lexer.scm +430 -0
- data/share/guile/2.2/language/elisp/parser.scm +222 -0
- data/share/guile/2.2/language/elisp/runtime/function-slot.scm +63 -0
- data/share/guile/2.2/language/elisp/runtime/value-slot.scm +24 -0
- data/share/guile/2.2/language/elisp/runtime.scm +153 -0
- data/share/guile/2.2/language/elisp/spec.scm +43 -0
- data/share/guile/2.2/language/scheme/compile-tree-il.scm +33 -0
- data/share/guile/2.2/language/scheme/decompile-tree-il.scm +796 -0
- data/share/guile/2.2/language/scheme/spec.scm +63 -0
- data/share/guile/2.2/language/tree-il/analyze.scm +1568 -0
- data/share/guile/2.2/language/tree-il/canonicalize.scm +82 -0
- data/share/guile/2.2/language/tree-il/compile-cps.scm +1149 -0
- data/share/guile/2.2/language/tree-il/debug.scm +246 -0
- data/share/guile/2.2/language/tree-il/effects.scm +591 -0
- data/share/guile/2.2/language/tree-il/fix-letrec.scm +314 -0
- data/share/guile/2.2/language/tree-il/optimize.scm +43 -0
- data/share/guile/2.2/language/tree-il/peval.scm +1669 -0
- data/share/guile/2.2/language/tree-il/primitives.scm +630 -0
- data/share/guile/2.2/language/tree-il/spec.scm +46 -0
- data/share/guile/2.2/language/tree-il.scm +630 -0
- data/share/guile/2.2/language/value/spec.scm +30 -0
- data/share/guile/2.2/oop/goops/accessors.scm +72 -0
- data/share/guile/2.2/oop/goops/active-slot.scm +63 -0
- data/share/guile/2.2/oop/goops/composite-slot.scm +83 -0
- data/share/guile/2.2/oop/goops/describe.scm +189 -0
- data/share/guile/2.2/oop/goops/internal.scm +30 -0
- data/share/guile/2.2/oop/goops/save.scm +874 -0
- data/share/guile/2.2/oop/goops/simple.scm +30 -0
- data/share/guile/2.2/oop/goops/stklos.scm +74 -0
- data/share/guile/2.2/oop/goops.scm +3176 -0
- data/share/guile/2.2/rnrs/arithmetic/bitwise.scm +92 -0
- data/share/guile/2.2/rnrs/arithmetic/fixnums.scm +291 -0
- data/share/guile/2.2/rnrs/arithmetic/flonums.scm +203 -0
- data/share/guile/2.2/rnrs/base.scm +291 -0
- data/share/guile/2.2/rnrs/bytevectors.scm +83 -0
- data/share/guile/2.2/rnrs/conditions.scm +225 -0
- data/share/guile/2.2/rnrs/control.scm +22 -0
- data/share/guile/2.2/rnrs/enums.scm +152 -0
- data/share/guile/2.2/rnrs/eval.scm +39 -0
- data/share/guile/2.2/rnrs/exceptions.scm +276 -0
- data/share/guile/2.2/rnrs/files.scm +96 -0
- data/share/guile/2.2/rnrs/hashtables.scm +190 -0
- data/share/guile/2.2/rnrs/io/ports.scm +554 -0
- data/share/guile/2.2/rnrs/io/simple.scm +167 -0
- data/share/guile/2.2/rnrs/lists.scm +55 -0
- data/share/guile/2.2/rnrs/mutable-pairs.scm +23 -0
- data/share/guile/2.2/rnrs/mutable-strings.scm +23 -0
- data/share/guile/2.2/rnrs/programs.scm +22 -0
- data/share/guile/2.2/rnrs/r5rs.scm +34 -0
- data/share/guile/2.2/rnrs/records/inspection.scm +81 -0
- data/share/guile/2.2/rnrs/records/procedural.scm +289 -0
- data/share/guile/2.2/rnrs/records/syntactic.scm +248 -0
- data/share/guile/2.2/rnrs/sorting.scm +27 -0
- data/share/guile/2.2/rnrs/syntax-case.scm +68 -0
- data/share/guile/2.2/rnrs/unicode.scm +104 -0
- data/share/guile/2.2/rnrs.scm +289 -0
- data/share/guile/2.2/scripts/api-diff.scm +179 -0
- data/share/guile/2.2/scripts/autofrisk.scm +218 -0
- data/share/guile/2.2/scripts/compile.scm +273 -0
- data/share/guile/2.2/scripts/disassemble.scm +38 -0
- data/share/guile/2.2/scripts/display-commentary.scm +67 -0
- data/share/guile/2.2/scripts/doc-snarf.scm +439 -0
- data/share/guile/2.2/scripts/frisk.scm +290 -0
- data/share/guile/2.2/scripts/generate-autoload.scm +144 -0
- data/share/guile/2.2/scripts/help.scm +188 -0
- data/share/guile/2.2/scripts/lint.scm +318 -0
- data/share/guile/2.2/scripts/list.scm +91 -0
- data/share/guile/2.2/scripts/punify.scm +87 -0
- data/share/guile/2.2/scripts/read-rfc822.scm +131 -0
- data/share/guile/2.2/scripts/read-scheme-source.scm +282 -0
- data/share/guile/2.2/scripts/read-text-outline.scm +253 -0
- data/share/guile/2.2/scripts/scan-api.scm +223 -0
- data/share/guile/2.2/scripts/snarf-check-and-output-texi.scm +303 -0
- data/share/guile/2.2/scripts/snarf-guile-m4-docs.scm +86 -0
- data/share/guile/2.2/scripts/summarize-guile-TODO.scm +213 -0
- data/share/guile/2.2/scripts/use2dot.scm +110 -0
- data/share/guile/2.2/srfi/srfi-1.scm +1061 -0
- data/share/guile/2.2/srfi/srfi-10.scm +89 -0
- data/share/guile/2.2/srfi/srfi-11.scm +146 -0
- data/share/guile/2.2/srfi/srfi-111.scm +37 -0
- data/share/guile/2.2/srfi/srfi-13.scm +132 -0
- data/share/guile/2.2/srfi/srfi-14.scm +99 -0
- data/share/guile/2.2/srfi/srfi-16.scm +51 -0
- data/share/guile/2.2/srfi/srfi-17.scm +174 -0
- data/share/guile/2.2/srfi/srfi-18.scm +382 -0
- data/share/guile/2.2/srfi/srfi-19.scm +1470 -0
- data/share/guile/2.2/srfi/srfi-2.scm +31 -0
- data/share/guile/2.2/srfi/srfi-26.scm +66 -0
- data/share/guile/2.2/srfi/srfi-27.scm +96 -0
- data/share/guile/2.2/srfi/srfi-28.scm +34 -0
- data/share/guile/2.2/srfi/srfi-31.scm +35 -0
- data/share/guile/2.2/srfi/srfi-34.scm +84 -0
- data/share/guile/2.2/srfi/srfi-35.scm +351 -0
- data/share/guile/2.2/srfi/srfi-37.scm +234 -0
- data/share/guile/2.2/srfi/srfi-38.scm +207 -0
- data/share/guile/2.2/srfi/srfi-39.scm +55 -0
- data/share/guile/2.2/srfi/srfi-4/gnu.scm +80 -0
- data/share/guile/2.2/srfi/srfi-4.scm +118 -0
- data/share/guile/2.2/srfi/srfi-41.scm +505 -0
- data/share/guile/2.2/srfi/srfi-42/ec.scm +1053 -0
- data/share/guile/2.2/srfi/srfi-42.scm +66 -0
- data/share/guile/2.2/srfi/srfi-43.scm +1077 -0
- data/share/guile/2.2/srfi/srfi-45.scm +93 -0
- data/share/guile/2.2/srfi/srfi-6.scm +29 -0
- data/share/guile/2.2/srfi/srfi-60.scm +73 -0
- data/share/guile/2.2/srfi/srfi-64/testing.scm +1040 -0
- data/share/guile/2.2/srfi/srfi-64.scm +55 -0
- data/share/guile/2.2/srfi/srfi-67/compare.scm +686 -0
- data/share/guile/2.2/srfi/srfi-67.scm +88 -0
- data/share/guile/2.2/srfi/srfi-69.scm +336 -0
- data/share/guile/2.2/srfi/srfi-71.scm +267 -0
- data/share/guile/2.2/srfi/srfi-8.scm +31 -0
- data/share/guile/2.2/srfi/srfi-88.scm +53 -0
- data/share/guile/2.2/srfi/srfi-9/gnu.scm +168 -0
- data/share/guile/2.2/srfi/srfi-9.scm +351 -0
- data/share/guile/2.2/srfi/srfi-98.scm +44 -0
- data/share/guile/2.2/statprof.scm +988 -0
- data/share/guile/2.2/sxml/apply-templates.scm +102 -0
- data/share/guile/2.2/sxml/fold.scm +250 -0
- data/share/guile/2.2/sxml/match.scm +75 -0
- data/share/guile/2.2/sxml/simple.scm +408 -0
- data/share/guile/2.2/sxml/ssax/input-parse.scm +180 -0
- data/share/guile/2.2/sxml/ssax.scm +265 -0
- data/share/guile/2.2/sxml/sxml-match.ss +1181 -0
- data/share/guile/2.2/sxml/transform.scm +298 -0
- data/share/guile/2.2/sxml/upstream/SSAX.scm +3235 -0
- data/share/guile/2.2/sxml/upstream/SXML-tree-trans.scm +249 -0
- data/share/guile/2.2/sxml/upstream/SXPath-old.scm +1216 -0
- data/share/guile/2.2/sxml/upstream/assert.scm +35 -0
- data/share/guile/2.2/sxml/upstream/input-parse.scm +326 -0
- data/share/guile/2.2/sxml/xpath.scm +493 -0
- data/share/guile/2.2/system/base/ck.scm +55 -0
- data/share/guile/2.2/system/base/compile.scm +282 -0
- data/share/guile/2.2/system/base/lalr.scm +51 -0
- data/share/guile/2.2/system/base/lalr.upstream.scm +2096 -0
- data/share/guile/2.2/system/base/language.scm +119 -0
- data/share/guile/2.2/system/base/message.scm +238 -0
- data/share/guile/2.2/system/base/pmatch.scm +68 -0
- data/share/guile/2.2/system/base/syntax.scm +299 -0
- data/share/guile/2.2/system/base/target.scm +152 -0
- data/share/guile/2.2/system/base/types.scm +561 -0
- data/share/guile/2.2/system/foreign-object.scm +91 -0
- data/share/guile/2.2/system/foreign.scm +200 -0
- data/share/guile/2.2/system/repl/command.scm +946 -0
- data/share/guile/2.2/system/repl/common.scm +263 -0
- data/share/guile/2.2/system/repl/coop-server.scm +200 -0
- data/share/guile/2.2/system/repl/debug.scm +210 -0
- data/share/guile/2.2/system/repl/describe.scm +347 -0
- data/share/guile/2.2/system/repl/error-handling.scm +183 -0
- data/share/guile/2.2/system/repl/repl.scm +233 -0
- data/share/guile/2.2/system/repl/server.scm +332 -0
- data/share/guile/2.2/system/syntax.scm +33 -0
- data/share/guile/2.2/system/vm/assembler.scm +2614 -0
- data/share/guile/2.2/system/vm/coverage.scm +351 -0
- data/share/guile/2.2/system/vm/debug.scm +766 -0
- data/share/guile/2.2/system/vm/disassembler.scm +658 -0
- data/share/guile/2.2/system/vm/dwarf.scm +1852 -0
- data/share/guile/2.2/system/vm/elf.scm +1042 -0
- data/share/guile/2.2/system/vm/frame.scm +485 -0
- data/share/guile/2.2/system/vm/inspect.scm +188 -0
- data/share/guile/2.2/system/vm/linker.scm +732 -0
- data/share/guile/2.2/system/vm/loader.scm +27 -0
- data/share/guile/2.2/system/vm/program.scm +312 -0
- data/share/guile/2.2/system/vm/trace.scm +121 -0
- data/share/guile/2.2/system/vm/trap-state.scm +302 -0
- data/share/guile/2.2/system/vm/traps.scm +608 -0
- data/share/guile/2.2/system/vm/vm.scm +32 -0
- data/share/guile/2.2/system/xref.scm +369 -0
- data/share/guile/2.2/texinfo/docbook.scm +240 -0
- data/share/guile/2.2/texinfo/html.scm +279 -0
- data/share/guile/2.2/texinfo/indexing.scm +75 -0
- data/share/guile/2.2/texinfo/plain-text.scm +322 -0
- data/share/guile/2.2/texinfo/reflection.scm +585 -0
- data/share/guile/2.2/texinfo/serialize.scm +300 -0
- data/share/guile/2.2/texinfo/string-utils.scm +410 -0
- data/share/guile/2.2/texinfo.scm +1263 -0
- data/share/guile/2.2/web/client.scm +513 -0
- data/share/guile/2.2/web/http.scm +2043 -0
- data/share/guile/2.2/web/request.scm +326 -0
- data/share/guile/2.2/web/response.scm +379 -0
- data/share/guile/2.2/web/server/http.scm +183 -0
- data/share/guile/2.2/web/server.scm +397 -0
- data/share/guile/2.2/web/uri.scm +552 -0
- data/share/lilypond/2.24.1/fontconfig/0bd3dc0958fa2205aaaa8ebb13e2872b-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/188ac73a183f12857f63bb60a4a6d603-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/32b6488e5b8292a2e95c79d947e009e8-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/3830d5c3ddfd5cd38a049b759396e72e-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/3f7329c5293ffd510edef78f73874cfd-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/4c599c202bc5c08e2d34565a40eac3b2-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/57e423e26b20ab21d0f2f29c145174c3-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/7ef2298fde41cc6eeb7af42e48b7d293-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/826f6b6ef79022e2eac8af26bf4b62f2-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/945677eb7aeaf62f1d50efc3fb3ec7d8-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/95530828ff6c81d309f8258d8d02a23e-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/CACHEDIR.TAG +4 -0
- data/share/lilypond/2.24.1/fontconfig/bf3b770c553c462765856025a94f1ce6-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/c855463f699352c367813e37f3f70ea7-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/d3e5c4ee2ceb1fc347f91d4cefc53bc0-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/d589a48862398ed80a3d6066f4f56f4c-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/d82eb4fd963d448e2fcb7d7b793b5df3-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/e13b20fdb08344e0e664864cc2ede53d-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/e52a45a1c8c8fe895fc0fc8c4e6999b8-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fontconfig/f1f2465696798768e9653f19e17ccdc8-le64.cache-8 +0 -0
- data/share/lilypond/2.24.1/fonts/00-lilypond-fonts.conf +99 -0
- data/share/lilypond/2.24.1/fonts/99-lilypond-fonts.conf +28 -0
- data/share/lilypond/2.24.1/fonts/otf/C059-BdIta.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/C059-Bold.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/C059-Italic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/C059-Roman.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Bold.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-BoldItalic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Italic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Regular.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Bold.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/NimbusSans-BoldItalic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Italic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Regular.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-11.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-13.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-14.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-16.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-18.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-20.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-23.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-26.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/emmentaler-brace.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-bold.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-bolditalic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-italic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-regular.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyreheros-bold.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyreheros-bolditalic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyreheros-italic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyreheros-regular.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyreschola-bold.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyreschola-bolditalic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyreschola-italic.otf +0 -0
- data/share/lilypond/2.24.1/fonts/otf/texgyreschola-regular.otf +0 -0
- data/share/lilypond/2.24.1/fonts/source/common-modules-and-initialization.mf +26 -0
- data/share/lilypond/2.24.1/fonts/source/debugging-settings.mf +14 -0
- data/share/lilypond/2.24.1/fonts/source/declare-autometric-parameters.mf +9 -0
- data/share/lilypond/2.24.1/fonts/source/feta-accidentals.mf +58 -0
- data/share/lilypond/2.24.1/fonts/source/feta-accordion.mf +575 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet-generic.mf +16 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet11.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet13.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet14.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet16.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet18.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet20.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet23.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-alphabet26.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-arrow.mf +114 -0
- data/share/lilypond/2.24.1/fonts/source/feta-arrowheads.mf +171 -0
- data/share/lilypond/2.24.1/fonts/source/feta-autometric.mf +303 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-a.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-b.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-c.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-d.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-e.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-f.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-g.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-generic.mf +47 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-h.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces-i.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-braces.mf +125 -0
- data/share/lilypond/2.24.1/fonts/source/feta-brackettips.mf +100 -0
- data/share/lilypond/2.24.1/fonts/source/feta-clefs.mf +963 -0
- data/share/lilypond/2.24.1/fonts/source/feta-dots.mf +37 -0
- data/share/lilypond/2.24.1/fonts/source/feta-dynamics.mf +891 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags-generic.mf +17 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags.mf +926 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags11.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags13.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags14.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags16.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags18.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags20.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags23.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flags26.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-flats.mf +668 -0
- data/share/lilypond/2.24.1/fonts/source/feta-macros.mf +506 -0
- data/share/lilypond/2.24.1/fonts/source/feta-naturals.mf +223 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads-generic.mf +17 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads.mf +2642 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads11.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads13.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads14.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads16.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads18.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads20.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads23.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-noteheads26.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta-numbers.mf +1677 -0
- data/share/lilypond/2.24.1/fonts/source/feta-other-generic.mf +27 -0
- data/share/lilypond/2.24.1/fonts/source/feta-params.mf +323 -0
- data/share/lilypond/2.24.1/fonts/source/feta-parenthesis.mf +63 -0
- data/share/lilypond/2.24.1/fonts/source/feta-pedals.mf +355 -0
- data/share/lilypond/2.24.1/fonts/source/feta-rests.mf +890 -0
- data/share/lilypond/2.24.1/fonts/source/feta-scripts.mf +2206 -0
- data/share/lilypond/2.24.1/fonts/source/feta-sharps.mf +524 -0
- data/share/lilypond/2.24.1/fonts/source/feta-sori-koron.mf +325 -0
- data/share/lilypond/2.24.1/fonts/source/feta-ties.mf +72 -0
- data/share/lilypond/2.24.1/fonts/source/feta-timesignatures.mf +119 -0
- data/share/lilypond/2.24.1/fonts/source/feta-trills.mf +321 -0
- data/share/lilypond/2.24.1/fonts/source/feta11.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta13.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta14.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta16.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta18.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta20.mf +7 -0
- data/share/lilypond/2.24.1/fonts/source/feta23.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/feta26.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-accidentals.mf +483 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-clefs.mf +1636 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-custodes.mf +503 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-dots.mf +62 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-flags.mf +319 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-macros.mf +225 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads-generic.mf +16 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads.mf +2191 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads11.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads13.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads14.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads16.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads18.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads20.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads23.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads26.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-other-generic.mf +24 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-rests.mf +428 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-scripts.mf +284 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan-timesignatures.mf +402 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan11.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan13.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan14.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan16.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan18.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan20.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan23.mf +6 -0
- data/share/lilypond/2.24.1/fonts/source/parmesan26.mf +6 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-11.svg +2525 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-11.woff +0 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-13.svg +2530 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-13.woff +0 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-14.svg +2526 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-14.woff +0 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-16.svg +2523 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-16.woff +0 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-18.svg +2519 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-18.woff +0 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-20.svg +2512 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-20.woff +0 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-23.svg +2506 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-23.woff +0 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-26.svg +2510 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-26.woff +0 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-brace.svg +1757 -0
- data/share/lilypond/2.24.1/fonts/svg/emmentaler-brace.woff +0 -0
- data/share/lilypond/2.24.1/ly/Welcome_to_LilyPond.ly +45 -0
- data/share/lilypond/2.24.1/ly/arabic.ly +185 -0
- data/share/lilypond/2.24.1/ly/articulate.ly +1013 -0
- data/share/lilypond/2.24.1/ly/bagpipe.ly +368 -0
- data/share/lilypond/2.24.1/ly/base-tkit.ly +135 -0
- data/share/lilypond/2.24.1/ly/catalan.ly +23 -0
- data/share/lilypond/2.24.1/ly/chord-modifiers-init.ly +63 -0
- data/share/lilypond/2.24.1/ly/chord-repetition-init.ly +60 -0
- data/share/lilypond/2.24.1/ly/context-mods-init.ly +119 -0
- data/share/lilypond/2.24.1/ly/declarations-init.ly +167 -0
- data/share/lilypond/2.24.1/ly/deutsch.ly +23 -0
- data/share/lilypond/2.24.1/ly/drumpitch-init.ly +366 -0
- data/share/lilypond/2.24.1/ly/dynamic-scripts-init.ly +54 -0
- data/share/lilypond/2.24.1/ly/english.ly +23 -0
- data/share/lilypond/2.24.1/ly/engraver-init.ly +1619 -0
- data/share/lilypond/2.24.1/ly/espanol.ly +23 -0
- data/share/lilypond/2.24.1/ly/event-listener.ly +241 -0
- data/share/lilypond/2.24.1/ly/festival.ly +38 -0
- data/share/lilypond/2.24.1/ly/generate-documentation.ly +7 -0
- data/share/lilypond/2.24.1/ly/grace-init.ly +56 -0
- data/share/lilypond/2.24.1/ly/graphviz-init.ly +174 -0
- data/share/lilypond/2.24.1/ly/gregorian.ly +268 -0
- data/share/lilypond/2.24.1/ly/guile-debugger.ly +55 -0
- data/share/lilypond/2.24.1/ly/hel-arabic.ly +307 -0
- data/share/lilypond/2.24.1/ly/init.ly +96 -0
- data/share/lilypond/2.24.1/ly/italiano.ly +23 -0
- data/share/lilypond/2.24.1/ly/lilypond-book-preamble.ly +47 -0
- data/share/lilypond/2.24.1/ly/lyrics-tkit.ly +68 -0
- data/share/lilypond/2.24.1/ly/makam.ly +166 -0
- data/share/lilypond/2.24.1/ly/midi-init.ly +59 -0
- data/share/lilypond/2.24.1/ly/music-functions-init.ly +2254 -0
- data/share/lilypond/2.24.1/ly/nederlands.ly +23 -0
- data/share/lilypond/2.24.1/ly/norsk.ly +23 -0
- data/share/lilypond/2.24.1/ly/paper-defaults-init.ly +188 -0
- data/share/lilypond/2.24.1/ly/performer-init.ly +398 -0
- data/share/lilypond/2.24.1/ly/persian.ly +335 -0
- data/share/lilypond/2.24.1/ly/piano-tkit.ly +61 -0
- data/share/lilypond/2.24.1/ly/portugues.ly +23 -0
- data/share/lilypond/2.24.1/ly/predefined-fretboards-init.ly +78 -0
- data/share/lilypond/2.24.1/ly/predefined-guitar-fretboards.ly +506 -0
- data/share/lilypond/2.24.1/ly/predefined-guitar-ninth-fretboards.ly +75 -0
- data/share/lilypond/2.24.1/ly/predefined-mandolin-fretboards.ly +876 -0
- data/share/lilypond/2.24.1/ly/predefined-ukulele-fretboards.ly +1285 -0
- data/share/lilypond/2.24.1/ly/property-init.ly +858 -0
- data/share/lilypond/2.24.1/ly/satb.ly +214 -0
- data/share/lilypond/2.24.1/ly/scale-definitions-init.ly +117 -0
- data/share/lilypond/2.24.1/ly/scheme-sandbox.ly +39 -0
- data/share/lilypond/2.24.1/ly/script-init.ly +94 -0
- data/share/lilypond/2.24.1/ly/spanners-init.ly +146 -0
- data/share/lilypond/2.24.1/ly/ssaattbb.ly +335 -0
- data/share/lilypond/2.24.1/ly/staff-tkit.ly +182 -0
- data/share/lilypond/2.24.1/ly/string-tunings-init.ly +94 -0
- data/share/lilypond/2.24.1/ly/suomi.ly +23 -0
- data/share/lilypond/2.24.1/ly/svenska.ly +23 -0
- data/share/lilypond/2.24.1/ly/swing.ly +362 -0
- data/share/lilypond/2.24.1/ly/text-replacements.ly +150 -0
- data/share/lilypond/2.24.1/ly/titling-init.ly +150 -0
- data/share/lilypond/2.24.1/ly/toc-init.ly +182 -0
- data/share/lilypond/2.24.1/ly/turkish-makam.ly +609 -0
- data/share/lilypond/2.24.1/ly/vlaams.ly +23 -0
- data/share/lilypond/2.24.1/ly/vocal-tkit.ly +103 -0
- data/share/lilypond/2.24.1/ly/voice-tkit.ly +34 -0
- data/share/lilypond/2.24.1/ps/encodingdefs.ps +2611 -0
- data/share/lilypond/2.24.1/ps/lilyponddefs.ps +49 -0
- data/share/lilypond/2.24.1/ps/music-drawing-routines.ps +329 -0
- data/share/lilypond/2.24.1/python/__pycache__/book_base.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/book_docbook.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/book_html.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/book_latex.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/book_snippets.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/book_texinfo.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/convertrules.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/langdefs.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/lilylib.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/midi.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/musicexp.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/musicxml.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/musicxml2ly_conversion.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/__pycache__/utilities.cpython-310.pyc +0 -0
- data/share/lilypond/2.24.1/python/book_base.py +331 -0
- data/share/lilypond/2.24.1/python/book_docbook.py +154 -0
- data/share/lilypond/2.24.1/python/book_html.py +178 -0
- data/share/lilypond/2.24.1/python/book_latex.py +373 -0
- data/share/lilypond/2.24.1/python/book_snippets.py +1052 -0
- data/share/lilypond/2.24.1/python/book_texinfo.py +437 -0
- data/share/lilypond/2.24.1/python/convertrules.py +4764 -0
- data/share/lilypond/2.24.1/python/langdefs.py +131 -0
- data/share/lilypond/2.24.1/python/lilylib.py +141 -0
- data/share/lilypond/2.24.1/python/midi.py +212 -0
- data/share/lilypond/2.24.1/python/musicexp.py +2781 -0
- data/share/lilypond/2.24.1/python/musicxml.py +1905 -0
- data/share/lilypond/2.24.1/python/musicxml2ly_conversion.py +80 -0
- data/share/lilypond/2.24.1/python/utilities.py +280 -0
- data/share/lilypond/2.24.1/scm/lily/accreg.scm +579 -0
- data/share/lilypond/2.24.1/scm/lily/auto-beam.scm +163 -0
- data/share/lilypond/2.24.1/scm/lily/autochange.scm +100 -0
- data/share/lilypond/2.24.1/scm/lily/backend-library.scm +593 -0
- data/share/lilypond/2.24.1/scm/lily/bar-line.scm +1281 -0
- data/share/lilypond/2.24.1/scm/lily/breath.scm +74 -0
- data/share/lilypond/2.24.1/scm/lily/c++.scm +174 -0
- data/share/lilypond/2.24.1/scm/lily/chord-entry.scm +278 -0
- data/share/lilypond/2.24.1/scm/lily/chord-ignatzek-names.scm +304 -0
- data/share/lilypond/2.24.1/scm/lily/chord-name.scm +217 -0
- data/share/lilypond/2.24.1/scm/lily/clip-region.scm +87 -0
- data/share/lilypond/2.24.1/scm/lily/color.scm +757 -0
- data/share/lilypond/2.24.1/scm/lily/curried-definitions.scm +68 -0
- data/share/lilypond/2.24.1/scm/lily/define-context-properties.scm +939 -0
- data/share/lilypond/2.24.1/scm/lily/define-event-classes.scm +142 -0
- data/share/lilypond/2.24.1/scm/lily/define-grob-interfaces.scm +640 -0
- data/share/lilypond/2.24.1/scm/lily/define-grob-properties.scm +1647 -0
- data/share/lilypond/2.24.1/scm/lily/define-grobs.scm +4027 -0
- data/share/lilypond/2.24.1/scm/lily/define-markup-commands.scm +5737 -0
- data/share/lilypond/2.24.1/scm/lily/define-music-callbacks.scm +257 -0
- data/share/lilypond/2.24.1/scm/lily/define-music-display-methods.scm +1350 -0
- data/share/lilypond/2.24.1/scm/lily/define-music-properties.scm +242 -0
- data/share/lilypond/2.24.1/scm/lily/define-music-types.scm +983 -0
- data/share/lilypond/2.24.1/scm/lily/define-note-names.scm +1421 -0
- data/share/lilypond/2.24.1/scm/lily/define-stencil-commands.scm +71 -0
- data/share/lilypond/2.24.1/scm/lily/define-woodwind-diagrams.scm +1215 -0
- data/share/lilypond/2.24.1/scm/lily/display-lily.scm +315 -0
- data/share/lilypond/2.24.1/scm/lily/display-woodwind-diagrams.scm +1985 -0
- data/share/lilypond/2.24.1/scm/lily/document-backend.scm +307 -0
- data/share/lilypond/2.24.1/scm/lily/document-context-mods.scm +98 -0
- data/share/lilypond/2.24.1/scm/lily/document-functions.scm +169 -0
- data/share/lilypond/2.24.1/scm/lily/document-identifiers.scm +76 -0
- data/share/lilypond/2.24.1/scm/lily/document-markup.scm +158 -0
- data/share/lilypond/2.24.1/scm/lily/document-music.scm +146 -0
- data/share/lilypond/2.24.1/scm/lily/document-outside-staff-priorities.scm +40 -0
- data/share/lilypond/2.24.1/scm/lily/document-paper-sizes.scm +71 -0
- data/share/lilypond/2.24.1/scm/lily/document-translation.scm +318 -0
- data/share/lilypond/2.24.1/scm/lily/document-type-predicates.scm +85 -0
- data/share/lilypond/2.24.1/scm/lily/documentation-generate.scm +259 -0
- data/share/lilypond/2.24.1/scm/lily/documentation-lib.scm +207 -0
- data/share/lilypond/2.24.1/scm/lily/file-cache.scm +28 -0
- data/share/lilypond/2.24.1/scm/lily/flag-styles.scm +249 -0
- data/share/lilypond/2.24.1/scm/lily/font-encodings.scm +1242 -0
- data/share/lilypond/2.24.1/scm/lily/font.scm +303 -0
- data/share/lilypond/2.24.1/scm/lily/framework-cairo.scm +26 -0
- data/share/lilypond/2.24.1/scm/lily/framework-ps.scm +896 -0
- data/share/lilypond/2.24.1/scm/lily/framework-svg.scm +172 -0
- data/share/lilypond/2.24.1/scm/lily/fret-diagrams.scm +1261 -0
- data/share/lilypond/2.24.1/scm/lily/graphviz.scm +78 -0
- data/share/lilypond/2.24.1/scm/lily/guile-debugger.scm +90 -0
- data/share/lilypond/2.24.1/scm/lily/harp-pedals.scm +172 -0
- data/share/lilypond/2.24.1/scm/lily/hyphenate-internal-words.scm +51 -0
- data/share/lilypond/2.24.1/scm/lily/layout-beam.scm +73 -0
- data/share/lilypond/2.24.1/scm/lily/layout-slur.scm +45 -0
- data/share/lilypond/2.24.1/scm/lily/lily-library.scm +1446 -0
- data/share/lilypond/2.24.1/scm/lily/lily-sort.scm +116 -0
- data/share/lilypond/2.24.1/scm/lily/lily.scm +929 -0
- data/share/lilypond/2.24.1/scm/lily/ly-syntax-constructors.scm +374 -0
- data/share/lilypond/2.24.1/scm/lily/markup-macros.scm +493 -0
- data/share/lilypond/2.24.1/scm/lily/markup.scm +126 -0
- data/share/lilypond/2.24.1/scm/lily/midi.scm +258 -0
- data/share/lilypond/2.24.1/scm/lily/modal-transforms.scm +337 -0
- data/share/lilypond/2.24.1/scm/lily/music-functions.scm +2878 -0
- data/share/lilypond/2.24.1/scm/lily/output-lib.scm +3377 -0
- data/share/lilypond/2.24.1/scm/lily/output-ps.scm +335 -0
- data/share/lilypond/2.24.1/scm/lily/output-svg.scm +684 -0
- data/share/lilypond/2.24.1/scm/lily/page.scm +321 -0
- data/share/lilypond/2.24.1/scm/lily/paper-system.scm +271 -0
- data/share/lilypond/2.24.1/scm/lily/paper.scm +376 -0
- data/share/lilypond/2.24.1/scm/lily/parser-clef.scm +205 -0
- data/share/lilypond/2.24.1/scm/lily/parser-ly-from-scheme.scm +170 -0
- data/share/lilypond/2.24.1/scm/lily/part-combiner.scm +998 -0
- data/share/lilypond/2.24.1/scm/lily/predefined-fretboards.scm +54 -0
- data/share/lilypond/2.24.1/scm/lily/ps-to-png.scm +182 -0
- data/share/lilypond/2.24.1/scm/lily/scheme-engravers.scm +1813 -0
- data/share/lilypond/2.24.1/scm/lily/scheme-performers.scm +126 -0
- data/share/lilypond/2.24.1/scm/lily/script.scm +416 -0
- data/share/lilypond/2.24.1/scm/lily/skyline.scm +25 -0
- data/share/lilypond/2.24.1/scm/lily/song-util.scm +191 -0
- data/share/lilypond/2.24.1/scm/lily/song.scm +853 -0
- data/share/lilypond/2.24.1/scm/lily/stencil.scm +998 -0
- data/share/lilypond/2.24.1/scm/lily/tablature.scm +392 -0
- data/share/lilypond/2.24.1/scm/lily/time-signature-settings.scm +473 -0
- data/share/lilypond/2.24.1/scm/lily/time-signature.scm +35 -0
- data/share/lilypond/2.24.1/scm/lily/titling.scm +99 -0
- data/share/lilypond/2.24.1/scm/lily/to-xml.scm +254 -0
- data/share/lilypond/2.24.1/scm/lily/translation-functions.scm +1169 -0
- data/share/lilypond/2.24.1/vim/compiler/lilypond.vim +36 -0
- data/share/lilypond/2.24.1/vim/ftdetect/lilypond.vim +4 -0
- data/share/lilypond/2.24.1/vim/ftplugin/lilypond.vim +91 -0
- data/share/lilypond/2.24.1/vim/indent/lilypond.vim +79 -0
- data/share/lilypond/2.24.1/vim/syntax/lilypond-words +1408 -0
- data/share/lilypond/2.24.1/vim/syntax/lilypond-words.vim +3 -0
- data/share/lilypond/2.24.1/vim/syntax/lilypond.vim +104 -0
- data/share/locale/ca/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/cs/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/da/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/de/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/el/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/eo/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/es/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/fi/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/fr/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/it/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/ja/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/nl/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/ru/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/sv/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/tr/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/uk/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/vi/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/zh_CN/LC_MESSAGES/lilypond.mo +0 -0
- data/share/locale/zh_TW/LC_MESSAGES/lilypond.mo +0 -0
- metadata +1108 -1
|
@@ -0,0 +1,3377 @@
|
|
|
1
|
+
;;;; This file is part of LilyPond, the GNU music typesetter.
|
|
2
|
+
;;;;
|
|
3
|
+
;;;; Copyright (C) 1998--2022 Jan Nieuwenhuizen <janneke@gnu.org>
|
|
4
|
+
;;;; Han-Wen Nienhuys <hanwen@xs4all.nl>
|
|
5
|
+
;;;;
|
|
6
|
+
;;;; LilyPond is free software: you can redistribute it and/or modify
|
|
7
|
+
;;;; it under the terms of the GNU General Public License as published by
|
|
8
|
+
;;;; the Free Software Foundation, either version 3 of the License, or
|
|
9
|
+
;;;; (at your option) any later version.
|
|
10
|
+
;;;;
|
|
11
|
+
;;;; LilyPond is distributed in the hope that it will be useful,
|
|
12
|
+
;;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
13
|
+
;;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
14
|
+
;;;; GNU General Public License for more details.
|
|
15
|
+
;;;;
|
|
16
|
+
;;;; You should have received a copy of the GNU General Public License
|
|
17
|
+
;;;; along with LilyPond. If not, see <http://www.gnu.org/licenses/>.
|
|
18
|
+
|
|
19
|
+
(use-modules (ice-9 match))
|
|
20
|
+
|
|
21
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
22
|
+
;; general
|
|
23
|
+
|
|
24
|
+
(define-public (grob::has-interface grob iface)
|
|
25
|
+
(memq iface (ly:grob-interfaces grob)))
|
|
26
|
+
|
|
27
|
+
(define-public (grob::is-live? grob)
|
|
28
|
+
(pair? (ly:grob-basic-properties grob)))
|
|
29
|
+
|
|
30
|
+
(define-public (grob::name grob)
|
|
31
|
+
"Return the name of the grob @var{grob} as a symbol."
|
|
32
|
+
(assq-ref (ly:grob-property grob 'meta) 'name))
|
|
33
|
+
|
|
34
|
+
(define-public (grob::rhythmic-location grob)
|
|
35
|
+
"Return a pair consisting of the measure number and moment within
|
|
36
|
+
the measure of grob @var{grob}."
|
|
37
|
+
(let* ((item (if (ly:spanner? grob)
|
|
38
|
+
(ly:spanner-bound grob LEFT)
|
|
39
|
+
grob))
|
|
40
|
+
(col (ly:item-get-column item)))
|
|
41
|
+
(if (ly:grob? col)
|
|
42
|
+
(ly:grob-property col 'rhythmic-location)
|
|
43
|
+
'())))
|
|
44
|
+
|
|
45
|
+
(define-public (grob::when grob)
|
|
46
|
+
"Return the global timestep (a @code{Moment}) of grob @var{grob}."
|
|
47
|
+
(let* ((item (if (ly:spanner? grob)
|
|
48
|
+
(ly:spanner-bound grob LEFT)
|
|
49
|
+
grob))
|
|
50
|
+
(col (ly:item-get-column item)))
|
|
51
|
+
(if (ly:grob? col)
|
|
52
|
+
(ly:grob-property col 'when)
|
|
53
|
+
'())))
|
|
54
|
+
|
|
55
|
+
(define-public (make-stencil-boxer thickness padding callback)
|
|
56
|
+
"Return function that adds a box around the grob passed as argument."
|
|
57
|
+
(lambda (grob)
|
|
58
|
+
(box-stencil (callback grob) thickness padding)))
|
|
59
|
+
|
|
60
|
+
(define-public (make-stencil-circler thickness padding callback)
|
|
61
|
+
"Return function that adds a circle around the grob passed as argument."
|
|
62
|
+
(lambda (grob)
|
|
63
|
+
(circle-stencil (callback grob) thickness padding)))
|
|
64
|
+
|
|
65
|
+
(define-public (print-circled-text-callback grob)
|
|
66
|
+
(grob-interpret-markup grob (make-circle-markup
|
|
67
|
+
(ly:grob-property grob 'text))))
|
|
68
|
+
|
|
69
|
+
(define-public (event-cause grob)
|
|
70
|
+
(let ((cause (ly:grob-property grob 'cause)))
|
|
71
|
+
|
|
72
|
+
(cond
|
|
73
|
+
((ly:stream-event? cause) cause)
|
|
74
|
+
((ly:grob? cause) (event-cause cause))
|
|
75
|
+
(else #f))))
|
|
76
|
+
|
|
77
|
+
(define-public (grob-interpret-markup grob text)
|
|
78
|
+
(let* ((layout (ly:grob-layout grob))
|
|
79
|
+
(defs (ly:output-def-lookup layout 'text-font-defaults))
|
|
80
|
+
(props (ly:grob-alist-chain grob defs)))
|
|
81
|
+
|
|
82
|
+
(ly:text-interface::interpret-markup layout props text)))
|
|
83
|
+
|
|
84
|
+
(define-public (grob::unpure-Y-extent-from-stencil pure-function)
|
|
85
|
+
"The unpure height will come from a stencil whereas the pure
|
|
86
|
+
height will come from @code{pure-function}."
|
|
87
|
+
(ly:make-unpure-pure-container ly:grob::stencil-height pure-function))
|
|
88
|
+
|
|
89
|
+
(define-public grob::unpure-horizontal-skylines-from-stencil
|
|
90
|
+
(ly:make-unpure-pure-container
|
|
91
|
+
ly:grob::horizontal-skylines-from-stencil
|
|
92
|
+
ly:grob::pure-simple-horizontal-skylines-from-extents))
|
|
93
|
+
|
|
94
|
+
(define-public grob::always-horizontal-skylines-from-stencil
|
|
95
|
+
(ly:make-unpure-pure-container
|
|
96
|
+
ly:grob::horizontal-skylines-from-stencil))
|
|
97
|
+
|
|
98
|
+
(define-public grob::unpure-vertical-skylines-from-stencil
|
|
99
|
+
(ly:make-unpure-pure-container
|
|
100
|
+
ly:grob::vertical-skylines-from-stencil
|
|
101
|
+
ly:grob::pure-simple-vertical-skylines-from-extents))
|
|
102
|
+
|
|
103
|
+
(define-public grob::always-vertical-skylines-from-stencil
|
|
104
|
+
(ly:make-unpure-pure-container
|
|
105
|
+
ly:grob::vertical-skylines-from-stencil))
|
|
106
|
+
|
|
107
|
+
(define-public grob::always-vertical-skylines-from-element-stencils
|
|
108
|
+
(ly:make-unpure-pure-container
|
|
109
|
+
ly:grob::vertical-skylines-from-element-stencils
|
|
110
|
+
ly:grob::pure-vertical-skylines-from-element-stencils))
|
|
111
|
+
|
|
112
|
+
(define-public grob::always-horizontal-skylines-from-element-stencils
|
|
113
|
+
(ly:make-unpure-pure-container
|
|
114
|
+
ly:grob::horizontal-skylines-from-element-stencils
|
|
115
|
+
ly:grob::pure-horizontal-skylines-from-element-stencils))
|
|
116
|
+
|
|
117
|
+
;; Using this as a callback for a grob's Y-extent promises
|
|
118
|
+
;; that the grob's stencil does not depend on line-spacing.
|
|
119
|
+
;; We use this promise to figure the space required by Clefs
|
|
120
|
+
;; and such at the note-spacing stage.
|
|
121
|
+
|
|
122
|
+
(define-public grob::always-Y-extent-from-stencil
|
|
123
|
+
(ly:make-unpure-pure-container ly:grob::stencil-height))
|
|
124
|
+
|
|
125
|
+
(define-public (layout-line-thickness grob)
|
|
126
|
+
"Get the line thickness of the @var{grob}'s corresponding layout."
|
|
127
|
+
(let* ((layout (ly:grob-layout grob))
|
|
128
|
+
(line-thickness (ly:output-def-lookup layout 'line-thickness)))
|
|
129
|
+
|
|
130
|
+
line-thickness))
|
|
131
|
+
|
|
132
|
+
(define (grob::objects-from-interface grob iface)
|
|
133
|
+
"For grob @var{grob} return the name and contents of all properties
|
|
134
|
+
within interface @var{iface} having type @code{ly:grob?} or
|
|
135
|
+
@code{ly:grob-array?}."
|
|
136
|
+
(let* ((iface-entry (hashq-ref (ly:all-grob-interfaces) iface))
|
|
137
|
+
(props (if iface-entry (last iface-entry) '()))
|
|
138
|
+
(pointer-props
|
|
139
|
+
(filter
|
|
140
|
+
(lambda (prop)
|
|
141
|
+
(let ((type (object-property prop 'backend-type?)))
|
|
142
|
+
(or (eq? type ly:grob?)
|
|
143
|
+
(eq? type ly:grob-array?))))
|
|
144
|
+
props)))
|
|
145
|
+
(if (null? pointer-props)
|
|
146
|
+
'()
|
|
147
|
+
(list iface
|
|
148
|
+
(map
|
|
149
|
+
(lambda (prop) (list prop (ly:grob-object grob prop)))
|
|
150
|
+
pointer-props)))))
|
|
151
|
+
|
|
152
|
+
(define-public (grob::all-objects grob)
|
|
153
|
+
"Return a list of the names and contents of all properties having type
|
|
154
|
+
@code{ly:grob?} or @code{ly:grob-array?} for all interfaces supported by
|
|
155
|
+
grob @var{grob}."
|
|
156
|
+
(let loop ((ifaces (ly:grob-interfaces grob)) (result '()))
|
|
157
|
+
(if (null? ifaces)
|
|
158
|
+
(cons grob (list result))
|
|
159
|
+
(let ((entry (grob::objects-from-interface grob (car ifaces))))
|
|
160
|
+
(if (pair? entry)
|
|
161
|
+
(loop (cdr ifaces) (append result (list entry)))
|
|
162
|
+
(loop (cdr ifaces) result))))))
|
|
163
|
+
|
|
164
|
+
(use-modules (ice-9 pretty-print))
|
|
165
|
+
(define-public (grob::display-objects grob)
|
|
166
|
+
"Display all objects stored in properties of grob @var{grob}."
|
|
167
|
+
(pretty-print (grob::all-objects grob))
|
|
168
|
+
(newline))
|
|
169
|
+
|
|
170
|
+
(define-public (grob::show-skylines-if-debug-skylines-set grob)
|
|
171
|
+
;; It looks like the default can be set to this
|
|
172
|
+
;; value directly, but that wouldn't work when
|
|
173
|
+
;; using ly:set-option in the file.
|
|
174
|
+
(ly:get-option 'debug-skylines))
|
|
175
|
+
|
|
176
|
+
|
|
177
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
178
|
+
;; beam slope
|
|
179
|
+
|
|
180
|
+
;; even though kievan noteheads do not have stems, their
|
|
181
|
+
;; invisible stems help with beam placement
|
|
182
|
+
;; this assures that invisible stems for kievan notes are aligned
|
|
183
|
+
;; to the center of kievan noteheads. that is thus where the beams'
|
|
184
|
+
;; x extrema will fall
|
|
185
|
+
(define-public (stem::kievan-offset-callback grob)
|
|
186
|
+
(let* ((note-heads (ly:grob-object grob 'note-heads #f))
|
|
187
|
+
(note-heads-grobs (if note-heads
|
|
188
|
+
(ly:grob-array->list note-heads)
|
|
189
|
+
'()))
|
|
190
|
+
(first-note-head (if (not (null? note-heads-grobs))
|
|
191
|
+
(car note-heads-grobs)
|
|
192
|
+
'()))
|
|
193
|
+
(note-head-w (if (not (null? first-note-head))
|
|
194
|
+
(ly:grob-extent first-note-head first-note-head X)
|
|
195
|
+
'(0 . 0))))
|
|
196
|
+
(interval-center note-head-w)))
|
|
197
|
+
|
|
198
|
+
|
|
199
|
+
;; sets position of beams for Kievan notation
|
|
200
|
+
(define-public (beam::get-kievan-positions grob)
|
|
201
|
+
(let* ((stems (ly:grob-object grob 'stems))
|
|
202
|
+
(stems-grobs (if (not (null? stems))
|
|
203
|
+
(ly:grob-array->list stems)
|
|
204
|
+
'()))
|
|
205
|
+
(first-stem (if (not (null? stems-grobs))
|
|
206
|
+
(car stems-grobs)
|
|
207
|
+
'()))
|
|
208
|
+
(note-heads (if (not (null? first-stem))
|
|
209
|
+
(ly:grob-object first-stem 'note-heads)
|
|
210
|
+
'()))
|
|
211
|
+
(note-heads-grobs (if (not (null? note-heads))
|
|
212
|
+
(ly:grob-array->list note-heads)
|
|
213
|
+
'()))
|
|
214
|
+
(first-note-head (if (not (null? note-heads-grobs))
|
|
215
|
+
(car note-heads-grobs)
|
|
216
|
+
'()))
|
|
217
|
+
(next-stem (if (not (null? stems))
|
|
218
|
+
(cadr stems-grobs)
|
|
219
|
+
'()))
|
|
220
|
+
(next-note-heads (if (not (null? next-stem))
|
|
221
|
+
(ly:grob-object next-stem 'note-heads)
|
|
222
|
+
'()))
|
|
223
|
+
(next-note-heads-grobs (if (not (null? next-note-heads))
|
|
224
|
+
(ly:grob-array->list next-note-heads)
|
|
225
|
+
'()))
|
|
226
|
+
(next-note-head (if (not (null? next-note-heads-grobs))
|
|
227
|
+
(car next-note-heads-grobs)
|
|
228
|
+
'()))
|
|
229
|
+
(left-pos (ly:grob-property first-note-head 'Y-offset))
|
|
230
|
+
(right-pos (ly:grob-property next-note-head 'Y-offset))
|
|
231
|
+
(direction (ly:grob-property grob 'direction))
|
|
232
|
+
(first-nh-height (ly:grob::stencil-height first-note-head))
|
|
233
|
+
(next-nh-height (ly:grob::stencil-height next-note-head))
|
|
234
|
+
(left-height (if (= direction DOWN)
|
|
235
|
+
(+ (car first-nh-height) 0.75)
|
|
236
|
+
(- (cdr first-nh-height) 0.75)))
|
|
237
|
+
(right-height (if (= direction DOWN)
|
|
238
|
+
(+ (car next-nh-height) 0.75)
|
|
239
|
+
(- (cdr next-nh-height) 0.75))))
|
|
240
|
+
(cons (+ left-pos left-height) (+ right-pos right-height))))
|
|
241
|
+
|
|
242
|
+
(define-public (beam::get-kievan-quantized-positions grob)
|
|
243
|
+
(let* ((pos (ly:grob-property grob 'positions))
|
|
244
|
+
(stems (ly:grob-object grob 'stems #f))
|
|
245
|
+
(stems-grobs (if stems
|
|
246
|
+
(ly:grob-array->list stems)
|
|
247
|
+
'())))
|
|
248
|
+
(for-each
|
|
249
|
+
(lambda (g)
|
|
250
|
+
(ly:grob-set-property! g 'stem-begin-position 0)
|
|
251
|
+
(ly:grob-set-property! g 'length 0))
|
|
252
|
+
stems-grobs)
|
|
253
|
+
pos))
|
|
254
|
+
|
|
255
|
+
;; calculates each slope of a broken beam individually
|
|
256
|
+
(define-public (beam::place-broken-parts-individually grob)
|
|
257
|
+
(ly:beam::quanting grob '(+inf.0 . -inf.0) #f))
|
|
258
|
+
|
|
259
|
+
;; calculates the slope of a beam as a single unit,
|
|
260
|
+
;; even if it is broken. this assures that the beam
|
|
261
|
+
;; will pick up where it left off after a line break
|
|
262
|
+
(define-public (beam::align-with-broken-parts grob)
|
|
263
|
+
(ly:beam::quanting grob '(+inf.0 . -inf.0) #t))
|
|
264
|
+
|
|
265
|
+
;; uses the broken beam style from edition peters combines the
|
|
266
|
+
;; values of place-broken-parts-individually and align-with-broken-parts above,
|
|
267
|
+
;; favoring place-broken-parts-individually when the beam naturally has a steeper
|
|
268
|
+
;; incline and align-with-broken-parts when the beam is flat
|
|
269
|
+
(define-public (beam::slope-like-broken-parts grob)
|
|
270
|
+
(define (slope y x)
|
|
271
|
+
(/ (- (cdr y) (car y)) (- (cdr x) (car x))))
|
|
272
|
+
(let* ((quant1 (ly:beam::quanting grob '(+inf.0 . -inf.0) #t))
|
|
273
|
+
(original (ly:grob-original grob))
|
|
274
|
+
(siblings (if (ly:grob? original)
|
|
275
|
+
(ly:spanner-broken-into original)
|
|
276
|
+
'())))
|
|
277
|
+
(if (null? siblings)
|
|
278
|
+
quant1
|
|
279
|
+
(let* ((quant2 (ly:beam::quanting grob '(+inf.0 . -inf.0) #f))
|
|
280
|
+
(x-span (ly:grob-property grob 'X-positions))
|
|
281
|
+
(slope1 (slope quant1 x-span))
|
|
282
|
+
(slope2 (slope quant2 x-span))
|
|
283
|
+
(quant2 (if (not (= (sign slope1) (sign slope2)))
|
|
284
|
+
'(0 . 0)
|
|
285
|
+
quant2))
|
|
286
|
+
(factor (/ (atan (abs slope1)) PI-OVER-TWO))
|
|
287
|
+
(base (offset-add
|
|
288
|
+
(offset-scale quant1 (- 1 factor))
|
|
289
|
+
(offset-scale quant2 factor))))
|
|
290
|
+
(ly:beam::quanting grob base #f)))))
|
|
291
|
+
|
|
292
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
293
|
+
;; cross-staff stuff
|
|
294
|
+
|
|
295
|
+
(define-public (script-or-side-position-cross-staff g)
|
|
296
|
+
(or
|
|
297
|
+
(ly:script-interface::calc-cross-staff g)
|
|
298
|
+
(ly:side-position-interface::calc-cross-staff g)))
|
|
299
|
+
|
|
300
|
+
|
|
301
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
302
|
+
;; side-position stuff
|
|
303
|
+
|
|
304
|
+
(define-public (only-if-beamed g)
|
|
305
|
+
(any (lambda (x) (ly:grob? (ly:grob-object x 'beam)))
|
|
306
|
+
(ly:grob-array->list (ly:grob-object g 'side-support-elements))))
|
|
307
|
+
|
|
308
|
+
(define-public side-position-interface::y-aligned-side
|
|
309
|
+
(ly:make-unpure-pure-container
|
|
310
|
+
ly:side-position-interface::y-aligned-side
|
|
311
|
+
ly:side-position-interface::pure-y-aligned-side))
|
|
312
|
+
|
|
313
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
314
|
+
;; break-alignable stuff
|
|
315
|
+
|
|
316
|
+
(define-public (break-alignable-interface::self-alignment-of-anchor g)
|
|
317
|
+
"Return a value for @var{g}'s @code{self-alignment-X} that will
|
|
318
|
+
place @var{g} on the same side of the reference point defined by a
|
|
319
|
+
@code{break-aligned} item such as a @code{Clef}."
|
|
320
|
+
(let ((parent (ly:break-alignable-interface::find-parent g)))
|
|
321
|
+
(if (ly:grob? parent)
|
|
322
|
+
(ly:grob-property parent 'break-align-anchor-alignment CENTER)
|
|
323
|
+
CENTER)))
|
|
324
|
+
|
|
325
|
+
(define-public (break-alignable-interface::self-alignment-opposite-of-anchor g)
|
|
326
|
+
"Return a value for @var{g}'s @code{self-alignment-X} that will
|
|
327
|
+
place @var{g} on the opposite side of the reference point defined by a
|
|
328
|
+
@code{break-aligned} item such as a @code{Clef}."
|
|
329
|
+
(* -1 (break-alignable-interface::self-alignment-of-anchor g)))
|
|
330
|
+
|
|
331
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
332
|
+
;; self-alignment stuff
|
|
333
|
+
|
|
334
|
+
(define-public self-alignment-interface::y-aligned-on-self
|
|
335
|
+
(ly:make-unpure-pure-container
|
|
336
|
+
ly:self-alignment-interface::y-aligned-on-self
|
|
337
|
+
ly:self-alignment-interface::pure-y-aligned-on-self))
|
|
338
|
+
|
|
339
|
+
(define-public (self-alignment-interface::self-aligned-on-breakable grob)
|
|
340
|
+
"Return the @code{X-offset} that places @var{grob} according to its
|
|
341
|
+
@code{self-alignment-X} over the reference point defined by the
|
|
342
|
+
@code{break-align-anchor-alignment} of a @code{break-aligned} item
|
|
343
|
+
such as a @code{Clef}."
|
|
344
|
+
(+ (ly:break-alignable-interface::self-align-callback grob)
|
|
345
|
+
(ly:self-alignment-interface::x-aligned-on-self grob)))
|
|
346
|
+
|
|
347
|
+
(define-public (break-alignment-list end-of-line middle begin-of-line)
|
|
348
|
+
"Return a callback that calculates a value based on a grob's break
|
|
349
|
+
direction."
|
|
350
|
+
(lambda (grob)
|
|
351
|
+
(let ((rval (case (ly:item-break-dir grob)
|
|
352
|
+
((1) begin-of-line)
|
|
353
|
+
((0) middle)
|
|
354
|
+
((-1) end-of-line))))
|
|
355
|
+
(if (procedure? rval)
|
|
356
|
+
(rval grob)
|
|
357
|
+
rval))))
|
|
358
|
+
|
|
359
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
360
|
+
;; staff ellipsis
|
|
361
|
+
|
|
362
|
+
(define-public (staff-ellipsis::calc-y-extent grob)
|
|
363
|
+
"Callback for @code{StaffEllipsis} grob, which is used with
|
|
364
|
+
@code{skipTypesetting}."
|
|
365
|
+
(let* ((staff-symbol (ly:grob-object grob 'staff-symbol))
|
|
366
|
+
(staff-extent (if (ly:grob? staff-symbol)
|
|
367
|
+
(ly:grob-extent staff-symbol staff-symbol Y)
|
|
368
|
+
(cons 0 0))))
|
|
369
|
+
;; widen slightly to cover the outer staff lines even with rounding error
|
|
370
|
+
(interval-widen staff-extent 1/32)))
|
|
371
|
+
|
|
372
|
+
(define-public (staff-ellipsis::print grob)
|
|
373
|
+
"Callback for @code{StaffEllipsis} grob, which is used with
|
|
374
|
+
@code{skipTypesetting}."
|
|
375
|
+
(let ((text-sten (grob-interpret-markup grob (ly:grob-property grob 'text))))
|
|
376
|
+
(ly:make-stencil (ly:stencil-expr text-sten)
|
|
377
|
+
(ly:stencil-extent text-sten X)
|
|
378
|
+
(ly:grob-extent grob grob Y))))
|
|
379
|
+
|
|
380
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
381
|
+
;; staff symbol
|
|
382
|
+
|
|
383
|
+
(define-public staff-symbol-referencer::callback
|
|
384
|
+
(ly:make-unpure-pure-container ly:staff-symbol-referencer::callback))
|
|
385
|
+
|
|
386
|
+
(define-public (staff-symbol::calc-widened-extent grob)
|
|
387
|
+
(let* ((basic-staff-space (ly:staff-symbol-staff-space grob))
|
|
388
|
+
;; DOCME: unclear what this is for.
|
|
389
|
+
(staff-space (if (zero? basic-staff-space)
|
|
390
|
+
1.0
|
|
391
|
+
basic-staff-space))
|
|
392
|
+
(ext (ly:grob-extent grob grob Y)))
|
|
393
|
+
(if (< (interval-length ext)
|
|
394
|
+
(* staff-space 2))
|
|
395
|
+
;; Avoid bar lines shorter than two staff spaces.
|
|
396
|
+
;; (Gould seems to use 4 spaces, judging from her
|
|
397
|
+
;; examples.) Cope by extending the bar line by one
|
|
398
|
+
;; staff space in each direction.
|
|
399
|
+
(interval-widen ext staff-space)
|
|
400
|
+
ext)))
|
|
401
|
+
|
|
402
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
403
|
+
;; note heads
|
|
404
|
+
|
|
405
|
+
(define-public (stem::calc-duration-log grob)
|
|
406
|
+
(ly:duration-log
|
|
407
|
+
(ly:event-property (event-cause grob) 'duration)))
|
|
408
|
+
|
|
409
|
+
(define (stem-stub::do-calculations grob)
|
|
410
|
+
(and (ly:grob-property (ly:grob-parent grob X) 'cross-staff)
|
|
411
|
+
(not (ly:grob-property (ly:grob-parent grob X) 'transparent))))
|
|
412
|
+
|
|
413
|
+
(define-public (stem-stub::pure-height grob beg end)
|
|
414
|
+
(if (stem-stub::do-calculations grob)
|
|
415
|
+
'(0 . 0)
|
|
416
|
+
'(+inf.0 . -inf.0)))
|
|
417
|
+
|
|
418
|
+
(define-public (stem-stub::width grob)
|
|
419
|
+
(if (stem-stub::do-calculations grob)
|
|
420
|
+
(grob::x-parent-width grob)
|
|
421
|
+
'(+inf.0 . -inf.0)))
|
|
422
|
+
|
|
423
|
+
(define-public (stem-stub::extra-spacing-height grob)
|
|
424
|
+
(if (stem-stub::do-calculations grob)
|
|
425
|
+
(let* ((dad (ly:grob-parent grob X))
|
|
426
|
+
(refp (ly:grob-common-refpoint grob dad Y))
|
|
427
|
+
(stem_ph (ly:grob-pure-height dad refp 0 INFINITY-INT))
|
|
428
|
+
(my_ph (ly:grob-pure-height grob refp 0 INFINITY-INT))
|
|
429
|
+
;; only account for distance if stem is on different staff than stub
|
|
430
|
+
(dist (if (grob::has-interface refp 'hara-kiri-group-spanner-interface)
|
|
431
|
+
0
|
|
432
|
+
(- (car my_ph) (car stem_ph)))))
|
|
433
|
+
(if (interval-empty? (interval-intersection stem_ph my_ph)) #f (coord-translate stem_ph dist)))
|
|
434
|
+
#f))
|
|
435
|
+
|
|
436
|
+
(define-public (note-head::calc-kievan-duration-log grob)
|
|
437
|
+
(min 3
|
|
438
|
+
(ly:duration-log
|
|
439
|
+
(ly:event-property (event-cause grob) 'duration))))
|
|
440
|
+
|
|
441
|
+
(define-public (note-head::calc-duration-log grob)
|
|
442
|
+
(min 2
|
|
443
|
+
(ly:duration-log
|
|
444
|
+
(ly:event-property (event-cause grob) 'duration))))
|
|
445
|
+
|
|
446
|
+
(define-public (dots::calc-dot-count grob)
|
|
447
|
+
(ly:duration-dot-count
|
|
448
|
+
(ly:event-property (event-cause grob) 'duration)))
|
|
449
|
+
|
|
450
|
+
(define-public (dots::calc-staff-position grob)
|
|
451
|
+
(let* ((head (ly:grob-parent grob Y))
|
|
452
|
+
(log (ly:grob-property head 'duration-log)))
|
|
453
|
+
|
|
454
|
+
(if (or (not (grob::has-interface head 'rest-interface))
|
|
455
|
+
(not (integer? log)))
|
|
456
|
+
0
|
|
457
|
+
(case log
|
|
458
|
+
((0) -2)
|
|
459
|
+
((5 6) 2)
|
|
460
|
+
((7 8) 4)
|
|
461
|
+
((9 10) 6)
|
|
462
|
+
(else 0)))))
|
|
463
|
+
|
|
464
|
+
(define-public (dots::calc-glyph-name grob)
|
|
465
|
+
(let ((style (ly:grob-property grob 'style)))
|
|
466
|
+
(format #f "dots.dot~a"
|
|
467
|
+
(if (symbol? style)
|
|
468
|
+
(symbol->string style)
|
|
469
|
+
""))))
|
|
470
|
+
|
|
471
|
+
(define-public (dots::calc-dot-stencil grob)
|
|
472
|
+
(let* ((font (ly:grob-default-font grob))
|
|
473
|
+
(name (ly:grob-property grob 'glyph-name))
|
|
474
|
+
(stencil (ly:font-get-glyph font name)))
|
|
475
|
+
(if (ly:stencil-empty? stencil)
|
|
476
|
+
(begin
|
|
477
|
+
(ly:grob-warning grob
|
|
478
|
+
#f
|
|
479
|
+
(G_ "dot glyph ~s not found")
|
|
480
|
+
name)
|
|
481
|
+
point-stencil)
|
|
482
|
+
stencil)))
|
|
483
|
+
|
|
484
|
+
(define-public (ly:dots::print grob)
|
|
485
|
+
(let* ((dot-stencil (ly:grob-property grob 'dot-stencil))
|
|
486
|
+
(padding (interval-length (ly:stencil-extent dot-stencil X)))
|
|
487
|
+
(count (ly:grob-property grob 'dot-count 0)))
|
|
488
|
+
(stack-stencils X RIGHT padding (make-list count dot-stencil))))
|
|
489
|
+
|
|
490
|
+
(define-public (dot-column-interface::pad-by-one-dot-width grob)
|
|
491
|
+
;; The default for padding dots is to pad by the width of one dot exactly
|
|
492
|
+
;; (this width depends on the dot style used). We do a little better than
|
|
493
|
+
;; assuming all dots have the same width by taking the max of all widths.
|
|
494
|
+
(apply max
|
|
495
|
+
(map
|
|
496
|
+
(lambda (d)
|
|
497
|
+
(if (grob::is-live? d)
|
|
498
|
+
(let* ((dot-stencil (ly:grob-property d 'dot-stencil))
|
|
499
|
+
(ext (ly:stencil-extent dot-stencil X)))
|
|
500
|
+
(interval-length ext))
|
|
501
|
+
0.0))
|
|
502
|
+
(ly:grob-array->list (ly:grob-object grob 'dots)))))
|
|
503
|
+
|
|
504
|
+
;; Kept separate from note-head::calc-glyph-name to allow use by
|
|
505
|
+
;; markup commands \note and \note-by-number
|
|
506
|
+
(define-public (select-head-glyph style log)
|
|
507
|
+
"Select a note head glyph string based on note head style @var{style}
|
|
508
|
+
and duration log @var{log}."
|
|
509
|
+
(if (symbol? style)
|
|
510
|
+
(case style
|
|
511
|
+
;; "default" style is directly handled in note-head.cc as a
|
|
512
|
+
;; special case (HW says, mainly for performance reasons).
|
|
513
|
+
;; Therefore, style "default" does not appear in this case
|
|
514
|
+
;; statement. -- jr
|
|
515
|
+
;; Though we not to care if style is '(), see below. -- harm
|
|
516
|
+
((xcircle) "2xcircle")
|
|
517
|
+
((harmonic) "0harmonic")
|
|
518
|
+
((harmonic-black) "2harmonic")
|
|
519
|
+
((harmonic-mixed) (if (<= log 1) "0harmonic"
|
|
520
|
+
"2harmonic"))
|
|
521
|
+
((baroque)
|
|
522
|
+
;; Oops, I actually would not call this "baroque", but, for
|
|
523
|
+
;; backwards compatibility to 1.4, this is supposed to take
|
|
524
|
+
;; brevis, longa and maxima from the neo-mensural font and all
|
|
525
|
+
;; other note heads from the default font. -- jr
|
|
526
|
+
(if (< log 0)
|
|
527
|
+
(string-append (number->string log) "neomensural")
|
|
528
|
+
(number->string log)))
|
|
529
|
+
((altdefault)
|
|
530
|
+
;; Like default, but brevis is drawn with double vertical lines
|
|
531
|
+
(if (= log -1)
|
|
532
|
+
(string-append (number->string log) "double")
|
|
533
|
+
(number->string log)))
|
|
534
|
+
((mensural)
|
|
535
|
+
(string-append (number->string log) (symbol->string style)))
|
|
536
|
+
((petrucci)
|
|
537
|
+
(if (< log 0)
|
|
538
|
+
(string-append (number->string log) "mensural")
|
|
539
|
+
(string-append (number->string log) (symbol->string style))))
|
|
540
|
+
((blackpetrucci)
|
|
541
|
+
(if (< log 0)
|
|
542
|
+
(string-append (number->string log) "blackmensural")
|
|
543
|
+
(string-append (number->string log) (symbol->string style))))
|
|
544
|
+
((semipetrucci)
|
|
545
|
+
(if (< log 0)
|
|
546
|
+
(string-append (number->string log) "semimensural")
|
|
547
|
+
(string-append (number->string log) "petrucci")))
|
|
548
|
+
((neomensural)
|
|
549
|
+
(string-append (number->string log) (symbol->string style)))
|
|
550
|
+
((kievan)
|
|
551
|
+
(string-append (number->string log) "kievan"))
|
|
552
|
+
(else
|
|
553
|
+
(if (string-match "vaticana*|hufnagel*|medicaea*"
|
|
554
|
+
(symbol->string style))
|
|
555
|
+
(symbol->string style)
|
|
556
|
+
(string-append (number->string (max 0 log))
|
|
557
|
+
(symbol->string style)))))
|
|
558
|
+
;; 'vaticana-ligature-interface has a 'glyph-name-property for NoteHead.
|
|
559
|
+
;; Probably best to return an empty list here, if called in a context
|
|
560
|
+
;; without setting 'style, i.e. 'style is '(), to avoid a scheme-error.
|
|
561
|
+
'()))
|
|
562
|
+
|
|
563
|
+
(define-public (note-head::calc-glyph-name grob)
|
|
564
|
+
(let* ((style (ly:grob-property grob 'style))
|
|
565
|
+
(log (min (if (eq? 'kievan style) 3 2) (ly:grob-property grob 'duration-log))))
|
|
566
|
+
(select-head-glyph style log)))
|
|
567
|
+
|
|
568
|
+
(define-public (note-head::brew-ez-stencil grob)
|
|
569
|
+
(let* ((log (ly:grob-property grob 'duration-log))
|
|
570
|
+
(pitch (ly:event-property (event-cause grob) 'pitch))
|
|
571
|
+
(pitch-index (ly:pitch-notename pitch))
|
|
572
|
+
(note-names (ly:grob-property grob 'note-names))
|
|
573
|
+
(pitch-string (if (and (vector? note-names)
|
|
574
|
+
(> (vector-length note-names) pitch-index))
|
|
575
|
+
(vector-ref note-names pitch-index)
|
|
576
|
+
(string
|
|
577
|
+
(integer->char
|
|
578
|
+
(+ (modulo (+ pitch-index 2) 7)
|
|
579
|
+
(char->integer #\A))))))
|
|
580
|
+
(staff-space (ly:staff-symbol-staff-space grob))
|
|
581
|
+
(line-thickness (ly:staff-symbol-line-thickness grob))
|
|
582
|
+
(stem (ly:grob-object grob 'stem #f))
|
|
583
|
+
(stem-thickness (* (if stem
|
|
584
|
+
(ly:grob-property stem 'thickness)
|
|
585
|
+
1.3)
|
|
586
|
+
line-thickness))
|
|
587
|
+
(font-size (ly:grob-property grob 'font-size 0))
|
|
588
|
+
(radius (* (magstep font-size) (/ (+ staff-space line-thickness) 2)))
|
|
589
|
+
(letter (make-fontsize-markup
|
|
590
|
+
-8
|
|
591
|
+
(make-center-align-markup (make-vcenter-markup pitch-string))))
|
|
592
|
+
(filled-circle (make-draw-circle-markup radius 0 #t)))
|
|
593
|
+
|
|
594
|
+
(ly:stencil-translate-axis
|
|
595
|
+
(grob-interpret-markup
|
|
596
|
+
grob
|
|
597
|
+
(if (>= log 2)
|
|
598
|
+
(make-combine-markup
|
|
599
|
+
filled-circle
|
|
600
|
+
(make-with-color-markup white letter))
|
|
601
|
+
(make-combine-markup
|
|
602
|
+
(make-combine-markup
|
|
603
|
+
filled-circle
|
|
604
|
+
(make-with-color-markup white (make-draw-circle-markup
|
|
605
|
+
(- radius stem-thickness) 0 #t)))
|
|
606
|
+
letter)))
|
|
607
|
+
radius X)))
|
|
608
|
+
|
|
609
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
610
|
+
;; clipping
|
|
611
|
+
|
|
612
|
+
(define-public (make-rhythmic-location bar-num num den)
|
|
613
|
+
(cons
|
|
614
|
+
bar-num (ly:make-moment num den)))
|
|
615
|
+
|
|
616
|
+
(define-public (rhythmic-location? a)
|
|
617
|
+
(and (pair? a)
|
|
618
|
+
(integer? (car a))
|
|
619
|
+
(ly:moment? (cdr a))))
|
|
620
|
+
|
|
621
|
+
(define-public (make-graceless-rhythmic-location loc)
|
|
622
|
+
(make-rhythmic-location
|
|
623
|
+
(car loc)
|
|
624
|
+
(ly:moment-main-numerator (rhythmic-location-measure-position loc))
|
|
625
|
+
(ly:moment-main-denominator (rhythmic-location-measure-position loc))))
|
|
626
|
+
|
|
627
|
+
(define-public rhythmic-location-measure-position cdr)
|
|
628
|
+
(define-public rhythmic-location-bar-number car)
|
|
629
|
+
|
|
630
|
+
(define-public (rhythmic-location<? a b)
|
|
631
|
+
(cond
|
|
632
|
+
((< (car a) (car b)) #t)
|
|
633
|
+
((> (car a) (car b)) #f)
|
|
634
|
+
(else
|
|
635
|
+
(ly:moment<? (cdr a) (cdr b)))))
|
|
636
|
+
|
|
637
|
+
(define-public (rhythmic-location<=? a b)
|
|
638
|
+
(not (rhythmic-location<? b a)))
|
|
639
|
+
(define-public (rhythmic-location>=? a b)
|
|
640
|
+
(not (rhythmic-location<? a b)))
|
|
641
|
+
(define-public (rhythmic-location>? a b)
|
|
642
|
+
(rhythmic-location<? b a))
|
|
643
|
+
|
|
644
|
+
(define-public (rhythmic-location=? a b)
|
|
645
|
+
(and (rhythmic-location<=? a b)
|
|
646
|
+
(rhythmic-location<=? b a)))
|
|
647
|
+
|
|
648
|
+
(define-public (rhythmic-location->file-string a)
|
|
649
|
+
(format #f "~a.~a.~a"
|
|
650
|
+
(car a)
|
|
651
|
+
(ly:moment-main-numerator (cdr a))
|
|
652
|
+
(ly:moment-main-denominator (cdr a))))
|
|
653
|
+
|
|
654
|
+
(define-public (rhythmic-location->string a)
|
|
655
|
+
(format #f "bar ~a ~a"
|
|
656
|
+
(car a)
|
|
657
|
+
(ly:moment->string (cdr a))))
|
|
658
|
+
|
|
659
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
660
|
+
;; break visibility
|
|
661
|
+
|
|
662
|
+
(define-public all-visible #(#t #t #t))
|
|
663
|
+
(define-public begin-of-line-invisible #(#t #t #f))
|
|
664
|
+
(define-public center-invisible #(#t #f #t))
|
|
665
|
+
(define-public end-of-line-invisible #(#f #t #t))
|
|
666
|
+
(define-public begin-of-line-visible #(#f #f #t))
|
|
667
|
+
(define-public center-visible #(#f #t #f))
|
|
668
|
+
(define-public end-of-line-visible #(#t #f #f))
|
|
669
|
+
(define-public all-invisible #(#f #f #f))
|
|
670
|
+
|
|
671
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
672
|
+
;; a generic extra-spacing-height routine
|
|
673
|
+
|
|
674
|
+
(define-public (item::extra-spacing-height-including-staff grob)
|
|
675
|
+
"Return a value for @code{extra-spacing-height} that augments the
|
|
676
|
+
extent of the grob to the extent of the staff."
|
|
677
|
+
(let ((staff-symbol (ly:grob-object grob 'staff-symbol #f)))
|
|
678
|
+
(if staff-symbol
|
|
679
|
+
(let* ((common (ly:grob-common-refpoint grob staff-symbol Y))
|
|
680
|
+
(my-ext (ly:grob-extent grob common Y))
|
|
681
|
+
(staff-ext (ly:grob-extent staff-symbol common Y))
|
|
682
|
+
(to-staff (pair-map - staff-ext my-ext)))
|
|
683
|
+
(pair-map (cons min max) '(0 . 0) to-staff))
|
|
684
|
+
'(0 . 0))))
|
|
685
|
+
|
|
686
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
687
|
+
;; neighbor-interface routines
|
|
688
|
+
|
|
689
|
+
|
|
690
|
+
(define-public (shift-right-at-line-begin g)
|
|
691
|
+
"Shift an item to the right, but only at the start of the line."
|
|
692
|
+
(if (and (ly:item? g)
|
|
693
|
+
(equal? (ly:item-break-dir g) RIGHT))
|
|
694
|
+
(ly:grob-translate-axis! g 3.5 X)))
|
|
695
|
+
|
|
696
|
+
(define-public (pure-from-neighbor-interface::extra-spacing-height-at-beginning-of-line grob)
|
|
697
|
+
(if (= 1 (ly:item-break-dir grob))
|
|
698
|
+
(pure-from-neighbor-interface::extra-spacing-height grob)
|
|
699
|
+
(cons -0.1 0.1)))
|
|
700
|
+
|
|
701
|
+
(define-public (pure-from-neighbor-interface::extra-spacing-height grob)
|
|
702
|
+
(let* ((height (ly:grob-pure-height grob grob 0 INFINITY-INT))
|
|
703
|
+
(from-neighbors (interval-union
|
|
704
|
+
height
|
|
705
|
+
(ly:axis-group-interface::pure-height
|
|
706
|
+
grob
|
|
707
|
+
0
|
|
708
|
+
INFINITY-INT))))
|
|
709
|
+
(pair-map - from-neighbors height)))
|
|
710
|
+
|
|
711
|
+
;; If there are neighbors, we place the height at their midpoint
|
|
712
|
+
;; to avoid protrusion of this pure height out of the vertical
|
|
713
|
+
;; axis group on either side. This will minimize the impact of the
|
|
714
|
+
;; grob on pure minimum translations.
|
|
715
|
+
|
|
716
|
+
;; TODO - there is a double call to axis-group-interface::pure-height
|
|
717
|
+
;; here and then in the extra-spacing-height function above. Can/should this
|
|
718
|
+
;; be rolled into one?
|
|
719
|
+
(define-public (pure-from-neighbor-interface::pure-height grob beg end)
|
|
720
|
+
(let* ((height (ly:axis-group-interface::pure-height
|
|
721
|
+
grob
|
|
722
|
+
0
|
|
723
|
+
INFINITY-INT))
|
|
724
|
+
(c (interval-center height)))
|
|
725
|
+
(if (interval-empty? height) empty-interval (cons c c))))
|
|
726
|
+
|
|
727
|
+
;; Minimizes the impact of the height on vertical spacing while allowing
|
|
728
|
+
;; it to appear in horizontal skylines of paper columns if necessary.
|
|
729
|
+
(define-public pure-from-neighbor-interface::height-if-pure
|
|
730
|
+
(ly:make-unpure-pure-container #f pure-from-neighbor-interface::pure-height))
|
|
731
|
+
|
|
732
|
+
(define-public (pure-from-neighbor-interface::account-for-span-bar grob)
|
|
733
|
+
(let* ((esh (pure-from-neighbor-interface::extra-spacing-height grob))
|
|
734
|
+
(hsb (ly:grob-object grob 'has-span-bar))
|
|
735
|
+
(ii (interval-intersection esh (cons -1.01 1.01))))
|
|
736
|
+
(if (pair? hsb)
|
|
737
|
+
(cons (car (if (and (car hsb)
|
|
738
|
+
(ly:grob-property grob 'allow-span-bar))
|
|
739
|
+
esh ii))
|
|
740
|
+
(cdr (if (cdr hsb) esh ii)))
|
|
741
|
+
ii)))
|
|
742
|
+
|
|
743
|
+
(define-public (pure-from-neighbor-interface::extra-spacing-height-including-staff grob)
|
|
744
|
+
(pair-map (cons min max)
|
|
745
|
+
(pure-from-neighbor-interface::extra-spacing-height grob)
|
|
746
|
+
(item::extra-spacing-height-including-staff grob)))
|
|
747
|
+
|
|
748
|
+
|
|
749
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
750
|
+
;; Tuplets
|
|
751
|
+
|
|
752
|
+
(define-public (tuplet-number::calc-direction grob)
|
|
753
|
+
(ly:tuplet-bracket::calc-direction (ly:grob-object grob 'bracket)))
|
|
754
|
+
|
|
755
|
+
(define-public (tuplet-number::calc-denominator-text grob)
|
|
756
|
+
(number->string (ly:event-property (event-cause grob) 'denominator)))
|
|
757
|
+
|
|
758
|
+
(define-public (tuplet-number::calc-fraction-text grob)
|
|
759
|
+
(let ((ev (event-cause grob)))
|
|
760
|
+
|
|
761
|
+
(format #f "~a:~a"
|
|
762
|
+
(ly:event-property ev 'denominator)
|
|
763
|
+
(ly:event-property ev 'numerator))))
|
|
764
|
+
|
|
765
|
+
;; a formatter function, which is simply a wrapper around an existing
|
|
766
|
+
;; tuplet formatter function. It takes the value returned by the given
|
|
767
|
+
;; function and appends a note of given length.
|
|
768
|
+
(define-public ((tuplet-number::append-note-wrapper function note) grob)
|
|
769
|
+
(let ((txt (and function (function grob))))
|
|
770
|
+
|
|
771
|
+
(if txt
|
|
772
|
+
(make-line-markup
|
|
773
|
+
(list txt (make-fontsize-markup -5 (make-note-markup note UP))))
|
|
774
|
+
(make-fontsize-markup -5 (make-note-markup note UP)))))
|
|
775
|
+
|
|
776
|
+
;; Print a tuplet denominator with a different number than the one derived from
|
|
777
|
+
;; the actual tuplet fraction
|
|
778
|
+
(define-public ((tuplet-number::non-default-tuplet-denominator-text denominator)
|
|
779
|
+
grob)
|
|
780
|
+
(number->string (if denominator
|
|
781
|
+
denominator
|
|
782
|
+
(ly:event-property (event-cause grob) 'denominator))))
|
|
783
|
+
|
|
784
|
+
;; Print a tuplet fraction with different numbers than the ones derived from
|
|
785
|
+
;; the actual tuplet fraction
|
|
786
|
+
(define-public ((tuplet-number::non-default-tuplet-fraction-text
|
|
787
|
+
denominator numerator) grob)
|
|
788
|
+
(let* ((ev (event-cause grob))
|
|
789
|
+
(den (if denominator denominator (ly:event-property ev 'denominator)))
|
|
790
|
+
(num (if numerator numerator (ly:event-property ev 'numerator))))
|
|
791
|
+
|
|
792
|
+
(format #f "~a:~a" den num)))
|
|
793
|
+
|
|
794
|
+
;; Print a tuplet fraction with note durations appended to the numerator and the
|
|
795
|
+
;; denominator
|
|
796
|
+
(define-public ((tuplet-number::fraction-with-notes
|
|
797
|
+
denominatornote numeratornote) grob)
|
|
798
|
+
(let* ((ev (event-cause grob))
|
|
799
|
+
(denominator (ly:event-property ev 'denominator))
|
|
800
|
+
(numerator (ly:event-property ev 'numerator)))
|
|
801
|
+
|
|
802
|
+
((tuplet-number::non-default-fraction-with-notes
|
|
803
|
+
denominator denominatornote numerator numeratornote) grob)))
|
|
804
|
+
|
|
805
|
+
;; Print a tuplet fraction with note durations appended to the numerator and the
|
|
806
|
+
;; denominator
|
|
807
|
+
(define-public ((tuplet-number::non-default-fraction-with-notes
|
|
808
|
+
denominator denominatornote numerator numeratornote) grob)
|
|
809
|
+
(let* ((ev (event-cause grob))
|
|
810
|
+
(den (if denominator denominator (ly:event-property ev 'denominator)))
|
|
811
|
+
(num (if numerator numerator (ly:event-property ev 'numerator))))
|
|
812
|
+
|
|
813
|
+
(make-concat-markup (list
|
|
814
|
+
(make-simple-markup (format #f "~a" den))
|
|
815
|
+
(make-fontsize-markup -5 (make-note-markup denominatornote UP))
|
|
816
|
+
(make-simple-markup " : ")
|
|
817
|
+
(make-simple-markup (format #f "~a" num))
|
|
818
|
+
(make-fontsize-markup -5 (make-note-markup numeratornote UP))))))
|
|
819
|
+
|
|
820
|
+
|
|
821
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
822
|
+
;; Color
|
|
823
|
+
|
|
824
|
+
(define-public (color? x)
|
|
825
|
+
(or
|
|
826
|
+
(string? x)
|
|
827
|
+
(and (list? x)
|
|
828
|
+
(let ((l (length x)))
|
|
829
|
+
(or (= 3 l)
|
|
830
|
+
(= 4 l)))
|
|
831
|
+
(every number? x)
|
|
832
|
+
(every (lambda (y) (<= 0 y 1)) x))))
|
|
833
|
+
|
|
834
|
+
(define*-public (rgb-color r g b #:optional (a #f))
|
|
835
|
+
(if a
|
|
836
|
+
(list r g b a)
|
|
837
|
+
(list r g b)))
|
|
838
|
+
|
|
839
|
+
;; predefined colors
|
|
840
|
+
(define-public black '(0.0 0.0 0.0))
|
|
841
|
+
(define-public white '(1.0 1.0 1.0))
|
|
842
|
+
(define-public red '(1.0 0.0 0.0))
|
|
843
|
+
(define-public green '(0.0 1.0 0.0))
|
|
844
|
+
(define-public blue '(0.0 0.0 1.0))
|
|
845
|
+
(define-public cyan '(0.0 1.0 1.0))
|
|
846
|
+
(define-public magenta '(1.0 0.0 1.0))
|
|
847
|
+
(define-public yellow '(1.0 1.0 0.0))
|
|
848
|
+
|
|
849
|
+
(define-public grey '(0.5 0.5 0.5))
|
|
850
|
+
(define-public darkred '(0.5 0.0 0.0))
|
|
851
|
+
(define-public darkgreen '(0.0 0.5 0.0))
|
|
852
|
+
(define-public darkblue '(0.0 0.0 0.5))
|
|
853
|
+
(define-public darkcyan '(0.0 0.5 0.5))
|
|
854
|
+
(define-public darkmagenta '(0.5 0.0 0.5))
|
|
855
|
+
(define-public darkyellow '(0.5 0.5 0.0))
|
|
856
|
+
|
|
857
|
+
|
|
858
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
859
|
+
;; key signature
|
|
860
|
+
|
|
861
|
+
(define-public (key-signature-interface::alteration-positions
|
|
862
|
+
entry c0-position grob)
|
|
863
|
+
(let ((step (car entry))
|
|
864
|
+
(alter (cdr entry)))
|
|
865
|
+
(if (pair? step)
|
|
866
|
+
(list (+ (cdr step) (* (car step) 7) c0-position))
|
|
867
|
+
(let* ((c-position (modulo c0-position 7))
|
|
868
|
+
(positions
|
|
869
|
+
(if (< alter 0)
|
|
870
|
+
;; See (flat|sharp)-positions in define-grob-properties.scm
|
|
871
|
+
(ly:grob-property grob 'flat-positions '(3))
|
|
872
|
+
(ly:grob-property grob 'sharp-positions '(3))))
|
|
873
|
+
(p (list-ref positions
|
|
874
|
+
(if (< c-position (length positions))
|
|
875
|
+
c-position 0)))
|
|
876
|
+
(max-position (if (pair? p) (cdr p) p))
|
|
877
|
+
(min-position (if (pair? p) (car p) (- max-position 6)))
|
|
878
|
+
(first-position (+ (modulo (- (+ c-position step)
|
|
879
|
+
min-position)
|
|
880
|
+
7)
|
|
881
|
+
min-position)))
|
|
882
|
+
(define (prepend x l) (if (> x max-position)
|
|
883
|
+
l
|
|
884
|
+
(prepend (+ x 7) (cons x l))))
|
|
885
|
+
(prepend first-position '())))))
|
|
886
|
+
|
|
887
|
+
(define-public (key-signature-interface::alteration-position
|
|
888
|
+
step alter c0-position)
|
|
889
|
+
;; Deprecated. Not a documented interface, and no longer used in LilyPond,
|
|
890
|
+
;; but needed for a popular file, LilyJAZZ.ily for version 2.16
|
|
891
|
+
(if (pair? step)
|
|
892
|
+
(+ (cdr step) (* (car step) 7) c0-position)
|
|
893
|
+
(let* ((c-pos (modulo c0-position 7))
|
|
894
|
+
(hi (list-ref
|
|
895
|
+
(if (< alter 0)
|
|
896
|
+
'(2 3 4 2 1 2 1) ; position of highest flat
|
|
897
|
+
'(4 5 4 2 3 2 3)); position of highest sharp
|
|
898
|
+
c-pos)))
|
|
899
|
+
(- hi (modulo (- hi (+ c-pos step)) 7)))))
|
|
900
|
+
|
|
901
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
902
|
+
;; annotations
|
|
903
|
+
|
|
904
|
+
(define-public (numbered-footnotes int)
|
|
905
|
+
(make-tiny-markup (number->string (+ 1 int))))
|
|
906
|
+
|
|
907
|
+
(define-public (symbol-footnotes int)
|
|
908
|
+
(define (helper symbols out idx n)
|
|
909
|
+
(if (< n 1)
|
|
910
|
+
out
|
|
911
|
+
(helper symbols
|
|
912
|
+
(string-append out (list-ref symbols idx))
|
|
913
|
+
idx
|
|
914
|
+
(- n 1))))
|
|
915
|
+
(make-tiny-markup (helper '("*" "†" "‡" "§" "¶")
|
|
916
|
+
""
|
|
917
|
+
(remainder int 5)
|
|
918
|
+
(+ 1 (quotient int 5)))))
|
|
919
|
+
|
|
920
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
921
|
+
;; accidentals
|
|
922
|
+
|
|
923
|
+
(define-public (accidental-interface::calc-alteration grob)
|
|
924
|
+
(ly:pitch-alteration (ly:event-property (event-cause grob) 'pitch)))
|
|
925
|
+
|
|
926
|
+
(define-public (accidental-interface::calc-glyph-name grob)
|
|
927
|
+
(let* ((alteration (ly:grob-property grob 'alteration))
|
|
928
|
+
(layout (ly:grob-layout grob))
|
|
929
|
+
(defs (ly:output-def-lookup layout 'font-defaults '()))
|
|
930
|
+
(chain (ly:grob-alist-chain grob defs))
|
|
931
|
+
(alist (chain-assoc-get 'alteration-glyph-name-alist chain '()))
|
|
932
|
+
(glyph (assv-ref alist alteration)))
|
|
933
|
+
(or glyph
|
|
934
|
+
(begin
|
|
935
|
+
(ly:warning (G_ "no glyph name for alteration ~a in \
|
|
936
|
+
alteration-glyph-name-alist; try defining one in alterationGlyphs")
|
|
937
|
+
alteration)
|
|
938
|
+
"noteheads.s1cross"))))
|
|
939
|
+
|
|
940
|
+
(define-public accidental-interface::height
|
|
941
|
+
(ly:make-unpure-pure-container
|
|
942
|
+
ly:accidental-interface::height))
|
|
943
|
+
|
|
944
|
+
(define-public standard-alteration-glyph-name-alist
|
|
945
|
+
'(
|
|
946
|
+
;; ordered for optimal performance.
|
|
947
|
+
(0 . "accidentals.natural")
|
|
948
|
+
(-1/2 . "accidentals.flat")
|
|
949
|
+
(1/2 . "accidentals.sharp")
|
|
950
|
+
|
|
951
|
+
(1 . "accidentals.doublesharp")
|
|
952
|
+
(-1 . "accidentals.flatflat")
|
|
953
|
+
|
|
954
|
+
(3/4 . "accidentals.sharp.slashslash.stemstemstem")
|
|
955
|
+
(1/4 . "accidentals.sharp.slashslash.stem")
|
|
956
|
+
(-1/4 . "accidentals.mirroredflat")
|
|
957
|
+
(-3/4 . "accidentals.mirroredflat.flat")))
|
|
958
|
+
|
|
959
|
+
;; FIXME: standard vs default, alteration-FOO vs FOO-alteration
|
|
960
|
+
(define-public alteration-default-glyph-name-alist
|
|
961
|
+
standard-alteration-glyph-name-alist)
|
|
962
|
+
|
|
963
|
+
(define-public makam-alteration-glyph-name-alist
|
|
964
|
+
'((1 . "accidentals.doublesharp")
|
|
965
|
+
(8/9 . "accidentals.sharp.slashslashslash.stemstem")
|
|
966
|
+
(5/9 . "accidentals.sharp.slashslashslash.stem")
|
|
967
|
+
(4/9 . "accidentals.sharp")
|
|
968
|
+
(1/9 . "accidentals.sharp.slashslash.stem")
|
|
969
|
+
(0 . "accidentals.natural")
|
|
970
|
+
(-1/9 . "accidentals.mirroredflat")
|
|
971
|
+
(-4/9 . "accidentals.flat.slash")
|
|
972
|
+
(-5/9 . "accidentals.flat")
|
|
973
|
+
(-8/9 . "accidentals.flat.slashslash")
|
|
974
|
+
(-1 . "accidentals.flatflat")))
|
|
975
|
+
|
|
976
|
+
(define-public alteration-hufnagel-glyph-name-alist
|
|
977
|
+
'((-1/2 . "accidentals.hufnagelM1")
|
|
978
|
+
(0 . "accidentals.vaticana0")
|
|
979
|
+
(1/2 . "accidentals.mensural1")))
|
|
980
|
+
|
|
981
|
+
(define-public alteration-medicaea-glyph-name-alist
|
|
982
|
+
'((-1/2 . "accidentals.medicaeaM1")
|
|
983
|
+
(0 . "accidentals.vaticana0")
|
|
984
|
+
(1/2 . "accidentals.mensural1")))
|
|
985
|
+
|
|
986
|
+
(define-public alteration-vaticana-glyph-name-alist
|
|
987
|
+
'((-1/2 . "accidentals.vaticanaM1")
|
|
988
|
+
(0 . "accidentals.vaticana0")
|
|
989
|
+
(1/2 . "accidentals.mensural1")))
|
|
990
|
+
|
|
991
|
+
(define-public alteration-mensural-glyph-name-alist
|
|
992
|
+
'((-1/2 . "accidentals.mensuralM1")
|
|
993
|
+
(0 . "accidentals.vaticana0")
|
|
994
|
+
(1/2 . "accidentals.mensural1")))
|
|
995
|
+
|
|
996
|
+
(define-public alteration-kievan-glyph-name-alist
|
|
997
|
+
'((-1/2 . "accidentals.kievanM1")
|
|
998
|
+
(1/2 . "accidentals.kievan1")))
|
|
999
|
+
|
|
1000
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1001
|
+
;; * Pitch Trill Heads
|
|
1002
|
+
;; * Parentheses
|
|
1003
|
+
|
|
1004
|
+
(define-public (parentheses-interface::calc-parenthesis-stencils grob)
|
|
1005
|
+
(let* ((font (ly:grob-default-font grob))
|
|
1006
|
+
(lp (ly:font-get-glyph font "accidentals.leftparen"))
|
|
1007
|
+
(rp (ly:font-get-glyph font "accidentals.rightparen")))
|
|
1008
|
+
|
|
1009
|
+
(list lp rp)))
|
|
1010
|
+
|
|
1011
|
+
(define-public (parentheses-interface::calc-angled-bracket-stencils grob)
|
|
1012
|
+
(let* ((parent (ly:grob-parent grob Y))
|
|
1013
|
+
(y-extent (ly:grob-extent parent parent Y))
|
|
1014
|
+
(half-thickness 0.05) ; should it be a property?
|
|
1015
|
+
(width 0.5) ; should it be a property?
|
|
1016
|
+
(angularity 1.5) ; makes angle brackets
|
|
1017
|
+
(white-padding 0.1) ; should it be a property?
|
|
1018
|
+
(lp (ly:stencil-aligned-to
|
|
1019
|
+
(ly:stencil-aligned-to
|
|
1020
|
+
(make-parenthesis-stencil y-extent
|
|
1021
|
+
half-thickness
|
|
1022
|
+
width
|
|
1023
|
+
angularity
|
|
1024
|
+
-1)
|
|
1025
|
+
Y CENTER)
|
|
1026
|
+
X RIGHT))
|
|
1027
|
+
(lp-x-extent
|
|
1028
|
+
(interval-widen (ly:stencil-extent lp X) white-padding))
|
|
1029
|
+
(rp (ly:stencil-aligned-to
|
|
1030
|
+
(ly:stencil-aligned-to
|
|
1031
|
+
(make-parenthesis-stencil y-extent
|
|
1032
|
+
half-thickness
|
|
1033
|
+
width
|
|
1034
|
+
angularity
|
|
1035
|
+
1)
|
|
1036
|
+
Y CENTER)
|
|
1037
|
+
X LEFT))
|
|
1038
|
+
(rp-x-extent
|
|
1039
|
+
(interval-widen (ly:stencil-extent rp X) white-padding)))
|
|
1040
|
+
(set! lp (ly:make-stencil (ly:stencil-expr lp)
|
|
1041
|
+
lp-x-extent
|
|
1042
|
+
(ly:stencil-extent lp Y)))
|
|
1043
|
+
(set! rp (ly:make-stencil (ly:stencil-expr rp)
|
|
1044
|
+
rp-x-extent
|
|
1045
|
+
(ly:stencil-extent rp Y)))
|
|
1046
|
+
(list (stencil-whiteout-box lp)
|
|
1047
|
+
(stencil-whiteout-box rp))))
|
|
1048
|
+
|
|
1049
|
+
(define-public (parentheses-interface::y-extent grob) (ly:grob::stencil-height grob))
|
|
1050
|
+
|
|
1051
|
+
(define-public (parenthesize-elements grob)
|
|
1052
|
+
(let* ((elts (ly:grob-array->list (ly:grob-object grob 'elements)))
|
|
1053
|
+
(get-friends
|
|
1054
|
+
(lambda (g)
|
|
1055
|
+
(let ((syms (ly:grob-property g 'parenthesis-friends '()))
|
|
1056
|
+
(get-friend (lambda (s)
|
|
1057
|
+
(let ((f (ly:grob-object g s)))
|
|
1058
|
+
(cond
|
|
1059
|
+
((ly:grob? f) (list f))
|
|
1060
|
+
((ly:grob-array? f) (ly:grob-array->list f))
|
|
1061
|
+
(else '()))))))
|
|
1062
|
+
(apply append (map get-friend syms)))))
|
|
1063
|
+
(parenthesized-elts
|
|
1064
|
+
(ly:grob-list->grob-array
|
|
1065
|
+
(apply append elts (map get-friends elts))))
|
|
1066
|
+
(refp (ly:grob-common-refpoint-of-array grob parenthesized-elts X))
|
|
1067
|
+
(x-ext (ly:relative-group-extent parenthesized-elts refp X))
|
|
1068
|
+
(padding (ly:grob-property grob 'padding 0.1))
|
|
1069
|
+
(wide-ext (interval-widen x-ext padding))
|
|
1070
|
+
(my-x (ly:grob-relative-coordinate grob refp X))
|
|
1071
|
+
(parenthesis-positions (coord-translate wide-ext (- my-x)))
|
|
1072
|
+
(stencils (ly:grob-property grob 'stencils))
|
|
1073
|
+
(lp (car stencils))
|
|
1074
|
+
(rp (cadr stencils)))
|
|
1075
|
+
(ly:stencil-add
|
|
1076
|
+
(ly:stencil-translate-axis lp (interval-start parenthesis-positions) X)
|
|
1077
|
+
(ly:stencil-translate-axis rp (interval-end parenthesis-positions) X))))
|
|
1078
|
+
|
|
1079
|
+
(define-public (parentheses-interface::print grob)
|
|
1080
|
+
(let* ((y-parent (ly:grob-parent grob Y))
|
|
1081
|
+
;; The Y alignment is based on elements and not parenthesized-elements.
|
|
1082
|
+
;; We don't want the friends, or parenthesized notes with a flat would
|
|
1083
|
+
;; look bad.
|
|
1084
|
+
(elts (ly:grob-object grob 'elements))
|
|
1085
|
+
(refp (ly:grob-common-refpoint-of-array grob elts Y))
|
|
1086
|
+
(stencil (parenthesize-elements grob))
|
|
1087
|
+
(y-ext (ly:relative-group-extent elts refp Y))
|
|
1088
|
+
(y-center (interval-center y-ext))
|
|
1089
|
+
(my-y (ly:grob-relative-coordinate grob refp Y))
|
|
1090
|
+
(translation (- y-center my-y)))
|
|
1091
|
+
(ly:stencil-translate-axis stencil translation Y)))
|
|
1092
|
+
|
|
1093
|
+
|
|
1094
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1095
|
+
;; offset callbacks
|
|
1096
|
+
|
|
1097
|
+
(define-public (pure-chain-offset-callback grob start end prev-offset)
|
|
1098
|
+
"Sometimes, a chained offset callback is unpure and there is
|
|
1099
|
+
no way to write a pure function that estimates its behavior.
|
|
1100
|
+
In this case, we use a pure equivalent that will simply pass
|
|
1101
|
+
the previous calculated offset value."
|
|
1102
|
+
prev-offset)
|
|
1103
|
+
|
|
1104
|
+
(define-public (scale-by-font-size x)
|
|
1105
|
+
(ly:make-unpure-pure-container
|
|
1106
|
+
(lambda (grob)
|
|
1107
|
+
(* x (magstep (ly:grob-property grob 'font-size 0))))))
|
|
1108
|
+
|
|
1109
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1110
|
+
;;
|
|
1111
|
+
|
|
1112
|
+
(define-public (grob::compose-function func data)
|
|
1113
|
+
"Create a callback entity @var{func} to be stored in a grob property,
|
|
1114
|
+
based on the grob property data @var{data} (which can be plain data, a
|
|
1115
|
+
callback itself, or an unpure-pure container).
|
|
1116
|
+
|
|
1117
|
+
Function or unpure-pure container @var{func} accepts a grob and a
|
|
1118
|
+
value and returns another value. Depending on the type of @var{data},
|
|
1119
|
+
@var{func} is used for building a grob callback or an
|
|
1120
|
+
unpure-pure container."
|
|
1121
|
+
(if (or (ly:unpure-pure-container? func)
|
|
1122
|
+
(ly:unpure-pure-container? data))
|
|
1123
|
+
(ly:make-unpure-pure-container
|
|
1124
|
+
(lambda (grob) (ly:unpure-call func grob (ly:unpure-call data grob)))
|
|
1125
|
+
(lambda (grob start end)
|
|
1126
|
+
(ly:pure-call func grob start end
|
|
1127
|
+
(ly:pure-call data grob start end))))
|
|
1128
|
+
(lambda (grob) (ly:unpure-call func grob (ly:unpure-call data grob)))))
|
|
1129
|
+
|
|
1130
|
+
;; Don't use define* since then we can't start the body with define in
|
|
1131
|
+
;; Guile-1.8: crazy bug.
|
|
1132
|
+
(define-public (grob::offset-function func data . rest)
|
|
1133
|
+
"Create a callback entity @var{func} to be stored in a grob property,
|
|
1134
|
+
based on the grob property data @var{data} (which can be plain data, a
|
|
1135
|
+
callback itself, or an unpure-pure container).
|
|
1136
|
+
|
|
1137
|
+
Function @var{func} accepts a grob and returns a value that is added
|
|
1138
|
+
to the value resulting from @var{data}. Optional argument @var{plus}
|
|
1139
|
+
defaults to @samp{+} but may be changed to allow for using a different
|
|
1140
|
+
underlying accumulation.
|
|
1141
|
+
|
|
1142
|
+
If @var{data} is @code{#f} or @code{'()}, it is not included in the sum."
|
|
1143
|
+
(define plus (if (null? rest) + (car rest)))
|
|
1144
|
+
(define (maybeplus a b)
|
|
1145
|
+
(if (or (not b) (null? b)) a (plus a b)))
|
|
1146
|
+
(cond ((or (not data) (null? data))
|
|
1147
|
+
func)
|
|
1148
|
+
((or (ly:unpure-pure-container? func)
|
|
1149
|
+
(ly:unpure-pure-container? data))
|
|
1150
|
+
(ly:make-unpure-pure-container
|
|
1151
|
+
(lambda rest
|
|
1152
|
+
(maybeplus (apply ly:unpure-call func rest)
|
|
1153
|
+
(apply ly:unpure-call data rest)))
|
|
1154
|
+
(lambda rest
|
|
1155
|
+
(maybeplus (apply ly:pure-call func rest)
|
|
1156
|
+
(apply ly:pure-call data rest)))))
|
|
1157
|
+
((or (procedure? func)
|
|
1158
|
+
(procedure? data))
|
|
1159
|
+
(lambda rest
|
|
1160
|
+
(maybeplus (apply ly:unpure-call func rest)
|
|
1161
|
+
(apply ly:unpure-call data rest))))
|
|
1162
|
+
(else (plus func data))))
|
|
1163
|
+
|
|
1164
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1165
|
+
;; falls/doits
|
|
1166
|
+
|
|
1167
|
+
(define-public (bend::print spanner)
|
|
1168
|
+
(define (close a b)
|
|
1169
|
+
(< (abs (- a b)) 0.01))
|
|
1170
|
+
|
|
1171
|
+
(let* ((delta-y (* 0.5 (ly:grob-property spanner 'delta-position)))
|
|
1172
|
+
(left-span (ly:spanner-bound spanner LEFT))
|
|
1173
|
+
(dots (if (and (grob::has-interface left-span 'note-head-interface)
|
|
1174
|
+
(ly:grob-object left-span 'dot #f))
|
|
1175
|
+
(ly:grob-object left-span 'dot) #f))
|
|
1176
|
+
|
|
1177
|
+
(right-span (ly:spanner-bound spanner RIGHT))
|
|
1178
|
+
(thickness (* (ly:grob-property spanner 'thickness)
|
|
1179
|
+
(ly:output-def-lookup (ly:grob-layout spanner)
|
|
1180
|
+
'line-thickness)))
|
|
1181
|
+
(padding (ly:grob-property spanner 'padding 0.5))
|
|
1182
|
+
(common (ly:grob-common-refpoint right-span
|
|
1183
|
+
(ly:grob-common-refpoint spanner
|
|
1184
|
+
left-span X)
|
|
1185
|
+
X))
|
|
1186
|
+
(common-y (ly:grob-common-refpoint spanner left-span Y))
|
|
1187
|
+
(minimum-length (ly:grob-property spanner 'minimum-length 0.5))
|
|
1188
|
+
|
|
1189
|
+
(left-x (+ padding
|
|
1190
|
+
(max
|
|
1191
|
+
(interval-end (ly:generic-bound-extent
|
|
1192
|
+
left-span common))
|
|
1193
|
+
(if
|
|
1194
|
+
(and dots
|
|
1195
|
+
(close
|
|
1196
|
+
(ly:grob-relative-coordinate dots common-y Y)
|
|
1197
|
+
(ly:grob-relative-coordinate spanner common-y Y)))
|
|
1198
|
+
(interval-end
|
|
1199
|
+
(ly:grob-robust-relative-extent dots common X))
|
|
1200
|
+
(- INFINITY-INT)))))
|
|
1201
|
+
(right-x (max (- (interval-start
|
|
1202
|
+
(ly:generic-bound-extent right-span common))
|
|
1203
|
+
padding)
|
|
1204
|
+
(+ left-x minimum-length)))
|
|
1205
|
+
(self-x (ly:grob-relative-coordinate spanner common X))
|
|
1206
|
+
(dx (- right-x left-x))
|
|
1207
|
+
(exp (list 'path thickness
|
|
1208
|
+
`(rmoveto
|
|
1209
|
+
,(- left-x self-x) 0
|
|
1210
|
+
|
|
1211
|
+
rcurveto
|
|
1212
|
+
,(/ dx 3)
|
|
1213
|
+
0
|
|
1214
|
+
,dx ,(* 0.66 delta-y)
|
|
1215
|
+
,dx ,delta-y))))
|
|
1216
|
+
|
|
1217
|
+
(ly:make-stencil
|
|
1218
|
+
exp
|
|
1219
|
+
(cons (- left-x self-x) (- right-x self-x))
|
|
1220
|
+
(cons (min 0 delta-y)
|
|
1221
|
+
(max 0 delta-y)))))
|
|
1222
|
+
|
|
1223
|
+
|
|
1224
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1225
|
+
;; grace spacing
|
|
1226
|
+
|
|
1227
|
+
(define-public (grace-spacing::calc-shortest-duration grob)
|
|
1228
|
+
(let* ((cols (ly:grob-object grob 'columns))
|
|
1229
|
+
(get-difference
|
|
1230
|
+
(lambda (idx)
|
|
1231
|
+
(ly:moment-sub (ly:grob-property
|
|
1232
|
+
(ly:grob-array-ref cols (1+ idx)) 'when)
|
|
1233
|
+
(ly:grob-property
|
|
1234
|
+
(ly:grob-array-ref cols idx) 'when))))
|
|
1235
|
+
|
|
1236
|
+
(moment-min (lambda (x y)
|
|
1237
|
+
(cond
|
|
1238
|
+
((and x y)
|
|
1239
|
+
(if (ly:moment<? x y)
|
|
1240
|
+
x
|
|
1241
|
+
y))
|
|
1242
|
+
(x x)
|
|
1243
|
+
(y y)))))
|
|
1244
|
+
|
|
1245
|
+
(fold moment-min #f (map get-difference
|
|
1246
|
+
(iota (1- (ly:grob-array-length cols)))))))
|
|
1247
|
+
|
|
1248
|
+
|
|
1249
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1250
|
+
;; fingering
|
|
1251
|
+
|
|
1252
|
+
(define-public (fingering::calc-text grob)
|
|
1253
|
+
(let ((event (event-cause grob)))
|
|
1254
|
+
(or (ly:event-property event 'text #f)
|
|
1255
|
+
(number->string (ly:event-property event 'digit) 10))))
|
|
1256
|
+
|
|
1257
|
+
(define-public (string-number::calc-text grob)
|
|
1258
|
+
(let ((event (event-cause grob)))
|
|
1259
|
+
(or (ly:event-property event 'text #f)
|
|
1260
|
+
(number-format
|
|
1261
|
+
(ly:grob-property grob 'number-type)
|
|
1262
|
+
(ly:event-property event 'string-number)))))
|
|
1263
|
+
|
|
1264
|
+
(define-public (stroke-finger::calc-text grob)
|
|
1265
|
+
(let ((event (event-cause grob)))
|
|
1266
|
+
(or (ly:event-property event 'text #f)
|
|
1267
|
+
(let ((digit-names (ly:grob-property grob 'digit-names)))
|
|
1268
|
+
(vector-ref digit-names
|
|
1269
|
+
(1- (max 1
|
|
1270
|
+
(min (vector-length digit-names)
|
|
1271
|
+
(ly:event-property event 'digit)))))))))
|
|
1272
|
+
|
|
1273
|
+
|
|
1274
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1275
|
+
;; dynamics
|
|
1276
|
+
|
|
1277
|
+
(define-public (hairpin::calc-grow-direction grob)
|
|
1278
|
+
(if (ly:in-event-class? (event-cause grob) 'decrescendo-event)
|
|
1279
|
+
START
|
|
1280
|
+
STOP))
|
|
1281
|
+
|
|
1282
|
+
(define-public (dynamic-text-spanner::before-line-breaking grob)
|
|
1283
|
+
"Monitor left bound of @code{DynamicTextSpanner} for absolute dynamics.
|
|
1284
|
+
If found, ensure @code{DynamicText} does not collide with spanner text by
|
|
1285
|
+
changing @code{'attach-dir} and @code{'padding}. Reads the
|
|
1286
|
+
@code{'right-padding} property of @code{DynamicText} to fine-tune space
|
|
1287
|
+
between the two text elements."
|
|
1288
|
+
(let ((left-bound (ly:spanner-bound grob LEFT)))
|
|
1289
|
+
(if (grob::has-interface left-bound 'dynamic-text-interface)
|
|
1290
|
+
(let* ((details (ly:grob-property grob 'bound-details))
|
|
1291
|
+
(left-details (ly:assoc-get 'left details))
|
|
1292
|
+
(my-padding (ly:assoc-get 'padding left-details))
|
|
1293
|
+
(script-padding (ly:grob-property left-bound 'right-padding 0)))
|
|
1294
|
+
|
|
1295
|
+
(and (number? my-padding)
|
|
1296
|
+
(ly:grob-set-nested-property! grob
|
|
1297
|
+
'(bound-details left attach-dir)
|
|
1298
|
+
RIGHT)
|
|
1299
|
+
(ly:grob-set-nested-property! grob
|
|
1300
|
+
'(bound-details left padding)
|
|
1301
|
+
(+ my-padding script-padding)))))))
|
|
1302
|
+
|
|
1303
|
+
(define-public (make-connected-line points grob)
|
|
1304
|
+
"Take a list of points, @var{points}.
|
|
1305
|
+
Return a line connecting @var{points},
|
|
1306
|
+
using @code{ly:@/line-interface::@/line} and getting layout information from
|
|
1307
|
+
@var{grob}."
|
|
1308
|
+
(define (connected-points grob ls pts)
|
|
1309
|
+
(if (not (pair? (cdr pts)))
|
|
1310
|
+
(reduce ly:stencil-add empty-stencil ls)
|
|
1311
|
+
(connected-points
|
|
1312
|
+
grob
|
|
1313
|
+
(cons
|
|
1314
|
+
(ly:line-interface::line
|
|
1315
|
+
grob
|
|
1316
|
+
(car (first pts))
|
|
1317
|
+
(cdr (first pts))
|
|
1318
|
+
(car (second pts))
|
|
1319
|
+
(cdr (second pts)))
|
|
1320
|
+
ls)
|
|
1321
|
+
(cdr pts))))
|
|
1322
|
+
(if (< (length points) 2)
|
|
1323
|
+
(begin
|
|
1324
|
+
(ly:warning
|
|
1325
|
+
"'make-connected-line' needs at least two points: ~a"
|
|
1326
|
+
points)
|
|
1327
|
+
empty-stencil)
|
|
1328
|
+
(connected-points grob '() points)))
|
|
1329
|
+
|
|
1330
|
+
(define-public ((elbowed-hairpin coords mirrored?) grob)
|
|
1331
|
+
"Create hairpin based on a list of @var{coords} in @code{(cons x y)}
|
|
1332
|
+
form. @code{x}@tie{}is the portion of the width consumed for a given line
|
|
1333
|
+
and @code{y}@tie{}is the portion of the height. For example,
|
|
1334
|
+
@code{'((0 . 0) (0.3 . 0.7) (0.8 . 0.9) (1.0 . 1.0))} means that at the point
|
|
1335
|
+
where the hairpin has consumed 30% of its width, it must
|
|
1336
|
+
be at 70% of its height. Once it is to 80% width, it
|
|
1337
|
+
must be at 90% height. It finishes at 100% width and 100% height.
|
|
1338
|
+
If @var{coords} does not begin with @code{'(0 . 0)} the final hairpin may have
|
|
1339
|
+
an open tip. For example '(0 . 0.5) will cause an open end of 50% of the usual
|
|
1340
|
+
height.
|
|
1341
|
+
|
|
1342
|
+
@var{mirrored?} indicates if the hairpin is mirrored over the y@tie{}axis or
|
|
1343
|
+
if just the upper part is drawn.
|
|
1344
|
+
|
|
1345
|
+
Returns a function that accepts a hairpin grob as an argument
|
|
1346
|
+
and draws the stencil based on its coordinates.
|
|
1347
|
+
|
|
1348
|
+
@c @lilypond is not allowed in the IR.
|
|
1349
|
+
@example
|
|
1350
|
+
#(define simple-hairpin
|
|
1351
|
+
(elbowed-hairpin '((0 . 0)(1.0 . 1.0)) #t))
|
|
1352
|
+
|
|
1353
|
+
\\relative c' @{
|
|
1354
|
+
\\override Hairpin #'stencil = #simple-hairpin
|
|
1355
|
+
a\\p\\< a a a\\f
|
|
1356
|
+
@}
|
|
1357
|
+
@end example
|
|
1358
|
+
"
|
|
1359
|
+
(define (scale-coords coords-list x y)
|
|
1360
|
+
(map
|
|
1361
|
+
(lambda (coord) (cons (* x (car coord)) (* y (cdr coord))))
|
|
1362
|
+
coords-list))
|
|
1363
|
+
|
|
1364
|
+
(define (hairpin::print-part points decresc? me)
|
|
1365
|
+
(let ((stil (make-connected-line points me)))
|
|
1366
|
+
(if decresc? (ly:stencil-scale stil -1 1) stil)))
|
|
1367
|
+
|
|
1368
|
+
;; outer let to trigger suicide
|
|
1369
|
+
(let ((sten (ly:hairpin::print grob)))
|
|
1370
|
+
(if (grob::is-live? grob)
|
|
1371
|
+
(let* ((decresc? (eqv? (ly:grob-property grob 'grow-direction) LEFT))
|
|
1372
|
+
(xex (ly:stencil-extent sten X))
|
|
1373
|
+
(lenx (interval-length xex))
|
|
1374
|
+
(yex (ly:stencil-extent sten Y))
|
|
1375
|
+
(leny (interval-length yex))
|
|
1376
|
+
(xtrans (+ (car xex) (if decresc? lenx 0)))
|
|
1377
|
+
(ytrans (car yex))
|
|
1378
|
+
(uplist (scale-coords coords lenx (/ leny 2)))
|
|
1379
|
+
(downlist (scale-coords coords lenx (/ leny -2)))
|
|
1380
|
+
(stil
|
|
1381
|
+
(ly:stencil-aligned-to
|
|
1382
|
+
(ly:stencil-translate
|
|
1383
|
+
(ly:stencil-add
|
|
1384
|
+
(hairpin::print-part uplist decresc? grob)
|
|
1385
|
+
(if mirrored?
|
|
1386
|
+
(hairpin::print-part downlist decresc? grob)
|
|
1387
|
+
empty-stencil))
|
|
1388
|
+
(cons xtrans ytrans))
|
|
1389
|
+
Y CENTER))
|
|
1390
|
+
(stil-y-extent (ly:stencil-extent stil Y)))
|
|
1391
|
+
;; Return a final stencil properly aligned in Y-axis direction and with
|
|
1392
|
+
;; proper extents. Otherwise stencil-operations like 'box-stencil' will
|
|
1393
|
+
;; return badly. Extent in X-axis direction is taken from the original,
|
|
1394
|
+
;; in Y-axis direction from the new stencil.
|
|
1395
|
+
(ly:make-stencil (ly:stencil-expr stil) xex stil-y-extent))
|
|
1396
|
+
;; return empty, if no Hairpin.stencil present.
|
|
1397
|
+
'())))
|
|
1398
|
+
|
|
1399
|
+
(define-public flared-hairpin
|
|
1400
|
+
(elbowed-hairpin '((0 . 0) (0.95 . 0.4) (1.0 . 1.0)) #t))
|
|
1401
|
+
|
|
1402
|
+
(define-public constante-hairpin
|
|
1403
|
+
(elbowed-hairpin '((0 . 0) (1.0 . 0.0) (1.0 . 1.0)) #f))
|
|
1404
|
+
|
|
1405
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1406
|
+
;; lyrics
|
|
1407
|
+
|
|
1408
|
+
(define-public (lyric-text::print grob)
|
|
1409
|
+
"Allow interpretation of tildes as lyric tieing marks."
|
|
1410
|
+
;; See also similar code in Lyric_performer.
|
|
1411
|
+
(let ((text (ly:grob-property grob 'text)))
|
|
1412
|
+
|
|
1413
|
+
(grob-interpret-markup grob (if (string? text)
|
|
1414
|
+
(make-tied-lyric-markup text)
|
|
1415
|
+
text))))
|
|
1416
|
+
|
|
1417
|
+
(define-public ((grob::calc-property-by-copy prop) grob)
|
|
1418
|
+
(ly:event-property (event-cause grob) prop))
|
|
1419
|
+
|
|
1420
|
+
(define-public (lyric-hyphen::vaticana-style grob)
|
|
1421
|
+
"Draw a @code{LyricHyphen} grob as needed for Gregorian chant in
|
|
1422
|
+
Editio Vaticana style, that is, apply it once, flush-left. If the
|
|
1423
|
+
@code{text} property of @code{LyricHyphen} is set, print this markup.
|
|
1424
|
+
If the property is not set, use a hyphen character."
|
|
1425
|
+
|
|
1426
|
+
(define (span-point side common dir)
|
|
1427
|
+
(let ((iv (ly:grob-robust-relative-extent side common X)))
|
|
1428
|
+
(interval-bound iv dir)))
|
|
1429
|
+
|
|
1430
|
+
(define (get-text-stencil grob)
|
|
1431
|
+
(grob-interpret-markup
|
|
1432
|
+
grob
|
|
1433
|
+
(ly:grob-property grob 'text "-")))
|
|
1434
|
+
|
|
1435
|
+
(let* ((left-bound (ly:spanner-bound grob LEFT))
|
|
1436
|
+
(right-bound (ly:spanner-bound grob RIGHT))
|
|
1437
|
+
(common (ly:grob-common-refpoint left-bound right-bound X))
|
|
1438
|
+
(left-span (span-point left-bound common RIGHT))
|
|
1439
|
+
(right-span (span-point right-bound common LEFT))
|
|
1440
|
+
(span-length (- right-span left-span))
|
|
1441
|
+
(padding (ly:grob-property grob 'padding 0.1))
|
|
1442
|
+
(dash-sten (get-text-stencil grob))
|
|
1443
|
+
(dash-extent (ly:stencil-extent dash-sten X))
|
|
1444
|
+
(dash-length (interval-length dash-extent))
|
|
1445
|
+
(usable-length
|
|
1446
|
+
(- span-length
|
|
1447
|
+
(if (zero? (ly:item-break-dir left-bound)) padding 0)
|
|
1448
|
+
(if (zero? (ly:item-break-dir right-bound)) padding 0)))
|
|
1449
|
+
(offset
|
|
1450
|
+
(+ (- left-span (ly:grob-relative-coordinate grob common X))
|
|
1451
|
+
(if (zero? (ly:item-break-dir left-bound)) padding 0))))
|
|
1452
|
+
|
|
1453
|
+
(if (or (< dash-length usable-length)
|
|
1454
|
+
(negative? (ly:item-break-dir right-bound)))
|
|
1455
|
+
(ly:stencil-translate-axis
|
|
1456
|
+
dash-sten offset X))))
|
|
1457
|
+
|
|
1458
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1459
|
+
;; general inheritance
|
|
1460
|
+
|
|
1461
|
+
(define-public ((grob::inherit-parent-property axis property . default) grob)
|
|
1462
|
+
"@var{grob} callback generator for inheriting a @var{property} from
|
|
1463
|
+
an @var{axis} parent, defaulting to @var{default} if there is no
|
|
1464
|
+
parent or the parent has no setting."
|
|
1465
|
+
(let ((parent (ly:grob-parent grob axis)))
|
|
1466
|
+
(cond
|
|
1467
|
+
((ly:grob? parent)
|
|
1468
|
+
(apply ly:grob-property parent property default))
|
|
1469
|
+
((pair? default) (car default))
|
|
1470
|
+
(else '()))))
|
|
1471
|
+
|
|
1472
|
+
(define ((grob::relay-other-property property) grob)
|
|
1473
|
+
"@var{grob} callback generator for returning the value of another
|
|
1474
|
+
property, which is identified by the symbol @var{property}."
|
|
1475
|
+
(ly:grob-property grob property))
|
|
1476
|
+
(export grob::relay-other-property)
|
|
1477
|
+
|
|
1478
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1479
|
+
;; balloons
|
|
1480
|
+
|
|
1481
|
+
;; TODO: What if the host of the broken piece picked here is dead?
|
|
1482
|
+
;; For a hairpin, the last part is typically removed. The problem
|
|
1483
|
+
;; is that for grobs with more complex behavior, suicide could happen
|
|
1484
|
+
;; late in the process.
|
|
1485
|
+
|
|
1486
|
+
;; TODO: Make interface for items more similar to spanner-placement
|
|
1487
|
+
;; for spanners?
|
|
1488
|
+
|
|
1489
|
+
(define-public (ly:balloon-interface::remove-irrelevant-spanner grob)
|
|
1490
|
+
(if (ly:spanner? grob)
|
|
1491
|
+
(let* ((spanner-placement (ly:grob-property grob 'spanner-placement))
|
|
1492
|
+
(irrelevant?
|
|
1493
|
+
(cond
|
|
1494
|
+
((eqv? spanner-placement LEFT)
|
|
1495
|
+
not-first-broken-spanner?)
|
|
1496
|
+
((eqv? spanner-placement RIGHT)
|
|
1497
|
+
not-last-broken-spanner?)
|
|
1498
|
+
(else
|
|
1499
|
+
(ly:grob-warning
|
|
1500
|
+
grob
|
|
1501
|
+
'after-line-breaking
|
|
1502
|
+
"spanner-placement must be #LEFT or #RIGHT, found ~s"
|
|
1503
|
+
spanner-placement)
|
|
1504
|
+
not-first-broken-spanner?))))
|
|
1505
|
+
(if (irrelevant? grob)
|
|
1506
|
+
(ly:grob-suicide! grob)))))
|
|
1507
|
+
|
|
1508
|
+
(define-public balloon::height
|
|
1509
|
+
(ly:make-unpure-pure-container
|
|
1510
|
+
ly:grob::stencil-height
|
|
1511
|
+
ly:balloon-interface::pure-height))
|
|
1512
|
+
|
|
1513
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1514
|
+
;; fret boards
|
|
1515
|
+
|
|
1516
|
+
(define-public (fret-board::calc-stencil grob)
|
|
1517
|
+
(grob-interpret-markup
|
|
1518
|
+
grob
|
|
1519
|
+
(make-fret-diagram-verbose-markup
|
|
1520
|
+
(ly:grob-property grob 'dot-placement-list))))
|
|
1521
|
+
|
|
1522
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1523
|
+
;; slurs
|
|
1524
|
+
|
|
1525
|
+
(define-public slur::height
|
|
1526
|
+
(ly:make-unpure-pure-container
|
|
1527
|
+
ly:slur::height
|
|
1528
|
+
ly:slur::pure-height))
|
|
1529
|
+
|
|
1530
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1531
|
+
;; scripts
|
|
1532
|
+
|
|
1533
|
+
(define-public (caesura-script-interface::before-line-breaking script)
|
|
1534
|
+
"Callback for @code{CaesuraScript} grob. Eliminate scripts aligned to
|
|
1535
|
+
bar lines if they might collide with a span bar. Some types of bar
|
|
1536
|
+
lines have visible span bars and some don't. For consistent notation,
|
|
1537
|
+
we don't check whether particular @code{SpanBar} grobs are actually
|
|
1538
|
+
visible, just that they exist."
|
|
1539
|
+
(define (find-span-bars)
|
|
1540
|
+
(let ((parent (ly:grob-parent script X)))
|
|
1541
|
+
(if (grob::has-interface parent 'bar-line-interface)
|
|
1542
|
+
(ly:grob-object parent 'has-span-bar)
|
|
1543
|
+
#f)))
|
|
1544
|
+
|
|
1545
|
+
(let ((span-bars (find-span-bars)))
|
|
1546
|
+
(when (pair? span-bars)
|
|
1547
|
+
(let* ((dir (ly:grob-property script 'direction))
|
|
1548
|
+
(span-bar (index-cell span-bars dir)))
|
|
1549
|
+
(when (ly:grob? span-bar)
|
|
1550
|
+
(ly:grob-suicide! script))))))
|
|
1551
|
+
|
|
1552
|
+
(define-public (script-interface::calc-x-offset grob)
|
|
1553
|
+
(ly:grob-property grob 'positioning-done)
|
|
1554
|
+
(let* ((shift-when-alone (ly:grob-property grob 'toward-stem-shift 0.0))
|
|
1555
|
+
(shift-in-column (ly:grob-property grob 'toward-stem-shift-in-column))
|
|
1556
|
+
(script-column (ly:grob-object grob 'script-column #f))
|
|
1557
|
+
(shift
|
|
1558
|
+
(if (and script-column
|
|
1559
|
+
(number? shift-in-column)
|
|
1560
|
+
;; ScriptColumn can contain grobs other than Script.
|
|
1561
|
+
;; These should not result in a shift.
|
|
1562
|
+
(any (lambda (s)
|
|
1563
|
+
(and (not (eq? s grob))
|
|
1564
|
+
(grob::has-interface s 'script-interface)
|
|
1565
|
+
(not (grob::has-interface s
|
|
1566
|
+
'accidental-suggestion-interface))))
|
|
1567
|
+
(ly:grob-array->list
|
|
1568
|
+
(ly:grob-object script-column 'scripts))))
|
|
1569
|
+
shift-in-column shift-when-alone))
|
|
1570
|
+
(note-head-location
|
|
1571
|
+
(ly:self-alignment-interface::aligned-on-x-parent grob))
|
|
1572
|
+
(note-head-grob (ly:grob-parent grob X))
|
|
1573
|
+
(stem-grob (ly:grob-object note-head-grob 'stem #f)))
|
|
1574
|
+
|
|
1575
|
+
(+ note-head-location
|
|
1576
|
+
;; If the script has the same direction as the stem, move the script
|
|
1577
|
+
;; in accordance with the value of 'shift'. Since scripts can also be
|
|
1578
|
+
;; over skips, we need to check whether the grob has a stem at all.
|
|
1579
|
+
(if stem-grob
|
|
1580
|
+
(let ((dir1 (ly:grob-property grob 'direction))
|
|
1581
|
+
(dir2 (ly:grob-property stem-grob 'direction)))
|
|
1582
|
+
(if (equal? dir1 dir2)
|
|
1583
|
+
(let* ((common-refp (ly:grob-common-refpoint grob stem-grob X))
|
|
1584
|
+
(stem-location
|
|
1585
|
+
(ly:grob-relative-coordinate stem-grob common-refp X)))
|
|
1586
|
+
(* shift (- stem-location note-head-location)))
|
|
1587
|
+
0.0))
|
|
1588
|
+
0.0))))
|
|
1589
|
+
|
|
1590
|
+
|
|
1591
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1592
|
+
;; instrument names
|
|
1593
|
+
|
|
1594
|
+
(define-public (system-start-text::print grob)
|
|
1595
|
+
(let* ((left-bound (ly:spanner-bound grob LEFT))
|
|
1596
|
+
(left-mom (ly:grob-property left-bound 'when))
|
|
1597
|
+
(name (if (moment<=? left-mom ZERO-MOMENT)
|
|
1598
|
+
(ly:grob-property grob 'long-text)
|
|
1599
|
+
(ly:grob-property grob 'text))))
|
|
1600
|
+
|
|
1601
|
+
(if (and (markup? name)
|
|
1602
|
+
(!= (ly:item-break-dir left-bound) CENTER))
|
|
1603
|
+
|
|
1604
|
+
(grob-interpret-markup grob name)
|
|
1605
|
+
(ly:grob-suicide! grob))))
|
|
1606
|
+
|
|
1607
|
+
(define-public (system-start-text::calc-x-offset grob)
|
|
1608
|
+
(let* ((left-bound (ly:spanner-bound grob LEFT))
|
|
1609
|
+
(left-mom (ly:grob-property left-bound 'when))
|
|
1610
|
+
(layout (ly:grob-layout grob))
|
|
1611
|
+
(indent (ly:output-def-lookup layout
|
|
1612
|
+
(if (moment<=? left-mom ZERO-MOMENT)
|
|
1613
|
+
'indent
|
|
1614
|
+
'short-indent)
|
|
1615
|
+
0.0))
|
|
1616
|
+
(system (ly:grob-system grob))
|
|
1617
|
+
(my-extent (ly:grob-extent grob system X))
|
|
1618
|
+
(elements (ly:grob-object system 'elements))
|
|
1619
|
+
(common (ly:grob-common-refpoint-of-array system elements X))
|
|
1620
|
+
(total-left +inf.0)
|
|
1621
|
+
(align-x (ly:grob-property grob 'self-alignment-X 0))
|
|
1622
|
+
(padding (min 0 (- (interval-length my-extent) indent)))
|
|
1623
|
+
(right-padding (- padding
|
|
1624
|
+
(/ (* padding (1+ align-x)) 2))))
|
|
1625
|
+
|
|
1626
|
+
;; compensate for the variation in delimiter extents by
|
|
1627
|
+
;; calculating an X-offset correction based on the extents
|
|
1628
|
+
;; of all delimiters in this system
|
|
1629
|
+
;; finally we take most-left coordinate and indent
|
|
1630
|
+
(let most-left-delim-x ((l (ly:grob-array-length elements)))
|
|
1631
|
+
(if (> l 0)
|
|
1632
|
+
(let ((elt (ly:grob-array-ref elements (1- l))))
|
|
1633
|
+
(if (grob::has-interface elt 'system-start-delimiter-interface)
|
|
1634
|
+
(let ((dims (ly:grob-extent elt common X)))
|
|
1635
|
+
(set! total-left (min total-left (car dims)))))
|
|
1636
|
+
(most-left-delim-x (1- l)))))
|
|
1637
|
+
|
|
1638
|
+
(+
|
|
1639
|
+
(ly:side-position-interface::x-aligned-side grob)
|
|
1640
|
+
right-padding
|
|
1641
|
+
(- (interval-length (cons total-left indent))))))
|
|
1642
|
+
|
|
1643
|
+
(define-public (system-start-text::calc-y-offset grob)
|
|
1644
|
+
|
|
1645
|
+
(define (live-elements-list me)
|
|
1646
|
+
(let ((elements (ly:grob-object me 'elements)))
|
|
1647
|
+
|
|
1648
|
+
(filter! grob::is-live?
|
|
1649
|
+
(ly:grob-array->list elements))))
|
|
1650
|
+
|
|
1651
|
+
(let* ((left-bound (ly:spanner-bound grob LEFT))
|
|
1652
|
+
(live-elts (live-elements-list grob))
|
|
1653
|
+
(system (ly:grob-system grob))
|
|
1654
|
+
(extent empty-interval))
|
|
1655
|
+
|
|
1656
|
+
(if (and (pair? live-elts)
|
|
1657
|
+
(interval-sane? (ly:grob-extent grob system Y)))
|
|
1658
|
+
(let get-extent ((lst live-elts))
|
|
1659
|
+
(if (pair? lst)
|
|
1660
|
+
(let ((axis-group (car lst)))
|
|
1661
|
+
|
|
1662
|
+
(if (and (ly:spanner? axis-group)
|
|
1663
|
+
(equal? (ly:spanner-bound axis-group LEFT)
|
|
1664
|
+
left-bound))
|
|
1665
|
+
(set! extent (add-point extent
|
|
1666
|
+
(ly:grob-relative-coordinate
|
|
1667
|
+
axis-group system Y))))
|
|
1668
|
+
(get-extent (cdr lst)))))
|
|
1669
|
+
;; no live axis group(s) for this instrument name -> remove from system
|
|
1670
|
+
(ly:grob-suicide! grob))
|
|
1671
|
+
|
|
1672
|
+
(+
|
|
1673
|
+
(ly:self-alignment-interface::y-aligned-on-self grob)
|
|
1674
|
+
(interval-center extent))))
|
|
1675
|
+
|
|
1676
|
+
|
|
1677
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1678
|
+
;; axis group interface
|
|
1679
|
+
|
|
1680
|
+
(define-public axis-group-interface::height
|
|
1681
|
+
(ly:make-unpure-pure-container
|
|
1682
|
+
ly:axis-group-interface::height
|
|
1683
|
+
ly:axis-group-interface::pure-height))
|
|
1684
|
+
|
|
1685
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1686
|
+
;; ambitus
|
|
1687
|
+
|
|
1688
|
+
;; Calculate the gaps between ambitus heads and ends of ambitus line.
|
|
1689
|
+
;; Start by determining desired length of the ambitus line (based on
|
|
1690
|
+
;; length-fraction property), calc gap from that and make sure that
|
|
1691
|
+
;; it doesn't exceed maximum allowed value.
|
|
1692
|
+
|
|
1693
|
+
(define-public (ambitus-line::calc-gap grob)
|
|
1694
|
+
(let ((heads (ly:grob-object grob 'note-heads #f)))
|
|
1695
|
+
|
|
1696
|
+
(if (and heads
|
|
1697
|
+
(= (ly:grob-array-length heads) 2))
|
|
1698
|
+
(let* ((common (ly:grob-common-refpoint-of-array grob heads Y))
|
|
1699
|
+
(head-down (ly:grob-array-ref heads 0))
|
|
1700
|
+
(head-up (ly:grob-array-ref heads 1))
|
|
1701
|
+
(fraction (ly:grob-property grob 'length-fraction 0.7))
|
|
1702
|
+
(max-gap (ly:grob-property grob 'maximum-gap 0.45))
|
|
1703
|
+
;; distance between noteheads:
|
|
1704
|
+
(distance (- (interval-start (ly:grob-extent head-up common Y))
|
|
1705
|
+
(interval-end (ly:grob-extent head-down common Y))))
|
|
1706
|
+
(gap (* 0.5 distance (- 1 fraction))))
|
|
1707
|
+
|
|
1708
|
+
(min gap max-gap))
|
|
1709
|
+
0)))
|
|
1710
|
+
|
|
1711
|
+
;; Print a line connecting ambitus heads:
|
|
1712
|
+
|
|
1713
|
+
(define-public (ambitus::print grob)
|
|
1714
|
+
(let ((heads (ly:grob-object grob 'note-heads #f)))
|
|
1715
|
+
|
|
1716
|
+
(if (and heads
|
|
1717
|
+
(= (ly:grob-array-length heads) 2))
|
|
1718
|
+
(let* ((common (ly:grob-common-refpoint-of-array grob heads Y))
|
|
1719
|
+
(head-down (ly:grob-array-ref heads 0))
|
|
1720
|
+
(head-up (ly:grob-array-ref heads 1))
|
|
1721
|
+
;; The value used when 'gap' property cannot be read is small
|
|
1722
|
+
;; to make sure that ambitus of a fifth will have a visible line.
|
|
1723
|
+
(gap (ly:grob-property grob 'gap 0.25))
|
|
1724
|
+
(point-min (+ (interval-end (ly:grob-extent head-down common Y))
|
|
1725
|
+
gap))
|
|
1726
|
+
(point-max (- (interval-start (ly:grob-extent head-up common Y))
|
|
1727
|
+
gap)))
|
|
1728
|
+
|
|
1729
|
+
(if (< (+ point-min 0.1) point-max) ; don't print lines shorter than 0.1ss
|
|
1730
|
+
(let* ((layout (ly:grob-layout grob))
|
|
1731
|
+
(line-thick (ly:output-def-lookup layout 'line-thickness))
|
|
1732
|
+
(blot (ly:output-def-lookup layout 'blot-diameter))
|
|
1733
|
+
(grob-thick (ly:grob-property grob 'thickness 2))
|
|
1734
|
+
(width (* line-thick grob-thick))
|
|
1735
|
+
(x-ext (symmetric-interval (/ width 2)))
|
|
1736
|
+
(y-ext (cons point-min point-max))
|
|
1737
|
+
(line (ly:round-filled-box x-ext y-ext blot))
|
|
1738
|
+
(y-coord (ly:grob-relative-coordinate grob common Y)))
|
|
1739
|
+
|
|
1740
|
+
(ly:stencil-translate-axis line (- y-coord) Y))
|
|
1741
|
+
empty-stencil))
|
|
1742
|
+
(begin
|
|
1743
|
+
(ly:grob-suicide! grob)
|
|
1744
|
+
(list)))))
|
|
1745
|
+
|
|
1746
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1747
|
+
;; laissez-vibrer tie
|
|
1748
|
+
|
|
1749
|
+
(define-public (semi-tie::calc-cross-staff grob)
|
|
1750
|
+
(let* ((note-head (ly:grob-object grob 'note-head))
|
|
1751
|
+
(stem (ly:grob-object note-head 'stem #f)))
|
|
1752
|
+
(and stem
|
|
1753
|
+
(ly:grob-property stem 'cross-staff #f))))
|
|
1754
|
+
|
|
1755
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1756
|
+
;; volta-bracket
|
|
1757
|
+
|
|
1758
|
+
(define-public (volta-bracket-interface::pure-height grob start end)
|
|
1759
|
+
(let ((edge-height (ly:grob-property grob 'edge-height)))
|
|
1760
|
+
(if (number-pair? edge-height)
|
|
1761
|
+
(let ((smaller (min (car edge-height) (cdr edge-height)))
|
|
1762
|
+
(larger (max (car edge-height) (cdr edge-height))))
|
|
1763
|
+
(interval-union '(0 . 0) (cons smaller larger)))
|
|
1764
|
+
'(0 . 0))))
|
|
1765
|
+
|
|
1766
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1767
|
+
;; centered-spanner-interface
|
|
1768
|
+
|
|
1769
|
+
(define-public (centered-spanner-interface::calc-x-offset grob)
|
|
1770
|
+
"Compute the shift from this spanner's reference point to a point
|
|
1771
|
+
centered between two non-musical columns, according to the
|
|
1772
|
+
@code{spacing-@/pair} property. This also takes
|
|
1773
|
+
@code{self-@/alignment-X} into account. The default for
|
|
1774
|
+
@code{spacing-@/pair} is @code{'(break-@/alignment
|
|
1775
|
+
.@tie{}break-@/alignment)}."
|
|
1776
|
+
(let* ((left-bound (ly:spanner-bound grob LEFT))
|
|
1777
|
+
(right-bound (ly:spanner-bound grob RIGHT))
|
|
1778
|
+
(refp (ly:grob-common-refpoint left-bound right-bound X))
|
|
1779
|
+
(base-position (ly:grob-relative-coordinate grob refp X))
|
|
1780
|
+
(spacing-pair
|
|
1781
|
+
(ly:grob-property grob
|
|
1782
|
+
'spacing-pair
|
|
1783
|
+
'(break-alignment . break-alignment)))
|
|
1784
|
+
(ext-L (ly:paper-column::break-align-width left-bound
|
|
1785
|
+
(car spacing-pair)))
|
|
1786
|
+
(L-end (interval-end ext-L))
|
|
1787
|
+
(ext-R (ly:paper-column::break-align-width right-bound
|
|
1788
|
+
(cdr spacing-pair)))
|
|
1789
|
+
(R-start (interval-start ext-R))
|
|
1790
|
+
;; Amount of translation from our basic position to
|
|
1791
|
+
;; the right of our left bound.
|
|
1792
|
+
(to-left-bound (- L-end base-position))
|
|
1793
|
+
;; From that to the middle between left and right bound.
|
|
1794
|
+
(to-middle (* 0.5 (- R-start L-end)))
|
|
1795
|
+
;; Correction to align according to self-alignment-X.
|
|
1796
|
+
(alignment-translation
|
|
1797
|
+
(ly:self-alignment-interface::x-aligned-on-self grob)))
|
|
1798
|
+
(+ to-left-bound to-middle alignment-translation)))
|
|
1799
|
+
|
|
1800
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1801
|
+
;; Measure counter.
|
|
1802
|
+
|
|
1803
|
+
(define-public (measure-counter::text grob)
|
|
1804
|
+
"A number for a measure count. Broken measures are numbered in
|
|
1805
|
+
parentheses. When the counter spans several measures (like with
|
|
1806
|
+
compressed multi-measure rests), it displays a measure range."
|
|
1807
|
+
(let* ((left-number-text (ly:grob-property grob 'left-number-text))
|
|
1808
|
+
(right-number-text (ly:grob-property grob 'right-number-text))
|
|
1809
|
+
(left-markup
|
|
1810
|
+
(if (markup? left-number-text) left-number-text empty-markup))
|
|
1811
|
+
(sep-and-right-markup
|
|
1812
|
+
(if (markup? right-number-text)
|
|
1813
|
+
(make-line-markup
|
|
1814
|
+
(list
|
|
1815
|
+
(let ((sep (ly:grob-property grob 'number-range-separator)))
|
|
1816
|
+
(if (markup? sep) sep empty-markup))
|
|
1817
|
+
(if (markup? right-number-text) right-number-text empty-markup)))
|
|
1818
|
+
empty-markup))
|
|
1819
|
+
(text (make-line-markup (list left-markup sep-and-right-markup)))
|
|
1820
|
+
(orig (ly:grob-original grob))
|
|
1821
|
+
(siblings (ly:spanner-broken-into orig))) ; have we been split?
|
|
1822
|
+
(if (or (null? siblings)
|
|
1823
|
+
(eq? grob (car siblings)))
|
|
1824
|
+
text
|
|
1825
|
+
(make-parenthesize-markup text))))
|
|
1826
|
+
|
|
1827
|
+
|
|
1828
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1829
|
+
;; HorizontalBracketText
|
|
1830
|
+
|
|
1831
|
+
(define-public (ly:horizontal-bracket-text::print grob)
|
|
1832
|
+
(let ((text (ly:grob-property grob 'text)))
|
|
1833
|
+
(if (or (null? text)
|
|
1834
|
+
(equal? text "")
|
|
1835
|
+
(equal? text empty-markup))
|
|
1836
|
+
(begin
|
|
1837
|
+
(ly:grob-suicide! grob)
|
|
1838
|
+
'())
|
|
1839
|
+
(let* ((orig (ly:grob-original grob))
|
|
1840
|
+
(siblings (ly:spanner-broken-into orig))
|
|
1841
|
+
(text
|
|
1842
|
+
(if (or (null? siblings)
|
|
1843
|
+
(eq? grob (car siblings)))
|
|
1844
|
+
text
|
|
1845
|
+
(if (string? text)
|
|
1846
|
+
(string-append "(" text ")")
|
|
1847
|
+
(make-parenthesize-markup text)))))
|
|
1848
|
+
(grob-interpret-markup grob text)))))
|
|
1849
|
+
|
|
1850
|
+
(define-public (ly:horizontal-bracket-text::calc-direction grob)
|
|
1851
|
+
(let* ((bracket (ly:grob-object grob 'bracket))
|
|
1852
|
+
(bracket-dir (ly:grob-property bracket 'direction DOWN)))
|
|
1853
|
+
bracket-dir))
|
|
1854
|
+
|
|
1855
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1856
|
+
;; BendSpanner
|
|
1857
|
+
|
|
1858
|
+
(define (quarterdiff->string alist quarterdiff)
|
|
1859
|
+
"Takes the alist @var{alist}, stored in
|
|
1860
|
+
@code{BendSpanner.details.bend-amount-strings}. Applied to @var{quarterdiff},
|
|
1861
|
+
which is supposed to be an integer representing the amount of quarter-steps
|
|
1862
|
+
between two pitches, it returns a fraction as a string like ¾, probably a mixed
|
|
1863
|
+
number string like 1½.
|
|
1864
|
+
The actual formatting relies on the settings in @var{alist}."
|
|
1865
|
+
(let ((wholesteps (floor (/ quarterdiff 4))))
|
|
1866
|
+
(format #f "~a~a"
|
|
1867
|
+
(case wholesteps
|
|
1868
|
+
((0) "")
|
|
1869
|
+
((1) (if (and (zero? (modulo quarterdiff 4))
|
|
1870
|
+
(assoc-get 'full alist))
|
|
1871
|
+
(assoc-get 'full alist)
|
|
1872
|
+
wholesteps))
|
|
1873
|
+
(else wholesteps))
|
|
1874
|
+
(case (modulo quarterdiff 4)
|
|
1875
|
+
((1) (or (assoc-get 'quarter alist) "¼"))
|
|
1876
|
+
((2) (or (assoc-get 'half alist) "½"))
|
|
1877
|
+
((3) (or (assoc-get 'three-quarter alist)"¾"))
|
|
1878
|
+
(else "")))))
|
|
1879
|
+
|
|
1880
|
+
(define (get-quarter-diffs pitch-list-pair)
|
|
1881
|
+
"Takes @var{pitch-list-pair}, which is expected to be a pair of lists, both
|
|
1882
|
+
containing pitches, and to be sorted with @code{ly:pitch<?} in advance.
|
|
1883
|
+
Returns a number representing the amount of quarter tones between the highest
|
|
1884
|
+
pitches from the two sub-lists."
|
|
1885
|
+
;; For event-chords, bendings to different amounts are very unlikely, so we take
|
|
1886
|
+
;; the highest pitch of every sublist for comparison.
|
|
1887
|
+
(let* ((starting-pitch-list (car pitch-list-pair))
|
|
1888
|
+
(target-pitch-list (cdr pitch-list-pair))
|
|
1889
|
+
(top-starting-pitch (last starting-pitch-list))
|
|
1890
|
+
(top-target-pitch (last target-pitch-list)))
|
|
1891
|
+
(- (ly:pitch-quartertones top-target-pitch)
|
|
1892
|
+
(ly:pitch-quartertones top-starting-pitch))))
|
|
1893
|
+
|
|
1894
|
+
(define-public (get-bound-note-heads spanner)
|
|
1895
|
+
"Take a spanner grob and return a pair containing all note heads of the
|
|
1896
|
+
initial starting and the final @code{NoteColumn}."
|
|
1897
|
+
(let* ((orig (ly:grob-original spanner))
|
|
1898
|
+
;; get the bend-spanner's starting/ending NoteColumns
|
|
1899
|
+
(left-bound (ly:spanner-bound orig LEFT))
|
|
1900
|
+
(right-bound (ly:spanner-bound orig RIGHT))
|
|
1901
|
+
;; get their NoteHeads
|
|
1902
|
+
(left-note-heads-array (ly:grob-object left-bound 'note-heads #f))
|
|
1903
|
+
(right-note-heads-array (ly:grob-object right-bound 'note-heads #f)))
|
|
1904
|
+
(if (and left-note-heads-array right-note-heads-array)
|
|
1905
|
+
(cons
|
|
1906
|
+
(ly:grob-array->list left-note-heads-array)
|
|
1907
|
+
(ly:grob-array->list right-note-heads-array))
|
|
1908
|
+
;; TODO display proper location
|
|
1909
|
+
;; sth at the lines of (*location*) ...
|
|
1910
|
+
(ly:error
|
|
1911
|
+
"~a needs NoteColumns with NoteHeads as bounds: ~a"
|
|
1912
|
+
spanner
|
|
1913
|
+
(list left-note-heads-array right-note-heads-array)))))
|
|
1914
|
+
|
|
1915
|
+
(define (bend::remove-certain-tab-note-heads tab-note-heads)
|
|
1916
|
+
"Takes the list @var{tab-note-heads} and removes all note heads, which
|
|
1917
|
+
are played on open strings, unless grob-property @code{bend-me} is set to
|
|
1918
|
+
@code{#t}.
|
|
1919
|
+
Other note heads with @code{bend-me} set to @code{#f} are removed as well."
|
|
1920
|
+
(remove
|
|
1921
|
+
(lambda (tnh) (not (ly:grob-property tnh 'bend-me)))
|
|
1922
|
+
tab-note-heads))
|
|
1923
|
+
|
|
1924
|
+
(define (bounding-note-heads-pitches spanner)
|
|
1925
|
+
"Takes a spanner grob, gets the note heads from the starting and ending bound,
|
|
1926
|
+
applying @code{get-bound-note-heads}, removes not spanned ones, gets the pitches
|
|
1927
|
+
of the note heads of each bound, sorts them with @code{ly:pitch<?} and returns
|
|
1928
|
+
them as a pair."
|
|
1929
|
+
(let* ((all-left-right-note-heads (get-bound-note-heads spanner))
|
|
1930
|
+
(left-notes
|
|
1931
|
+
(bend::remove-certain-tab-note-heads
|
|
1932
|
+
(car all-left-right-note-heads)))
|
|
1933
|
+
(right-notes
|
|
1934
|
+
(bend::remove-certain-tab-note-heads
|
|
1935
|
+
(cdr all-left-right-note-heads)))
|
|
1936
|
+
(left-pitches
|
|
1937
|
+
(map
|
|
1938
|
+
(lambda (note-head)
|
|
1939
|
+
(ly:event-property (event-cause note-head) 'pitch))
|
|
1940
|
+
left-notes))
|
|
1941
|
+
(sorted-left-pitches (sort left-pitches ly:pitch<?))
|
|
1942
|
+
(right-pitches
|
|
1943
|
+
(map
|
|
1944
|
+
(lambda (note-head)
|
|
1945
|
+
(ly:event-property (event-cause note-head) 'pitch))
|
|
1946
|
+
right-notes))
|
|
1947
|
+
(sorted-right-pitches (sort right-pitches ly:pitch<?)))
|
|
1948
|
+
(cons sorted-left-pitches sorted-right-pitches)))
|
|
1949
|
+
|
|
1950
|
+
(define-public (bend::target-cautionary spanner)
|
|
1951
|
+
"Set @code{'display-cautionary} of all relevant note heads of spanners right
|
|
1952
|
+
bound to true. As a result they appear parenthesized.
|
|
1953
|
+
This procedure is the default value of @code{'before-line-breaking}."
|
|
1954
|
+
(let* ((all-right-note-heads (cdr (get-bound-note-heads spanner)))
|
|
1955
|
+
(right-note-heads
|
|
1956
|
+
(bend::remove-certain-tab-note-heads all-right-note-heads)))
|
|
1957
|
+
(for-each
|
|
1958
|
+
(lambda (right-tab-nh)
|
|
1959
|
+
(ly:grob-set-property! right-tab-nh 'display-cautionary #t))
|
|
1960
|
+
right-note-heads)))
|
|
1961
|
+
|
|
1962
|
+
(define-public (bend::text-string spanner)
|
|
1963
|
+
"Take a spanner grob and calculate a list with the quarter tone diffs between
|
|
1964
|
+
the pitches of starting and ending bound. Because bending to different amounts
|
|
1965
|
+
is very unlikely, only the first element of this list is returned as a string."
|
|
1966
|
+
(let* ((sorted-left-right-pitches (bounding-note-heads-pitches spanner))
|
|
1967
|
+
(quarter-diffs (get-quarter-diffs sorted-left-right-pitches))
|
|
1968
|
+
(bend-amount-strings
|
|
1969
|
+
(assoc-get
|
|
1970
|
+
'bend-amount-strings
|
|
1971
|
+
(ly:grob-property spanner 'details)
|
|
1972
|
+
'())))
|
|
1973
|
+
(quarterdiff->string bend-amount-strings quarter-diffs)))
|
|
1974
|
+
|
|
1975
|
+
(define (get-top-most-tab-head tab-heads-list)
|
|
1976
|
+
"Get the @code{TabNoteHead} with the highest value of @code{'staff-position}
|
|
1977
|
+
from @var{tab-heads-list}."
|
|
1978
|
+
;; TODO this may cause wrong results for unusual string-tunings
|
|
1979
|
+
(car
|
|
1980
|
+
(sort
|
|
1981
|
+
tab-heads-list
|
|
1982
|
+
(lambda (tnh1 tnh2)
|
|
1983
|
+
(>
|
|
1984
|
+
(ly:grob-property tnh1 'staff-position)
|
|
1985
|
+
(ly:grob-property tnh2 'staff-position))))))
|
|
1986
|
+
|
|
1987
|
+
(define (make-tab-heads-transparent tab-heads)
|
|
1988
|
+
"Set @code{transparent} to @code{#t} in @code{TabVoice} for the bends target
|
|
1989
|
+
note head. If @code{\\tabFullNotation} is set, the stem and flag will be
|
|
1990
|
+
transparent as well.
|
|
1991
|
+
Doesn't work for beams."
|
|
1992
|
+
;; TODO Needs design decision whether beams should be transparent or not.
|
|
1993
|
+
;; If yes, a different approach is needed.
|
|
1994
|
+
(for-each
|
|
1995
|
+
(lambda (tab-note-head)
|
|
1996
|
+
(if (grob::has-interface tab-note-head 'tab-note-head-interface)
|
|
1997
|
+
(let* ((stem (ly:grob-object tab-note-head 'stem #f))
|
|
1998
|
+
(flag (ly:grob-object stem 'flag #f))
|
|
1999
|
+
(dot (ly:grob-object tab-note-head 'dot #f)))
|
|
2000
|
+
(if stem (ly:grob-set-property! stem 'transparent #t))
|
|
2001
|
+
(if flag (ly:grob-set-property! flag 'transparent #t))
|
|
2002
|
+
(if dot (ly:grob-set-property! dot 'transparent #t))
|
|
2003
|
+
(ly:grob-set-property! tab-note-head 'transparent #t))))
|
|
2004
|
+
tab-heads))
|
|
2005
|
+
|
|
2006
|
+
(define-public (bend::calc-bend-x-end
|
|
2007
|
+
bend-spanner top-left-tab-nhd top-right-tab-nhd)
|
|
2008
|
+
"Calculate the ending x@tie{}coordinate of @var{bend-spanner}. At the line
|
|
2009
|
+
end, take the items of @code{BreakAlignGroup} into account and a little
|
|
2010
|
+
bit of padding. Ends an unbroken spanner or the last of a broken one in the
|
|
2011
|
+
middle of the topmost note head of its bounding note column."
|
|
2012
|
+
(let ((top-right-tab-nhd-x-ext
|
|
2013
|
+
(ly:grob-extent top-right-tab-nhd top-right-tab-nhd X))
|
|
2014
|
+
(curve-x-padding-line-end
|
|
2015
|
+
(assoc-get
|
|
2016
|
+
'curve-x-padding-line-end
|
|
2017
|
+
(ly:grob-property bend-spanner 'details)
|
|
2018
|
+
0))
|
|
2019
|
+
(sys (ly:grob-system bend-spanner))
|
|
2020
|
+
(right-bound
|
|
2021
|
+
(ly:spanner-bound bend-spanner RIGHT)))
|
|
2022
|
+
|
|
2023
|
+
(if (middle-broken-spanner? bend-spanner)
|
|
2024
|
+
(ly:warning
|
|
2025
|
+
(G_ "~a with two line-breaks is not yet supported")
|
|
2026
|
+
bend-spanner))
|
|
2027
|
+
|
|
2028
|
+
(if (unbroken-or-first-broken-spanner? bend-spanner)
|
|
2029
|
+
;; For the first part of a broken bend-spanner ensure avoiding items of
|
|
2030
|
+
;; BreakAlignGroup by taking its most left item's coordinate into the
|
|
2031
|
+
;; calculation.
|
|
2032
|
+
(let* ((right-bound-elts
|
|
2033
|
+
(list-copy
|
|
2034
|
+
(ly:grob-array->list
|
|
2035
|
+
(ly:grob-object right-bound 'elements))))
|
|
2036
|
+
(right-break-align-grobs
|
|
2037
|
+
(if (grob::has-interface right-bound 'paper-column-interface)
|
|
2038
|
+
(filter
|
|
2039
|
+
(lambda (g)
|
|
2040
|
+
(grob::has-interface g 'break-aligned-interface))
|
|
2041
|
+
right-bound-elts)
|
|
2042
|
+
(list right-bound)))
|
|
2043
|
+
(right-break-align-grobs-left-most
|
|
2044
|
+
(car
|
|
2045
|
+
(sort
|
|
2046
|
+
right-break-align-grobs
|
|
2047
|
+
(lambda (g1 g2)
|
|
2048
|
+
(<
|
|
2049
|
+
(ly:grob-relative-coordinate g1 sys X)
|
|
2050
|
+
(ly:grob-relative-coordinate g2 sys X))))))
|
|
2051
|
+
(right-ref-grob-coord
|
|
2052
|
+
(ly:grob-relative-coordinate
|
|
2053
|
+
right-break-align-grobs-left-most sys X))
|
|
2054
|
+
(left-bound
|
|
2055
|
+
(ly:spanner-bound bend-spanner LEFT))
|
|
2056
|
+
(left-bound-x-coord
|
|
2057
|
+
(if (ly:grob? left-bound)
|
|
2058
|
+
(ly:grob-relative-coordinate
|
|
2059
|
+
left-bound
|
|
2060
|
+
(ly:grob-common-refpoint left-bound sys X)
|
|
2061
|
+
X)
|
|
2062
|
+
0)))
|
|
2063
|
+
(+
|
|
2064
|
+
(-
|
|
2065
|
+
right-ref-grob-coord
|
|
2066
|
+
left-bound-x-coord
|
|
2067
|
+
(if (unbroken-spanner? bend-spanner) 0 curve-x-padding-line-end))
|
|
2068
|
+
;; ensure it ends in the middle of the topmost TabNoteHead of the
|
|
2069
|
+
;; right-bounding NoteColumn, if any.
|
|
2070
|
+
(if (unbroken-spanner? bend-spanner)
|
|
2071
|
+
(interval-center top-right-tab-nhd-x-ext)
|
|
2072
|
+
0)))
|
|
2073
|
+
;; last of broken bend-spanner
|
|
2074
|
+
;; simply take the right-bound coordinate
|
|
2075
|
+
(let* ((right-bound-x-coord
|
|
2076
|
+
(if (ly:grob? right-bound)
|
|
2077
|
+
(ly:grob-relative-coordinate right-bound sys X)
|
|
2078
|
+
0)))
|
|
2079
|
+
(+ right-bound-x-coord (interval-center top-right-tab-nhd-x-ext))))))
|
|
2080
|
+
|
|
2081
|
+
(define-public (bend::calc-bend-x-begin
|
|
2082
|
+
bend-spanner bounding-noteheads factor quarter-tone-diffs)
|
|
2083
|
+
"Calculate the starting values in x@tie{}direction of the bend.
|
|
2084
|
+
After a line break, the values from the right bound are taken minus
|
|
2085
|
+
1.5@tie{}staff spaces.
|
|
2086
|
+
For bends-down or if grob property @code{'style} equals to @code{'pre-bend},
|
|
2087
|
+
@code{'hold} or @code{'pre-bend-hold}, @code{interval-center} is applied the
|
|
2088
|
+
topmost note head of the starting note heads.
|
|
2089
|
+
In any other case the right edge of the starting note head is used. The value
|
|
2090
|
+
of @code{BendSpanner.@/details.@/horizontal-left-padding} is added, which may be
|
|
2091
|
+
changed by an appropriate override.
|
|
2092
|
+
Returns a list of the same length as the amount of bend-starting note heads."
|
|
2093
|
+
(let* ((staff-space (ly:staff-symbol-staff-space bend-spanner))
|
|
2094
|
+
(left-note-heads-list-length (length (car bounding-noteheads)))
|
|
2095
|
+
(style (ly:grob-property bend-spanner 'style))
|
|
2096
|
+
(horizontal-left-padding
|
|
2097
|
+
(assoc-get
|
|
2098
|
+
'horizontal-left-padding
|
|
2099
|
+
(ly:grob-property bend-spanner 'details 0)))
|
|
2100
|
+
(top-left-tab-nhd (get-top-most-tab-head (car bounding-noteheads)))
|
|
2101
|
+
(top-right-tab-nhd (get-top-most-tab-head (cdr bounding-noteheads)))
|
|
2102
|
+
(top-left-tab-nhd-x-ext
|
|
2103
|
+
(ly:grob-extent top-left-tab-nhd top-left-tab-nhd X)))
|
|
2104
|
+
(cond ((end-broken-spanner? bend-spanner)
|
|
2105
|
+
(make-list
|
|
2106
|
+
left-note-heads-list-length
|
|
2107
|
+
(- (bend::calc-bend-x-end
|
|
2108
|
+
bend-spanner top-left-tab-nhd top-right-tab-nhd)
|
|
2109
|
+
;; 1.5 is my choice, harm
|
|
2110
|
+
(* 1.5 staff-space))))
|
|
2111
|
+
((or (negative? quarter-tone-diffs)
|
|
2112
|
+
(eq? style 'pre-bend)
|
|
2113
|
+
(eq? style 'pre-bend-hold)
|
|
2114
|
+
(eq? style 'hold)
|
|
2115
|
+
(> factor 1))
|
|
2116
|
+
(make-list
|
|
2117
|
+
left-note-heads-list-length
|
|
2118
|
+
(interval-center top-left-tab-nhd-x-ext)))
|
|
2119
|
+
(else
|
|
2120
|
+
(map
|
|
2121
|
+
(lambda (tnh)
|
|
2122
|
+
(+ (cdr (ly:grob-extent tnh tnh X)) horizontal-left-padding))
|
|
2123
|
+
(car bounding-noteheads))))))
|
|
2124
|
+
|
|
2125
|
+
(define* (bend::calc-y-coordinates
|
|
2126
|
+
bend-spanner staff-space tab-note-heads
|
|
2127
|
+
#:optional quarter-tones-diffs)
|
|
2128
|
+
"Calculates Y-coordinate of @var{bend-spanner}'s start/end in relation to the
|
|
2129
|
+
provided @var{tab-note-heads}.
|
|
2130
|
+
For style @code{'pre-bend} or @code{'pre-bend-hold} or if the bend does not
|
|
2131
|
+
point up the resulting value is offset to the top of the topmost note head.
|
|
2132
|
+
Some vertical padding is added, taken from @var{bend-spanner}'s @code{'details}
|
|
2133
|
+
sub-property @code{'vertical-padding}."
|
|
2134
|
+
(let* ((vertical-padding
|
|
2135
|
+
(assoc-get
|
|
2136
|
+
'vertical-padding
|
|
2137
|
+
(ly:grob-property bend-spanner 'details)))
|
|
2138
|
+
(style (ly:grob-property bend-spanner 'style))
|
|
2139
|
+
(quarter-tones (if quarter-tones-diffs (list quarter-tones-diffs) '()))
|
|
2140
|
+
(top-tab-note-head (get-top-most-tab-head tab-note-heads))
|
|
2141
|
+
(relevant-tab-note-heads
|
|
2142
|
+
(if (or (eq? style 'pre-bend)
|
|
2143
|
+
(eq? style 'pre-bend-hold)
|
|
2144
|
+
(and quarter-tones-diffs (negative? quarter-tones-diffs))
|
|
2145
|
+
(not quarter-tones-diffs))
|
|
2146
|
+
(list top-tab-note-head)
|
|
2147
|
+
tab-note-heads)))
|
|
2148
|
+
(sort
|
|
2149
|
+
(map
|
|
2150
|
+
(lambda (tab-nh)
|
|
2151
|
+
(+
|
|
2152
|
+
(* (/ (ly:grob-property tab-nh 'staff-position) 2) staff-space)
|
|
2153
|
+
(if (or (eq? style 'pre-bend)
|
|
2154
|
+
(eq? style 'pre-bend-hold)
|
|
2155
|
+
(and quarter-tones-diffs (negative? quarter-tones-diffs))
|
|
2156
|
+
(not quarter-tones-diffs))
|
|
2157
|
+
(+
|
|
2158
|
+
(cdr (ly:grob-extent top-tab-note-head top-tab-note-head Y))
|
|
2159
|
+
vertical-padding)
|
|
2160
|
+
(* vertical-padding staff-space))))
|
|
2161
|
+
relevant-tab-note-heads)
|
|
2162
|
+
<)))
|
|
2163
|
+
|
|
2164
|
+
;; The final BendSpanner.stencil is calculated in several steps:
|
|
2165
|
+
;; - the text stencil
|
|
2166
|
+
;; - the arrow head stencil
|
|
2167
|
+
;; - the lines and curves
|
|
2168
|
+
;; - a basic printing procedure
|
|
2169
|
+
;; - joining the results of the basic printing procedure into one stencil
|
|
2170
|
+
;; - the final stencil putting together text, arrow head, lines and curves
|
|
2171
|
+
(define (bend::text-stencil x y text grob)
|
|
2172
|
+
"Returns a stencil that prints the bends amount, translated to the end of
|
|
2173
|
+
the bends arrow head, given by @var{x} and@tie{}@var{y}. A little vertical
|
|
2174
|
+
padding is added."
|
|
2175
|
+
(let* ((layout (ly:grob-layout grob))
|
|
2176
|
+
(props (ly:grob-alist-chain grob))
|
|
2177
|
+
(staff-space (ly:staff-symbol-staff-space grob))
|
|
2178
|
+
(font-size (ly:grob-property grob 'font-size 0.0))
|
|
2179
|
+
(scale-factor (magstep font-size))
|
|
2180
|
+
(vertical-padding
|
|
2181
|
+
(assoc-get
|
|
2182
|
+
'vertical-padding
|
|
2183
|
+
(ly:grob-property grob 'details))))
|
|
2184
|
+
(ly:stencil-translate
|
|
2185
|
+
(ly:stencil-aligned-to
|
|
2186
|
+
(interpret-markup layout props text)
|
|
2187
|
+
X CENTER)
|
|
2188
|
+
;; double vertical-padding is my choice, harm
|
|
2189
|
+
;; TODO let it rely on a separate details-property?
|
|
2190
|
+
(cons x (+ y (* scale-factor vertical-padding 2))))))
|
|
2191
|
+
|
|
2192
|
+
(define-public (bend::arrow-head-stencil
|
|
2193
|
+
thickness x-y-coords height width dir)
|
|
2194
|
+
"Return an arrow head stencil, calculated from the given dimensions
|
|
2195
|
+
@var{height} and @var{width}, and translated to @var{x-y-coords}, the end of
|
|
2196
|
+
the bend-spanners (curved) line."
|
|
2197
|
+
(let* ((pts-list
|
|
2198
|
+
(list
|
|
2199
|
+
;; horizontal-left point, x and y coord
|
|
2200
|
+
(/ width -2) 0
|
|
2201
|
+
;; horizontal-right point, x and y coord
|
|
2202
|
+
(/ width 2) 0
|
|
2203
|
+
;; arrow-top point, x and y coord
|
|
2204
|
+
0 (* height dir))))
|
|
2205
|
+
(ly:stencil-translate
|
|
2206
|
+
(ly:make-stencil
|
|
2207
|
+
`(polygon ,pts-list ,thickness #t)
|
|
2208
|
+
(interval-widen (cons (/ width -2) (/ width 2)) (/ thickness 2))
|
|
2209
|
+
(interval-widen (ordered-cons 0 (* height dir)) (/ thickness 2)))
|
|
2210
|
+
x-y-coords)))
|
|
2211
|
+
|
|
2212
|
+
(define* (bend::make-line-curve-stencil
|
|
2213
|
+
thickness points-list #:optional line-style)
|
|
2214
|
+
"Prints a possibly curved line. If the line is horizontal a dashed line is
|
|
2215
|
+
returned, relying on @var{line-style}. By default this is
|
|
2216
|
+
@code{BendSpanner.details.dashed-line-settings}."
|
|
2217
|
+
(let* ((pts-length (length points-list))
|
|
2218
|
+
(command-list
|
|
2219
|
+
(case pts-length
|
|
2220
|
+
((4)
|
|
2221
|
+
`(moveto
|
|
2222
|
+
,(list-ref points-list 0)
|
|
2223
|
+
,(list-ref points-list 1)
|
|
2224
|
+
lineto
|
|
2225
|
+
,(list-ref points-list 2)
|
|
2226
|
+
,(list-ref points-list 3)))
|
|
2227
|
+
((10)
|
|
2228
|
+
`(moveto
|
|
2229
|
+
,(list-ref points-list 0)
|
|
2230
|
+
,(list-ref points-list 1)
|
|
2231
|
+
lineto
|
|
2232
|
+
,(list-ref points-list 2)
|
|
2233
|
+
,(list-ref points-list 3)
|
|
2234
|
+
curveto
|
|
2235
|
+
,(list-ref points-list 4)
|
|
2236
|
+
,(list-ref points-list 5)
|
|
2237
|
+
,(list-ref points-list 6)
|
|
2238
|
+
,(list-ref points-list 7)
|
|
2239
|
+
,(list-ref points-list 8)
|
|
2240
|
+
,(list-ref points-list 9)))
|
|
2241
|
+
(else
|
|
2242
|
+
(ly:error
|
|
2243
|
+
"list-length ~a needs to have 4 or 10 elements" points-list)))))
|
|
2244
|
+
;; For a horizontal line and proper settings of line-style return a
|
|
2245
|
+
;; translated dashed-line-stencil.
|
|
2246
|
+
(if (and (= (list-ref points-list 1) (list-ref points-list 3))
|
|
2247
|
+
(= 4 pts-length)
|
|
2248
|
+
(= 3 (length+ line-style)))
|
|
2249
|
+
(let ((x-end (- (list-ref points-list 2) (car points-list))))
|
|
2250
|
+
(ly:stencil-translate
|
|
2251
|
+
(ly:make-stencil
|
|
2252
|
+
(list
|
|
2253
|
+
'dashed-line
|
|
2254
|
+
thickness
|
|
2255
|
+
(car line-style) ;; on
|
|
2256
|
+
(cadr line-style) ; off
|
|
2257
|
+
x-end ;; x-end
|
|
2258
|
+
0 ;; y-end
|
|
2259
|
+
(last line-style)) ;; phase
|
|
2260
|
+
;; x-ext
|
|
2261
|
+
(cons 0 x-end)
|
|
2262
|
+
;; y-ext
|
|
2263
|
+
(cons (/ thickness -2) (/ thickness 2)))
|
|
2264
|
+
(cons (car points-list) (cadr points-list))))
|
|
2265
|
+
(make-path-stencil command-list thickness 1 1 #f))))
|
|
2266
|
+
|
|
2267
|
+
(define (bend::draw-curves thickness begin-x middle-x end-x begin-y end-y grob)
|
|
2268
|
+
"Returns the combined stencils created by @code{bend::curve-stencils-list}.
|
|
2269
|
+
All stencils let room to place an arrow head between them and the text
|
|
2270
|
+
indicating the amount string is bent.
|
|
2271
|
+
The descending y@tie{}value of the end point of the curves is taken from
|
|
2272
|
+
@code{details.curve-y-padding-line-end}."
|
|
2273
|
+
;; 'begin-x' will be provided by 'bend::calc-bend-x-begin', always
|
|
2274
|
+
;; returning a list.
|
|
2275
|
+
;; 'begin-y' is supposed to be a list, this should be ensured while calling
|
|
2276
|
+
;; 'bend::draw-curves'
|
|
2277
|
+
(let* ((font-size (ly:grob-property grob 'font-size 0.0))
|
|
2278
|
+
(scale-factor (magstep font-size))
|
|
2279
|
+
(details (ly:grob-property grob 'details))
|
|
2280
|
+
(bend-dir
|
|
2281
|
+
(if (> end-y (apply max begin-y)) -1 1))
|
|
2282
|
+
(bend-arrowhead-height
|
|
2283
|
+
(* scale-factor (assoc-get 'bend-arrowhead-height details)))
|
|
2284
|
+
(curve-line-end-y-padding
|
|
2285
|
+
(if (not-last-broken-spanner? grob)
|
|
2286
|
+
(assoc-get 'curve-y-padding-line-end details 0)
|
|
2287
|
+
0))
|
|
2288
|
+
;; recalculate `end-y' to make room for the arrow head
|
|
2289
|
+
(new-end-y
|
|
2290
|
+
(make-list
|
|
2291
|
+
(length begin-y)
|
|
2292
|
+
(+ end-y (* bend-arrowhead-height bend-dir))))
|
|
2293
|
+
(y-endings
|
|
2294
|
+
(if (zero? curve-line-end-y-padding) ;; i.e. no line-break
|
|
2295
|
+
new-end-y
|
|
2296
|
+
;; otherwise return a list with descending values
|
|
2297
|
+
(reverse
|
|
2298
|
+
(map
|
|
2299
|
+
(lambda (y-end i) (- y-end (* i curve-line-end-y-padding)))
|
|
2300
|
+
new-end-y
|
|
2301
|
+
(iota (length begin-y))))))
|
|
2302
|
+
(curve-stils
|
|
2303
|
+
(map
|
|
2304
|
+
(lambda (beg-x beg-y ending-y)
|
|
2305
|
+
(let* ((lst
|
|
2306
|
+
(list
|
|
2307
|
+
;; moveto
|
|
2308
|
+
beg-x beg-y
|
|
2309
|
+
;; lineto
|
|
2310
|
+
middle-x beg-y
|
|
2311
|
+
;; curveto
|
|
2312
|
+
middle-x beg-y end-x beg-y end-x ending-y)))
|
|
2313
|
+
(bend::make-line-curve-stencil thickness lst)))
|
|
2314
|
+
begin-x
|
|
2315
|
+
begin-y
|
|
2316
|
+
y-endings)))
|
|
2317
|
+
(apply ly:stencil-add curve-stils)))
|
|
2318
|
+
|
|
2319
|
+
(define-public (bend-spanner::print grob)
|
|
2320
|
+
"Return the final stencil. A line and curve, an arrow head and a text
|
|
2321
|
+
representing the amount a string is bent."
|
|
2322
|
+
(let* (;; We need to get _all_ bounding tab-note-heads to calculate the
|
|
2323
|
+
;; correct vertical position of the end of a down-spanner not only the
|
|
2324
|
+
;; ones which actually starts a bend.
|
|
2325
|
+
;; This is important, if the topmost string is not bent.
|
|
2326
|
+
;; But for creating the bend-stencil(s) we only need those which are
|
|
2327
|
+
;; actually bent.
|
|
2328
|
+
;; If after selecting no note-heads remain, print a warning and suicide
|
|
2329
|
+
;; the BendSpanner
|
|
2330
|
+
(details (ly:grob-property grob 'details))
|
|
2331
|
+
(all-left-right-note-heads (get-bound-note-heads grob))
|
|
2332
|
+
(factor (assoc-get 'successive-level details))
|
|
2333
|
+
(previous-dir (assoc-get 'previous-dir details))
|
|
2334
|
+
(left-right-note-heads
|
|
2335
|
+
(cons
|
|
2336
|
+
(bend::remove-certain-tab-note-heads
|
|
2337
|
+
(car all-left-right-note-heads))
|
|
2338
|
+
(bend::remove-certain-tab-note-heads
|
|
2339
|
+
(cdr all-left-right-note-heads)))))
|
|
2340
|
+
(cond
|
|
2341
|
+
;; fool-proof, the user may have set a non-integer by accident
|
|
2342
|
+
((not (integer? factor))
|
|
2343
|
+
(begin
|
|
2344
|
+
(ly:warning (G_ "Factor ~a needs to be an integer value." factor))
|
|
2345
|
+
(ly:grob-suicide! grob)))
|
|
2346
|
+
(else
|
|
2347
|
+
(let* ((staff-symbol (ly:grob-object grob 'staff-symbol))
|
|
2348
|
+
(line-count (ly:grob-property staff-symbol 'line-count))
|
|
2349
|
+
(staff-space (ly:staff-symbol-staff-space grob))
|
|
2350
|
+
(staff-symbol-line-thickness
|
|
2351
|
+
(ly:staff-symbol-line-thickness grob))
|
|
2352
|
+
;; style may be '(), 'hold, 'pre-bend or 'pre-bend-hold
|
|
2353
|
+
(style (ly:grob-property grob 'style))
|
|
2354
|
+
(details (ly:grob-property grob 'details))
|
|
2355
|
+
(dashed-line-settings (assoc-get 'dashed-line-settings details))
|
|
2356
|
+
(font-size (ly:grob-property grob 'font-size 0.0))
|
|
2357
|
+
(scale-factor (magstep font-size))
|
|
2358
|
+
;; get the topmost TabNoteHeads
|
|
2359
|
+
(top-right-tab-nh
|
|
2360
|
+
(get-top-most-tab-head (cdr all-left-right-note-heads)))
|
|
2361
|
+
(top-left-tab-nh
|
|
2362
|
+
(get-top-most-tab-head (car all-left-right-note-heads)))
|
|
2363
|
+
(sorted-left-right-pitches
|
|
2364
|
+
(bounding-note-heads-pitches grob))
|
|
2365
|
+
(quarter-diffs
|
|
2366
|
+
(get-quarter-diffs sorted-left-right-pitches))
|
|
2367
|
+
(bend-direction
|
|
2368
|
+
(if (negative? quarter-diffs) DOWN UP))
|
|
2369
|
+
(bend-up? (positive? bend-direction))
|
|
2370
|
+
(bend-down? (negative? bend-direction))
|
|
2371
|
+
(begin-x-list
|
|
2372
|
+
(bend::calc-bend-x-begin
|
|
2373
|
+
grob
|
|
2374
|
+
left-right-note-heads
|
|
2375
|
+
factor
|
|
2376
|
+
quarter-diffs))
|
|
2377
|
+
(begin-x (car begin-x-list))
|
|
2378
|
+
(begin-y-list
|
|
2379
|
+
(bend::calc-y-coordinates
|
|
2380
|
+
grob staff-space
|
|
2381
|
+
;; for pre-bend and pre-bend-hold we take
|
|
2382
|
+
;; all note-heads into account to avoid collisions
|
|
2383
|
+
;; with a probably not bent open string
|
|
2384
|
+
(if (or (eq? style 'pre-bend)
|
|
2385
|
+
(eq? style 'pre-bend-hold))
|
|
2386
|
+
(car all-left-right-note-heads)
|
|
2387
|
+
(car left-right-note-heads))
|
|
2388
|
+
quarter-diffs))
|
|
2389
|
+
(curve-x-padding-line-end
|
|
2390
|
+
(if (and (first-broken-spanner? grob)
|
|
2391
|
+
(not (eq? style 'pre-bend-hold)))
|
|
2392
|
+
(assoc-get 'curve-x-padding-line-end details 0)
|
|
2393
|
+
0))
|
|
2394
|
+
(end-x
|
|
2395
|
+
(bend::calc-bend-x-end
|
|
2396
|
+
grob top-left-tab-nh top-right-tab-nh))
|
|
2397
|
+
(y-distance-from-tabstaff-to-arrow-tip
|
|
2398
|
+
(* scale-factor
|
|
2399
|
+
(assoc-get 'y-distance-from-tabstaff-to-arrow-tip details)))
|
|
2400
|
+
(end-y
|
|
2401
|
+
(lambda (mult)
|
|
2402
|
+
(+
|
|
2403
|
+
(* (/ (1- line-count) 2) staff-space)
|
|
2404
|
+
(* mult y-distance-from-tabstaff-to-arrow-tip))))
|
|
2405
|
+
(bend-arrowhead-width
|
|
2406
|
+
(* scale-factor
|
|
2407
|
+
(assoc-get 'bend-arrowhead-width details)))
|
|
2408
|
+
(bend-arrowhead-height
|
|
2409
|
+
(* scale-factor
|
|
2410
|
+
(assoc-get 'bend-arrowhead-height details)))
|
|
2411
|
+
(bend-line-thickness
|
|
2412
|
+
(* staff-symbol-line-thickness
|
|
2413
|
+
(ly:grob-property grob 'thickness)))
|
|
2414
|
+
;; curvature-factor, usually between 0 and 1,
|
|
2415
|
+
;; determines the horizontal part of a bend-spanner as percentage
|
|
2416
|
+
;; of the total horizontal extent
|
|
2417
|
+
;; 0.35 as fall-back is my choice, harm
|
|
2418
|
+
(curvature-factor
|
|
2419
|
+
(assoc-get 'curvature-factor details 0.35))
|
|
2420
|
+
(middle-x
|
|
2421
|
+
(+
|
|
2422
|
+
begin-x
|
|
2423
|
+
(* curvature-factor
|
|
2424
|
+
(- end-x begin-x))
|
|
2425
|
+
;; if the curve gets some padding at line-break
|
|
2426
|
+
;; do it here as well - warrants nicer output
|
|
2427
|
+
(- curve-x-padding-line-end)))
|
|
2428
|
+
(arrow-stencil-proc (assoc-get 'arrow-stencil details))
|
|
2429
|
+
(target-visibility (assoc-get 'target-visibility details #f))
|
|
2430
|
+
;; A vector of 3 booleans, #(end-of-line unbroken begin-of-line)
|
|
2431
|
+
(head-text-break-visibility
|
|
2432
|
+
(assoc-get 'head-text-break-visibility details))
|
|
2433
|
+
(head-text-print-condition
|
|
2434
|
+
(cond ((first-broken-spanner? grob)
|
|
2435
|
+
(vector-ref head-text-break-visibility 0))
|
|
2436
|
+
((end-broken-spanner? grob)
|
|
2437
|
+
(vector-ref head-text-break-visibility 2))
|
|
2438
|
+
(else
|
|
2439
|
+
(vector-ref head-text-break-visibility 1))))
|
|
2440
|
+
(bend-amount
|
|
2441
|
+
;; Use 'text if set, fall back to 'bend::text-string'
|
|
2442
|
+
(or (ly:grob-property grob 'text #f)
|
|
2443
|
+
(bend::text-string grob))))
|
|
2444
|
+
|
|
2445
|
+
;; For up-bends, make target note heads transparent.
|
|
2446
|
+
;; If details.target-visibility is set #t they will be parenthesized
|
|
2447
|
+
;;
|
|
2448
|
+
;; Down-bends will get their target note-heads parenthesized via
|
|
2449
|
+
;; 'display-cautionary.
|
|
2450
|
+
;;
|
|
2451
|
+
;; For tied notes all notes except the ones from the first
|
|
2452
|
+
;; note-column become transparent
|
|
2453
|
+
(if (and (positive? quarter-diffs) (not target-visibility))
|
|
2454
|
+
(make-tab-heads-transparent
|
|
2455
|
+
(ly:grob-array->list
|
|
2456
|
+
(ly:grob-object
|
|
2457
|
+
(ly:spanner-bound (ly:grob-original grob) RIGHT)
|
|
2458
|
+
'note-heads))))
|
|
2459
|
+
|
|
2460
|
+
;; the final stencil
|
|
2461
|
+
(ly:stencil-add
|
|
2462
|
+
point-stencil
|
|
2463
|
+
;; The text-stencil, indicating bend-amount
|
|
2464
|
+
;; printed for up-bends only
|
|
2465
|
+
;; in case of line-break it will be printed only at line-begin,
|
|
2466
|
+
;; for 'pre-bend and 'prebend-hold, it is printed at line end
|
|
2467
|
+
(if (and (> bend-direction -1) head-text-print-condition)
|
|
2468
|
+
(let ((text-pos
|
|
2469
|
+
(if (or (eq? style 'pre-bend) (eq? style 'pre-bend-hold))
|
|
2470
|
+
begin-x
|
|
2471
|
+
end-x)))
|
|
2472
|
+
(bend::text-stencil
|
|
2473
|
+
text-pos
|
|
2474
|
+
(end-y factor)
|
|
2475
|
+
bend-amount
|
|
2476
|
+
grob))
|
|
2477
|
+
empty-stencil)
|
|
2478
|
+
|
|
2479
|
+
(cond
|
|
2480
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2481
|
+
;; hold
|
|
2482
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2483
|
+
((eq? style 'hold)
|
|
2484
|
+
(let ((line-end-x-padding
|
|
2485
|
+
(if (first-broken-spanner? grob)
|
|
2486
|
+
(assoc-get 'curve-x-padding-line-end details 0)
|
|
2487
|
+
0)))
|
|
2488
|
+
(bend::make-line-curve-stencil
|
|
2489
|
+
bend-line-thickness
|
|
2490
|
+
(list
|
|
2491
|
+
begin-x
|
|
2492
|
+
(end-y factor)
|
|
2493
|
+
(- end-x line-end-x-padding)
|
|
2494
|
+
(end-y factor))
|
|
2495
|
+
dashed-line-settings)))
|
|
2496
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2497
|
+
;; pre-bend and pre-bend-hold
|
|
2498
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2499
|
+
((or (eq? style 'pre-bend) (eq? style 'pre-bend-hold))
|
|
2500
|
+
(let* ((vertical-line
|
|
2501
|
+
(if (unbroken-or-first-broken-spanner? grob)
|
|
2502
|
+
(bend::make-line-curve-stencil
|
|
2503
|
+
bend-line-thickness
|
|
2504
|
+
(list
|
|
2505
|
+
begin-x
|
|
2506
|
+
(last begin-y-list)
|
|
2507
|
+
begin-x
|
|
2508
|
+
(end-y factor)))
|
|
2509
|
+
empty-stencil))
|
|
2510
|
+
(horizontal-line
|
|
2511
|
+
(if (eq? style 'pre-bend-hold)
|
|
2512
|
+
(let ((line-end-x-padding
|
|
2513
|
+
(if (first-broken-spanner? grob)
|
|
2514
|
+
(assoc-get
|
|
2515
|
+
'curve-x-padding-line-end details 0)
|
|
2516
|
+
0)))
|
|
2517
|
+
(bend::make-line-curve-stencil
|
|
2518
|
+
bend-line-thickness
|
|
2519
|
+
(list
|
|
2520
|
+
begin-x
|
|
2521
|
+
(end-y factor)
|
|
2522
|
+
(- end-x line-end-x-padding)
|
|
2523
|
+
(end-y factor))
|
|
2524
|
+
dashed-line-settings))
|
|
2525
|
+
empty-stencil))
|
|
2526
|
+
(arrow-head
|
|
2527
|
+
(if head-text-print-condition
|
|
2528
|
+
(arrow-stencil-proc
|
|
2529
|
+
bend-line-thickness
|
|
2530
|
+
;;end-curve-coords:
|
|
2531
|
+
(cons
|
|
2532
|
+
begin-x
|
|
2533
|
+
(- (end-y factor)
|
|
2534
|
+
bend-arrowhead-height))
|
|
2535
|
+
bend-arrowhead-height
|
|
2536
|
+
bend-arrowhead-width
|
|
2537
|
+
bend-direction)
|
|
2538
|
+
empty-stencil))
|
|
2539
|
+
)
|
|
2540
|
+
(ly:stencil-add
|
|
2541
|
+
arrow-head
|
|
2542
|
+
vertical-line
|
|
2543
|
+
horizontal-line)))
|
|
2544
|
+
;;;;;;;;;;;;;;;;;;;;;;
|
|
2545
|
+
;; consecutive bends
|
|
2546
|
+
;;;;;;;;;;;;;;;;;;;;;;
|
|
2547
|
+
(else
|
|
2548
|
+
(if (> factor 1)
|
|
2549
|
+
(let* ((val (if bend-down?
|
|
2550
|
+
bend-direction
|
|
2551
|
+
0))
|
|
2552
|
+
(arrow-head
|
|
2553
|
+
(if head-text-print-condition
|
|
2554
|
+
(arrow-stencil-proc
|
|
2555
|
+
bend-line-thickness
|
|
2556
|
+
;; end-curve-coords
|
|
2557
|
+
(cons end-x
|
|
2558
|
+
(+ (end-y (+ factor val))
|
|
2559
|
+
(* -1
|
|
2560
|
+
bend-direction
|
|
2561
|
+
bend-arrowhead-height)))
|
|
2562
|
+
bend-arrowhead-height
|
|
2563
|
+
bend-arrowhead-width
|
|
2564
|
+
bend-direction)
|
|
2565
|
+
empty-stencil))
|
|
2566
|
+
(curves
|
|
2567
|
+
(bend::draw-curves
|
|
2568
|
+
bend-line-thickness
|
|
2569
|
+
begin-x-list middle-x
|
|
2570
|
+
end-x
|
|
2571
|
+
(list
|
|
2572
|
+
(end-y
|
|
2573
|
+
(+ factor val
|
|
2574
|
+
(* -1 bend-direction))))
|
|
2575
|
+
(end-y (+ factor val))
|
|
2576
|
+
grob)))
|
|
2577
|
+
(ly:stencil-add arrow-head curves))
|
|
2578
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2579
|
+
;;;; default bends, i.e. factor is 1
|
|
2580
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2581
|
+
(let* ((new-end-y
|
|
2582
|
+
(if bend-up?
|
|
2583
|
+
(end-y factor)
|
|
2584
|
+
(let* ((end-y-list
|
|
2585
|
+
(bend::calc-y-coordinates
|
|
2586
|
+
grob
|
|
2587
|
+
staff-space
|
|
2588
|
+
(cdr all-left-right-note-heads))))
|
|
2589
|
+
(last end-y-list))))
|
|
2590
|
+
(new-begin-y
|
|
2591
|
+
(if bend-up?
|
|
2592
|
+
begin-y-list
|
|
2593
|
+
(list (end-y factor))))
|
|
2594
|
+
(arrow-head
|
|
2595
|
+
(if head-text-print-condition
|
|
2596
|
+
(arrow-stencil-proc
|
|
2597
|
+
bend-line-thickness
|
|
2598
|
+
;; end-curve-coords
|
|
2599
|
+
(cons
|
|
2600
|
+
end-x
|
|
2601
|
+
(+ new-end-y
|
|
2602
|
+
(* -1
|
|
2603
|
+
bend-direction
|
|
2604
|
+
bend-arrowhead-height)))
|
|
2605
|
+
bend-arrowhead-height
|
|
2606
|
+
bend-arrowhead-width
|
|
2607
|
+
bend-direction)
|
|
2608
|
+
empty-stencil))
|
|
2609
|
+
(curve
|
|
2610
|
+
(bend::draw-curves
|
|
2611
|
+
bend-line-thickness
|
|
2612
|
+
begin-x-list
|
|
2613
|
+
middle-x
|
|
2614
|
+
end-x
|
|
2615
|
+
new-begin-y
|
|
2616
|
+
new-end-y
|
|
2617
|
+
grob)))
|
|
2618
|
+
(ly:stencil-add arrow-head curve)))))))))))
|
|
2619
|
+
|
|
2620
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2621
|
+
;; DurationLine
|
|
2622
|
+
|
|
2623
|
+
;;;; We separate coding the stencil of DurationLine into
|
|
2624
|
+
;;;; - coding arrow-stencil
|
|
2625
|
+
;;;; - coding hook-stencil
|
|
2626
|
+
;;;; - coding duration-line::calc (providing all needed values)
|
|
2627
|
+
;;;; - coding duration-line::print (putting it all together)
|
|
2628
|
+
;;;;
|
|
2629
|
+
;;;; This lowers the hurdle to change those stencil-definitions for the user, if
|
|
2630
|
+
;;;; he wants to.
|
|
2631
|
+
(define-public (arrow-stencil x y thick staff-space grob)
|
|
2632
|
+
"Return a right-pointing, filled arrow-head, where @var{x} determines the basic
|
|
2633
|
+
horizontal position and @var{y} determines the basic vertical position.
|
|
2634
|
+
Both values are adjusted using @var{staff-space}, which is @code{StaffSymbol}'s
|
|
2635
|
+
staff space. @var{thick} is the used line thickness."
|
|
2636
|
+
(let* ((arrow-length (ly:grob-property grob 'arrow-length))
|
|
2637
|
+
(arrow-width (ly:grob-property grob 'arrow-width))
|
|
2638
|
+
(moveto-x
|
|
2639
|
+
;; In duration-line::calc the right end is shortened a bit.
|
|
2640
|
+
;; Thus place the arrow-tip to the right of it.
|
|
2641
|
+
;; (* arrow-length (* staff-space 2/3)) is my choice for it, here and
|
|
2642
|
+
;; in duration-line::calc, harm
|
|
2643
|
+
(+ x (* arrow-length (* staff-space 2/3))))
|
|
2644
|
+
(moveto-y (* y staff-space))
|
|
2645
|
+
;; scale arrow-width/length by staff-space
|
|
2646
|
+
(scaled-arrow-width
|
|
2647
|
+
(* arrow-width staff-space))
|
|
2648
|
+
(scaled-arrow-length
|
|
2649
|
+
(* arrow-length staff-space)))
|
|
2650
|
+
(make-path-stencil
|
|
2651
|
+
(list
|
|
2652
|
+
'moveto moveto-x moveto-y
|
|
2653
|
+
'rlineto (- scaled-arrow-length) (/ scaled-arrow-width 2)
|
|
2654
|
+
'rlineto 0 (* scaled-arrow-width -1)
|
|
2655
|
+
'closepath)
|
|
2656
|
+
thick
|
|
2657
|
+
1 1 #t)))
|
|
2658
|
+
|
|
2659
|
+
(define-public (hook-stencil x y staff-space thick blot grob)
|
|
2660
|
+
"Return a hook stencil where @var{x} determines the horizontal position and
|
|
2661
|
+
@var{y}@tie{}determines the basic vertical position.
|
|
2662
|
+
The final stencil is adjusted vertically using @var{staff-space}, which is
|
|
2663
|
+
@code{StaffSymbol}'s staff space, and uses @var{blot}, which is the current
|
|
2664
|
+
@code{'blot-diameter}. The stencil's thickness is usually taken from @var{grob}
|
|
2665
|
+
@code{'details}, @var{thick} serves as a fallback value."
|
|
2666
|
+
(let* ((details (ly:grob-property grob 'details))
|
|
2667
|
+
(hook-dir (assoc-get 'hook-direction details 1))
|
|
2668
|
+
(hook-height
|
|
2669
|
+
(assoc-get 'hook-height details (* staff-space 2/3)))
|
|
2670
|
+
(hook-thick
|
|
2671
|
+
(or (assoc-get 'hook-thickness details) thick))
|
|
2672
|
+
(hook-X-ext
|
|
2673
|
+
(cons (- x hook-thick) x))
|
|
2674
|
+
(hook-Y-ext
|
|
2675
|
+
(ordered-cons
|
|
2676
|
+
(* hook-dir (+ hook-height thick))
|
|
2677
|
+
0)))
|
|
2678
|
+
(ly:round-filled-box
|
|
2679
|
+
hook-X-ext
|
|
2680
|
+
(coord-translate hook-Y-ext (* y staff-space))
|
|
2681
|
+
blot)))
|
|
2682
|
+
|
|
2683
|
+
(define-public (duration-line::calc grob)
|
|
2684
|
+
"Return list of values needed to print a stencil for @code{DurationLine}."
|
|
2685
|
+
(let* ((note-head-or-rest?
|
|
2686
|
+
(lambda (x)
|
|
2687
|
+
(and (ly:grob? x)
|
|
2688
|
+
(or (grob::has-interface x 'note-head-interface)
|
|
2689
|
+
(grob::has-interface x 'rest-interface)))))
|
|
2690
|
+
(staff-space (ly:staff-symbol-staff-space grob))
|
|
2691
|
+
(grob-layout (ly:grob-layout grob))
|
|
2692
|
+
(layout-thick (layout-line-thickness grob))
|
|
2693
|
+
(blot-diameter
|
|
2694
|
+
(ly:output-def-lookup grob-layout 'blot-diameter))
|
|
2695
|
+
(style (ly:grob-property grob 'style 'beam))
|
|
2696
|
+
(details (ly:grob-property grob 'details))
|
|
2697
|
+
(thickness (ly:grob-property grob 'thickness 4))
|
|
2698
|
+
(left-bound-details
|
|
2699
|
+
(ly:grob-property grob 'left-bound-info))
|
|
2700
|
+
(right-bound-details
|
|
2701
|
+
(ly:grob-property grob 'right-bound-info))
|
|
2702
|
+
(start-at-dot?
|
|
2703
|
+
(assoc-get 'start-at-dot left-bound-details #f))
|
|
2704
|
+
(end-on-accidental?
|
|
2705
|
+
(assoc-get 'end-on-accidental right-bound-details))
|
|
2706
|
+
(end-on-arpeggio?
|
|
2707
|
+
(assoc-get 'end-on-arpeggio right-bound-details))
|
|
2708
|
+
(left-padding
|
|
2709
|
+
(assoc-get 'padding left-bound-details 0))
|
|
2710
|
+
(right-padding
|
|
2711
|
+
(assoc-get 'padding right-bound-details 0))
|
|
2712
|
+
(right-end-style
|
|
2713
|
+
(assoc-get 'end-style right-bound-details #f))
|
|
2714
|
+
;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2715
|
+
;;;; DurationLine start
|
|
2716
|
+
;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2717
|
+
(left-bound (ly:spanner-bound grob LEFT))
|
|
2718
|
+
(left-column
|
|
2719
|
+
(if (note-head-or-rest? left-bound)
|
|
2720
|
+
(ly:grob-parent left-bound X)
|
|
2721
|
+
left-bound))
|
|
2722
|
+
;;;;
|
|
2723
|
+
;;;; adjust for DotColumn of left NoteColumn
|
|
2724
|
+
;;;;
|
|
2725
|
+
;; If DotColumn is present and `start-at-dot' is enabled, we want a
|
|
2726
|
+
;; little extra padding, taken from details.extra-dot-padding.
|
|
2727
|
+
(dot-column (ly:note-column-dot-column left-column))
|
|
2728
|
+
(adjust-for-dot-column
|
|
2729
|
+
(if (and start-at-dot? (ly:grob? dot-column))
|
|
2730
|
+
(assoc-get 'extra-dot-padding details)
|
|
2731
|
+
0))
|
|
2732
|
+
;; `left-X' is line-starting X-coordinate relative to grob's system
|
|
2733
|
+
;; NB the final line-stencil will start at left-bound not at `left-X'
|
|
2734
|
+
;; we need this value to calculate `right-end' lateron
|
|
2735
|
+
(left-X
|
|
2736
|
+
(ly:grob-relative-coordinate
|
|
2737
|
+
left-bound (ly:grob-system left-bound) X))
|
|
2738
|
+
(left-info-X (assoc-get 'X left-bound-details))
|
|
2739
|
+
;; `left-Y' is line-starting Y-coordinate, taken from staff-postion
|
|
2740
|
+
;; of grob's first initiating NoteHead.
|
|
2741
|
+
(left-bound-original (ly:spanner-bound (ly:grob-original grob) LEFT))
|
|
2742
|
+
(raw-left-Y
|
|
2743
|
+
(if (grob::has-interface left-bound-original 'note-column-interface)
|
|
2744
|
+
(let* ((nhds-array
|
|
2745
|
+
(ly:grob-object left-bound-original 'note-heads #f))
|
|
2746
|
+
(nhds-list
|
|
2747
|
+
(if nhds-array
|
|
2748
|
+
(ly:grob-array->list nhds-array)
|
|
2749
|
+
'()))
|
|
2750
|
+
(nhds-pos
|
|
2751
|
+
(map
|
|
2752
|
+
(lambda (nhd) (ly:grob-property nhd 'staff-position))
|
|
2753
|
+
nhds-list)))
|
|
2754
|
+
;; the middle-y of NoteColumn
|
|
2755
|
+
(/ (+ (apply min nhds-pos) (apply max nhds-pos)) 2))
|
|
2756
|
+
;; staff-position of NoteHead/Rest
|
|
2757
|
+
(ly:grob-property left-bound-original 'staff-position 0)))
|
|
2758
|
+
(left-Y
|
|
2759
|
+
(/ (+ (ly:grob-property grob 'Y-offset 0) raw-left-Y) 2))
|
|
2760
|
+
;;;;
|
|
2761
|
+
;;;; final calculation of `left-start'
|
|
2762
|
+
;;;;
|
|
2763
|
+
|
|
2764
|
+
;; `left-start' is line-starting X-coordinate relative to left-bound
|
|
2765
|
+
;;
|
|
2766
|
+
;; If DurationLine is started at "skip", `left-bound' may be
|
|
2767
|
+
;; PaperColumn, with non-zero x-extent. Their x-extent should be
|
|
2768
|
+
;; disregarded in this case, using zero instead.
|
|
2769
|
+
(left-start
|
|
2770
|
+
(+ (if (and (unbroken-or-first-broken-spanner? grob)
|
|
2771
|
+
(grob::has-interface left-bound 'paper-column-interface))
|
|
2772
|
+
0
|
|
2773
|
+
(- left-info-X left-X))
|
|
2774
|
+
adjust-for-dot-column
|
|
2775
|
+
left-padding))
|
|
2776
|
+
;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2777
|
+
;;;; DurationLine end
|
|
2778
|
+
;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2779
|
+
(right-bound (ly:spanner-bound grob RIGHT))
|
|
2780
|
+
;;;;
|
|
2781
|
+
;;;; adjust or Arpeggio of right NoteColumn
|
|
2782
|
+
;;;;
|
|
2783
|
+
;;;; TODO: build this into the line-spanner-interface, allowing it
|
|
2784
|
+
;;;; to be used on other line spanners.
|
|
2785
|
+
(arpeggio-start
|
|
2786
|
+
(if end-on-arpeggio?
|
|
2787
|
+
(let* ((conditional-elements
|
|
2788
|
+
(ly:grob-object right-bound 'conditional-elements #f))
|
|
2789
|
+
(cond-elts-list
|
|
2790
|
+
(if conditional-elements
|
|
2791
|
+
(ly:grob-array->list conditional-elements)
|
|
2792
|
+
'()))
|
|
2793
|
+
(arpeggio-ls
|
|
2794
|
+
(filter
|
|
2795
|
+
(lambda (g)
|
|
2796
|
+
(grob::has-interface g 'arpeggio-interface))
|
|
2797
|
+
cond-elts-list)))
|
|
2798
|
+
(if (and (pair? arpeggio-ls) (ly:grob? (car arpeggio-ls)))
|
|
2799
|
+
(interval-start (ly:grob-extent (car arpeggio-ls)
|
|
2800
|
+
(ly:grob-system grob)
|
|
2801
|
+
X))
|
|
2802
|
+
#f))
|
|
2803
|
+
#f))
|
|
2804
|
+
|
|
2805
|
+
;;;;
|
|
2806
|
+
;;;; adjust for arrow
|
|
2807
|
+
;;;;
|
|
2808
|
+
(adjust-for-arrow
|
|
2809
|
+
(if (eq? right-end-style 'arrow)
|
|
2810
|
+
;; We do not go for the full arrow-length, to avoid a
|
|
2811
|
+
;; visible gap for certain styles
|
|
2812
|
+
(* (ly:grob-property grob 'arrow-length)
|
|
2813
|
+
(* staff-space 2/3))
|
|
2814
|
+
0))
|
|
2815
|
+
;;;;
|
|
2816
|
+
;;;; final calculation of `right-end'
|
|
2817
|
+
;;;;
|
|
2818
|
+
(right-info-X
|
|
2819
|
+
(assoc-get 'X right-bound-details 0))
|
|
2820
|
+
;; Repect padding and other possible items.
|
|
2821
|
+
(right-end
|
|
2822
|
+
(- (or arpeggio-start right-info-X)
|
|
2823
|
+
left-X
|
|
2824
|
+
right-padding
|
|
2825
|
+
adjust-for-arrow))
|
|
2826
|
+
|
|
2827
|
+
;; TODO find a method to accept user-generated line-ending stencils
|
|
2828
|
+
|
|
2829
|
+
;;;;
|
|
2830
|
+
;;;; arrow
|
|
2831
|
+
;;;;
|
|
2832
|
+
(arrow-stil
|
|
2833
|
+
(if (and (not (eq? style 'none))
|
|
2834
|
+
(eq? right-end-style 'arrow))
|
|
2835
|
+
(begin
|
|
2836
|
+
;; For 1/3 see remark in `arrow-stencil' above
|
|
2837
|
+
(if (> (* 1/3 staff-space (ly:grob-property grob 'arrow-length))
|
|
2838
|
+
(- right-end left-start))
|
|
2839
|
+
(ly:warning
|
|
2840
|
+
(G_ "Not enough space to print a nice arrow.
|
|
2841
|
+
Please consider to increase 'minimum-length or decrease 'arrow-length.")))
|
|
2842
|
+
(arrow-stencil
|
|
2843
|
+
right-end left-Y layout-thick staff-space grob))
|
|
2844
|
+
empty-stencil))
|
|
2845
|
+
;;;;;;;;
|
|
2846
|
+
;;;; hook
|
|
2847
|
+
;;;;;;;;
|
|
2848
|
+
(hook-stil
|
|
2849
|
+
;; hooks are currently implemented for beam-style only
|
|
2850
|
+
(if (and (eq? style 'beam) (eq? right-end-style 'hook))
|
|
2851
|
+
(hook-stencil
|
|
2852
|
+
right-end left-Y staff-space thickness blot-diameter grob)
|
|
2853
|
+
empty-stencil)))
|
|
2854
|
+
|
|
2855
|
+
(if (> left-start right-end)
|
|
2856
|
+
(ly:warning (G_ "Please consider to increase 'minimum-length")))
|
|
2857
|
+
|
|
2858
|
+
;;;;;;;;;;;;;;;;;;;;
|
|
2859
|
+
;;;; final alist
|
|
2860
|
+
;;;;;;;;;;;;;;;;;;;;
|
|
2861
|
+
|
|
2862
|
+
(list
|
|
2863
|
+
(cons 'x-start left-start)
|
|
2864
|
+
(cons 'x-end right-end)
|
|
2865
|
+
(cons 'y left-Y)
|
|
2866
|
+
(cons 'staff-space staff-space)
|
|
2867
|
+
(cons 'blot blot-diameter)
|
|
2868
|
+
(cons 'style style)
|
|
2869
|
+
(cons 'thick thickness)
|
|
2870
|
+
(cons 'arrow arrow-stil)
|
|
2871
|
+
(cons 'hook hook-stil))))
|
|
2872
|
+
|
|
2873
|
+
(define-public (duration-line::print grob)
|
|
2874
|
+
"Return the stencil of @code{DurationLine}."
|
|
2875
|
+
(let* ((vals (duration-line::calc grob))
|
|
2876
|
+
(style (assoc-get 'style vals))
|
|
2877
|
+
(left-start (assoc-get 'x-start vals))
|
|
2878
|
+
(right-end (assoc-get 'x-end vals))
|
|
2879
|
+
(left-Y (assoc-get 'y vals))
|
|
2880
|
+
(staff-space (assoc-get 'staff-space vals))
|
|
2881
|
+
(blot-diameter (assoc-get 'blot vals))
|
|
2882
|
+
(thick (assoc-get 'thick vals))
|
|
2883
|
+
(hook-stil (assoc-get 'hook vals))
|
|
2884
|
+
(arrow-stil (assoc-get 'arrow vals)))
|
|
2885
|
+
|
|
2886
|
+
(if (eq? style 'beam)
|
|
2887
|
+
(ly:stencil-add
|
|
2888
|
+
(ly:round-filled-box
|
|
2889
|
+
(cons left-start right-end)
|
|
2890
|
+
(coord-translate
|
|
2891
|
+
(cons (/ thick -2) (/ thick 2))
|
|
2892
|
+
(* left-Y staff-space))
|
|
2893
|
+
blot-diameter)
|
|
2894
|
+
hook-stil
|
|
2895
|
+
arrow-stil)
|
|
2896
|
+
(ly:stencil-add
|
|
2897
|
+
(ly:line-interface::line
|
|
2898
|
+
grob
|
|
2899
|
+
left-start
|
|
2900
|
+
(* left-Y staff-space)
|
|
2901
|
+
right-end
|
|
2902
|
+
(* left-Y staff-space))
|
|
2903
|
+
arrow-stil))))
|
|
2904
|
+
|
|
2905
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
2906
|
+
;; finger glide spanner
|
|
2907
|
+
|
|
2908
|
+
(define-public finger-glide::print
|
|
2909
|
+
(lambda (grob)
|
|
2910
|
+
"The stencil printing procedure for grob @code{FingerGlideSpanner}.
|
|
2911
|
+
Depending on the grob property @code{style} several forms of appearance are
|
|
2912
|
+
printed.
|
|
2913
|
+
Possible settings for grob property @code{style} are @code{zigzag},
|
|
2914
|
+
@code{trill}, @code{dashed-line}, @code{dotted-line}, @code{stub-left},
|
|
2915
|
+
@code{stub-right}, @code{stub-both}, @code{bow}, @code{none} and @code{line},
|
|
2916
|
+
which is the default."
|
|
2917
|
+
(let* ((style (ly:grob-property grob 'style 'line)))
|
|
2918
|
+
(if (eq? style 'line)
|
|
2919
|
+
(ly:line-spanner::print grob)
|
|
2920
|
+
(let* ((thick (ly:grob-property grob 'thickness 1))
|
|
2921
|
+
(line-thick (ly:staff-symbol-line-thickness grob))
|
|
2922
|
+
(left-bound-info
|
|
2923
|
+
(ly:grob-property grob 'left-bound-info))
|
|
2924
|
+
(right-bound-info
|
|
2925
|
+
(ly:grob-property grob 'right-bound-info))
|
|
2926
|
+
(left-padding (assoc-get 'padding left-bound-info 0.5))
|
|
2927
|
+
(right-padding (assoc-get 'padding right-bound-info 0.5))
|
|
2928
|
+
(left-bound (ly:spanner-bound grob LEFT))
|
|
2929
|
+
(right-bound (ly:spanner-bound grob RIGHT))
|
|
2930
|
+
(sys (ly:grob-system grob))
|
|
2931
|
+
(left-coord
|
|
2932
|
+
(ly:grob-relative-coordinate left-bound sys X))
|
|
2933
|
+
(X-left (assoc-get 'X left-bound-info))
|
|
2934
|
+
(x-start (- X-left left-coord (- left-padding)))
|
|
2935
|
+
(X-right (assoc-get 'X right-bound-info))
|
|
2936
|
+
(x-end (- X-right left-coord (+ right-padding)))
|
|
2937
|
+
(y-end (assoc-get 'Y right-bound-info))
|
|
2938
|
+
(y-start
|
|
2939
|
+
(cond (;; TODO sufficient?
|
|
2940
|
+
(and (end-broken-spanner? grob) (eq? style 'bow))
|
|
2941
|
+
y-end)
|
|
2942
|
+
(else
|
|
2943
|
+
(assoc-get 'Y left-bound-info))))
|
|
2944
|
+
(x-length (- x-end x-start))
|
|
2945
|
+
(y-height (- y-end y-start))
|
|
2946
|
+
;; We calculate the length of the stubs in X-axis direction and
|
|
2947
|
+
;; use this value to draw the stub-lines below.
|
|
2948
|
+
;; This ensures a constant printed magnitude for all gradients
|
|
2949
|
+
(left-info-stub-length
|
|
2950
|
+
(assoc-get 'left-stub-length left-bound-info 1))
|
|
2951
|
+
(left-stub-x-y
|
|
2952
|
+
(ly:directed (cons x-length y-height) left-info-stub-length))
|
|
2953
|
+
(right-info-stub-length
|
|
2954
|
+
(assoc-get 'right-stub-length right-bound-info 1))
|
|
2955
|
+
(right-stub-x-y
|
|
2956
|
+
(ly:directed (cons x-length y-height) right-info-stub-length))
|
|
2957
|
+
(left-stub-stil
|
|
2958
|
+
(if (and (grob::has-interface left-bound 'finger-interface)
|
|
2959
|
+
(member style '(stub-left stub-both)))
|
|
2960
|
+
(make-line-stencil
|
|
2961
|
+
(* line-thick thick)
|
|
2962
|
+
x-start
|
|
2963
|
+
y-start
|
|
2964
|
+
(+ x-start (car left-stub-x-y))
|
|
2965
|
+
(+ y-start (cdr left-stub-x-y)))
|
|
2966
|
+
empty-stencil))
|
|
2967
|
+
(right-stub-stil
|
|
2968
|
+
(if (and (grob::has-interface right-bound 'finger-interface)
|
|
2969
|
+
(member style '(stub-right stub-both)))
|
|
2970
|
+
(make-line-stencil
|
|
2971
|
+
(* line-thick thick)
|
|
2972
|
+
(- x-end (car right-stub-x-y))
|
|
2973
|
+
(- y-end (cdr right-stub-x-y))
|
|
2974
|
+
x-end
|
|
2975
|
+
y-end)
|
|
2976
|
+
empty-stencil)))
|
|
2977
|
+
|
|
2978
|
+
(case style
|
|
2979
|
+
((stub-both)
|
|
2980
|
+
(ly:stencil-add left-stub-stil right-stub-stil))
|
|
2981
|
+
((stub-left) left-stub-stil)
|
|
2982
|
+
((stub-right) right-stub-stil)
|
|
2983
|
+
((bow)
|
|
2984
|
+
(let* ((details (ly:grob-property grob 'details))
|
|
2985
|
+
;; TODO find a more sufficient fall back
|
|
2986
|
+
(fall-back (if (negative? y-start) DOWN UP))
|
|
2987
|
+
;; Go for direction modifiers, if used
|
|
2988
|
+
(cause (ly:grob-property grob 'cause))
|
|
2989
|
+
(dirs
|
|
2990
|
+
(filter-map
|
|
2991
|
+
(lambda (art)
|
|
2992
|
+
(ly:prob-property art 'direction #f))
|
|
2993
|
+
(ly:prob-property cause 'articulations)))
|
|
2994
|
+
(dir
|
|
2995
|
+
(if (and (pair? dirs) (ly:dir? (car dirs)))
|
|
2996
|
+
(car dirs)
|
|
2997
|
+
#f))
|
|
2998
|
+
(bow-direction
|
|
2999
|
+
(or (assoc-get 'bow-direction details)
|
|
3000
|
+
dir
|
|
3001
|
+
fall-back)))
|
|
3002
|
+
(make-tie-stencil
|
|
3003
|
+
(cons x-start y-start)
|
|
3004
|
+
(cons x-end y-end)
|
|
3005
|
+
(* line-thick thick)
|
|
3006
|
+
bow-direction)))
|
|
3007
|
+
(else (ly:line-spanner::print grob))))))))
|
|
3008
|
+
|
|
3009
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
3010
|
+
;; control points and polygons
|
|
3011
|
+
|
|
3012
|
+
(define-public ((control-point::calc-offset axis) grob)
|
|
3013
|
+
(let* ((bezier (ly:grob-object grob 'bezier))
|
|
3014
|
+
(control-points (ly:grob-property bezier 'control-points))
|
|
3015
|
+
(index (ly:grob-property grob 'index))
|
|
3016
|
+
(offset (list-ref control-points index)))
|
|
3017
|
+
(coord-axis offset axis)))
|
|
3018
|
+
|
|
3019
|
+
(define-public (control-polygon::calc-text grob)
|
|
3020
|
+
(let* ((bezier (ly:grob-object grob 'bezier))
|
|
3021
|
+
(control-points (ly:grob-property bezier 'control-points)))
|
|
3022
|
+
(make-polygon-markup control-points)))
|
|
3023
|
+
|
|
3024
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
3025
|
+
;; sticky grobs
|
|
3026
|
+
|
|
3027
|
+
(define-public ((sticky-grob-interface::inherit-property property) grob)
|
|
3028
|
+
(ly:grob-property
|
|
3029
|
+
(ly:grob-object grob 'sticky-host)
|
|
3030
|
+
property))
|
|
3031
|
+
|
|
3032
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
3033
|
+
;; pitched trills
|
|
3034
|
+
|
|
3035
|
+
;; Why not ly:axis-group-interface::pure-height? The latter callback is
|
|
3036
|
+
;; designed for vertical axis group spanners, filtering out grobs not in
|
|
3037
|
+
;; the [start, end] interval. That's not correct for TrillPitchGroup,
|
|
3038
|
+
;; a horizontal axis group item (remember that item pure heights are assumed
|
|
3039
|
+
;; not to depend on start and end, and cached once and for all).
|
|
3040
|
+
|
|
3041
|
+
;; TODO: perhaps this could be incorporated into the axis-group-interface too?
|
|
3042
|
+
(define-public (trill-pitch-group::pure-height grob start end)
|
|
3043
|
+
(let* ((vertical-axis-group (ly:grob-parent grob Y))
|
|
3044
|
+
(elements (ly:grob-array->list (ly:grob-object grob 'elements)))
|
|
3045
|
+
(pure-group-extent
|
|
3046
|
+
(reduce interval-union
|
|
3047
|
+
empty-interval
|
|
3048
|
+
(map
|
|
3049
|
+
(lambda (elt)
|
|
3050
|
+
(ly:grob-pure-height elt vertical-axis-group 0 0))
|
|
3051
|
+
elements)))
|
|
3052
|
+
;; It would be crazy to make this nonzero, but anyway.
|
|
3053
|
+
(my-pure-coord (ly:grob-pure-property grob 'Y-offset 0 0 0.0)))
|
|
3054
|
+
(coord-translate pure-group-extent (- my-pure-coord))))
|
|
3055
|
+
|
|
3056
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
3057
|
+
;; chord grids
|
|
3058
|
+
|
|
3059
|
+
(define-public (chord-square::width grob)
|
|
3060
|
+
;; The BarLine's X-extent is not necessarily the right measure of where to
|
|
3061
|
+
;; start and stop. For a chord square at the left of a repeat bar line ":|.",
|
|
3062
|
+
;; you want to extent the square to the '|' glyph, not the ':' one. This uses
|
|
3063
|
+
;; a simple approach to determine the correct point: take a skyline of the bar
|
|
3064
|
+
;; line, pad it a bit (mainly to protect against rounding errors), and take
|
|
3065
|
+
;; the height at the Y positions of the two horizontal lines of the square.
|
|
3066
|
+
(match-let* (((low . high) (ly:grob-extent grob grob Y))
|
|
3067
|
+
(common (ly:grob-system grob))
|
|
3068
|
+
(my-coord (ly:grob-relative-coordinate grob common X)))
|
|
3069
|
+
(define (x-position-for-bound dir)
|
|
3070
|
+
(let* ((bound (ly:spanner-bound grob dir))
|
|
3071
|
+
(bound-coord (ly:grob-relative-coordinate bound common X))
|
|
3072
|
+
(basic-position (- bound-coord my-coord)))
|
|
3073
|
+
(if (grob::has-interface bound 'bar-line-interface)
|
|
3074
|
+
(let* ((skyline-pair (ly:grob-property bound 'horizontal-skylines))
|
|
3075
|
+
(skyline (index-cell skyline-pair (- dir)))
|
|
3076
|
+
(padded (ly:skyline-pad skyline 0.05))
|
|
3077
|
+
(correction
|
|
3078
|
+
((if (eqv? dir LEFT)
|
|
3079
|
+
max
|
|
3080
|
+
min)
|
|
3081
|
+
(ly:skyline-height padded low)
|
|
3082
|
+
(ly:skyline-height padded high))))
|
|
3083
|
+
(+ basic-position correction))
|
|
3084
|
+
;; If it's not a bar line, the bound is probably the
|
|
3085
|
+
;; NonMusicalPaperColumn at the beginning of the piece; there is no
|
|
3086
|
+
;; bar line there but system start delimiters (unless the original bar
|
|
3087
|
+
;; line is a repeat bar line, since those *are* printed at the start
|
|
3088
|
+
;; of the piece). It's unclear what breakable items one could have
|
|
3089
|
+
;; there (there are never any clefs or such in chord grids), so we
|
|
3090
|
+
;; just assume that column has zero width.
|
|
3091
|
+
basic-position)))
|
|
3092
|
+
(pair-map x-position-for-bound (cons LEFT RIGHT))))
|
|
3093
|
+
|
|
3094
|
+
(define-public (chord-square::height grob)
|
|
3095
|
+
;; If the chord square is in a \stopStaff passage, kill it.
|
|
3096
|
+
(let* (;; Use ly:grob-object on `grob` here since the left bound might be a
|
|
3097
|
+
;; paper column, which was not created in ChordGrid (but in
|
|
3098
|
+
;; ChordGridScore) and consequently doesn't have 'staff-symbol set.
|
|
3099
|
+
(left-staff-symbol (ly:grob-object grob 'staff-symbol #f))
|
|
3100
|
+
;; On the other hand, the right bound is always a BarLine.
|
|
3101
|
+
(right-staff-symbol
|
|
3102
|
+
(let ((right (ly:spanner-bound grob RIGHT)))
|
|
3103
|
+
(when (not (grob::has-interface right 'bar-line-interface))
|
|
3104
|
+
(ly:programming-error
|
|
3105
|
+
"right bound of ChordSquare should be bar line, found ~a" right))
|
|
3106
|
+
(ly:grob-object right 'staff-symbol #f)))
|
|
3107
|
+
;; The ChordSquare needs either of the two staff symbols spanning it
|
|
3108
|
+
;; entirely.
|
|
3109
|
+
(bound-column-when
|
|
3110
|
+
(lambda (spanner direction)
|
|
3111
|
+
(let* ((bound (ly:spanner-bound spanner direction))
|
|
3112
|
+
(column (ly:item-get-column bound)))
|
|
3113
|
+
(ly:grob-property column 'when))))
|
|
3114
|
+
(staff-symbol-spans-square?
|
|
3115
|
+
(lambda (staff-symbol direction)
|
|
3116
|
+
(let ((staff-symbol-when (bound-column-when staff-symbol direction))
|
|
3117
|
+
(square-when (bound-column-when grob direction)))
|
|
3118
|
+
((if (eqv? direction LEFT)
|
|
3119
|
+
moment<=?
|
|
3120
|
+
(lambda (a b)
|
|
3121
|
+
(moment<=? b a)))
|
|
3122
|
+
staff-symbol-when
|
|
3123
|
+
square-when))))
|
|
3124
|
+
(staff-symbol-to-use
|
|
3125
|
+
(cond
|
|
3126
|
+
((and left-staff-symbol
|
|
3127
|
+
(staff-symbol-spans-square? left-staff-symbol RIGHT))
|
|
3128
|
+
left-staff-symbol)
|
|
3129
|
+
((and right-staff-symbol
|
|
3130
|
+
(staff-symbol-spans-square? right-staff-symbol LEFT))
|
|
3131
|
+
right-staff-symbol)
|
|
3132
|
+
(else
|
|
3133
|
+
#f))))
|
|
3134
|
+
(if staff-symbol-to-use
|
|
3135
|
+
(interval-widen (ly:grob-extent staff-symbol-to-use staff-symbol-to-use Y)
|
|
3136
|
+
(- (ly:staff-symbol-line-thickness staff-symbol-to-use)))
|
|
3137
|
+
(begin
|
|
3138
|
+
(let ((chord-names (ly:grob-object grob 'chord-names #f)))
|
|
3139
|
+
(when chord-names
|
|
3140
|
+
(ly:warning
|
|
3141
|
+
"removing chord names on chord square because no staff symbol was found")
|
|
3142
|
+
(for-each ly:grob-suicide!
|
|
3143
|
+
(ly:grob-array->list chord-names))))
|
|
3144
|
+
(ly:grob-suicide! grob)))))
|
|
3145
|
+
|
|
3146
|
+
(define (check-division-alist grob prop-name)
|
|
3147
|
+
(let ((alist (ly:grob-property grob prop-name)))
|
|
3148
|
+
;; Assume `alist` is an alist, which is checked by the alist? predicate on
|
|
3149
|
+
;; the property.
|
|
3150
|
+
(for-each
|
|
3151
|
+
(lambda (entry)
|
|
3152
|
+
(let ((key (car entry)))
|
|
3153
|
+
(cond
|
|
3154
|
+
((not (number-list? key))
|
|
3155
|
+
(ly:warning "key in ~a should be numer list: ~a"
|
|
3156
|
+
prop-name
|
|
3157
|
+
key))
|
|
3158
|
+
;; Also checks for exactness since (eqv? 1 1.0) => #f
|
|
3159
|
+
;; (unlike (= 1 1.0) => #t).
|
|
3160
|
+
((not (eqv? 1 (apply + key)))
|
|
3161
|
+
(ly:warning "key in ~a should contain exact numbers adding up to 1: ~a"
|
|
3162
|
+
prop-name
|
|
3163
|
+
key)))))
|
|
3164
|
+
alist)
|
|
3165
|
+
alist))
|
|
3166
|
+
|
|
3167
|
+
(define-public (chord-square::print grob)
|
|
3168
|
+
(let* ((division (ly:grob-property grob 'measure-division))
|
|
3169
|
+
(lines-alist (check-division-alist grob 'measure-division-lines-alist))
|
|
3170
|
+
(lines (or (assoc-get division lines-alist)
|
|
3171
|
+
(begin
|
|
3172
|
+
(ly:warning
|
|
3173
|
+
(G_ "no entry in measure-division-lines-alist for measure division ~a")
|
|
3174
|
+
division)
|
|
3175
|
+
'())))
|
|
3176
|
+
(X-ext (ly:grob-extent grob grob X))
|
|
3177
|
+
(Y-ext (ly:grob-extent grob grob Y)))
|
|
3178
|
+
(apply ly:stencil-add
|
|
3179
|
+
(map
|
|
3180
|
+
(match-lambda
|
|
3181
|
+
((x1 y1 x2 y2)
|
|
3182
|
+
(let ((scaled-x1 (interval-index X-ext x1))
|
|
3183
|
+
(scaled-y1 (interval-index Y-ext y1))
|
|
3184
|
+
(scaled-x2 (interval-index X-ext x2))
|
|
3185
|
+
(scaled-y2 (interval-index Y-ext y2)))
|
|
3186
|
+
(ly:line-interface::line grob scaled-x1 scaled-y1 scaled-x2 scaled-y2))))
|
|
3187
|
+
lines))))
|
|
3188
|
+
|
|
3189
|
+
(define-public ((grid-chord-name::calc-offset-on-axis axis) grob)
|
|
3190
|
+
(let* ((square (ly:grob-parent grob X))
|
|
3191
|
+
(division (ly:grob-property square 'measure-division))
|
|
3192
|
+
(placement-alist
|
|
3193
|
+
(check-division-alist square 'measure-division-chord-placement-alist))
|
|
3194
|
+
(placement (or (assoc-get division placement-alist)
|
|
3195
|
+
(begin
|
|
3196
|
+
(ly:warning
|
|
3197
|
+
(G_ "no entry in measure-division-chord-placement-alist \
|
|
3198
|
+
for measure division ~a")
|
|
3199
|
+
division)
|
|
3200
|
+
(circular-list '(0 . 0)))))
|
|
3201
|
+
(index (ly:grob-property grob 'index))
|
|
3202
|
+
(coords (list-ref placement index))
|
|
3203
|
+
(coord (coord-axis coords axis))
|
|
3204
|
+
(extent (ly:grob-extent square square axis))
|
|
3205
|
+
(scaled-coord (interval-index extent coord))
|
|
3206
|
+
(stencil (ly:grob-property grob 'stencil))
|
|
3207
|
+
(stencil-extent (ly:stencil-extent stencil axis))
|
|
3208
|
+
;; TODO is configurability (self-alignment-{X,Y}?) called for?
|
|
3209
|
+
(center (interval-center stencil-extent)))
|
|
3210
|
+
(- scaled-coord center)))
|
|
3211
|
+
|
|
3212
|
+
(define-public grid-chord-name::calc-X-offset (grid-chord-name::calc-offset-on-axis X))
|
|
3213
|
+
(define-public grid-chord-name::calc-Y-offset (grid-chord-name::calc-offset-on-axis Y))
|
|
3214
|
+
|
|
3215
|
+
(define-public default-measure-division-lines-alist
|
|
3216
|
+
'(((1) . ())
|
|
3217
|
+
((1/2 1/2) . ((-1 -1 1 1)))
|
|
3218
|
+
((1/2 1/4 1/4) . ((-1 -1 1 1) (0 0 1 -1)))
|
|
3219
|
+
((1/4 1/4 1/2) . ((-1 -1 1 1) (-1 1 0 0)))
|
|
3220
|
+
((1/4 1/4 1/4 1/4) . ((-1 -1 1 1) (-1 1 1 -1)))
|
|
3221
|
+
((1/4 3/4) . ((-1 -1 0 0) (-1 1 0 0)))
|
|
3222
|
+
((3/4 1/4) . ((0 0 1 -1) (0 0 1 1)))))
|
|
3223
|
+
|
|
3224
|
+
(define-public default-measure-division-chord-placement-alist
|
|
3225
|
+
'(((1) . ((0 . 0)))
|
|
3226
|
+
((1/2 1/2) . ((-0.4 . 0.4) (0.4 . -0.4)))
|
|
3227
|
+
((1/2 1/4 1/4) . ((-0.4 . 0.4) (0 . -0.65) (0.63 . 0)))
|
|
3228
|
+
((1/4 1/4 1/2) . ((-0.63 . 0) (0 . 0.65) (0.4 . -0.4)))
|
|
3229
|
+
((1/4 1/4 1/4 1/4) . ((-0.63 . 0) (0 . 0.7) (0 . -0.65) (0.63 . 0)))
|
|
3230
|
+
((1/4 3/4) . ((-0.63 . 0) (0.38 . 0)))
|
|
3231
|
+
((3/4 1/4) . ((-0.38 . 0) (0.63 . 0)))))
|
|
3232
|
+
|
|
3233
|
+
(define-public median-measure-division-lines-alist
|
|
3234
|
+
(assoc-set!
|
|
3235
|
+
(alist-copy default-measure-division-lines-alist)
|
|
3236
|
+
'(1/4 1/4 1/4 1/4)
|
|
3237
|
+
'((0 -1 0 1) (-1 0 1 0))))
|
|
3238
|
+
|
|
3239
|
+
(define-public median-measure-division-chord-placement-alist
|
|
3240
|
+
(assoc-set!
|
|
3241
|
+
(alist-copy default-measure-division-chord-placement-alist)
|
|
3242
|
+
'(1/4 1/4 1/4 1/4)
|
|
3243
|
+
'((-0.5 . 0.5) (0.5 . 0.5) (-0.5 . -0.5) (0.5 . -0.5))))
|
|
3244
|
+
|
|
3245
|
+
|
|
3246
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
3247
|
+
;; staff highlights
|
|
3248
|
+
|
|
3249
|
+
(define (staff-highlight::width grob)
|
|
3250
|
+
(let ((refp (ly:grob-system grob)))
|
|
3251
|
+
(define (bound-start/end direction)
|
|
3252
|
+
(let ((bound (ly:spanner-bound grob direction)))
|
|
3253
|
+
(cond
|
|
3254
|
+
(((if (eqv? direction LEFT)
|
|
3255
|
+
not-first-broken-spanner?
|
|
3256
|
+
not-last-broken-spanner?)
|
|
3257
|
+
grob)
|
|
3258
|
+
(let ((ext (ly:grob-robust-relative-extent bound refp X)))
|
|
3259
|
+
(interval-index ext direction)))
|
|
3260
|
+
((let ((break-alignment (ly:grob-object bound 'break-alignment #f)))
|
|
3261
|
+
(and break-alignment
|
|
3262
|
+
(ly:break-alignment-interface::find-nonempty-break-align-group
|
|
3263
|
+
break-alignment
|
|
3264
|
+
'staff-bar)))
|
|
3265
|
+
=> (lambda (bar-group)
|
|
3266
|
+
(interval-end (ly:grob-extent bar-group refp X))))
|
|
3267
|
+
(else
|
|
3268
|
+
;; By default, don't include any prefatory material. The simplest way
|
|
3269
|
+
;; would be to take the end/start of the extent of our left bound
|
|
3270
|
+
;; (NonMusicalPaperColumn), but this makes the highlight boundary look
|
|
3271
|
+
;; too close to the prefatory matter, so we pad a bit with
|
|
3272
|
+
;; bound-prefatory-paddings. However, we absolutely want to avoid
|
|
3273
|
+
;; having the highlight boundary cross a note head, so we cap at the
|
|
3274
|
+
;; boundary with musical material. This is given to us by the
|
|
3275
|
+
;; 'columns array, which contains all PaperColumns the highlight
|
|
3276
|
+
;; spans. (Columns spanned by the original highlight but not by this
|
|
3277
|
+
;; broken piece have been removed by break substitution, and the array
|
|
3278
|
+
;; is ordered.) Note that we use a paper column, not a note column.
|
|
3279
|
+
;; Highlights in a staff may be influenced by the presence of
|
|
3280
|
+
;; suspended notes in another staff. This is intentional. If there
|
|
3281
|
+
;; are highlights in parallel in different staves, we want them to
|
|
3282
|
+
;; start and end at the same places.
|
|
3283
|
+
(let ((non-musical-boundary-ext (ly:grob-extent bound refp X)))
|
|
3284
|
+
(if (interval-empty? non-musical-boundary-ext)
|
|
3285
|
+
;; If there is no prefatory material at all, no need to shy away
|
|
3286
|
+
;; from this column.
|
|
3287
|
+
(ly:grob-relative-coordinate bound refp X)
|
|
3288
|
+
(let* ((non-musical-boundary
|
|
3289
|
+
(interval-index non-musical-boundary-ext (- direction)))
|
|
3290
|
+
(padding (index-cell (ly:grob-property grob 'bound-prefatory-paddings)
|
|
3291
|
+
direction))
|
|
3292
|
+
(columns (ly:grob-array->list (ly:grob-object grob 'columns)))
|
|
3293
|
+
(musical-boundary
|
|
3294
|
+
;; Find the first/last column that actually contains
|
|
3295
|
+
;; material. If there are skips, they don't factor into
|
|
3296
|
+
;; the highlight start and end.
|
|
3297
|
+
(any
|
|
3298
|
+
(lambda (col)
|
|
3299
|
+
(let* ((basic-ext (ly:grob-extent col refp X))
|
|
3300
|
+
;; The extent of a PaperColumn does not
|
|
3301
|
+
;; include accidentals.
|
|
3302
|
+
(conditional
|
|
3303
|
+
(ly:grob-object col 'conditional-elements))
|
|
3304
|
+
(conditional-ext
|
|
3305
|
+
(ly:relative-group-extent conditional refp X))
|
|
3306
|
+
(ext
|
|
3307
|
+
(interval-union basic-ext conditional-ext)))
|
|
3308
|
+
(and (not (interval-empty? ext))
|
|
3309
|
+
(interval-index ext direction))))
|
|
3310
|
+
(if (eqv? direction LEFT)
|
|
3311
|
+
;; search from left
|
|
3312
|
+
columns
|
|
3313
|
+
;; search from right
|
|
3314
|
+
(reverse columns))))
|
|
3315
|
+
(wished-coord ((if (eqv? direction LEFT)
|
|
3316
|
+
+
|
|
3317
|
+
-)
|
|
3318
|
+
non-musical-boundary
|
|
3319
|
+
padding)))
|
|
3320
|
+
(if (or (not musical-boundary)
|
|
3321
|
+
((if (eqv? direction LEFT)
|
|
3322
|
+
<=
|
|
3323
|
+
>=)
|
|
3324
|
+
wished-coord
|
|
3325
|
+
musical-boundary))
|
|
3326
|
+
wished-coord
|
|
3327
|
+
musical-boundary))))))))
|
|
3328
|
+
(let ((base-position (ly:grob-relative-coordinate grob refp X))
|
|
3329
|
+
(start (bound-start/end LEFT))
|
|
3330
|
+
(end (bound-start/end RIGHT))
|
|
3331
|
+
(shorten-pair (ly:grob-property grob 'shorten-pair)))
|
|
3332
|
+
(cons
|
|
3333
|
+
(- (+ start (car shorten-pair))
|
|
3334
|
+
base-position)
|
|
3335
|
+
(- (- end (cdr shorten-pair))
|
|
3336
|
+
base-position)))))
|
|
3337
|
+
|
|
3338
|
+
(define (staff-highlight::height grob)
|
|
3339
|
+
(let* ((staff-symbol-array (ly:grob-object grob 'elements))
|
|
3340
|
+
(refp (ly:grob-common-refpoint-of-array grob staff-symbol-array Y)))
|
|
3341
|
+
;; Combine StaffSymbol heights. Use the same "widened"
|
|
3342
|
+
;; extents as bar lines.
|
|
3343
|
+
(fold (lambda (staff-symbol height-so-far)
|
|
3344
|
+
(interval-union
|
|
3345
|
+
height-so-far
|
|
3346
|
+
(let ((ext (ly:grob-property staff-symbol 'widened-extent))
|
|
3347
|
+
(coord (ly:grob-relative-coordinate staff-symbol refp Y)))
|
|
3348
|
+
(coord-translate ext coord))))
|
|
3349
|
+
empty-interval
|
|
3350
|
+
(ly:grob-array->list staff-symbol-array))))
|
|
3351
|
+
|
|
3352
|
+
(define (staff-highlight::print grob)
|
|
3353
|
+
(let* ((width (ly:grob-extent grob grob X))
|
|
3354
|
+
(height (ly:grob-extent grob grob Y)))
|
|
3355
|
+
(make-filled-box-stencil width height)))
|
|
3356
|
+
|
|
3357
|
+
|
|
3358
|
+
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
3359
|
+
;; text marks
|
|
3360
|
+
|
|
3361
|
+
(define-public (text-mark-interface::calc-break-visibility grob)
|
|
3362
|
+
(let* ((ev (event-cause grob))
|
|
3363
|
+
(is-end-mark (eqv? LEFT (ly:event-property ev 'horizontal-direction))))
|
|
3364
|
+
(if is-end-mark begin-of-line-invisible end-of-line-invisible)))
|
|
3365
|
+
|
|
3366
|
+
(define-public (text-mark-interface::calc-self-alignment-X grob)
|
|
3367
|
+
;; \textEndMark aligns on the right, as it's intended for text that look back
|
|
3368
|
+
;; at the preceding music, and is visible at the end of a line. \textMark
|
|
3369
|
+
;; aligns on the left; text marks are often long (in the sense of "longer than
|
|
3370
|
+
;; rehearsal marks, which are just one letter"), so centering doesn't look
|
|
3371
|
+
;; very well. That said, text marks fit various exotic use cases, so it is to
|
|
3372
|
+
;; be expected that the user will have to tweak self-alignment-X sometimes.
|
|
3373
|
+
(let* ((ev (event-cause grob))
|
|
3374
|
+
(is-end-mark (eqv? LEFT (ly:event-property ev 'horizontal-direction))))
|
|
3375
|
+
(if is-end-mark
|
|
3376
|
+
RIGHT
|
|
3377
|
+
LEFT)))
|