LilyPond-Ruby 0.0.2.1 → 0.1.2
Sign up to get free protection for your applications and to get access to all the features.
- 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/guile.rb +19 -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/lib/lilypond/builder.rb +161 -0
- data/lib/lilypond-ruby.rb +18 -3
- 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 +1135 -4
@@ -0,0 +1,848 @@
|
|
1
|
+
;;; Continuation-passing style (CPS) intermediate language (IL)
|
2
|
+
|
3
|
+
;; Copyright (C) 2013, 2014, 2015 Free Software Foundation, Inc.
|
4
|
+
|
5
|
+
;;;; This library is free software; you can redistribute it and/or
|
6
|
+
;;;; modify it under the terms of the GNU Lesser General Public
|
7
|
+
;;;; License as published by the Free Software Foundation; either
|
8
|
+
;;;; version 3 of the License, or (at your option) any later version.
|
9
|
+
;;;;
|
10
|
+
;;;; This library is distributed in the hope that it will be useful,
|
11
|
+
;;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
12
|
+
;;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
13
|
+
;;;; Lesser General Public License for more details.
|
14
|
+
;;;;
|
15
|
+
;;;; You should have received a copy of the GNU Lesser General Public
|
16
|
+
;;;; License along with this library; if not, write to the Free Software
|
17
|
+
;;;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
|
18
|
+
|
19
|
+
;;; Commentary:
|
20
|
+
;;;
|
21
|
+
;;; This pass converts a CPS term in such a way that no function has any
|
22
|
+
;;; free variables. Instead, closures are built explicitly with
|
23
|
+
;;; make-closure primcalls, and free variables are referenced through
|
24
|
+
;;; the closure.
|
25
|
+
;;;
|
26
|
+
;;; Closure conversion also removes any $rec expressions that
|
27
|
+
;;; contification did not handle. See (language cps) for a further
|
28
|
+
;;; discussion of $rec.
|
29
|
+
;;;
|
30
|
+
;;; Code:
|
31
|
+
|
32
|
+
(define-module (language cps closure-conversion)
|
33
|
+
#:use-module (ice-9 match)
|
34
|
+
#:use-module ((srfi srfi-1) #:select (fold
|
35
|
+
filter-map
|
36
|
+
))
|
37
|
+
#:use-module (srfi srfi-11)
|
38
|
+
#:use-module (language cps)
|
39
|
+
#:use-module (language cps utils)
|
40
|
+
#:use-module (language cps with-cps)
|
41
|
+
#:use-module (language cps intmap)
|
42
|
+
#:use-module (language cps intset)
|
43
|
+
#:export (convert-closures))
|
44
|
+
|
45
|
+
(define (compute-function-bodies conts kfun)
|
46
|
+
"Compute a map from FUN-LABEL->BODY-LABEL... for all $fun instances in
|
47
|
+
conts."
|
48
|
+
(let visit-fun ((kfun kfun) (out empty-intmap))
|
49
|
+
(let ((body (compute-function-body conts kfun)))
|
50
|
+
(intset-fold
|
51
|
+
(lambda (label out)
|
52
|
+
(match (intmap-ref conts label)
|
53
|
+
(($ $kargs _ _ ($ $continue _ _ ($ $fun kfun)))
|
54
|
+
(visit-fun kfun out))
|
55
|
+
(($ $kargs _ _ ($ $continue _ _ ($ $rec _ _ (($ $fun kfun) ...))))
|
56
|
+
(fold visit-fun out kfun))
|
57
|
+
(_ out)))
|
58
|
+
body
|
59
|
+
(intmap-add out kfun body)))))
|
60
|
+
|
61
|
+
(define (compute-program-body functions)
|
62
|
+
(intmap-fold (lambda (label body out) (intset-union body out))
|
63
|
+
functions
|
64
|
+
empty-intset))
|
65
|
+
|
66
|
+
(define (filter-reachable conts functions)
|
67
|
+
(let ((reachable (compute-program-body functions)))
|
68
|
+
(intmap-fold
|
69
|
+
(lambda (label cont out)
|
70
|
+
(if (intset-ref reachable label)
|
71
|
+
out
|
72
|
+
(intmap-remove out label)))
|
73
|
+
conts conts)))
|
74
|
+
|
75
|
+
(define (compute-non-operator-uses conts)
|
76
|
+
(persistent-intset
|
77
|
+
(intmap-fold
|
78
|
+
(lambda (label cont uses)
|
79
|
+
(define (add-use var uses) (intset-add! uses var))
|
80
|
+
(define (add-uses vars uses)
|
81
|
+
(match vars
|
82
|
+
(() uses)
|
83
|
+
((var . vars) (add-uses vars (add-use var uses)))))
|
84
|
+
(match cont
|
85
|
+
(($ $kargs _ _ ($ $continue _ _ exp))
|
86
|
+
(match exp
|
87
|
+
((or ($ $const) ($ $prim) ($ $fun) ($ $rec)) uses)
|
88
|
+
(($ $values args)
|
89
|
+
(add-uses args uses))
|
90
|
+
(($ $call proc args)
|
91
|
+
(add-uses args uses))
|
92
|
+
(($ $branch kt ($ $values (arg)))
|
93
|
+
(add-use arg uses))
|
94
|
+
(($ $branch kt ($ $primcall name args))
|
95
|
+
(add-uses args uses))
|
96
|
+
(($ $primcall name args)
|
97
|
+
(add-uses args uses))
|
98
|
+
(($ $prompt escape? tag handler)
|
99
|
+
(add-use tag uses))))
|
100
|
+
(_ uses)))
|
101
|
+
conts
|
102
|
+
empty-intset)))
|
103
|
+
|
104
|
+
(define (compute-singly-referenced-labels conts body)
|
105
|
+
(define (add-ref label single multiple)
|
106
|
+
(define (ref k single multiple)
|
107
|
+
(if (intset-ref single k)
|
108
|
+
(values single (intset-add! multiple k))
|
109
|
+
(values (intset-add! single k) multiple)))
|
110
|
+
(define (ref0) (values single multiple))
|
111
|
+
(define (ref1 k) (ref k single multiple))
|
112
|
+
(define (ref2 k k*)
|
113
|
+
(if k*
|
114
|
+
(let-values (((single multiple) (ref k single multiple)))
|
115
|
+
(ref k* single multiple))
|
116
|
+
(ref1 k)))
|
117
|
+
(match (intmap-ref conts label)
|
118
|
+
(($ $kreceive arity k) (ref1 k))
|
119
|
+
(($ $kfun src meta self ktail kclause) (ref2 ktail kclause))
|
120
|
+
(($ $ktail) (ref0))
|
121
|
+
(($ $kclause arity kbody kalt) (ref2 kbody kalt))
|
122
|
+
(($ $kargs names syms ($ $continue k src exp))
|
123
|
+
(ref2 k (match exp (($ $branch k) k) (($ $prompt _ _ k) k) (_ #f))))))
|
124
|
+
(let*-values (((single multiple) (values empty-intset empty-intset))
|
125
|
+
((single multiple) (intset-fold add-ref body single multiple)))
|
126
|
+
(intset-subtract (persistent-intset single)
|
127
|
+
(persistent-intset multiple))))
|
128
|
+
|
129
|
+
(define (compute-function-names conts functions)
|
130
|
+
"Compute a map of FUN-LABEL->BOUND-VAR... for each labelled function
|
131
|
+
whose bound vars we know."
|
132
|
+
(define (add-named-fun var kfun out)
|
133
|
+
(let ((self (match (intmap-ref conts kfun)
|
134
|
+
(($ $kfun src meta self) self))))
|
135
|
+
(intmap-add out kfun (intset var self))))
|
136
|
+
(intmap-fold
|
137
|
+
(lambda (label body out)
|
138
|
+
(let ((single (compute-singly-referenced-labels conts body)))
|
139
|
+
(intset-fold
|
140
|
+
(lambda (label out)
|
141
|
+
(match (intmap-ref conts label)
|
142
|
+
(($ $kargs _ _ ($ $continue k _ ($ $fun kfun)))
|
143
|
+
(if (intset-ref single k)
|
144
|
+
(match (intmap-ref conts k)
|
145
|
+
(($ $kargs (_) (var)) (add-named-fun var kfun out))
|
146
|
+
(_ out))
|
147
|
+
out))
|
148
|
+
(($ $kargs _ _ ($ $continue k _ ($ $rec _ vars (($ $fun kfun) ...))))
|
149
|
+
(unless (intset-ref single k)
|
150
|
+
(error "$rec continuation has multiple predecessors??"))
|
151
|
+
(fold add-named-fun out vars kfun))
|
152
|
+
(_ out)))
|
153
|
+
body
|
154
|
+
out)))
|
155
|
+
functions
|
156
|
+
empty-intmap))
|
157
|
+
|
158
|
+
(define (compute-well-known-functions conts bound->label)
|
159
|
+
"Compute a set of labels indicating the well-known functions in
|
160
|
+
@var{conts}. A well-known function is a function whose bound names we
|
161
|
+
know and which is never used in a non-operator position."
|
162
|
+
(intset-subtract
|
163
|
+
(persistent-intset
|
164
|
+
(intmap-fold (lambda (bound label candidates)
|
165
|
+
(intset-add! candidates label))
|
166
|
+
bound->label
|
167
|
+
empty-intset))
|
168
|
+
(persistent-intset
|
169
|
+
(intset-fold (lambda (var not-well-known)
|
170
|
+
(match (intmap-ref bound->label var (lambda (_) #f))
|
171
|
+
(#f not-well-known)
|
172
|
+
(label (intset-add! not-well-known label))))
|
173
|
+
(compute-non-operator-uses conts)
|
174
|
+
empty-intset))))
|
175
|
+
|
176
|
+
(define (intset-cons i set)
|
177
|
+
(intset-add set i))
|
178
|
+
|
179
|
+
(define (compute-shared-closures conts well-known)
|
180
|
+
"Compute a map LABEL->VAR indicating the sets of functions that will
|
181
|
+
share a closure. If a functions's label is in the map, it is shared.
|
182
|
+
The entries indicate the var of the shared closure, which will be one of
|
183
|
+
the bound vars of the closure."
|
184
|
+
(intmap-fold
|
185
|
+
(lambda (label cont out)
|
186
|
+
(match cont
|
187
|
+
(($ $kargs _ _
|
188
|
+
($ $continue _ _ ($ $rec names vars (($ $fun kfuns) ...))))
|
189
|
+
;; The split-rec pass should have ensured that this $rec forms a
|
190
|
+
;; strongly-connected component, so the free variables from all of
|
191
|
+
;; the functions will be alive as long as one of the closures is
|
192
|
+
;; alive. For that reason we can consider storing all free
|
193
|
+
;; variables in one closure and sharing it.
|
194
|
+
(let* ((kfuns-set (fold intset-cons empty-intset kfuns))
|
195
|
+
(unknown-kfuns (intset-subtract kfuns-set well-known)))
|
196
|
+
(cond
|
197
|
+
((or (eq? empty-intset kfuns-set) (trivial-intset kfuns-set))
|
198
|
+
;; There is only zero or one function bound here. Trivially
|
199
|
+
;; shared already.
|
200
|
+
out)
|
201
|
+
((eq? empty-intset unknown-kfuns)
|
202
|
+
;; All functions are well-known; we can share a closure. Use
|
203
|
+
;; the first bound variable.
|
204
|
+
(let ((closure (car vars)))
|
205
|
+
(intset-fold (lambda (kfun out)
|
206
|
+
(intmap-add out kfun closure))
|
207
|
+
kfuns-set out)))
|
208
|
+
((trivial-intset unknown-kfuns)
|
209
|
+
=> (lambda (unknown-kfun)
|
210
|
+
;; Only one function is not-well-known. Use that
|
211
|
+
;; function's closure as the shared closure.
|
212
|
+
(let ((closure (assq-ref (map cons kfuns vars) unknown-kfun)))
|
213
|
+
(intset-fold (lambda (kfun out)
|
214
|
+
(intmap-add out kfun closure))
|
215
|
+
kfuns-set out))))
|
216
|
+
(else
|
217
|
+
;; More than one not-well-known function means we need more
|
218
|
+
;; than one proper closure, so we can't share.
|
219
|
+
out))))
|
220
|
+
(_ out)))
|
221
|
+
conts
|
222
|
+
empty-intmap))
|
223
|
+
|
224
|
+
(define* (rewrite-shared-closure-calls cps functions label->bound shared kfun)
|
225
|
+
"Rewrite CPS such that every call to a function with a shared closure
|
226
|
+
instead is a $callk to that label, but passing the shared closure as the
|
227
|
+
proc argument. For recursive calls, use the appropriate 'self'
|
228
|
+
variable, if possible. Also rewrite uses of the non-well-known but
|
229
|
+
shared closures to use the appropriate 'self' variable, if possible."
|
230
|
+
;; env := var -> (var . label)
|
231
|
+
(define (rewrite-fun kfun cps env)
|
232
|
+
(define (subst var)
|
233
|
+
(match (intmap-ref env var (lambda (_) #f))
|
234
|
+
(#f var)
|
235
|
+
((var . label) var)))
|
236
|
+
|
237
|
+
(define (rename-exp label cps names vars k src exp)
|
238
|
+
(intmap-replace!
|
239
|
+
cps label
|
240
|
+
(build-cont
|
241
|
+
($kargs names vars
|
242
|
+
($continue k src
|
243
|
+
,(rewrite-exp exp
|
244
|
+
((or ($ $const) ($ $prim)) ,exp)
|
245
|
+
(($ $call proc args)
|
246
|
+
,(let ((args (map subst args)))
|
247
|
+
(rewrite-exp (intmap-ref env proc (lambda (_) #f))
|
248
|
+
(#f ($call proc ,args))
|
249
|
+
((closure . label) ($callk label closure ,args)))))
|
250
|
+
(($ $primcall name args)
|
251
|
+
($primcall name ,(map subst args)))
|
252
|
+
(($ $branch k ($ $values (arg)))
|
253
|
+
($branch k ($values ((subst arg)))))
|
254
|
+
(($ $branch k ($ $primcall name args))
|
255
|
+
($branch k ($primcall name ,(map subst args))))
|
256
|
+
(($ $values args)
|
257
|
+
($values ,(map subst args)))
|
258
|
+
(($ $prompt escape? tag handler)
|
259
|
+
($prompt escape? (subst tag) handler))))))))
|
260
|
+
|
261
|
+
(define (visit-exp label cps names vars k src exp)
|
262
|
+
(define (compute-env label bound self rec-bound rec-labels env)
|
263
|
+
(define (add-bound-var bound label env)
|
264
|
+
(intmap-add env bound (cons self label) (lambda (old new) new)))
|
265
|
+
(if (intmap-ref shared label (lambda (_) #f))
|
266
|
+
;; Within a function with a shared closure, rewrite
|
267
|
+
;; references to bound vars to use the "self" var.
|
268
|
+
(fold add-bound-var env rec-bound rec-labels)
|
269
|
+
;; Otherwise be sure to use "self" references in any
|
270
|
+
;; closure.
|
271
|
+
(add-bound-var bound label env)))
|
272
|
+
(match exp
|
273
|
+
(($ $fun label)
|
274
|
+
(rewrite-fun label cps env))
|
275
|
+
(($ $rec names vars (($ $fun labels) ...))
|
276
|
+
(fold (lambda (label var cps)
|
277
|
+
(match (intmap-ref cps label)
|
278
|
+
(($ $kfun src meta self)
|
279
|
+
(rewrite-fun label cps
|
280
|
+
(compute-env label var self vars labels
|
281
|
+
env)))))
|
282
|
+
cps labels vars))
|
283
|
+
(_ (rename-exp label cps names vars k src exp))))
|
284
|
+
|
285
|
+
(define (rewrite-cont label cps)
|
286
|
+
(match (intmap-ref cps label)
|
287
|
+
(($ $kargs names vars ($ $continue k src exp))
|
288
|
+
(visit-exp label cps names vars k src exp))
|
289
|
+
(_ cps)))
|
290
|
+
|
291
|
+
(intset-fold rewrite-cont (intmap-ref functions kfun) cps))
|
292
|
+
|
293
|
+
;; Initial environment is bound-var -> (shared-var . label) map for
|
294
|
+
;; functions with shared closures.
|
295
|
+
(let ((env (intmap-fold (lambda (label shared env)
|
296
|
+
(intset-fold (lambda (bound env)
|
297
|
+
(intmap-add env bound
|
298
|
+
(cons shared label)))
|
299
|
+
(intset-remove
|
300
|
+
(intmap-ref label->bound label)
|
301
|
+
(match (intmap-ref cps label)
|
302
|
+
(($ $kfun src meta self) self)))
|
303
|
+
env))
|
304
|
+
shared
|
305
|
+
empty-intmap)))
|
306
|
+
(persistent-intmap (rewrite-fun kfun cps env))))
|
307
|
+
|
308
|
+
(define (compute-free-vars conts kfun shared)
|
309
|
+
"Compute a FUN-LABEL->FREE-VAR... map describing all free variable
|
310
|
+
references."
|
311
|
+
(define (add-def var defs) (intset-add! defs var))
|
312
|
+
(define (add-defs vars defs)
|
313
|
+
(match vars
|
314
|
+
(() defs)
|
315
|
+
((var . vars) (add-defs vars (add-def var defs)))))
|
316
|
+
(define (add-use var uses)
|
317
|
+
(intset-add! uses var))
|
318
|
+
(define (add-uses vars uses)
|
319
|
+
(match vars
|
320
|
+
(() uses)
|
321
|
+
((var . vars) (add-uses vars (add-use var uses)))))
|
322
|
+
(define (visit-nested-funs body)
|
323
|
+
(intset-fold
|
324
|
+
(lambda (label out)
|
325
|
+
(match (intmap-ref conts label)
|
326
|
+
(($ $kargs _ _ ($ $continue _ _
|
327
|
+
($ $fun kfun)))
|
328
|
+
(intmap-union out (visit-fun kfun)))
|
329
|
+
(($ $kargs _ _ ($ $continue _ _
|
330
|
+
($ $rec _ _ (($ $fun labels) ...))))
|
331
|
+
(let* ((out (fold (lambda (kfun out)
|
332
|
+
(intmap-union out (visit-fun kfun)))
|
333
|
+
out labels))
|
334
|
+
(free (fold (lambda (kfun free)
|
335
|
+
(intset-union free (intmap-ref out kfun)))
|
336
|
+
empty-intset labels)))
|
337
|
+
(fold (lambda (kfun out)
|
338
|
+
;; For functions that share a closure, the free
|
339
|
+
;; variables for one will be the union of the free
|
340
|
+
;; variables for all.
|
341
|
+
(if (intmap-ref shared kfun (lambda (_) #f))
|
342
|
+
(intmap-replace out kfun free)
|
343
|
+
out))
|
344
|
+
out
|
345
|
+
labels)))
|
346
|
+
(_ out)))
|
347
|
+
body
|
348
|
+
empty-intmap))
|
349
|
+
(define (visit-fun kfun)
|
350
|
+
(let* ((body (compute-function-body conts kfun))
|
351
|
+
(free (visit-nested-funs body)))
|
352
|
+
(call-with-values
|
353
|
+
(lambda ()
|
354
|
+
(intset-fold
|
355
|
+
(lambda (label defs uses)
|
356
|
+
(match (intmap-ref conts label)
|
357
|
+
(($ $kargs names vars ($ $continue k src exp))
|
358
|
+
(values
|
359
|
+
(add-defs vars defs)
|
360
|
+
(match exp
|
361
|
+
((or ($ $const) ($ $prim)) uses)
|
362
|
+
(($ $fun kfun)
|
363
|
+
(intset-union (persistent-intset uses)
|
364
|
+
(intmap-ref free kfun)))
|
365
|
+
(($ $rec names vars (($ $fun kfun) ...))
|
366
|
+
(fold (lambda (kfun uses)
|
367
|
+
(intset-union (persistent-intset uses)
|
368
|
+
(intmap-ref free kfun)))
|
369
|
+
uses kfun))
|
370
|
+
(($ $values args)
|
371
|
+
(add-uses args uses))
|
372
|
+
(($ $call proc args)
|
373
|
+
(add-use proc (add-uses args uses)))
|
374
|
+
(($ $callk label proc args)
|
375
|
+
(add-use proc (add-uses args uses)))
|
376
|
+
(($ $branch kt ($ $values (arg)))
|
377
|
+
(add-use arg uses))
|
378
|
+
(($ $branch kt ($ $primcall name args))
|
379
|
+
(add-uses args uses))
|
380
|
+
(($ $primcall name args)
|
381
|
+
(add-uses args uses))
|
382
|
+
(($ $prompt escape? tag handler)
|
383
|
+
(add-use tag uses)))))
|
384
|
+
(($ $kfun src meta self)
|
385
|
+
(values (add-def self defs) uses))
|
386
|
+
(_ (values defs uses))))
|
387
|
+
body empty-intset empty-intset))
|
388
|
+
(lambda (defs uses)
|
389
|
+
(intmap-add free kfun (intset-subtract
|
390
|
+
(persistent-intset uses)
|
391
|
+
(persistent-intset defs)))))))
|
392
|
+
(visit-fun kfun))
|
393
|
+
|
394
|
+
(define (eliminate-closure? label free-vars)
|
395
|
+
(eq? (intmap-ref free-vars label) empty-intset))
|
396
|
+
|
397
|
+
(define (closure-label label shared bound->label)
|
398
|
+
(cond
|
399
|
+
((intmap-ref shared label (lambda (_) #f))
|
400
|
+
=> (lambda (closure)
|
401
|
+
(intmap-ref bound->label closure)))
|
402
|
+
(else label)))
|
403
|
+
|
404
|
+
(define (closure-alias label well-known free-vars)
|
405
|
+
(and (intset-ref well-known label)
|
406
|
+
(trivial-intset (intmap-ref free-vars label))))
|
407
|
+
|
408
|
+
(define (prune-free-vars free-vars bound->label well-known shared)
|
409
|
+
"Given the label->bound-var map @var{free-vars}, remove free variables
|
410
|
+
that are known functions with zero free variables, and replace
|
411
|
+
references to well-known functions with one free variable with that free
|
412
|
+
variable, until we reach a fixed point on the free-vars map."
|
413
|
+
(define (prune-free in-label free free-vars)
|
414
|
+
(intset-fold (lambda (var free)
|
415
|
+
(match (intmap-ref bound->label var (lambda (_) #f))
|
416
|
+
(#f free)
|
417
|
+
(label
|
418
|
+
(cond
|
419
|
+
((eliminate-closure? label free-vars)
|
420
|
+
(intset-remove free var))
|
421
|
+
((closure-alias (closure-label label shared bound->label)
|
422
|
+
well-known free-vars)
|
423
|
+
=> (lambda (alias)
|
424
|
+
;; If VAR is free in LABEL, then ALIAS must
|
425
|
+
;; also be free because its definition must
|
426
|
+
;; precede VAR's definition.
|
427
|
+
(intset-add (intset-remove free var) alias)))
|
428
|
+
(else free)))))
|
429
|
+
free free))
|
430
|
+
(fixpoint (lambda (free-vars)
|
431
|
+
(intmap-fold (lambda (label free free-vars)
|
432
|
+
(intmap-replace free-vars label
|
433
|
+
(prune-free label free free-vars)))
|
434
|
+
free-vars
|
435
|
+
free-vars))
|
436
|
+
free-vars))
|
437
|
+
|
438
|
+
(define (intset-find set i)
|
439
|
+
(let lp ((idx 0) (start #f))
|
440
|
+
(let ((start (intset-next set start)))
|
441
|
+
(cond
|
442
|
+
((not start) (error "not found" set i))
|
443
|
+
((= start i) idx)
|
444
|
+
(else (lp (1+ idx) (1+ start)))))))
|
445
|
+
|
446
|
+
(define (intset-count set)
|
447
|
+
(intset-fold (lambda (_ count) (1+ count)) set 0))
|
448
|
+
|
449
|
+
(define (convert-one cps label body free-vars bound->label well-known shared)
|
450
|
+
(define (well-known? label)
|
451
|
+
(intset-ref well-known label))
|
452
|
+
|
453
|
+
(let* ((free (intmap-ref free-vars label))
|
454
|
+
(nfree (intset-count free))
|
455
|
+
(self-known? (well-known? (closure-label label shared bound->label)))
|
456
|
+
(self (match (intmap-ref cps label) (($ $kfun _ _ self) self))))
|
457
|
+
(define (convert-arg cps var k)
|
458
|
+
"Convert one possibly free variable reference to a bound reference.
|
459
|
+
|
460
|
+
If @var{var} is free, it is replaced by a closure reference via a
|
461
|
+
@code{free-ref} primcall, and @var{k} is called with the new var.
|
462
|
+
Otherwise @var{var} is bound, so @var{k} is called with @var{var}."
|
463
|
+
;; We know that var is not the name of a well-known function.
|
464
|
+
(cond
|
465
|
+
((and=> (intmap-ref bound->label var (lambda (_) #f))
|
466
|
+
(lambda (kfun)
|
467
|
+
(and (eq? empty-intset (intmap-ref free-vars kfun))
|
468
|
+
kfun)))
|
469
|
+
;; A not-well-known function with zero free vars. Copy as a
|
470
|
+
;; constant, relying on the linker to reify just one copy.
|
471
|
+
=> (lambda (kfun)
|
472
|
+
(with-cps cps
|
473
|
+
(letv var*)
|
474
|
+
(let$ body (k var*))
|
475
|
+
(letk k* ($kargs (#f) (var*) ,body))
|
476
|
+
(build-term ($continue k* #f ($closure kfun 0))))))
|
477
|
+
((intset-ref free var)
|
478
|
+
(match (vector self-known? nfree)
|
479
|
+
(#(#t 1)
|
480
|
+
;; A reference to the one free var of a well-known function.
|
481
|
+
(with-cps cps
|
482
|
+
($ (k self))))
|
483
|
+
(#(#t 2)
|
484
|
+
;; A reference to one of the two free vars in a well-known
|
485
|
+
;; function.
|
486
|
+
(let ((op (if (= var (intset-next free)) 'car 'cdr)))
|
487
|
+
(with-cps cps
|
488
|
+
(letv var*)
|
489
|
+
(let$ body (k var*))
|
490
|
+
(letk k* ($kargs (#f) (var*) ,body))
|
491
|
+
(build-term ($continue k* #f ($primcall op (self)))))))
|
492
|
+
(_
|
493
|
+
(let ((idx (intset-find free var)))
|
494
|
+
(cond
|
495
|
+
(self-known?
|
496
|
+
(with-cps cps
|
497
|
+
(letv var* u64)
|
498
|
+
(let$ body (k var*))
|
499
|
+
(letk k* ($kargs (#f) (var*) ,body))
|
500
|
+
(letk kunbox ($kargs ('idx) (u64)
|
501
|
+
($continue k* #f
|
502
|
+
($primcall 'vector-ref (self u64)))))
|
503
|
+
($ (with-cps-constants ((idx idx))
|
504
|
+
(build-term
|
505
|
+
($continue kunbox #f
|
506
|
+
($primcall 'scm->u64 (idx))))))))
|
507
|
+
(else
|
508
|
+
(with-cps cps
|
509
|
+
(letv var*)
|
510
|
+
(let$ body (k var*))
|
511
|
+
(letk k* ($kargs (#f) (var*) ,body))
|
512
|
+
($ (with-cps-constants ((idx idx))
|
513
|
+
(build-term
|
514
|
+
($continue k* #f
|
515
|
+
($primcall 'free-ref (self idx)))))))))))))
|
516
|
+
(else
|
517
|
+
(with-cps cps
|
518
|
+
($ (k var))))))
|
519
|
+
|
520
|
+
(define (convert-args cps vars k)
|
521
|
+
"Convert a number of possibly free references to bound references.
|
522
|
+
@var{k} is called with the bound references, and should return the
|
523
|
+
term."
|
524
|
+
(match vars
|
525
|
+
(()
|
526
|
+
(with-cps cps
|
527
|
+
($ (k '()))))
|
528
|
+
((var . vars)
|
529
|
+
(convert-arg cps var
|
530
|
+
(lambda (cps var)
|
531
|
+
(convert-args cps vars
|
532
|
+
(lambda (cps vars)
|
533
|
+
(with-cps cps
|
534
|
+
($ (k (cons var vars)))))))))))
|
535
|
+
|
536
|
+
(define (allocate-closure cps k src label known? nfree)
|
537
|
+
"Allocate a new closure, and pass it to $var{k}."
|
538
|
+
(match (vector known? nfree)
|
539
|
+
(#(#f nfree)
|
540
|
+
;; The call sites cannot be enumerated; allocate a closure.
|
541
|
+
(with-cps cps
|
542
|
+
(build-term ($continue k src ($closure label nfree)))))
|
543
|
+
(#(#t 2)
|
544
|
+
;; Well-known closure with two free variables; the closure is a
|
545
|
+
;; pair.
|
546
|
+
(with-cps cps
|
547
|
+
($ (with-cps-constants ((false #f))
|
548
|
+
(build-term
|
549
|
+
($continue k src ($primcall 'cons (false false))))))))
|
550
|
+
;; Well-known callee with more than two free variables; the closure
|
551
|
+
;; is a vector.
|
552
|
+
(#(#t nfree)
|
553
|
+
(unless (> nfree 2)
|
554
|
+
(error "unexpected well-known nullary, unary, or binary closure"))
|
555
|
+
(with-cps cps
|
556
|
+
($ (with-cps-constants ((nfree nfree)
|
557
|
+
(false #f))
|
558
|
+
(letv u64)
|
559
|
+
(letk kunbox ($kargs ('nfree) (u64)
|
560
|
+
($continue k src
|
561
|
+
($primcall 'make-vector (u64 false)))))
|
562
|
+
(build-term
|
563
|
+
($continue kunbox src ($primcall 'scm->u64 (nfree))))))))))
|
564
|
+
|
565
|
+
(define (init-closure cps k src var known? free)
|
566
|
+
"Initialize the free variables @var{closure-free} in a closure
|
567
|
+
bound to @var{var}, and continue to @var{k}."
|
568
|
+
(match (vector known? (intset-count free))
|
569
|
+
;; Well-known callee with zero or one free variables; no
|
570
|
+
;; initialization necessary.
|
571
|
+
(#(#t (or 0 1))
|
572
|
+
(with-cps cps
|
573
|
+
(build-term ($continue k src ($values ())))))
|
574
|
+
;; Well-known callee with two free variables; do a set-car! and
|
575
|
+
;; set-cdr!.
|
576
|
+
(#(#t 2)
|
577
|
+
(let* ((free0 (intset-next free))
|
578
|
+
(free1 (intset-next free (1+ free0))))
|
579
|
+
(convert-arg cps free0
|
580
|
+
(lambda (cps v0)
|
581
|
+
(with-cps cps
|
582
|
+
(let$ body
|
583
|
+
(convert-arg free1
|
584
|
+
(lambda (cps v1)
|
585
|
+
(with-cps cps
|
586
|
+
(build-term
|
587
|
+
($continue k src
|
588
|
+
($primcall 'set-cdr! (var v1))))))))
|
589
|
+
(letk kcdr ($kargs () () ,body))
|
590
|
+
(build-term
|
591
|
+
($continue kcdr src ($primcall 'set-car! (var v0)))))))))
|
592
|
+
;; Otherwise residualize a sequence of vector-set! or free-set!,
|
593
|
+
;; depending on whether the callee is well-known or not.
|
594
|
+
(_
|
595
|
+
(let lp ((cps cps) (prev #f) (idx 0))
|
596
|
+
(match (intset-next free prev)
|
597
|
+
(#f (with-cps cps
|
598
|
+
(build-term ($continue k src ($values ())))))
|
599
|
+
(v (with-cps cps
|
600
|
+
(let$ body (lp (1+ v) (1+ idx)))
|
601
|
+
(letk k ($kargs () () ,body))
|
602
|
+
($ (convert-arg v
|
603
|
+
(lambda (cps v)
|
604
|
+
(cond
|
605
|
+
(known?
|
606
|
+
(with-cps cps
|
607
|
+
(letv u64)
|
608
|
+
(letk kunbox
|
609
|
+
($kargs ('idx) (u64)
|
610
|
+
($continue k src
|
611
|
+
($primcall 'vector-set! (var u64 v)))))
|
612
|
+
($ (with-cps-constants ((idx idx))
|
613
|
+
(build-term
|
614
|
+
($continue kunbox src
|
615
|
+
($primcall 'scm->u64 (idx))))))))
|
616
|
+
(else
|
617
|
+
(with-cps cps
|
618
|
+
($ (with-cps-constants ((idx idx))
|
619
|
+
(build-term
|
620
|
+
($continue k src
|
621
|
+
($primcall 'free-set!
|
622
|
+
(var idx v)))))))))))))))))))
|
623
|
+
|
624
|
+
(define (make-single-closure cps k src kfun)
|
625
|
+
(let ((free (intmap-ref free-vars kfun)))
|
626
|
+
(match (vector (well-known? kfun) (intset-count free))
|
627
|
+
(#(#f 0)
|
628
|
+
(with-cps cps
|
629
|
+
(build-term ($continue k src ($closure kfun 0)))))
|
630
|
+
(#(#t 0)
|
631
|
+
(with-cps cps
|
632
|
+
(build-term ($continue k src ($const #f)))))
|
633
|
+
(#(#t 1)
|
634
|
+
;; A well-known closure of one free variable is replaced
|
635
|
+
;; at each use with the free variable itself, so we don't
|
636
|
+
;; need a binding at all; and yet, the continuation
|
637
|
+
;; expects one value, so give it something. DCE should
|
638
|
+
;; clean up later.
|
639
|
+
(with-cps cps
|
640
|
+
(build-term ($continue k src ($const #f)))))
|
641
|
+
(#(well-known? nfree)
|
642
|
+
;; A bit of a mess, but beta conversion should remove the
|
643
|
+
;; final $values if possible.
|
644
|
+
(with-cps cps
|
645
|
+
(letv closure)
|
646
|
+
(letk k* ($kargs () () ($continue k src ($values (closure)))))
|
647
|
+
(let$ init (init-closure k* src closure well-known? free))
|
648
|
+
(letk knew ($kargs (#f) (closure) ,init))
|
649
|
+
($ (allocate-closure knew src kfun well-known? nfree)))))))
|
650
|
+
|
651
|
+
;; The callee is known, but not necessarily well-known.
|
652
|
+
(define (convert-known-proc-call cps k src label closure args)
|
653
|
+
(define (have-closure cps closure)
|
654
|
+
(convert-args cps args
|
655
|
+
(lambda (cps args)
|
656
|
+
(with-cps cps
|
657
|
+
(build-term
|
658
|
+
($continue k src ($callk label closure args)))))))
|
659
|
+
(cond
|
660
|
+
((eq? (intmap-ref free-vars label) empty-intset)
|
661
|
+
;; Known call, no free variables; no closure needed.
|
662
|
+
;; Pass #f as closure argument.
|
663
|
+
(with-cps cps
|
664
|
+
($ (with-cps-constants ((false #f))
|
665
|
+
($ (have-closure false))))))
|
666
|
+
((and (well-known? (closure-label label shared bound->label))
|
667
|
+
(trivial-intset (intmap-ref free-vars label)))
|
668
|
+
;; Well-known closures with one free variable are
|
669
|
+
;; replaced at their use sites by uses of the one free
|
670
|
+
;; variable.
|
671
|
+
=> (lambda (var)
|
672
|
+
(convert-arg cps var have-closure)))
|
673
|
+
(else
|
674
|
+
;; Otherwise just load the proc.
|
675
|
+
(convert-arg cps closure have-closure))))
|
676
|
+
|
677
|
+
(define (visit-term cps term)
|
678
|
+
(match term
|
679
|
+
(($ $continue k src (or ($ $const) ($ $prim)))
|
680
|
+
(with-cps cps
|
681
|
+
term))
|
682
|
+
|
683
|
+
(($ $continue k src ($ $fun kfun))
|
684
|
+
(with-cps cps
|
685
|
+
($ (make-single-closure k src kfun))))
|
686
|
+
|
687
|
+
;; Remove letrec.
|
688
|
+
(($ $continue k src ($ $rec names vars (($ $fun kfuns) ...)))
|
689
|
+
(match (vector names vars kfuns)
|
690
|
+
(#(() () ())
|
691
|
+
;; Trivial empty case.
|
692
|
+
(with-cps cps
|
693
|
+
(build-term ($continue k src ($values ())))))
|
694
|
+
(#((name) (var) (kfun))
|
695
|
+
;; Trivial single case. We have already proven that K has
|
696
|
+
;; only LABEL as its predecessor, so we have been able
|
697
|
+
;; already to rewrite free references to the bound name with
|
698
|
+
;; the self name.
|
699
|
+
(with-cps cps
|
700
|
+
($ (make-single-closure k src kfun))))
|
701
|
+
(#(_ _ (kfun0 . _))
|
702
|
+
;; A non-trivial strongly-connected component. Does it have
|
703
|
+
;; a shared closure?
|
704
|
+
(match (intmap-ref shared kfun0 (lambda (_) #f))
|
705
|
+
(#f
|
706
|
+
;; Nope. Allocate closures for each function.
|
707
|
+
(let lp ((cps (match (intmap-ref cps k)
|
708
|
+
;; Steal declarations from the continuation.
|
709
|
+
(($ $kargs names vals body)
|
710
|
+
(intmap-replace cps k
|
711
|
+
(build-cont
|
712
|
+
($kargs () () ,body))))))
|
713
|
+
(in (map vector names vars kfuns))
|
714
|
+
(init (lambda (cps)
|
715
|
+
(with-cps cps
|
716
|
+
(build-term
|
717
|
+
($continue k src ($values ())))))))
|
718
|
+
(match in
|
719
|
+
(() (init cps))
|
720
|
+
((#(name var kfun) . in)
|
721
|
+
(let* ((known? (well-known? kfun))
|
722
|
+
(free (intmap-ref free-vars kfun))
|
723
|
+
(nfree (intset-count free)))
|
724
|
+
(define (next-init cps)
|
725
|
+
(with-cps cps
|
726
|
+
(let$ body (init))
|
727
|
+
(letk k ($kargs () () ,body))
|
728
|
+
($ (init-closure k src var known? free))))
|
729
|
+
(with-cps cps
|
730
|
+
(let$ body (lp in next-init))
|
731
|
+
(letk k ($kargs (name) (var) ,body))
|
732
|
+
($ (allocate-closure k src kfun known? nfree))))))))
|
733
|
+
(shared
|
734
|
+
;; If shared is in the bound->var map, that means one of
|
735
|
+
;; the functions is not well-known. Otherwise use kfun0
|
736
|
+
;; as the function label, but just so make-single-closure
|
737
|
+
;; can find the free vars, not for embedding in the
|
738
|
+
;; closure.
|
739
|
+
(let* ((kfun (intmap-ref bound->label shared (lambda (_) kfun0)))
|
740
|
+
(cps (match (intmap-ref cps k)
|
741
|
+
;; Make continuation declare only the shared
|
742
|
+
;; closure.
|
743
|
+
(($ $kargs names vals body)
|
744
|
+
(intmap-replace cps k
|
745
|
+
(build-cont
|
746
|
+
($kargs (#f) (shared) ,body)))))))
|
747
|
+
(with-cps cps
|
748
|
+
($ (make-single-closure k src kfun)))))))))
|
749
|
+
|
750
|
+
(($ $continue k src ($ $call proc args))
|
751
|
+
(match (intmap-ref bound->label proc (lambda (_) #f))
|
752
|
+
(#f
|
753
|
+
(convert-arg cps proc
|
754
|
+
(lambda (cps proc)
|
755
|
+
(convert-args cps args
|
756
|
+
(lambda (cps args)
|
757
|
+
(with-cps cps
|
758
|
+
(build-term
|
759
|
+
($continue k src ($call proc args)))))))))
|
760
|
+
(label
|
761
|
+
(convert-known-proc-call cps k src label proc args))))
|
762
|
+
|
763
|
+
(($ $continue k src ($ $callk label proc args))
|
764
|
+
(convert-known-proc-call cps k src label proc args))
|
765
|
+
|
766
|
+
(($ $continue k src ($ $primcall name args))
|
767
|
+
(convert-args cps args
|
768
|
+
(lambda (cps args)
|
769
|
+
(with-cps cps
|
770
|
+
(build-term
|
771
|
+
($continue k src ($primcall name args)))))))
|
772
|
+
|
773
|
+
(($ $continue k src ($ $branch kt ($ $primcall name args)))
|
774
|
+
(convert-args cps args
|
775
|
+
(lambda (cps args)
|
776
|
+
(with-cps cps
|
777
|
+
(build-term
|
778
|
+
($continue k src
|
779
|
+
($branch kt ($primcall name args))))))))
|
780
|
+
|
781
|
+
(($ $continue k src ($ $branch kt ($ $values (arg))))
|
782
|
+
(convert-arg cps arg
|
783
|
+
(lambda (cps arg)
|
784
|
+
(with-cps cps
|
785
|
+
(build-term
|
786
|
+
($continue k src
|
787
|
+
($branch kt ($values (arg)))))))))
|
788
|
+
|
789
|
+
(($ $continue k src ($ $values args))
|
790
|
+
(convert-args cps args
|
791
|
+
(lambda (cps args)
|
792
|
+
(with-cps cps
|
793
|
+
(build-term
|
794
|
+
($continue k src ($values args)))))))
|
795
|
+
|
796
|
+
(($ $continue k src ($ $prompt escape? tag handler))
|
797
|
+
(convert-arg cps tag
|
798
|
+
(lambda (cps tag)
|
799
|
+
(with-cps cps
|
800
|
+
(build-term
|
801
|
+
($continue k src
|
802
|
+
($prompt escape? tag handler)))))))))
|
803
|
+
|
804
|
+
(intset-fold (lambda (label cps)
|
805
|
+
(match (intmap-ref cps label (lambda (_) #f))
|
806
|
+
(($ $kargs names vars term)
|
807
|
+
(with-cps cps
|
808
|
+
(let$ term (visit-term term))
|
809
|
+
(setk label ($kargs names vars ,term))))
|
810
|
+
(_ cps)))
|
811
|
+
body
|
812
|
+
cps)))
|
813
|
+
|
814
|
+
(define (convert-closures cps)
|
815
|
+
"Convert free reference in @var{cps} to primcalls to @code{free-ref},
|
816
|
+
and allocate and initialize flat closures."
|
817
|
+
(let* ((kfun 0) ;; Ass-u-me.
|
818
|
+
;; label -> body-label...
|
819
|
+
(functions (compute-function-bodies cps kfun))
|
820
|
+
(cps (filter-reachable cps functions))
|
821
|
+
;; label -> bound-var...
|
822
|
+
(label->bound (compute-function-names cps functions))
|
823
|
+
;; bound-var -> label
|
824
|
+
(bound->label (invert-partition label->bound))
|
825
|
+
;; label...
|
826
|
+
(well-known (compute-well-known-functions cps bound->label))
|
827
|
+
;; label -> closure-var
|
828
|
+
(shared (compute-shared-closures cps well-known))
|
829
|
+
(cps (rewrite-shared-closure-calls cps functions label->bound shared
|
830
|
+
kfun))
|
831
|
+
;; label -> free-var...
|
832
|
+
(free-vars (compute-free-vars cps kfun shared))
|
833
|
+
(free-vars (prune-free-vars free-vars bound->label well-known shared)))
|
834
|
+
(let ((free-in-program (intmap-ref free-vars kfun)))
|
835
|
+
(unless (eq? empty-intset free-in-program)
|
836
|
+
(error "Expected no free vars in program" free-in-program)))
|
837
|
+
(with-fresh-name-state cps
|
838
|
+
(persistent-intmap
|
839
|
+
(intmap-fold
|
840
|
+
(lambda (label body cps)
|
841
|
+
(convert-one cps label body free-vars bound->label well-known shared))
|
842
|
+
functions
|
843
|
+
cps)))))
|
844
|
+
|
845
|
+
;;; Local Variables:
|
846
|
+
;;; eval: (put 'convert-arg 'scheme-indent-function 2)
|
847
|
+
;;; eval: (put 'convert-args 'scheme-indent-function 2)
|
848
|
+
;;; End:
|