LilyPond-Ruby 0.1.1 → 0.1.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1109) hide show
  1. checksums.yaml +4 -4
  2. data/etc/fonts/conf.d/10-hinting-slight.conf +15 -0
  3. data/etc/fonts/conf.d/10-scale-bitmap-fonts.conf +83 -0
  4. data/etc/fonts/conf.d/11-lcdfilter-default.conf +17 -0
  5. data/etc/fonts/conf.d/20-unhint-small-vera.conf +49 -0
  6. data/etc/fonts/conf.d/30-metric-aliases.conf +637 -0
  7. data/etc/fonts/conf.d/40-nonlatin.conf +332 -0
  8. data/etc/fonts/conf.d/45-generic.conf +136 -0
  9. data/etc/fonts/conf.d/45-latin.conf +301 -0
  10. data/etc/fonts/conf.d/48-spacing.conf +16 -0
  11. data/etc/fonts/conf.d/49-sansserif.conf +22 -0
  12. data/etc/fonts/conf.d/50-user.conf +16 -0
  13. data/etc/fonts/conf.d/51-local.conf +7 -0
  14. data/etc/fonts/conf.d/60-generic.conf +64 -0
  15. data/etc/fonts/conf.d/60-latin.conf +88 -0
  16. data/etc/fonts/conf.d/65-fonts-persian.conf +418 -0
  17. data/etc/fonts/conf.d/65-nonlatin.conf +228 -0
  18. data/etc/fonts/conf.d/69-unifont.conf +28 -0
  19. data/etc/fonts/conf.d/80-delicious.conf +19 -0
  20. data/etc/fonts/conf.d/90-synthetic.conf +64 -0
  21. data/etc/fonts/conf.d/README +23 -0
  22. data/etc/fonts/fonts.conf +101 -0
  23. data/etc/relocate/fontconfig.reloc +2 -0
  24. data/etc/relocate/guile.reloc +2 -0
  25. data/etc/relocate/libexec.reloc +1 -0
  26. data/lib/guile/2.2/ccache/ice-9/and-let-star.go +0 -0
  27. data/lib/guile/2.2/ccache/ice-9/arrays.go +0 -0
  28. data/lib/guile/2.2/ccache/ice-9/atomic.go +0 -0
  29. data/lib/guile/2.2/ccache/ice-9/binary-ports.go +0 -0
  30. data/lib/guile/2.2/ccache/ice-9/boot-9.go +0 -0
  31. data/lib/guile/2.2/ccache/ice-9/buffered-input.go +0 -0
  32. data/lib/guile/2.2/ccache/ice-9/calling.go +0 -0
  33. data/lib/guile/2.2/ccache/ice-9/channel.go +0 -0
  34. data/lib/guile/2.2/ccache/ice-9/command-line.go +0 -0
  35. data/lib/guile/2.2/ccache/ice-9/common-list.go +0 -0
  36. data/lib/guile/2.2/ccache/ice-9/control.go +0 -0
  37. data/lib/guile/2.2/ccache/ice-9/curried-definitions.go +0 -0
  38. data/lib/guile/2.2/ccache/ice-9/debug.go +0 -0
  39. data/lib/guile/2.2/ccache/ice-9/deprecated.go +0 -0
  40. data/lib/guile/2.2/ccache/ice-9/documentation.go +0 -0
  41. data/lib/guile/2.2/ccache/ice-9/eval-string.go +0 -0
  42. data/lib/guile/2.2/ccache/ice-9/eval.go +0 -0
  43. data/lib/guile/2.2/ccache/ice-9/expect.go +0 -0
  44. data/lib/guile/2.2/ccache/ice-9/fdes-finalizers.go +0 -0
  45. data/lib/guile/2.2/ccache/ice-9/format.go +0 -0
  46. data/lib/guile/2.2/ccache/ice-9/ftw.go +0 -0
  47. data/lib/guile/2.2/ccache/ice-9/futures.go +0 -0
  48. data/lib/guile/2.2/ccache/ice-9/gap-buffer.go +0 -0
  49. data/lib/guile/2.2/ccache/ice-9/getopt-long.go +0 -0
  50. data/lib/guile/2.2/ccache/ice-9/hash-table.go +0 -0
  51. data/lib/guile/2.2/ccache/ice-9/hcons.go +0 -0
  52. data/lib/guile/2.2/ccache/ice-9/history.go +0 -0
  53. data/lib/guile/2.2/ccache/ice-9/i18n.go +0 -0
  54. data/lib/guile/2.2/ccache/ice-9/iconv.go +0 -0
  55. data/lib/guile/2.2/ccache/ice-9/lineio.go +0 -0
  56. data/lib/guile/2.2/ccache/ice-9/list.go +0 -0
  57. data/lib/guile/2.2/ccache/ice-9/local-eval.go +0 -0
  58. data/lib/guile/2.2/ccache/ice-9/ls.go +0 -0
  59. data/lib/guile/2.2/ccache/ice-9/mapping.go +0 -0
  60. data/lib/guile/2.2/ccache/ice-9/match.go +0 -0
  61. data/lib/guile/2.2/ccache/ice-9/networking.go +0 -0
  62. data/lib/guile/2.2/ccache/ice-9/null.go +0 -0
  63. data/lib/guile/2.2/ccache/ice-9/occam-channel.go +0 -0
  64. data/lib/guile/2.2/ccache/ice-9/optargs.go +0 -0
  65. data/lib/guile/2.2/ccache/ice-9/peg/cache.go +0 -0
  66. data/lib/guile/2.2/ccache/ice-9/peg/codegen.go +0 -0
  67. data/lib/guile/2.2/ccache/ice-9/peg/simplify-tree.go +0 -0
  68. data/lib/guile/2.2/ccache/ice-9/peg/string-peg.go +0 -0
  69. data/lib/guile/2.2/ccache/ice-9/peg/using-parsers.go +0 -0
  70. data/lib/guile/2.2/ccache/ice-9/peg.go +0 -0
  71. data/lib/guile/2.2/ccache/ice-9/poe.go +0 -0
  72. data/lib/guile/2.2/ccache/ice-9/poll.go +0 -0
  73. data/lib/guile/2.2/ccache/ice-9/popen.go +0 -0
  74. data/lib/guile/2.2/ccache/ice-9/ports.go +0 -0
  75. data/lib/guile/2.2/ccache/ice-9/posix.go +0 -0
  76. data/lib/guile/2.2/ccache/ice-9/pretty-print.go +0 -0
  77. data/lib/guile/2.2/ccache/ice-9/psyntax-pp.go +0 -0
  78. data/lib/guile/2.2/ccache/ice-9/q.go +0 -0
  79. data/lib/guile/2.2/ccache/ice-9/r5rs.go +0 -0
  80. data/lib/guile/2.2/ccache/ice-9/rdelim.go +0 -0
  81. data/lib/guile/2.2/ccache/ice-9/receive.go +0 -0
  82. data/lib/guile/2.2/ccache/ice-9/regex.go +0 -0
  83. data/lib/guile/2.2/ccache/ice-9/runq.go +0 -0
  84. data/lib/guile/2.2/ccache/ice-9/rw.go +0 -0
  85. data/lib/guile/2.2/ccache/ice-9/safe-r5rs.go +0 -0
  86. data/lib/guile/2.2/ccache/ice-9/safe.go +0 -0
  87. data/lib/guile/2.2/ccache/ice-9/sandbox.go +0 -0
  88. data/lib/guile/2.2/ccache/ice-9/save-stack.go +0 -0
  89. data/lib/guile/2.2/ccache/ice-9/scm-style-repl.go +0 -0
  90. data/lib/guile/2.2/ccache/ice-9/serialize.go +0 -0
  91. data/lib/guile/2.2/ccache/ice-9/session.go +0 -0
  92. data/lib/guile/2.2/ccache/ice-9/slib.go +0 -0
  93. data/lib/guile/2.2/ccache/ice-9/stack-catch.go +0 -0
  94. data/lib/guile/2.2/ccache/ice-9/streams.go +0 -0
  95. data/lib/guile/2.2/ccache/ice-9/string-fun.go +0 -0
  96. data/lib/guile/2.2/ccache/ice-9/suspendable-ports.go +0 -0
  97. data/lib/guile/2.2/ccache/ice-9/syncase.go +0 -0
  98. data/lib/guile/2.2/ccache/ice-9/textual-ports.go +0 -0
  99. data/lib/guile/2.2/ccache/ice-9/threads.go +0 -0
  100. data/lib/guile/2.2/ccache/ice-9/time.go +0 -0
  101. data/lib/guile/2.2/ccache/ice-9/top-repl.go +0 -0
  102. data/lib/guile/2.2/ccache/ice-9/unicode.go +0 -0
  103. data/lib/guile/2.2/ccache/ice-9/vlist.go +0 -0
  104. data/lib/guile/2.2/ccache/ice-9/weak-vector.go +0 -0
  105. data/lib/guile/2.2/ccache/language/brainfuck/compile-scheme.go +0 -0
  106. data/lib/guile/2.2/ccache/language/brainfuck/compile-tree-il.go +0 -0
  107. data/lib/guile/2.2/ccache/language/brainfuck/parse.go +0 -0
  108. data/lib/guile/2.2/ccache/language/brainfuck/spec.go +0 -0
  109. data/lib/guile/2.2/ccache/language/bytecode/spec.go +0 -0
  110. data/lib/guile/2.2/ccache/language/bytecode.go +0 -0
  111. data/lib/guile/2.2/ccache/language/cps/closure-conversion.go +0 -0
  112. data/lib/guile/2.2/ccache/language/cps/compile-bytecode.go +0 -0
  113. data/lib/guile/2.2/ccache/language/cps/constructors.go +0 -0
  114. data/lib/guile/2.2/ccache/language/cps/contification.go +0 -0
  115. data/lib/guile/2.2/ccache/language/cps/cse.go +0 -0
  116. data/lib/guile/2.2/ccache/language/cps/dce.go +0 -0
  117. data/lib/guile/2.2/ccache/language/cps/effects-analysis.go +0 -0
  118. data/lib/guile/2.2/ccache/language/cps/elide-values.go +0 -0
  119. data/lib/guile/2.2/ccache/language/cps/handle-interrupts.go +0 -0
  120. data/lib/guile/2.2/ccache/language/cps/intmap.go +0 -0
  121. data/lib/guile/2.2/ccache/language/cps/intset.go +0 -0
  122. data/lib/guile/2.2/ccache/language/cps/licm.go +0 -0
  123. data/lib/guile/2.2/ccache/language/cps/optimize.go +0 -0
  124. data/lib/guile/2.2/ccache/language/cps/peel-loops.go +0 -0
  125. data/lib/guile/2.2/ccache/language/cps/primitives.go +0 -0
  126. data/lib/guile/2.2/ccache/language/cps/prune-bailouts.go +0 -0
  127. data/lib/guile/2.2/ccache/language/cps/prune-top-level-scopes.go +0 -0
  128. data/lib/guile/2.2/ccache/language/cps/reify-primitives.go +0 -0
  129. data/lib/guile/2.2/ccache/language/cps/renumber.go +0 -0
  130. data/lib/guile/2.2/ccache/language/cps/rotate-loops.go +0 -0
  131. data/lib/guile/2.2/ccache/language/cps/self-references.go +0 -0
  132. data/lib/guile/2.2/ccache/language/cps/simplify.go +0 -0
  133. data/lib/guile/2.2/ccache/language/cps/slot-allocation.go +0 -0
  134. data/lib/guile/2.2/ccache/language/cps/spec.go +0 -0
  135. data/lib/guile/2.2/ccache/language/cps/specialize-numbers.go +0 -0
  136. data/lib/guile/2.2/ccache/language/cps/specialize-primcalls.go +0 -0
  137. data/lib/guile/2.2/ccache/language/cps/split-rec.go +0 -0
  138. data/lib/guile/2.2/ccache/language/cps/type-checks.go +0 -0
  139. data/lib/guile/2.2/ccache/language/cps/type-fold.go +0 -0
  140. data/lib/guile/2.2/ccache/language/cps/types.go +0 -0
  141. data/lib/guile/2.2/ccache/language/cps/utils.go +0 -0
  142. data/lib/guile/2.2/ccache/language/cps/verify.go +0 -0
  143. data/lib/guile/2.2/ccache/language/cps/with-cps.go +0 -0
  144. data/lib/guile/2.2/ccache/language/cps.go +0 -0
  145. data/lib/guile/2.2/ccache/language/ecmascript/array.go +0 -0
  146. data/lib/guile/2.2/ccache/language/ecmascript/base.go +0 -0
  147. data/lib/guile/2.2/ccache/language/ecmascript/compile-tree-il.go +0 -0
  148. data/lib/guile/2.2/ccache/language/ecmascript/function.go +0 -0
  149. data/lib/guile/2.2/ccache/language/ecmascript/impl.go +0 -0
  150. data/lib/guile/2.2/ccache/language/ecmascript/parse.go +0 -0
  151. data/lib/guile/2.2/ccache/language/ecmascript/spec.go +0 -0
  152. data/lib/guile/2.2/ccache/language/ecmascript/tokenize.go +0 -0
  153. data/lib/guile/2.2/ccache/language/elisp/bindings.go +0 -0
  154. data/lib/guile/2.2/ccache/language/elisp/boot.go +0 -0
  155. data/lib/guile/2.2/ccache/language/elisp/compile-tree-il.go +0 -0
  156. data/lib/guile/2.2/ccache/language/elisp/falias.go +0 -0
  157. data/lib/guile/2.2/ccache/language/elisp/lexer.go +0 -0
  158. data/lib/guile/2.2/ccache/language/elisp/parser.go +0 -0
  159. data/lib/guile/2.2/ccache/language/elisp/runtime/function-slot.go +0 -0
  160. data/lib/guile/2.2/ccache/language/elisp/runtime/value-slot.go +0 -0
  161. data/lib/guile/2.2/ccache/language/elisp/runtime.go +0 -0
  162. data/lib/guile/2.2/ccache/language/elisp/spec.go +0 -0
  163. data/lib/guile/2.2/ccache/language/scheme/compile-tree-il.go +0 -0
  164. data/lib/guile/2.2/ccache/language/scheme/decompile-tree-il.go +0 -0
  165. data/lib/guile/2.2/ccache/language/scheme/spec.go +0 -0
  166. data/lib/guile/2.2/ccache/language/tree-il/analyze.go +0 -0
  167. data/lib/guile/2.2/ccache/language/tree-il/canonicalize.go +0 -0
  168. data/lib/guile/2.2/ccache/language/tree-il/compile-cps.go +0 -0
  169. data/lib/guile/2.2/ccache/language/tree-il/debug.go +0 -0
  170. data/lib/guile/2.2/ccache/language/tree-il/effects.go +0 -0
  171. data/lib/guile/2.2/ccache/language/tree-il/fix-letrec.go +0 -0
  172. data/lib/guile/2.2/ccache/language/tree-il/optimize.go +0 -0
  173. data/lib/guile/2.2/ccache/language/tree-il/peval.go +0 -0
  174. data/lib/guile/2.2/ccache/language/tree-il/primitives.go +0 -0
  175. data/lib/guile/2.2/ccache/language/tree-il/spec.go +0 -0
  176. data/lib/guile/2.2/ccache/language/tree-il.go +0 -0
  177. data/lib/guile/2.2/ccache/language/value/spec.go +0 -0
  178. data/lib/guile/2.2/ccache/oop/goops/accessors.go +0 -0
  179. data/lib/guile/2.2/ccache/oop/goops/active-slot.go +0 -0
  180. data/lib/guile/2.2/ccache/oop/goops/composite-slot.go +0 -0
  181. data/lib/guile/2.2/ccache/oop/goops/describe.go +0 -0
  182. data/lib/guile/2.2/ccache/oop/goops/internal.go +0 -0
  183. data/lib/guile/2.2/ccache/oop/goops/save.go +0 -0
  184. data/lib/guile/2.2/ccache/oop/goops/simple.go +0 -0
  185. data/lib/guile/2.2/ccache/oop/goops/stklos.go +0 -0
  186. data/lib/guile/2.2/ccache/oop/goops.go +0 -0
  187. data/lib/guile/2.2/ccache/rnrs/arithmetic/bitwise.go +0 -0
  188. data/lib/guile/2.2/ccache/rnrs/arithmetic/fixnums.go +0 -0
  189. data/lib/guile/2.2/ccache/rnrs/arithmetic/flonums.go +0 -0
  190. data/lib/guile/2.2/ccache/rnrs/base.go +0 -0
  191. data/lib/guile/2.2/ccache/rnrs/bytevectors.go +0 -0
  192. data/lib/guile/2.2/ccache/rnrs/conditions.go +0 -0
  193. data/lib/guile/2.2/ccache/rnrs/control.go +0 -0
  194. data/lib/guile/2.2/ccache/rnrs/enums.go +0 -0
  195. data/lib/guile/2.2/ccache/rnrs/eval.go +0 -0
  196. data/lib/guile/2.2/ccache/rnrs/exceptions.go +0 -0
  197. data/lib/guile/2.2/ccache/rnrs/files.go +0 -0
  198. data/lib/guile/2.2/ccache/rnrs/hashtables.go +0 -0
  199. data/lib/guile/2.2/ccache/rnrs/io/ports.go +0 -0
  200. data/lib/guile/2.2/ccache/rnrs/io/simple.go +0 -0
  201. data/lib/guile/2.2/ccache/rnrs/lists.go +0 -0
  202. data/lib/guile/2.2/ccache/rnrs/mutable-pairs.go +0 -0
  203. data/lib/guile/2.2/ccache/rnrs/mutable-strings.go +0 -0
  204. data/lib/guile/2.2/ccache/rnrs/programs.go +0 -0
  205. data/lib/guile/2.2/ccache/rnrs/r5rs.go +0 -0
  206. data/lib/guile/2.2/ccache/rnrs/records/inspection.go +0 -0
  207. data/lib/guile/2.2/ccache/rnrs/records/procedural.go +0 -0
  208. data/lib/guile/2.2/ccache/rnrs/records/syntactic.go +0 -0
  209. data/lib/guile/2.2/ccache/rnrs/sorting.go +0 -0
  210. data/lib/guile/2.2/ccache/rnrs/syntax-case.go +0 -0
  211. data/lib/guile/2.2/ccache/rnrs/unicode.go +0 -0
  212. data/lib/guile/2.2/ccache/rnrs.go +0 -0
  213. data/lib/guile/2.2/ccache/scripts/api-diff.go +0 -0
  214. data/lib/guile/2.2/ccache/scripts/autofrisk.go +0 -0
  215. data/lib/guile/2.2/ccache/scripts/compile.go +0 -0
  216. data/lib/guile/2.2/ccache/scripts/disassemble.go +0 -0
  217. data/lib/guile/2.2/ccache/scripts/display-commentary.go +0 -0
  218. data/lib/guile/2.2/ccache/scripts/doc-snarf.go +0 -0
  219. data/lib/guile/2.2/ccache/scripts/frisk.go +0 -0
  220. data/lib/guile/2.2/ccache/scripts/generate-autoload.go +0 -0
  221. data/lib/guile/2.2/ccache/scripts/help.go +0 -0
  222. data/lib/guile/2.2/ccache/scripts/lint.go +0 -0
  223. data/lib/guile/2.2/ccache/scripts/list.go +0 -0
  224. data/lib/guile/2.2/ccache/scripts/punify.go +0 -0
  225. data/lib/guile/2.2/ccache/scripts/read-rfc822.go +0 -0
  226. data/lib/guile/2.2/ccache/scripts/read-scheme-source.go +0 -0
  227. data/lib/guile/2.2/ccache/scripts/read-text-outline.go +0 -0
  228. data/lib/guile/2.2/ccache/scripts/scan-api.go +0 -0
  229. data/lib/guile/2.2/ccache/scripts/snarf-check-and-output-texi.go +0 -0
  230. data/lib/guile/2.2/ccache/scripts/snarf-guile-m4-docs.go +0 -0
  231. data/lib/guile/2.2/ccache/scripts/summarize-guile-TODO.go +0 -0
  232. data/lib/guile/2.2/ccache/scripts/use2dot.go +0 -0
  233. data/lib/guile/2.2/ccache/srfi/srfi-1.go +0 -0
  234. data/lib/guile/2.2/ccache/srfi/srfi-10.go +0 -0
  235. data/lib/guile/2.2/ccache/srfi/srfi-11.go +0 -0
  236. data/lib/guile/2.2/ccache/srfi/srfi-111.go +0 -0
  237. data/lib/guile/2.2/ccache/srfi/srfi-13.go +0 -0
  238. data/lib/guile/2.2/ccache/srfi/srfi-14.go +0 -0
  239. data/lib/guile/2.2/ccache/srfi/srfi-16.go +0 -0
  240. data/lib/guile/2.2/ccache/srfi/srfi-17.go +0 -0
  241. data/lib/guile/2.2/ccache/srfi/srfi-18.go +0 -0
  242. data/lib/guile/2.2/ccache/srfi/srfi-19.go +0 -0
  243. data/lib/guile/2.2/ccache/srfi/srfi-2.go +0 -0
  244. data/lib/guile/2.2/ccache/srfi/srfi-26.go +0 -0
  245. data/lib/guile/2.2/ccache/srfi/srfi-27.go +0 -0
  246. data/lib/guile/2.2/ccache/srfi/srfi-28.go +0 -0
  247. data/lib/guile/2.2/ccache/srfi/srfi-31.go +0 -0
  248. data/lib/guile/2.2/ccache/srfi/srfi-34.go +0 -0
  249. data/lib/guile/2.2/ccache/srfi/srfi-35.go +0 -0
  250. data/lib/guile/2.2/ccache/srfi/srfi-37.go +0 -0
  251. data/lib/guile/2.2/ccache/srfi/srfi-38.go +0 -0
  252. data/lib/guile/2.2/ccache/srfi/srfi-39.go +0 -0
  253. data/lib/guile/2.2/ccache/srfi/srfi-4/gnu.go +0 -0
  254. data/lib/guile/2.2/ccache/srfi/srfi-4.go +0 -0
  255. data/lib/guile/2.2/ccache/srfi/srfi-41.go +0 -0
  256. data/lib/guile/2.2/ccache/srfi/srfi-42.go +0 -0
  257. data/lib/guile/2.2/ccache/srfi/srfi-43.go +0 -0
  258. data/lib/guile/2.2/ccache/srfi/srfi-45.go +0 -0
  259. data/lib/guile/2.2/ccache/srfi/srfi-6.go +0 -0
  260. data/lib/guile/2.2/ccache/srfi/srfi-60.go +0 -0
  261. data/lib/guile/2.2/ccache/srfi/srfi-64.go +0 -0
  262. data/lib/guile/2.2/ccache/srfi/srfi-67.go +0 -0
  263. data/lib/guile/2.2/ccache/srfi/srfi-69.go +0 -0
  264. data/lib/guile/2.2/ccache/srfi/srfi-71.go +0 -0
  265. data/lib/guile/2.2/ccache/srfi/srfi-8.go +0 -0
  266. data/lib/guile/2.2/ccache/srfi/srfi-88.go +0 -0
  267. data/lib/guile/2.2/ccache/srfi/srfi-9/gnu.go +0 -0
  268. data/lib/guile/2.2/ccache/srfi/srfi-9.go +0 -0
  269. data/lib/guile/2.2/ccache/srfi/srfi-98.go +0 -0
  270. data/lib/guile/2.2/ccache/statprof.go +0 -0
  271. data/lib/guile/2.2/ccache/sxml/apply-templates.go +0 -0
  272. data/lib/guile/2.2/ccache/sxml/fold.go +0 -0
  273. data/lib/guile/2.2/ccache/sxml/match.go +0 -0
  274. data/lib/guile/2.2/ccache/sxml/simple.go +0 -0
  275. data/lib/guile/2.2/ccache/sxml/ssax/input-parse.go +0 -0
  276. data/lib/guile/2.2/ccache/sxml/ssax.go +0 -0
  277. data/lib/guile/2.2/ccache/sxml/transform.go +0 -0
  278. data/lib/guile/2.2/ccache/sxml/xpath.go +0 -0
  279. data/lib/guile/2.2/ccache/system/base/ck.go +0 -0
  280. data/lib/guile/2.2/ccache/system/base/compile.go +0 -0
  281. data/lib/guile/2.2/ccache/system/base/lalr.go +0 -0
  282. data/lib/guile/2.2/ccache/system/base/language.go +0 -0
  283. data/lib/guile/2.2/ccache/system/base/message.go +0 -0
  284. data/lib/guile/2.2/ccache/system/base/pmatch.go +0 -0
  285. data/lib/guile/2.2/ccache/system/base/syntax.go +0 -0
  286. data/lib/guile/2.2/ccache/system/base/target.go +0 -0
  287. data/lib/guile/2.2/ccache/system/base/types.go +0 -0
  288. data/lib/guile/2.2/ccache/system/foreign-object.go +0 -0
  289. data/lib/guile/2.2/ccache/system/foreign.go +0 -0
  290. data/lib/guile/2.2/ccache/system/repl/command.go +0 -0
  291. data/lib/guile/2.2/ccache/system/repl/common.go +0 -0
  292. data/lib/guile/2.2/ccache/system/repl/coop-server.go +0 -0
  293. data/lib/guile/2.2/ccache/system/repl/debug.go +0 -0
  294. data/lib/guile/2.2/ccache/system/repl/error-handling.go +0 -0
  295. data/lib/guile/2.2/ccache/system/repl/repl.go +0 -0
  296. data/lib/guile/2.2/ccache/system/repl/server.go +0 -0
  297. data/lib/guile/2.2/ccache/system/syntax.go +0 -0
  298. data/lib/guile/2.2/ccache/system/vm/assembler.go +0 -0
  299. data/lib/guile/2.2/ccache/system/vm/coverage.go +0 -0
  300. data/lib/guile/2.2/ccache/system/vm/debug.go +0 -0
  301. data/lib/guile/2.2/ccache/system/vm/disassembler.go +0 -0
  302. data/lib/guile/2.2/ccache/system/vm/dwarf.go +0 -0
  303. data/lib/guile/2.2/ccache/system/vm/elf.go +0 -0
  304. data/lib/guile/2.2/ccache/system/vm/frame.go +0 -0
  305. data/lib/guile/2.2/ccache/system/vm/inspect.go +0 -0
  306. data/lib/guile/2.2/ccache/system/vm/linker.go +0 -0
  307. data/lib/guile/2.2/ccache/system/vm/loader.go +0 -0
  308. data/lib/guile/2.2/ccache/system/vm/program.go +0 -0
  309. data/lib/guile/2.2/ccache/system/vm/trace.go +0 -0
  310. data/lib/guile/2.2/ccache/system/vm/trap-state.go +0 -0
  311. data/lib/guile/2.2/ccache/system/vm/traps.go +0 -0
  312. data/lib/guile/2.2/ccache/system/vm/vm.go +0 -0
  313. data/lib/guile/2.2/ccache/system/xref.go +0 -0
  314. data/lib/guile/2.2/ccache/texinfo/docbook.go +0 -0
  315. data/lib/guile/2.2/ccache/texinfo/html.go +0 -0
  316. data/lib/guile/2.2/ccache/texinfo/indexing.go +0 -0
  317. data/lib/guile/2.2/ccache/texinfo/plain-text.go +0 -0
  318. data/lib/guile/2.2/ccache/texinfo/reflection.go +0 -0
  319. data/lib/guile/2.2/ccache/texinfo/serialize.go +0 -0
  320. data/lib/guile/2.2/ccache/texinfo/string-utils.go +0 -0
  321. data/lib/guile/2.2/ccache/texinfo.go +0 -0
  322. data/lib/guile/2.2/ccache/web/client.go +0 -0
  323. data/lib/guile/2.2/ccache/web/http.go +0 -0
  324. data/lib/guile/2.2/ccache/web/request.go +0 -0
  325. data/lib/guile/2.2/ccache/web/response.go +0 -0
  326. data/lib/guile/2.2/ccache/web/server/http.go +0 -0
  327. data/lib/guile/2.2/ccache/web/server.go +0 -0
  328. data/lib/guile/2.2/ccache/web/uri.go +0 -0
  329. data/lib/lilypond/2.24.1/ccache/lily/accreg.go +0 -0
  330. data/lib/lilypond/2.24.1/ccache/lily/auto-beam.go +0 -0
  331. data/lib/lilypond/2.24.1/ccache/lily/autochange.go +0 -0
  332. data/lib/lilypond/2.24.1/ccache/lily/backend-library.go +0 -0
  333. data/lib/lilypond/2.24.1/ccache/lily/bar-line.go +0 -0
  334. data/lib/lilypond/2.24.1/ccache/lily/breath.go +0 -0
  335. data/lib/lilypond/2.24.1/ccache/lily/c++.go +0 -0
  336. data/lib/lilypond/2.24.1/ccache/lily/chord-entry.go +0 -0
  337. data/lib/lilypond/2.24.1/ccache/lily/chord-ignatzek-names.go +0 -0
  338. data/lib/lilypond/2.24.1/ccache/lily/chord-name.go +0 -0
  339. data/lib/lilypond/2.24.1/ccache/lily/clip-region.go +0 -0
  340. data/lib/lilypond/2.24.1/ccache/lily/color.go +0 -0
  341. data/lib/lilypond/2.24.1/ccache/lily/curried-definitions.go +0 -0
  342. data/lib/lilypond/2.24.1/ccache/lily/define-context-properties.go +0 -0
  343. data/lib/lilypond/2.24.1/ccache/lily/define-event-classes.go +0 -0
  344. data/lib/lilypond/2.24.1/ccache/lily/define-grob-interfaces.go +0 -0
  345. data/lib/lilypond/2.24.1/ccache/lily/define-grob-properties.go +0 -0
  346. data/lib/lilypond/2.24.1/ccache/lily/define-grobs.go +0 -0
  347. data/lib/lilypond/2.24.1/ccache/lily/define-markup-commands.go +0 -0
  348. data/lib/lilypond/2.24.1/ccache/lily/define-music-callbacks.go +0 -0
  349. data/lib/lilypond/2.24.1/ccache/lily/define-music-display-methods.go +0 -0
  350. data/lib/lilypond/2.24.1/ccache/lily/define-music-properties.go +0 -0
  351. data/lib/lilypond/2.24.1/ccache/lily/define-music-types.go +0 -0
  352. data/lib/lilypond/2.24.1/ccache/lily/define-note-names.go +0 -0
  353. data/lib/lilypond/2.24.1/ccache/lily/define-stencil-commands.go +0 -0
  354. data/lib/lilypond/2.24.1/ccache/lily/define-woodwind-diagrams.go +0 -0
  355. data/lib/lilypond/2.24.1/ccache/lily/display-lily.go +0 -0
  356. data/lib/lilypond/2.24.1/ccache/lily/display-woodwind-diagrams.go +0 -0
  357. data/lib/lilypond/2.24.1/ccache/lily/file-cache.go +0 -0
  358. data/lib/lilypond/2.24.1/ccache/lily/flag-styles.go +0 -0
  359. data/lib/lilypond/2.24.1/ccache/lily/font-encodings.go +0 -0
  360. data/lib/lilypond/2.24.1/ccache/lily/font.go +0 -0
  361. data/lib/lilypond/2.24.1/ccache/lily/framework-cairo.go +0 -0
  362. data/lib/lilypond/2.24.1/ccache/lily/framework-ps.go +0 -0
  363. data/lib/lilypond/2.24.1/ccache/lily/framework-svg.go +0 -0
  364. data/lib/lilypond/2.24.1/ccache/lily/fret-diagrams.go +0 -0
  365. data/lib/lilypond/2.24.1/ccache/lily/graphviz.go +0 -0
  366. data/lib/lilypond/2.24.1/ccache/lily/harp-pedals.go +0 -0
  367. data/lib/lilypond/2.24.1/ccache/lily/layout-beam.go +0 -0
  368. data/lib/lilypond/2.24.1/ccache/lily/layout-slur.go +0 -0
  369. data/lib/lilypond/2.24.1/ccache/lily/lily-library.go +0 -0
  370. data/lib/lilypond/2.24.1/ccache/lily/lily.go +0 -0
  371. data/lib/lilypond/2.24.1/ccache/lily/ly-syntax-constructors.go +0 -0
  372. data/lib/lilypond/2.24.1/ccache/lily/markup-macros.go +0 -0
  373. data/lib/lilypond/2.24.1/ccache/lily/markup.go +0 -0
  374. data/lib/lilypond/2.24.1/ccache/lily/midi.go +0 -0
  375. data/lib/lilypond/2.24.1/ccache/lily/modal-transforms.go +0 -0
  376. data/lib/lilypond/2.24.1/ccache/lily/music-functions.go +0 -0
  377. data/lib/lilypond/2.24.1/ccache/lily/output-lib.go +0 -0
  378. data/lib/lilypond/2.24.1/ccache/lily/output-ps.go +0 -0
  379. data/lib/lilypond/2.24.1/ccache/lily/output-svg.go +0 -0
  380. data/lib/lilypond/2.24.1/ccache/lily/page.go +0 -0
  381. data/lib/lilypond/2.24.1/ccache/lily/paper-system.go +0 -0
  382. data/lib/lilypond/2.24.1/ccache/lily/paper.go +0 -0
  383. data/lib/lilypond/2.24.1/ccache/lily/parser-clef.go +0 -0
  384. data/lib/lilypond/2.24.1/ccache/lily/parser-ly-from-scheme.go +0 -0
  385. data/lib/lilypond/2.24.1/ccache/lily/part-combiner.go +0 -0
  386. data/lib/lilypond/2.24.1/ccache/lily/predefined-fretboards.go +0 -0
  387. data/lib/lilypond/2.24.1/ccache/lily/ps-to-png.go +0 -0
  388. data/lib/lilypond/2.24.1/ccache/lily/scheme-engravers.go +0 -0
  389. data/lib/lilypond/2.24.1/ccache/lily/scheme-performers.go +0 -0
  390. data/lib/lilypond/2.24.1/ccache/lily/script.go +0 -0
  391. data/lib/lilypond/2.24.1/ccache/lily/skyline.go +0 -0
  392. data/lib/lilypond/2.24.1/ccache/lily/song-util.go +0 -0
  393. data/lib/lilypond/2.24.1/ccache/lily/song.go +0 -0
  394. data/lib/lilypond/2.24.1/ccache/lily/stencil.go +0 -0
  395. data/lib/lilypond/2.24.1/ccache/lily/tablature.go +0 -0
  396. data/lib/lilypond/2.24.1/ccache/lily/time-signature-settings.go +0 -0
  397. data/lib/lilypond/2.24.1/ccache/lily/time-signature.go +0 -0
  398. data/lib/lilypond/2.24.1/ccache/lily/titling.go +0 -0
  399. data/lib/lilypond/2.24.1/ccache/lily/to-xml.go +0 -0
  400. data/lib/lilypond/2.24.1/ccache/lily/translation-functions.go +0 -0
  401. data/share/emacs/site-lisp/lilypond-font-lock.el +208 -0
  402. data/share/emacs/site-lisp/lilypond-indent.el +605 -0
  403. data/share/emacs/site-lisp/lilypond-init.el +21 -0
  404. data/share/emacs/site-lisp/lilypond-mode.el +1204 -0
  405. data/share/emacs/site-lisp/lilypond-song.el +556 -0
  406. data/share/emacs/site-lisp/lilypond-what-beat.el +279 -0
  407. data/share/emacs/site-lisp/lilypond-words.el +1428 -0
  408. data/share/guile/2.2/guile-procedures.txt +8860 -0
  409. data/share/guile/2.2/ice-9/and-let-star.scm +73 -0
  410. data/share/guile/2.2/ice-9/arrays.scm +70 -0
  411. data/share/guile/2.2/ice-9/atomic.scm +38 -0
  412. data/share/guile/2.2/ice-9/binary-ports.scm +53 -0
  413. data/share/guile/2.2/ice-9/boot-9.scm +4131 -0
  414. data/share/guile/2.2/ice-9/buffered-input.scm +109 -0
  415. data/share/guile/2.2/ice-9/calling.scm +326 -0
  416. data/share/guile/2.2/ice-9/channel.scm +170 -0
  417. data/share/guile/2.2/ice-9/command-line.scm +477 -0
  418. data/share/guile/2.2/ice-9/common-list.scm +278 -0
  419. data/share/guile/2.2/ice-9/control.scm +110 -0
  420. data/share/guile/2.2/ice-9/curried-definitions.scm +57 -0
  421. data/share/guile/2.2/ice-9/debug.scm +25 -0
  422. data/share/guile/2.2/ice-9/deprecated.scm +93 -0
  423. data/share/guile/2.2/ice-9/documentation.scm +203 -0
  424. data/share/guile/2.2/ice-9/eval-string.scm +90 -0
  425. data/share/guile/2.2/ice-9/eval.scm +723 -0
  426. data/share/guile/2.2/ice-9/expect.scm +171 -0
  427. data/share/guile/2.2/ice-9/fdes-finalizers.scm +25 -0
  428. data/share/guile/2.2/ice-9/format.scm +1626 -0
  429. data/share/guile/2.2/ice-9/ftw.scm +564 -0
  430. data/share/guile/2.2/ice-9/futures.scm +308 -0
  431. data/share/guile/2.2/ice-9/gap-buffer.scm +283 -0
  432. data/share/guile/2.2/ice-9/getopt-long.scm +371 -0
  433. data/share/guile/2.2/ice-9/hash-table.scm +45 -0
  434. data/share/guile/2.2/ice-9/hcons.scm +80 -0
  435. data/share/guile/2.2/ice-9/history.scm +65 -0
  436. data/share/guile/2.2/ice-9/i18n.scm +531 -0
  437. data/share/guile/2.2/ice-9/iconv.scm +95 -0
  438. data/share/guile/2.2/ice-9/lineio.scm +115 -0
  439. data/share/guile/2.2/ice-9/list.scm +36 -0
  440. data/share/guile/2.2/ice-9/local-eval.scm +261 -0
  441. data/share/guile/2.2/ice-9/ls.scm +94 -0
  442. data/share/guile/2.2/ice-9/mapping.scm +118 -0
  443. data/share/guile/2.2/ice-9/match.scm +59 -0
  444. data/share/guile/2.2/ice-9/match.upstream.scm +917 -0
  445. data/share/guile/2.2/ice-9/networking.scm +94 -0
  446. data/share/guile/2.2/ice-9/null.scm +34 -0
  447. data/share/guile/2.2/ice-9/occam-channel.scm +261 -0
  448. data/share/guile/2.2/ice-9/optargs.scm +381 -0
  449. data/share/guile/2.2/ice-9/peg/cache.scm +45 -0
  450. data/share/guile/2.2/ice-9/peg/codegen.scm +359 -0
  451. data/share/guile/2.2/ice-9/peg/simplify-tree.scm +97 -0
  452. data/share/guile/2.2/ice-9/peg/string-peg.scm +273 -0
  453. data/share/guile/2.2/ice-9/peg/using-parsers.scm +116 -0
  454. data/share/guile/2.2/ice-9/peg.scm +42 -0
  455. data/share/guile/2.2/ice-9/poe.scm +116 -0
  456. data/share/guile/2.2/ice-9/poll.scm +172 -0
  457. data/share/guile/2.2/ice-9/popen.scm +178 -0
  458. data/share/guile/2.2/ice-9/ports.scm +566 -0
  459. data/share/guile/2.2/ice-9/posix.scm +75 -0
  460. data/share/guile/2.2/ice-9/pretty-print.scm +483 -0
  461. data/share/guile/2.2/ice-9/psyntax-pp.scm +3542 -0
  462. data/share/guile/2.2/ice-9/psyntax.scm +3326 -0
  463. data/share/guile/2.2/ice-9/q.scm +153 -0
  464. data/share/guile/2.2/ice-9/quasisyntax.scm +136 -0
  465. data/share/guile/2.2/ice-9/r5rs.scm +45 -0
  466. data/share/guile/2.2/ice-9/r6rs-libraries.scm +242 -0
  467. data/share/guile/2.2/ice-9/rdelim.scm +208 -0
  468. data/share/guile/2.2/ice-9/receive.scm +26 -0
  469. data/share/guile/2.2/ice-9/regex.scm +229 -0
  470. data/share/guile/2.2/ice-9/runq.scm +241 -0
  471. data/share/guile/2.2/ice-9/rw.scm +27 -0
  472. data/share/guile/2.2/ice-9/safe-r5rs.scm +145 -0
  473. data/share/guile/2.2/ice-9/safe.scm +34 -0
  474. data/share/guile/2.2/ice-9/sandbox.scm +1399 -0
  475. data/share/guile/2.2/ice-9/save-stack.scm +58 -0
  476. data/share/guile/2.2/ice-9/scm-style-repl.scm +279 -0
  477. data/share/guile/2.2/ice-9/serialize.scm +114 -0
  478. data/share/guile/2.2/ice-9/session.scm +530 -0
  479. data/share/guile/2.2/ice-9/slib.scm +33 -0
  480. data/share/guile/2.2/ice-9/stack-catch.scm +47 -0
  481. data/share/guile/2.2/ice-9/streams.scm +168 -0
  482. data/share/guile/2.2/ice-9/string-fun.scm +280 -0
  483. data/share/guile/2.2/ice-9/suspendable-ports.scm +788 -0
  484. data/share/guile/2.2/ice-9/syncase.scm +37 -0
  485. data/share/guile/2.2/ice-9/textual-ports.scm +70 -0
  486. data/share/guile/2.2/ice-9/threads.scm +392 -0
  487. data/share/guile/2.2/ice-9/time.scm +58 -0
  488. data/share/guile/2.2/ice-9/top-repl.scm +78 -0
  489. data/share/guile/2.2/ice-9/unicode.scm +26 -0
  490. data/share/guile/2.2/ice-9/vlist.scm +595 -0
  491. data/share/guile/2.2/ice-9/weak-vector.scm +31 -0
  492. data/share/guile/2.2/language/brainfuck/compile-scheme.scm +123 -0
  493. data/share/guile/2.2/language/brainfuck/compile-tree-il.scm +184 -0
  494. data/share/guile/2.2/language/brainfuck/parse.scm +95 -0
  495. data/share/guile/2.2/language/brainfuck/spec.scm +43 -0
  496. data/share/guile/2.2/language/bytecode/spec.scm +42 -0
  497. data/share/guile/2.2/language/bytecode.scm +104 -0
  498. data/share/guile/2.2/language/cps/closure-conversion.scm +848 -0
  499. data/share/guile/2.2/language/cps/compile-bytecode.scm +610 -0
  500. data/share/guile/2.2/language/cps/constructors.scm +106 -0
  501. data/share/guile/2.2/language/cps/contification.scm +448 -0
  502. data/share/guile/2.2/language/cps/cse.scm +414 -0
  503. data/share/guile/2.2/language/cps/dce.scm +363 -0
  504. data/share/guile/2.2/language/cps/effects-analysis.scm +597 -0
  505. data/share/guile/2.2/language/cps/elide-values.scm +88 -0
  506. data/share/guile/2.2/language/cps/handle-interrupts.scm +69 -0
  507. data/share/guile/2.2/language/cps/intmap.scm +765 -0
  508. data/share/guile/2.2/language/cps/intset.scm +830 -0
  509. data/share/guile/2.2/language/cps/licm.scm +308 -0
  510. data/share/guile/2.2/language/cps/optimize.scm +135 -0
  511. data/share/guile/2.2/language/cps/peel-loops.scm +287 -0
  512. data/share/guile/2.2/language/cps/primitives.scm +141 -0
  513. data/share/guile/2.2/language/cps/prune-bailouts.scm +86 -0
  514. data/share/guile/2.2/language/cps/prune-top-level-scopes.scm +63 -0
  515. data/share/guile/2.2/language/cps/reify-primitives.scm +179 -0
  516. data/share/guile/2.2/language/cps/renumber.scm +217 -0
  517. data/share/guile/2.2/language/cps/rotate-loops.scm +239 -0
  518. data/share/guile/2.2/language/cps/self-references.scm +79 -0
  519. data/share/guile/2.2/language/cps/simplify.scm +274 -0
  520. data/share/guile/2.2/language/cps/slot-allocation.scm +1058 -0
  521. data/share/guile/2.2/language/cps/spec.scm +51 -0
  522. data/share/guile/2.2/language/cps/specialize-numbers.scm +724 -0
  523. data/share/guile/2.2/language/cps/specialize-primcalls.scm +87 -0
  524. data/share/guile/2.2/language/cps/split-rec.scm +174 -0
  525. data/share/guile/2.2/language/cps/type-checks.scm +72 -0
  526. data/share/guile/2.2/language/cps/type-fold.scm +455 -0
  527. data/share/guile/2.2/language/cps/types.scm +1826 -0
  528. data/share/guile/2.2/language/cps/utils.scm +550 -0
  529. data/share/guile/2.2/language/cps/verify.scm +304 -0
  530. data/share/guile/2.2/language/cps/with-cps.scm +145 -0
  531. data/share/guile/2.2/language/cps.scm +358 -0
  532. data/share/guile/2.2/language/ecmascript/array.scm +121 -0
  533. data/share/guile/2.2/language/ecmascript/base.scm +251 -0
  534. data/share/guile/2.2/language/ecmascript/compile-tree-il.scm +576 -0
  535. data/share/guile/2.2/language/ecmascript/function.scm +78 -0
  536. data/share/guile/2.2/language/ecmascript/impl.scm +169 -0
  537. data/share/guile/2.2/language/ecmascript/parse.scm +352 -0
  538. data/share/guile/2.2/language/ecmascript/spec.scm +37 -0
  539. data/share/guile/2.2/language/ecmascript/tokenize.scm +513 -0
  540. data/share/guile/2.2/language/elisp/bindings.scm +107 -0
  541. data/share/guile/2.2/language/elisp/boot.el +617 -0
  542. data/share/guile/2.2/language/elisp/compile-tree-il.scm +812 -0
  543. data/share/guile/2.2/language/elisp/falias.scm +47 -0
  544. data/share/guile/2.2/language/elisp/lexer.scm +430 -0
  545. data/share/guile/2.2/language/elisp/parser.scm +222 -0
  546. data/share/guile/2.2/language/elisp/runtime/function-slot.scm +63 -0
  547. data/share/guile/2.2/language/elisp/runtime/value-slot.scm +24 -0
  548. data/share/guile/2.2/language/elisp/runtime.scm +153 -0
  549. data/share/guile/2.2/language/elisp/spec.scm +43 -0
  550. data/share/guile/2.2/language/scheme/compile-tree-il.scm +33 -0
  551. data/share/guile/2.2/language/scheme/decompile-tree-il.scm +796 -0
  552. data/share/guile/2.2/language/scheme/spec.scm +63 -0
  553. data/share/guile/2.2/language/tree-il/analyze.scm +1568 -0
  554. data/share/guile/2.2/language/tree-il/canonicalize.scm +82 -0
  555. data/share/guile/2.2/language/tree-il/compile-cps.scm +1149 -0
  556. data/share/guile/2.2/language/tree-il/debug.scm +246 -0
  557. data/share/guile/2.2/language/tree-il/effects.scm +591 -0
  558. data/share/guile/2.2/language/tree-il/fix-letrec.scm +314 -0
  559. data/share/guile/2.2/language/tree-il/optimize.scm +43 -0
  560. data/share/guile/2.2/language/tree-il/peval.scm +1669 -0
  561. data/share/guile/2.2/language/tree-il/primitives.scm +630 -0
  562. data/share/guile/2.2/language/tree-il/spec.scm +46 -0
  563. data/share/guile/2.2/language/tree-il.scm +630 -0
  564. data/share/guile/2.2/language/value/spec.scm +30 -0
  565. data/share/guile/2.2/oop/goops/accessors.scm +72 -0
  566. data/share/guile/2.2/oop/goops/active-slot.scm +63 -0
  567. data/share/guile/2.2/oop/goops/composite-slot.scm +83 -0
  568. data/share/guile/2.2/oop/goops/describe.scm +189 -0
  569. data/share/guile/2.2/oop/goops/internal.scm +30 -0
  570. data/share/guile/2.2/oop/goops/save.scm +874 -0
  571. data/share/guile/2.2/oop/goops/simple.scm +30 -0
  572. data/share/guile/2.2/oop/goops/stklos.scm +74 -0
  573. data/share/guile/2.2/oop/goops.scm +3176 -0
  574. data/share/guile/2.2/rnrs/arithmetic/bitwise.scm +92 -0
  575. data/share/guile/2.2/rnrs/arithmetic/fixnums.scm +291 -0
  576. data/share/guile/2.2/rnrs/arithmetic/flonums.scm +203 -0
  577. data/share/guile/2.2/rnrs/base.scm +291 -0
  578. data/share/guile/2.2/rnrs/bytevectors.scm +83 -0
  579. data/share/guile/2.2/rnrs/conditions.scm +225 -0
  580. data/share/guile/2.2/rnrs/control.scm +22 -0
  581. data/share/guile/2.2/rnrs/enums.scm +152 -0
  582. data/share/guile/2.2/rnrs/eval.scm +39 -0
  583. data/share/guile/2.2/rnrs/exceptions.scm +276 -0
  584. data/share/guile/2.2/rnrs/files.scm +96 -0
  585. data/share/guile/2.2/rnrs/hashtables.scm +190 -0
  586. data/share/guile/2.2/rnrs/io/ports.scm +554 -0
  587. data/share/guile/2.2/rnrs/io/simple.scm +167 -0
  588. data/share/guile/2.2/rnrs/lists.scm +55 -0
  589. data/share/guile/2.2/rnrs/mutable-pairs.scm +23 -0
  590. data/share/guile/2.2/rnrs/mutable-strings.scm +23 -0
  591. data/share/guile/2.2/rnrs/programs.scm +22 -0
  592. data/share/guile/2.2/rnrs/r5rs.scm +34 -0
  593. data/share/guile/2.2/rnrs/records/inspection.scm +81 -0
  594. data/share/guile/2.2/rnrs/records/procedural.scm +289 -0
  595. data/share/guile/2.2/rnrs/records/syntactic.scm +248 -0
  596. data/share/guile/2.2/rnrs/sorting.scm +27 -0
  597. data/share/guile/2.2/rnrs/syntax-case.scm +68 -0
  598. data/share/guile/2.2/rnrs/unicode.scm +104 -0
  599. data/share/guile/2.2/rnrs.scm +289 -0
  600. data/share/guile/2.2/scripts/api-diff.scm +179 -0
  601. data/share/guile/2.2/scripts/autofrisk.scm +218 -0
  602. data/share/guile/2.2/scripts/compile.scm +273 -0
  603. data/share/guile/2.2/scripts/disassemble.scm +38 -0
  604. data/share/guile/2.2/scripts/display-commentary.scm +67 -0
  605. data/share/guile/2.2/scripts/doc-snarf.scm +439 -0
  606. data/share/guile/2.2/scripts/frisk.scm +290 -0
  607. data/share/guile/2.2/scripts/generate-autoload.scm +144 -0
  608. data/share/guile/2.2/scripts/help.scm +188 -0
  609. data/share/guile/2.2/scripts/lint.scm +318 -0
  610. data/share/guile/2.2/scripts/list.scm +91 -0
  611. data/share/guile/2.2/scripts/punify.scm +87 -0
  612. data/share/guile/2.2/scripts/read-rfc822.scm +131 -0
  613. data/share/guile/2.2/scripts/read-scheme-source.scm +282 -0
  614. data/share/guile/2.2/scripts/read-text-outline.scm +253 -0
  615. data/share/guile/2.2/scripts/scan-api.scm +223 -0
  616. data/share/guile/2.2/scripts/snarf-check-and-output-texi.scm +303 -0
  617. data/share/guile/2.2/scripts/snarf-guile-m4-docs.scm +86 -0
  618. data/share/guile/2.2/scripts/summarize-guile-TODO.scm +213 -0
  619. data/share/guile/2.2/scripts/use2dot.scm +110 -0
  620. data/share/guile/2.2/srfi/srfi-1.scm +1061 -0
  621. data/share/guile/2.2/srfi/srfi-10.scm +89 -0
  622. data/share/guile/2.2/srfi/srfi-11.scm +146 -0
  623. data/share/guile/2.2/srfi/srfi-111.scm +37 -0
  624. data/share/guile/2.2/srfi/srfi-13.scm +132 -0
  625. data/share/guile/2.2/srfi/srfi-14.scm +99 -0
  626. data/share/guile/2.2/srfi/srfi-16.scm +51 -0
  627. data/share/guile/2.2/srfi/srfi-17.scm +174 -0
  628. data/share/guile/2.2/srfi/srfi-18.scm +382 -0
  629. data/share/guile/2.2/srfi/srfi-19.scm +1470 -0
  630. data/share/guile/2.2/srfi/srfi-2.scm +31 -0
  631. data/share/guile/2.2/srfi/srfi-26.scm +66 -0
  632. data/share/guile/2.2/srfi/srfi-27.scm +96 -0
  633. data/share/guile/2.2/srfi/srfi-28.scm +34 -0
  634. data/share/guile/2.2/srfi/srfi-31.scm +35 -0
  635. data/share/guile/2.2/srfi/srfi-34.scm +84 -0
  636. data/share/guile/2.2/srfi/srfi-35.scm +351 -0
  637. data/share/guile/2.2/srfi/srfi-37.scm +234 -0
  638. data/share/guile/2.2/srfi/srfi-38.scm +207 -0
  639. data/share/guile/2.2/srfi/srfi-39.scm +55 -0
  640. data/share/guile/2.2/srfi/srfi-4/gnu.scm +80 -0
  641. data/share/guile/2.2/srfi/srfi-4.scm +118 -0
  642. data/share/guile/2.2/srfi/srfi-41.scm +505 -0
  643. data/share/guile/2.2/srfi/srfi-42/ec.scm +1053 -0
  644. data/share/guile/2.2/srfi/srfi-42.scm +66 -0
  645. data/share/guile/2.2/srfi/srfi-43.scm +1077 -0
  646. data/share/guile/2.2/srfi/srfi-45.scm +93 -0
  647. data/share/guile/2.2/srfi/srfi-6.scm +29 -0
  648. data/share/guile/2.2/srfi/srfi-60.scm +73 -0
  649. data/share/guile/2.2/srfi/srfi-64/testing.scm +1040 -0
  650. data/share/guile/2.2/srfi/srfi-64.scm +55 -0
  651. data/share/guile/2.2/srfi/srfi-67/compare.scm +686 -0
  652. data/share/guile/2.2/srfi/srfi-67.scm +88 -0
  653. data/share/guile/2.2/srfi/srfi-69.scm +336 -0
  654. data/share/guile/2.2/srfi/srfi-71.scm +267 -0
  655. data/share/guile/2.2/srfi/srfi-8.scm +31 -0
  656. data/share/guile/2.2/srfi/srfi-88.scm +53 -0
  657. data/share/guile/2.2/srfi/srfi-9/gnu.scm +168 -0
  658. data/share/guile/2.2/srfi/srfi-9.scm +351 -0
  659. data/share/guile/2.2/srfi/srfi-98.scm +44 -0
  660. data/share/guile/2.2/statprof.scm +988 -0
  661. data/share/guile/2.2/sxml/apply-templates.scm +102 -0
  662. data/share/guile/2.2/sxml/fold.scm +250 -0
  663. data/share/guile/2.2/sxml/match.scm +75 -0
  664. data/share/guile/2.2/sxml/simple.scm +408 -0
  665. data/share/guile/2.2/sxml/ssax/input-parse.scm +180 -0
  666. data/share/guile/2.2/sxml/ssax.scm +265 -0
  667. data/share/guile/2.2/sxml/sxml-match.ss +1181 -0
  668. data/share/guile/2.2/sxml/transform.scm +298 -0
  669. data/share/guile/2.2/sxml/upstream/SSAX.scm +3235 -0
  670. data/share/guile/2.2/sxml/upstream/SXML-tree-trans.scm +249 -0
  671. data/share/guile/2.2/sxml/upstream/SXPath-old.scm +1216 -0
  672. data/share/guile/2.2/sxml/upstream/assert.scm +35 -0
  673. data/share/guile/2.2/sxml/upstream/input-parse.scm +326 -0
  674. data/share/guile/2.2/sxml/xpath.scm +493 -0
  675. data/share/guile/2.2/system/base/ck.scm +55 -0
  676. data/share/guile/2.2/system/base/compile.scm +282 -0
  677. data/share/guile/2.2/system/base/lalr.scm +51 -0
  678. data/share/guile/2.2/system/base/lalr.upstream.scm +2096 -0
  679. data/share/guile/2.2/system/base/language.scm +119 -0
  680. data/share/guile/2.2/system/base/message.scm +238 -0
  681. data/share/guile/2.2/system/base/pmatch.scm +68 -0
  682. data/share/guile/2.2/system/base/syntax.scm +299 -0
  683. data/share/guile/2.2/system/base/target.scm +152 -0
  684. data/share/guile/2.2/system/base/types.scm +561 -0
  685. data/share/guile/2.2/system/foreign-object.scm +91 -0
  686. data/share/guile/2.2/system/foreign.scm +200 -0
  687. data/share/guile/2.2/system/repl/command.scm +946 -0
  688. data/share/guile/2.2/system/repl/common.scm +263 -0
  689. data/share/guile/2.2/system/repl/coop-server.scm +200 -0
  690. data/share/guile/2.2/system/repl/debug.scm +210 -0
  691. data/share/guile/2.2/system/repl/describe.scm +347 -0
  692. data/share/guile/2.2/system/repl/error-handling.scm +183 -0
  693. data/share/guile/2.2/system/repl/repl.scm +233 -0
  694. data/share/guile/2.2/system/repl/server.scm +332 -0
  695. data/share/guile/2.2/system/syntax.scm +33 -0
  696. data/share/guile/2.2/system/vm/assembler.scm +2614 -0
  697. data/share/guile/2.2/system/vm/coverage.scm +351 -0
  698. data/share/guile/2.2/system/vm/debug.scm +766 -0
  699. data/share/guile/2.2/system/vm/disassembler.scm +658 -0
  700. data/share/guile/2.2/system/vm/dwarf.scm +1852 -0
  701. data/share/guile/2.2/system/vm/elf.scm +1042 -0
  702. data/share/guile/2.2/system/vm/frame.scm +485 -0
  703. data/share/guile/2.2/system/vm/inspect.scm +188 -0
  704. data/share/guile/2.2/system/vm/linker.scm +732 -0
  705. data/share/guile/2.2/system/vm/loader.scm +27 -0
  706. data/share/guile/2.2/system/vm/program.scm +312 -0
  707. data/share/guile/2.2/system/vm/trace.scm +121 -0
  708. data/share/guile/2.2/system/vm/trap-state.scm +302 -0
  709. data/share/guile/2.2/system/vm/traps.scm +608 -0
  710. data/share/guile/2.2/system/vm/vm.scm +32 -0
  711. data/share/guile/2.2/system/xref.scm +369 -0
  712. data/share/guile/2.2/texinfo/docbook.scm +240 -0
  713. data/share/guile/2.2/texinfo/html.scm +279 -0
  714. data/share/guile/2.2/texinfo/indexing.scm +75 -0
  715. data/share/guile/2.2/texinfo/plain-text.scm +322 -0
  716. data/share/guile/2.2/texinfo/reflection.scm +585 -0
  717. data/share/guile/2.2/texinfo/serialize.scm +300 -0
  718. data/share/guile/2.2/texinfo/string-utils.scm +410 -0
  719. data/share/guile/2.2/texinfo.scm +1263 -0
  720. data/share/guile/2.2/web/client.scm +513 -0
  721. data/share/guile/2.2/web/http.scm +2043 -0
  722. data/share/guile/2.2/web/request.scm +326 -0
  723. data/share/guile/2.2/web/response.scm +379 -0
  724. data/share/guile/2.2/web/server/http.scm +183 -0
  725. data/share/guile/2.2/web/server.scm +397 -0
  726. data/share/guile/2.2/web/uri.scm +552 -0
  727. data/share/lilypond/2.24.1/fontconfig/0bd3dc0958fa2205aaaa8ebb13e2872b-le64.cache-8 +0 -0
  728. data/share/lilypond/2.24.1/fontconfig/188ac73a183f12857f63bb60a4a6d603-le64.cache-8 +0 -0
  729. data/share/lilypond/2.24.1/fontconfig/32b6488e5b8292a2e95c79d947e009e8-le64.cache-8 +0 -0
  730. data/share/lilypond/2.24.1/fontconfig/3830d5c3ddfd5cd38a049b759396e72e-le64.cache-8 +0 -0
  731. data/share/lilypond/2.24.1/fontconfig/3f7329c5293ffd510edef78f73874cfd-le64.cache-8 +0 -0
  732. data/share/lilypond/2.24.1/fontconfig/4c599c202bc5c08e2d34565a40eac3b2-le64.cache-8 +0 -0
  733. data/share/lilypond/2.24.1/fontconfig/57e423e26b20ab21d0f2f29c145174c3-le64.cache-8 +0 -0
  734. data/share/lilypond/2.24.1/fontconfig/7ef2298fde41cc6eeb7af42e48b7d293-le64.cache-8 +0 -0
  735. data/share/lilypond/2.24.1/fontconfig/826f6b6ef79022e2eac8af26bf4b62f2-le64.cache-8 +0 -0
  736. data/share/lilypond/2.24.1/fontconfig/945677eb7aeaf62f1d50efc3fb3ec7d8-le64.cache-8 +0 -0
  737. data/share/lilypond/2.24.1/fontconfig/95530828ff6c81d309f8258d8d02a23e-le64.cache-8 +0 -0
  738. data/share/lilypond/2.24.1/fontconfig/CACHEDIR.TAG +4 -0
  739. data/share/lilypond/2.24.1/fontconfig/bf3b770c553c462765856025a94f1ce6-le64.cache-8 +0 -0
  740. data/share/lilypond/2.24.1/fontconfig/c855463f699352c367813e37f3f70ea7-le64.cache-8 +0 -0
  741. data/share/lilypond/2.24.1/fontconfig/d3e5c4ee2ceb1fc347f91d4cefc53bc0-le64.cache-8 +0 -0
  742. data/share/lilypond/2.24.1/fontconfig/d589a48862398ed80a3d6066f4f56f4c-le64.cache-8 +0 -0
  743. data/share/lilypond/2.24.1/fontconfig/d82eb4fd963d448e2fcb7d7b793b5df3-le64.cache-8 +0 -0
  744. data/share/lilypond/2.24.1/fontconfig/e13b20fdb08344e0e664864cc2ede53d-le64.cache-8 +0 -0
  745. data/share/lilypond/2.24.1/fontconfig/e52a45a1c8c8fe895fc0fc8c4e6999b8-le64.cache-8 +0 -0
  746. data/share/lilypond/2.24.1/fontconfig/f1f2465696798768e9653f19e17ccdc8-le64.cache-8 +0 -0
  747. data/share/lilypond/2.24.1/fonts/00-lilypond-fonts.conf +99 -0
  748. data/share/lilypond/2.24.1/fonts/99-lilypond-fonts.conf +28 -0
  749. data/share/lilypond/2.24.1/fonts/otf/C059-BdIta.otf +0 -0
  750. data/share/lilypond/2.24.1/fonts/otf/C059-Bold.otf +0 -0
  751. data/share/lilypond/2.24.1/fonts/otf/C059-Italic.otf +0 -0
  752. data/share/lilypond/2.24.1/fonts/otf/C059-Roman.otf +0 -0
  753. data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Bold.otf +0 -0
  754. data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-BoldItalic.otf +0 -0
  755. data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Italic.otf +0 -0
  756. data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Regular.otf +0 -0
  757. data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Bold.otf +0 -0
  758. data/share/lilypond/2.24.1/fonts/otf/NimbusSans-BoldItalic.otf +0 -0
  759. data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Italic.otf +0 -0
  760. data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Regular.otf +0 -0
  761. data/share/lilypond/2.24.1/fonts/otf/emmentaler-11.otf +0 -0
  762. data/share/lilypond/2.24.1/fonts/otf/emmentaler-13.otf +0 -0
  763. data/share/lilypond/2.24.1/fonts/otf/emmentaler-14.otf +0 -0
  764. data/share/lilypond/2.24.1/fonts/otf/emmentaler-16.otf +0 -0
  765. data/share/lilypond/2.24.1/fonts/otf/emmentaler-18.otf +0 -0
  766. data/share/lilypond/2.24.1/fonts/otf/emmentaler-20.otf +0 -0
  767. data/share/lilypond/2.24.1/fonts/otf/emmentaler-23.otf +0 -0
  768. data/share/lilypond/2.24.1/fonts/otf/emmentaler-26.otf +0 -0
  769. data/share/lilypond/2.24.1/fonts/otf/emmentaler-brace.otf +0 -0
  770. data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-bold.otf +0 -0
  771. data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-bolditalic.otf +0 -0
  772. data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-italic.otf +0 -0
  773. data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-regular.otf +0 -0
  774. data/share/lilypond/2.24.1/fonts/otf/texgyreheros-bold.otf +0 -0
  775. data/share/lilypond/2.24.1/fonts/otf/texgyreheros-bolditalic.otf +0 -0
  776. data/share/lilypond/2.24.1/fonts/otf/texgyreheros-italic.otf +0 -0
  777. data/share/lilypond/2.24.1/fonts/otf/texgyreheros-regular.otf +0 -0
  778. data/share/lilypond/2.24.1/fonts/otf/texgyreschola-bold.otf +0 -0
  779. data/share/lilypond/2.24.1/fonts/otf/texgyreschola-bolditalic.otf +0 -0
  780. data/share/lilypond/2.24.1/fonts/otf/texgyreschola-italic.otf +0 -0
  781. data/share/lilypond/2.24.1/fonts/otf/texgyreschola-regular.otf +0 -0
  782. data/share/lilypond/2.24.1/fonts/source/common-modules-and-initialization.mf +26 -0
  783. data/share/lilypond/2.24.1/fonts/source/debugging-settings.mf +14 -0
  784. data/share/lilypond/2.24.1/fonts/source/declare-autometric-parameters.mf +9 -0
  785. data/share/lilypond/2.24.1/fonts/source/feta-accidentals.mf +58 -0
  786. data/share/lilypond/2.24.1/fonts/source/feta-accordion.mf +575 -0
  787. data/share/lilypond/2.24.1/fonts/source/feta-alphabet-generic.mf +16 -0
  788. data/share/lilypond/2.24.1/fonts/source/feta-alphabet11.mf +6 -0
  789. data/share/lilypond/2.24.1/fonts/source/feta-alphabet13.mf +6 -0
  790. data/share/lilypond/2.24.1/fonts/source/feta-alphabet14.mf +6 -0
  791. data/share/lilypond/2.24.1/fonts/source/feta-alphabet16.mf +6 -0
  792. data/share/lilypond/2.24.1/fonts/source/feta-alphabet18.mf +6 -0
  793. data/share/lilypond/2.24.1/fonts/source/feta-alphabet20.mf +6 -0
  794. data/share/lilypond/2.24.1/fonts/source/feta-alphabet23.mf +6 -0
  795. data/share/lilypond/2.24.1/fonts/source/feta-alphabet26.mf +6 -0
  796. data/share/lilypond/2.24.1/fonts/source/feta-arrow.mf +114 -0
  797. data/share/lilypond/2.24.1/fonts/source/feta-arrowheads.mf +171 -0
  798. data/share/lilypond/2.24.1/fonts/source/feta-autometric.mf +303 -0
  799. data/share/lilypond/2.24.1/fonts/source/feta-braces-a.mf +6 -0
  800. data/share/lilypond/2.24.1/fonts/source/feta-braces-b.mf +6 -0
  801. data/share/lilypond/2.24.1/fonts/source/feta-braces-c.mf +6 -0
  802. data/share/lilypond/2.24.1/fonts/source/feta-braces-d.mf +6 -0
  803. data/share/lilypond/2.24.1/fonts/source/feta-braces-e.mf +6 -0
  804. data/share/lilypond/2.24.1/fonts/source/feta-braces-f.mf +6 -0
  805. data/share/lilypond/2.24.1/fonts/source/feta-braces-g.mf +6 -0
  806. data/share/lilypond/2.24.1/fonts/source/feta-braces-generic.mf +47 -0
  807. data/share/lilypond/2.24.1/fonts/source/feta-braces-h.mf +6 -0
  808. data/share/lilypond/2.24.1/fonts/source/feta-braces-i.mf +6 -0
  809. data/share/lilypond/2.24.1/fonts/source/feta-braces.mf +125 -0
  810. data/share/lilypond/2.24.1/fonts/source/feta-brackettips.mf +100 -0
  811. data/share/lilypond/2.24.1/fonts/source/feta-clefs.mf +963 -0
  812. data/share/lilypond/2.24.1/fonts/source/feta-dots.mf +37 -0
  813. data/share/lilypond/2.24.1/fonts/source/feta-dynamics.mf +891 -0
  814. data/share/lilypond/2.24.1/fonts/source/feta-flags-generic.mf +17 -0
  815. data/share/lilypond/2.24.1/fonts/source/feta-flags.mf +926 -0
  816. data/share/lilypond/2.24.1/fonts/source/feta-flags11.mf +6 -0
  817. data/share/lilypond/2.24.1/fonts/source/feta-flags13.mf +6 -0
  818. data/share/lilypond/2.24.1/fonts/source/feta-flags14.mf +6 -0
  819. data/share/lilypond/2.24.1/fonts/source/feta-flags16.mf +6 -0
  820. data/share/lilypond/2.24.1/fonts/source/feta-flags18.mf +6 -0
  821. data/share/lilypond/2.24.1/fonts/source/feta-flags20.mf +6 -0
  822. data/share/lilypond/2.24.1/fonts/source/feta-flags23.mf +6 -0
  823. data/share/lilypond/2.24.1/fonts/source/feta-flags26.mf +6 -0
  824. data/share/lilypond/2.24.1/fonts/source/feta-flats.mf +668 -0
  825. data/share/lilypond/2.24.1/fonts/source/feta-macros.mf +506 -0
  826. data/share/lilypond/2.24.1/fonts/source/feta-naturals.mf +223 -0
  827. data/share/lilypond/2.24.1/fonts/source/feta-noteheads-generic.mf +17 -0
  828. data/share/lilypond/2.24.1/fonts/source/feta-noteheads.mf +2642 -0
  829. data/share/lilypond/2.24.1/fonts/source/feta-noteheads11.mf +6 -0
  830. data/share/lilypond/2.24.1/fonts/source/feta-noteheads13.mf +6 -0
  831. data/share/lilypond/2.24.1/fonts/source/feta-noteheads14.mf +6 -0
  832. data/share/lilypond/2.24.1/fonts/source/feta-noteheads16.mf +6 -0
  833. data/share/lilypond/2.24.1/fonts/source/feta-noteheads18.mf +6 -0
  834. data/share/lilypond/2.24.1/fonts/source/feta-noteheads20.mf +6 -0
  835. data/share/lilypond/2.24.1/fonts/source/feta-noteheads23.mf +6 -0
  836. data/share/lilypond/2.24.1/fonts/source/feta-noteheads26.mf +6 -0
  837. data/share/lilypond/2.24.1/fonts/source/feta-numbers.mf +1677 -0
  838. data/share/lilypond/2.24.1/fonts/source/feta-other-generic.mf +27 -0
  839. data/share/lilypond/2.24.1/fonts/source/feta-params.mf +323 -0
  840. data/share/lilypond/2.24.1/fonts/source/feta-parenthesis.mf +63 -0
  841. data/share/lilypond/2.24.1/fonts/source/feta-pedals.mf +355 -0
  842. data/share/lilypond/2.24.1/fonts/source/feta-rests.mf +890 -0
  843. data/share/lilypond/2.24.1/fonts/source/feta-scripts.mf +2206 -0
  844. data/share/lilypond/2.24.1/fonts/source/feta-sharps.mf +524 -0
  845. data/share/lilypond/2.24.1/fonts/source/feta-sori-koron.mf +325 -0
  846. data/share/lilypond/2.24.1/fonts/source/feta-ties.mf +72 -0
  847. data/share/lilypond/2.24.1/fonts/source/feta-timesignatures.mf +119 -0
  848. data/share/lilypond/2.24.1/fonts/source/feta-trills.mf +321 -0
  849. data/share/lilypond/2.24.1/fonts/source/feta11.mf +6 -0
  850. data/share/lilypond/2.24.1/fonts/source/feta13.mf +6 -0
  851. data/share/lilypond/2.24.1/fonts/source/feta14.mf +6 -0
  852. data/share/lilypond/2.24.1/fonts/source/feta16.mf +6 -0
  853. data/share/lilypond/2.24.1/fonts/source/feta18.mf +6 -0
  854. data/share/lilypond/2.24.1/fonts/source/feta20.mf +7 -0
  855. data/share/lilypond/2.24.1/fonts/source/feta23.mf +6 -0
  856. data/share/lilypond/2.24.1/fonts/source/feta26.mf +6 -0
  857. data/share/lilypond/2.24.1/fonts/source/parmesan-accidentals.mf +483 -0
  858. data/share/lilypond/2.24.1/fonts/source/parmesan-clefs.mf +1636 -0
  859. data/share/lilypond/2.24.1/fonts/source/parmesan-custodes.mf +503 -0
  860. data/share/lilypond/2.24.1/fonts/source/parmesan-dots.mf +62 -0
  861. data/share/lilypond/2.24.1/fonts/source/parmesan-flags.mf +319 -0
  862. data/share/lilypond/2.24.1/fonts/source/parmesan-macros.mf +225 -0
  863. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads-generic.mf +16 -0
  864. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads.mf +2191 -0
  865. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads11.mf +6 -0
  866. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads13.mf +6 -0
  867. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads14.mf +6 -0
  868. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads16.mf +6 -0
  869. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads18.mf +6 -0
  870. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads20.mf +6 -0
  871. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads23.mf +6 -0
  872. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads26.mf +6 -0
  873. data/share/lilypond/2.24.1/fonts/source/parmesan-other-generic.mf +24 -0
  874. data/share/lilypond/2.24.1/fonts/source/parmesan-rests.mf +428 -0
  875. data/share/lilypond/2.24.1/fonts/source/parmesan-scripts.mf +284 -0
  876. data/share/lilypond/2.24.1/fonts/source/parmesan-timesignatures.mf +402 -0
  877. data/share/lilypond/2.24.1/fonts/source/parmesan11.mf +6 -0
  878. data/share/lilypond/2.24.1/fonts/source/parmesan13.mf +6 -0
  879. data/share/lilypond/2.24.1/fonts/source/parmesan14.mf +6 -0
  880. data/share/lilypond/2.24.1/fonts/source/parmesan16.mf +6 -0
  881. data/share/lilypond/2.24.1/fonts/source/parmesan18.mf +6 -0
  882. data/share/lilypond/2.24.1/fonts/source/parmesan20.mf +6 -0
  883. data/share/lilypond/2.24.1/fonts/source/parmesan23.mf +6 -0
  884. data/share/lilypond/2.24.1/fonts/source/parmesan26.mf +6 -0
  885. data/share/lilypond/2.24.1/fonts/svg/emmentaler-11.svg +2525 -0
  886. data/share/lilypond/2.24.1/fonts/svg/emmentaler-11.woff +0 -0
  887. data/share/lilypond/2.24.1/fonts/svg/emmentaler-13.svg +2530 -0
  888. data/share/lilypond/2.24.1/fonts/svg/emmentaler-13.woff +0 -0
  889. data/share/lilypond/2.24.1/fonts/svg/emmentaler-14.svg +2526 -0
  890. data/share/lilypond/2.24.1/fonts/svg/emmentaler-14.woff +0 -0
  891. data/share/lilypond/2.24.1/fonts/svg/emmentaler-16.svg +2523 -0
  892. data/share/lilypond/2.24.1/fonts/svg/emmentaler-16.woff +0 -0
  893. data/share/lilypond/2.24.1/fonts/svg/emmentaler-18.svg +2519 -0
  894. data/share/lilypond/2.24.1/fonts/svg/emmentaler-18.woff +0 -0
  895. data/share/lilypond/2.24.1/fonts/svg/emmentaler-20.svg +2512 -0
  896. data/share/lilypond/2.24.1/fonts/svg/emmentaler-20.woff +0 -0
  897. data/share/lilypond/2.24.1/fonts/svg/emmentaler-23.svg +2506 -0
  898. data/share/lilypond/2.24.1/fonts/svg/emmentaler-23.woff +0 -0
  899. data/share/lilypond/2.24.1/fonts/svg/emmentaler-26.svg +2510 -0
  900. data/share/lilypond/2.24.1/fonts/svg/emmentaler-26.woff +0 -0
  901. data/share/lilypond/2.24.1/fonts/svg/emmentaler-brace.svg +1757 -0
  902. data/share/lilypond/2.24.1/fonts/svg/emmentaler-brace.woff +0 -0
  903. data/share/lilypond/2.24.1/ly/Welcome_to_LilyPond.ly +45 -0
  904. data/share/lilypond/2.24.1/ly/arabic.ly +185 -0
  905. data/share/lilypond/2.24.1/ly/articulate.ly +1013 -0
  906. data/share/lilypond/2.24.1/ly/bagpipe.ly +368 -0
  907. data/share/lilypond/2.24.1/ly/base-tkit.ly +135 -0
  908. data/share/lilypond/2.24.1/ly/catalan.ly +23 -0
  909. data/share/lilypond/2.24.1/ly/chord-modifiers-init.ly +63 -0
  910. data/share/lilypond/2.24.1/ly/chord-repetition-init.ly +60 -0
  911. data/share/lilypond/2.24.1/ly/context-mods-init.ly +119 -0
  912. data/share/lilypond/2.24.1/ly/declarations-init.ly +167 -0
  913. data/share/lilypond/2.24.1/ly/deutsch.ly +23 -0
  914. data/share/lilypond/2.24.1/ly/drumpitch-init.ly +366 -0
  915. data/share/lilypond/2.24.1/ly/dynamic-scripts-init.ly +54 -0
  916. data/share/lilypond/2.24.1/ly/english.ly +23 -0
  917. data/share/lilypond/2.24.1/ly/engraver-init.ly +1619 -0
  918. data/share/lilypond/2.24.1/ly/espanol.ly +23 -0
  919. data/share/lilypond/2.24.1/ly/event-listener.ly +241 -0
  920. data/share/lilypond/2.24.1/ly/festival.ly +38 -0
  921. data/share/lilypond/2.24.1/ly/generate-documentation.ly +7 -0
  922. data/share/lilypond/2.24.1/ly/grace-init.ly +56 -0
  923. data/share/lilypond/2.24.1/ly/graphviz-init.ly +174 -0
  924. data/share/lilypond/2.24.1/ly/gregorian.ly +268 -0
  925. data/share/lilypond/2.24.1/ly/guile-debugger.ly +55 -0
  926. data/share/lilypond/2.24.1/ly/hel-arabic.ly +307 -0
  927. data/share/lilypond/2.24.1/ly/init.ly +96 -0
  928. data/share/lilypond/2.24.1/ly/italiano.ly +23 -0
  929. data/share/lilypond/2.24.1/ly/lilypond-book-preamble.ly +47 -0
  930. data/share/lilypond/2.24.1/ly/lyrics-tkit.ly +68 -0
  931. data/share/lilypond/2.24.1/ly/makam.ly +166 -0
  932. data/share/lilypond/2.24.1/ly/midi-init.ly +59 -0
  933. data/share/lilypond/2.24.1/ly/music-functions-init.ly +2254 -0
  934. data/share/lilypond/2.24.1/ly/nederlands.ly +23 -0
  935. data/share/lilypond/2.24.1/ly/norsk.ly +23 -0
  936. data/share/lilypond/2.24.1/ly/paper-defaults-init.ly +188 -0
  937. data/share/lilypond/2.24.1/ly/performer-init.ly +398 -0
  938. data/share/lilypond/2.24.1/ly/persian.ly +335 -0
  939. data/share/lilypond/2.24.1/ly/piano-tkit.ly +61 -0
  940. data/share/lilypond/2.24.1/ly/portugues.ly +23 -0
  941. data/share/lilypond/2.24.1/ly/predefined-fretboards-init.ly +78 -0
  942. data/share/lilypond/2.24.1/ly/predefined-guitar-fretboards.ly +506 -0
  943. data/share/lilypond/2.24.1/ly/predefined-guitar-ninth-fretboards.ly +75 -0
  944. data/share/lilypond/2.24.1/ly/predefined-mandolin-fretboards.ly +876 -0
  945. data/share/lilypond/2.24.1/ly/predefined-ukulele-fretboards.ly +1285 -0
  946. data/share/lilypond/2.24.1/ly/property-init.ly +858 -0
  947. data/share/lilypond/2.24.1/ly/satb.ly +214 -0
  948. data/share/lilypond/2.24.1/ly/scale-definitions-init.ly +117 -0
  949. data/share/lilypond/2.24.1/ly/scheme-sandbox.ly +39 -0
  950. data/share/lilypond/2.24.1/ly/script-init.ly +94 -0
  951. data/share/lilypond/2.24.1/ly/spanners-init.ly +146 -0
  952. data/share/lilypond/2.24.1/ly/ssaattbb.ly +335 -0
  953. data/share/lilypond/2.24.1/ly/staff-tkit.ly +182 -0
  954. data/share/lilypond/2.24.1/ly/string-tunings-init.ly +94 -0
  955. data/share/lilypond/2.24.1/ly/suomi.ly +23 -0
  956. data/share/lilypond/2.24.1/ly/svenska.ly +23 -0
  957. data/share/lilypond/2.24.1/ly/swing.ly +362 -0
  958. data/share/lilypond/2.24.1/ly/text-replacements.ly +150 -0
  959. data/share/lilypond/2.24.1/ly/titling-init.ly +150 -0
  960. data/share/lilypond/2.24.1/ly/toc-init.ly +182 -0
  961. data/share/lilypond/2.24.1/ly/turkish-makam.ly +609 -0
  962. data/share/lilypond/2.24.1/ly/vlaams.ly +23 -0
  963. data/share/lilypond/2.24.1/ly/vocal-tkit.ly +103 -0
  964. data/share/lilypond/2.24.1/ly/voice-tkit.ly +34 -0
  965. data/share/lilypond/2.24.1/ps/encodingdefs.ps +2611 -0
  966. data/share/lilypond/2.24.1/ps/lilyponddefs.ps +49 -0
  967. data/share/lilypond/2.24.1/ps/music-drawing-routines.ps +329 -0
  968. data/share/lilypond/2.24.1/python/__pycache__/book_base.cpython-310.pyc +0 -0
  969. data/share/lilypond/2.24.1/python/__pycache__/book_docbook.cpython-310.pyc +0 -0
  970. data/share/lilypond/2.24.1/python/__pycache__/book_html.cpython-310.pyc +0 -0
  971. data/share/lilypond/2.24.1/python/__pycache__/book_latex.cpython-310.pyc +0 -0
  972. data/share/lilypond/2.24.1/python/__pycache__/book_snippets.cpython-310.pyc +0 -0
  973. data/share/lilypond/2.24.1/python/__pycache__/book_texinfo.cpython-310.pyc +0 -0
  974. data/share/lilypond/2.24.1/python/__pycache__/convertrules.cpython-310.pyc +0 -0
  975. data/share/lilypond/2.24.1/python/__pycache__/langdefs.cpython-310.pyc +0 -0
  976. data/share/lilypond/2.24.1/python/__pycache__/lilylib.cpython-310.pyc +0 -0
  977. data/share/lilypond/2.24.1/python/__pycache__/midi.cpython-310.pyc +0 -0
  978. data/share/lilypond/2.24.1/python/__pycache__/musicexp.cpython-310.pyc +0 -0
  979. data/share/lilypond/2.24.1/python/__pycache__/musicxml.cpython-310.pyc +0 -0
  980. data/share/lilypond/2.24.1/python/__pycache__/musicxml2ly_conversion.cpython-310.pyc +0 -0
  981. data/share/lilypond/2.24.1/python/__pycache__/utilities.cpython-310.pyc +0 -0
  982. data/share/lilypond/2.24.1/python/book_base.py +331 -0
  983. data/share/lilypond/2.24.1/python/book_docbook.py +154 -0
  984. data/share/lilypond/2.24.1/python/book_html.py +178 -0
  985. data/share/lilypond/2.24.1/python/book_latex.py +373 -0
  986. data/share/lilypond/2.24.1/python/book_snippets.py +1052 -0
  987. data/share/lilypond/2.24.1/python/book_texinfo.py +437 -0
  988. data/share/lilypond/2.24.1/python/convertrules.py +4764 -0
  989. data/share/lilypond/2.24.1/python/langdefs.py +131 -0
  990. data/share/lilypond/2.24.1/python/lilylib.py +141 -0
  991. data/share/lilypond/2.24.1/python/midi.py +212 -0
  992. data/share/lilypond/2.24.1/python/musicexp.py +2781 -0
  993. data/share/lilypond/2.24.1/python/musicxml.py +1905 -0
  994. data/share/lilypond/2.24.1/python/musicxml2ly_conversion.py +80 -0
  995. data/share/lilypond/2.24.1/python/utilities.py +280 -0
  996. data/share/lilypond/2.24.1/scm/lily/accreg.scm +579 -0
  997. data/share/lilypond/2.24.1/scm/lily/auto-beam.scm +163 -0
  998. data/share/lilypond/2.24.1/scm/lily/autochange.scm +100 -0
  999. data/share/lilypond/2.24.1/scm/lily/backend-library.scm +593 -0
  1000. data/share/lilypond/2.24.1/scm/lily/bar-line.scm +1281 -0
  1001. data/share/lilypond/2.24.1/scm/lily/breath.scm +74 -0
  1002. data/share/lilypond/2.24.1/scm/lily/c++.scm +174 -0
  1003. data/share/lilypond/2.24.1/scm/lily/chord-entry.scm +278 -0
  1004. data/share/lilypond/2.24.1/scm/lily/chord-ignatzek-names.scm +304 -0
  1005. data/share/lilypond/2.24.1/scm/lily/chord-name.scm +217 -0
  1006. data/share/lilypond/2.24.1/scm/lily/clip-region.scm +87 -0
  1007. data/share/lilypond/2.24.1/scm/lily/color.scm +757 -0
  1008. data/share/lilypond/2.24.1/scm/lily/curried-definitions.scm +68 -0
  1009. data/share/lilypond/2.24.1/scm/lily/define-context-properties.scm +939 -0
  1010. data/share/lilypond/2.24.1/scm/lily/define-event-classes.scm +142 -0
  1011. data/share/lilypond/2.24.1/scm/lily/define-grob-interfaces.scm +640 -0
  1012. data/share/lilypond/2.24.1/scm/lily/define-grob-properties.scm +1647 -0
  1013. data/share/lilypond/2.24.1/scm/lily/define-grobs.scm +4027 -0
  1014. data/share/lilypond/2.24.1/scm/lily/define-markup-commands.scm +5737 -0
  1015. data/share/lilypond/2.24.1/scm/lily/define-music-callbacks.scm +257 -0
  1016. data/share/lilypond/2.24.1/scm/lily/define-music-display-methods.scm +1350 -0
  1017. data/share/lilypond/2.24.1/scm/lily/define-music-properties.scm +242 -0
  1018. data/share/lilypond/2.24.1/scm/lily/define-music-types.scm +983 -0
  1019. data/share/lilypond/2.24.1/scm/lily/define-note-names.scm +1421 -0
  1020. data/share/lilypond/2.24.1/scm/lily/define-stencil-commands.scm +71 -0
  1021. data/share/lilypond/2.24.1/scm/lily/define-woodwind-diagrams.scm +1215 -0
  1022. data/share/lilypond/2.24.1/scm/lily/display-lily.scm +315 -0
  1023. data/share/lilypond/2.24.1/scm/lily/display-woodwind-diagrams.scm +1985 -0
  1024. data/share/lilypond/2.24.1/scm/lily/document-backend.scm +307 -0
  1025. data/share/lilypond/2.24.1/scm/lily/document-context-mods.scm +98 -0
  1026. data/share/lilypond/2.24.1/scm/lily/document-functions.scm +169 -0
  1027. data/share/lilypond/2.24.1/scm/lily/document-identifiers.scm +76 -0
  1028. data/share/lilypond/2.24.1/scm/lily/document-markup.scm +158 -0
  1029. data/share/lilypond/2.24.1/scm/lily/document-music.scm +146 -0
  1030. data/share/lilypond/2.24.1/scm/lily/document-outside-staff-priorities.scm +40 -0
  1031. data/share/lilypond/2.24.1/scm/lily/document-paper-sizes.scm +71 -0
  1032. data/share/lilypond/2.24.1/scm/lily/document-translation.scm +318 -0
  1033. data/share/lilypond/2.24.1/scm/lily/document-type-predicates.scm +85 -0
  1034. data/share/lilypond/2.24.1/scm/lily/documentation-generate.scm +259 -0
  1035. data/share/lilypond/2.24.1/scm/lily/documentation-lib.scm +207 -0
  1036. data/share/lilypond/2.24.1/scm/lily/file-cache.scm +28 -0
  1037. data/share/lilypond/2.24.1/scm/lily/flag-styles.scm +249 -0
  1038. data/share/lilypond/2.24.1/scm/lily/font-encodings.scm +1242 -0
  1039. data/share/lilypond/2.24.1/scm/lily/font.scm +303 -0
  1040. data/share/lilypond/2.24.1/scm/lily/framework-cairo.scm +26 -0
  1041. data/share/lilypond/2.24.1/scm/lily/framework-ps.scm +896 -0
  1042. data/share/lilypond/2.24.1/scm/lily/framework-svg.scm +172 -0
  1043. data/share/lilypond/2.24.1/scm/lily/fret-diagrams.scm +1261 -0
  1044. data/share/lilypond/2.24.1/scm/lily/graphviz.scm +78 -0
  1045. data/share/lilypond/2.24.1/scm/lily/guile-debugger.scm +90 -0
  1046. data/share/lilypond/2.24.1/scm/lily/harp-pedals.scm +172 -0
  1047. data/share/lilypond/2.24.1/scm/lily/hyphenate-internal-words.scm +51 -0
  1048. data/share/lilypond/2.24.1/scm/lily/layout-beam.scm +73 -0
  1049. data/share/lilypond/2.24.1/scm/lily/layout-slur.scm +45 -0
  1050. data/share/lilypond/2.24.1/scm/lily/lily-library.scm +1446 -0
  1051. data/share/lilypond/2.24.1/scm/lily/lily-sort.scm +116 -0
  1052. data/share/lilypond/2.24.1/scm/lily/lily.scm +929 -0
  1053. data/share/lilypond/2.24.1/scm/lily/ly-syntax-constructors.scm +374 -0
  1054. data/share/lilypond/2.24.1/scm/lily/markup-macros.scm +493 -0
  1055. data/share/lilypond/2.24.1/scm/lily/markup.scm +126 -0
  1056. data/share/lilypond/2.24.1/scm/lily/midi.scm +258 -0
  1057. data/share/lilypond/2.24.1/scm/lily/modal-transforms.scm +337 -0
  1058. data/share/lilypond/2.24.1/scm/lily/music-functions.scm +2878 -0
  1059. data/share/lilypond/2.24.1/scm/lily/output-lib.scm +3377 -0
  1060. data/share/lilypond/2.24.1/scm/lily/output-ps.scm +335 -0
  1061. data/share/lilypond/2.24.1/scm/lily/output-svg.scm +684 -0
  1062. data/share/lilypond/2.24.1/scm/lily/page.scm +321 -0
  1063. data/share/lilypond/2.24.1/scm/lily/paper-system.scm +271 -0
  1064. data/share/lilypond/2.24.1/scm/lily/paper.scm +376 -0
  1065. data/share/lilypond/2.24.1/scm/lily/parser-clef.scm +205 -0
  1066. data/share/lilypond/2.24.1/scm/lily/parser-ly-from-scheme.scm +170 -0
  1067. data/share/lilypond/2.24.1/scm/lily/part-combiner.scm +998 -0
  1068. data/share/lilypond/2.24.1/scm/lily/predefined-fretboards.scm +54 -0
  1069. data/share/lilypond/2.24.1/scm/lily/ps-to-png.scm +182 -0
  1070. data/share/lilypond/2.24.1/scm/lily/scheme-engravers.scm +1813 -0
  1071. data/share/lilypond/2.24.1/scm/lily/scheme-performers.scm +126 -0
  1072. data/share/lilypond/2.24.1/scm/lily/script.scm +416 -0
  1073. data/share/lilypond/2.24.1/scm/lily/skyline.scm +25 -0
  1074. data/share/lilypond/2.24.1/scm/lily/song-util.scm +191 -0
  1075. data/share/lilypond/2.24.1/scm/lily/song.scm +853 -0
  1076. data/share/lilypond/2.24.1/scm/lily/stencil.scm +998 -0
  1077. data/share/lilypond/2.24.1/scm/lily/tablature.scm +392 -0
  1078. data/share/lilypond/2.24.1/scm/lily/time-signature-settings.scm +473 -0
  1079. data/share/lilypond/2.24.1/scm/lily/time-signature.scm +35 -0
  1080. data/share/lilypond/2.24.1/scm/lily/titling.scm +99 -0
  1081. data/share/lilypond/2.24.1/scm/lily/to-xml.scm +254 -0
  1082. data/share/lilypond/2.24.1/scm/lily/translation-functions.scm +1169 -0
  1083. data/share/lilypond/2.24.1/vim/compiler/lilypond.vim +36 -0
  1084. data/share/lilypond/2.24.1/vim/ftdetect/lilypond.vim +4 -0
  1085. data/share/lilypond/2.24.1/vim/ftplugin/lilypond.vim +91 -0
  1086. data/share/lilypond/2.24.1/vim/indent/lilypond.vim +79 -0
  1087. data/share/lilypond/2.24.1/vim/syntax/lilypond-words +1408 -0
  1088. data/share/lilypond/2.24.1/vim/syntax/lilypond-words.vim +3 -0
  1089. data/share/lilypond/2.24.1/vim/syntax/lilypond.vim +104 -0
  1090. data/share/locale/ca/LC_MESSAGES/lilypond.mo +0 -0
  1091. data/share/locale/cs/LC_MESSAGES/lilypond.mo +0 -0
  1092. data/share/locale/da/LC_MESSAGES/lilypond.mo +0 -0
  1093. data/share/locale/de/LC_MESSAGES/lilypond.mo +0 -0
  1094. data/share/locale/el/LC_MESSAGES/lilypond.mo +0 -0
  1095. data/share/locale/eo/LC_MESSAGES/lilypond.mo +0 -0
  1096. data/share/locale/es/LC_MESSAGES/lilypond.mo +0 -0
  1097. data/share/locale/fi/LC_MESSAGES/lilypond.mo +0 -0
  1098. data/share/locale/fr/LC_MESSAGES/lilypond.mo +0 -0
  1099. data/share/locale/it/LC_MESSAGES/lilypond.mo +0 -0
  1100. data/share/locale/ja/LC_MESSAGES/lilypond.mo +0 -0
  1101. data/share/locale/nl/LC_MESSAGES/lilypond.mo +0 -0
  1102. data/share/locale/ru/LC_MESSAGES/lilypond.mo +0 -0
  1103. data/share/locale/sv/LC_MESSAGES/lilypond.mo +0 -0
  1104. data/share/locale/tr/LC_MESSAGES/lilypond.mo +0 -0
  1105. data/share/locale/uk/LC_MESSAGES/lilypond.mo +0 -0
  1106. data/share/locale/vi/LC_MESSAGES/lilypond.mo +0 -0
  1107. data/share/locale/zh_CN/LC_MESSAGES/lilypond.mo +0 -0
  1108. data/share/locale/zh_TW/LC_MESSAGES/lilypond.mo +0 -0
  1109. metadata +1108 -1
@@ -0,0 +1,2096 @@
1
+ ;;;
2
+ ;;;; An Efficient and Portable LALR(1) Parser Generator for Scheme
3
+ ;;;
4
+ ;; Copyright 2014 Jan Nieuwenhuizen <janneke@gnu.org>
5
+ ;; Copyright 1993, 2010 Dominique Boucher
6
+ ;;
7
+ ;; This program is free software: you can redistribute it and/or
8
+ ;; modify it under the terms of the GNU Lesser General Public License
9
+ ;; as published by the Free Software Foundation, either version 3 of
10
+ ;; the License, or (at your option) any later version.
11
+ ;;
12
+ ;; This program is distributed in the hope that it will be useful,
13
+ ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
14
+ ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
+ ;; GNU Lesser General Public License for more details.
16
+ ;;
17
+ ;; You should have received a copy of the GNU General Public License
18
+ ;; along with this program. If not, see <http://www.gnu.org/licenses/>.
19
+
20
+
21
+ (define *lalr-scm-version* "2.5.0")
22
+
23
+
24
+ (cond-expand
25
+
26
+ ;; -- Gambit-C
27
+ (gambit
28
+
29
+ (define-macro (def-macro form . body)
30
+ `(define-macro ,form (let () ,@body)))
31
+
32
+ (def-macro (BITS-PER-WORD) 28)
33
+ (def-macro (logical-or x . y) `(bitwise-ior ,x ,@y))
34
+ (def-macro (lalr-error msg obj) `(error ,msg ,obj))
35
+
36
+ (define pprint pretty-print)
37
+ (define lalr-keyword? keyword?)
38
+ (define (note-source-location lvalue tok) lvalue))
39
+
40
+ ;; --
41
+ (bigloo
42
+ (define-macro (def-macro form . body)
43
+ `(define-macro ,form (let () ,@body)))
44
+
45
+ (define pprint (lambda (obj) (write obj) (newline)))
46
+ (define lalr-keyword? keyword?)
47
+ (def-macro (BITS-PER-WORD) 29)
48
+ (def-macro (logical-or x . y) `(bit-or ,x ,@y))
49
+ (def-macro (lalr-error msg obj) `(error "lalr-parser" ,msg ,obj))
50
+ (define (note-source-location lvalue tok) lvalue))
51
+
52
+ ;; -- Chicken
53
+ (chicken
54
+
55
+ (define-macro (def-macro form . body)
56
+ `(define-macro ,form (let () ,@body)))
57
+
58
+ (define pprint pretty-print)
59
+ (define lalr-keyword? symbol?)
60
+ (def-macro (BITS-PER-WORD) 30)
61
+ (def-macro (logical-or x . y) `(bitwise-ior ,x ,@y))
62
+ (def-macro (lalr-error msg obj) `(error ,msg ,obj))
63
+ (define (note-source-location lvalue tok) lvalue))
64
+
65
+ ;; -- STKlos
66
+ (stklos
67
+ (require "pp")
68
+
69
+ (define (pprint form) (pp form :port (current-output-port)))
70
+
71
+ (define lalr-keyword? keyword?)
72
+ (define-macro (BITS-PER-WORD) 30)
73
+ (define-macro (logical-or x . y) `(bit-or ,x ,@y))
74
+ (define-macro (lalr-error msg obj) `(error 'lalr-parser ,msg ,obj))
75
+ (define (note-source-location lvalue tok) lvalue))
76
+
77
+ ;; -- Guile
78
+ (guile
79
+ (use-modules (ice-9 pretty-print))
80
+ (use-modules (srfi srfi-9))
81
+
82
+ (define pprint pretty-print)
83
+ (define lalr-keyword? symbol?)
84
+ (define-macro (BITS-PER-WORD) 30)
85
+ (define-macro (logical-or x . y) `(logior ,x ,@y))
86
+ (define-macro (lalr-error msg obj) `(error ,msg ,obj))
87
+ (define (note-source-location lvalue tok)
88
+ (if (and (supports-source-properties? lvalue)
89
+ (not (source-property lvalue 'loc))
90
+ (lexical-token? tok))
91
+ (set-source-property! lvalue 'loc (lexical-token-source tok)))
92
+ lvalue))
93
+
94
+
95
+ ;; -- Kawa
96
+ (kawa
97
+ (require 'pretty-print)
98
+ (define (BITS-PER-WORD) 30)
99
+ (define logical-or logior)
100
+ (define (lalr-keyword? obj) (keyword? obj))
101
+ (define (pprint obj) (pretty-print obj))
102
+ (define (lalr-error msg obj) (error msg obj))
103
+ (define (note-source-location lvalue tok) lvalue))
104
+
105
+ ;; -- SISC
106
+ (sisc
107
+ (import logicops)
108
+ (import record)
109
+
110
+ (define pprint pretty-print)
111
+ (define lalr-keyword? symbol?)
112
+ (define-macro BITS-PER-WORD (lambda () 32))
113
+ (define-macro logical-or (lambda (x . y) `(logor ,x ,@y)))
114
+ (define-macro (lalr-error msg obj) `(error "~a ~S:" ,msg ,obj))
115
+ (define (note-source-location lvalue tok) lvalue))
116
+
117
+ (else
118
+ (error "Unsupported Scheme system")))
119
+
120
+
121
+ (define-record-type lexical-token
122
+ (make-lexical-token category source value)
123
+ lexical-token?
124
+ (category lexical-token-category)
125
+ (source lexical-token-source)
126
+ (value lexical-token-value))
127
+
128
+
129
+ (define-record-type source-location
130
+ (make-source-location input line column offset length)
131
+ source-location?
132
+ (input source-location-input)
133
+ (line source-location-line)
134
+ (column source-location-column)
135
+ (offset source-location-offset)
136
+ (length source-location-length))
137
+
138
+
139
+
140
+ ;; - Macros pour la gestion des vecteurs de bits
141
+
142
+ (define-macro (lalr-parser . arguments)
143
+ (define (set-bit v b)
144
+ (let ((x (quotient b (BITS-PER-WORD)))
145
+ (y (expt 2 (remainder b (BITS-PER-WORD)))))
146
+ (vector-set! v x (logical-or (vector-ref v x) y))))
147
+
148
+ (define (bit-union v1 v2 n)
149
+ (do ((i 0 (+ i 1)))
150
+ ((= i n))
151
+ (vector-set! v1 i (logical-or (vector-ref v1 i)
152
+ (vector-ref v2 i)))))
153
+
154
+ ;; - Macro pour les structures de donnees
155
+
156
+ (define (new-core) (make-vector 4 0))
157
+ (define (set-core-number! c n) (vector-set! c 0 n))
158
+ (define (set-core-acc-sym! c s) (vector-set! c 1 s))
159
+ (define (set-core-nitems! c n) (vector-set! c 2 n))
160
+ (define (set-core-items! c i) (vector-set! c 3 i))
161
+ (define (core-number c) (vector-ref c 0))
162
+ (define (core-acc-sym c) (vector-ref c 1))
163
+ (define (core-nitems c) (vector-ref c 2))
164
+ (define (core-items c) (vector-ref c 3))
165
+
166
+ (define (new-shift) (make-vector 3 0))
167
+ (define (set-shift-number! c x) (vector-set! c 0 x))
168
+ (define (set-shift-nshifts! c x) (vector-set! c 1 x))
169
+ (define (set-shift-shifts! c x) (vector-set! c 2 x))
170
+ (define (shift-number s) (vector-ref s 0))
171
+ (define (shift-nshifts s) (vector-ref s 1))
172
+ (define (shift-shifts s) (vector-ref s 2))
173
+
174
+ (define (new-red) (make-vector 3 0))
175
+ (define (set-red-number! c x) (vector-set! c 0 x))
176
+ (define (set-red-nreds! c x) (vector-set! c 1 x))
177
+ (define (set-red-rules! c x) (vector-set! c 2 x))
178
+ (define (red-number c) (vector-ref c 0))
179
+ (define (red-nreds c) (vector-ref c 1))
180
+ (define (red-rules c) (vector-ref c 2))
181
+
182
+
183
+ (define (new-set nelem)
184
+ (make-vector nelem 0))
185
+
186
+
187
+ (define (vector-map f v)
188
+ (let ((vm-n (- (vector-length v) 1)))
189
+ (let loop ((vm-low 0) (vm-high vm-n))
190
+ (if (= vm-low vm-high)
191
+ (vector-set! v vm-low (f (vector-ref v vm-low) vm-low))
192
+ (let ((vm-middle (quotient (+ vm-low vm-high) 2)))
193
+ (loop vm-low vm-middle)
194
+ (loop (+ vm-middle 1) vm-high))))))
195
+
196
+
197
+ ;; - Constantes
198
+ (define STATE-TABLE-SIZE 1009)
199
+
200
+
201
+ ;; - Tableaux
202
+ (define rrhs #f)
203
+ (define rlhs #f)
204
+ (define ritem #f)
205
+ (define nullable #f)
206
+ (define derives #f)
207
+ (define fderives #f)
208
+ (define firsts #f)
209
+ (define kernel-base #f)
210
+ (define kernel-end #f)
211
+ (define shift-symbol #f)
212
+ (define shift-set #f)
213
+ (define red-set #f)
214
+ (define state-table #f)
215
+ (define acces-symbol #f)
216
+ (define reduction-table #f)
217
+ (define shift-table #f)
218
+ (define consistent #f)
219
+ (define lookaheads #f)
220
+ (define LA #f)
221
+ (define LAruleno #f)
222
+ (define lookback #f)
223
+ (define goto-map #f)
224
+ (define from-state #f)
225
+ (define to-state #f)
226
+ (define includes #f)
227
+ (define F #f)
228
+ (define action-table #f)
229
+
230
+ ;; - Variables
231
+ (define nitems #f)
232
+ (define nrules #f)
233
+ (define nvars #f)
234
+ (define nterms #f)
235
+ (define nsyms #f)
236
+ (define nstates #f)
237
+ (define first-state #f)
238
+ (define last-state #f)
239
+ (define final-state #f)
240
+ (define first-shift #f)
241
+ (define last-shift #f)
242
+ (define first-reduction #f)
243
+ (define last-reduction #f)
244
+ (define nshifts #f)
245
+ (define maxrhs #f)
246
+ (define ngotos #f)
247
+ (define token-set-size #f)
248
+
249
+ (define driver-name 'lr-driver)
250
+
251
+ (define (glr-driver?)
252
+ (eq? driver-name 'glr-driver))
253
+ (define (lr-driver?)
254
+ (eq? driver-name 'lr-driver))
255
+
256
+ (define (gen-tables! tokens gram )
257
+ (initialize-all)
258
+ (rewrite-grammar
259
+ tokens
260
+ gram
261
+ (lambda (terms terms/prec vars gram gram/actions)
262
+ (set! the-terminals/prec (list->vector terms/prec))
263
+ (set! the-terminals (list->vector terms))
264
+ (set! the-nonterminals (list->vector vars))
265
+ (set! nterms (length terms))
266
+ (set! nvars (length vars))
267
+ (set! nsyms (+ nterms nvars))
268
+ (let ((no-of-rules (length gram/actions))
269
+ (no-of-items (let loop ((l gram/actions) (count 0))
270
+ (if (null? l)
271
+ count
272
+ (loop (cdr l) (+ count (length (caar l))))))))
273
+ (pack-grammar no-of-rules no-of-items gram)
274
+ (set-derives)
275
+ (set-nullable)
276
+ (generate-states)
277
+ (lalr)
278
+ (build-tables)
279
+ (compact-action-table terms)
280
+ gram/actions))))
281
+
282
+
283
+ (define (initialize-all)
284
+ (set! rrhs #f)
285
+ (set! rlhs #f)
286
+ (set! ritem #f)
287
+ (set! nullable #f)
288
+ (set! derives #f)
289
+ (set! fderives #f)
290
+ (set! firsts #f)
291
+ (set! kernel-base #f)
292
+ (set! kernel-end #f)
293
+ (set! shift-symbol #f)
294
+ (set! shift-set #f)
295
+ (set! red-set #f)
296
+ (set! state-table (make-vector STATE-TABLE-SIZE '()))
297
+ (set! acces-symbol #f)
298
+ (set! reduction-table #f)
299
+ (set! shift-table #f)
300
+ (set! consistent #f)
301
+ (set! lookaheads #f)
302
+ (set! LA #f)
303
+ (set! LAruleno #f)
304
+ (set! lookback #f)
305
+ (set! goto-map #f)
306
+ (set! from-state #f)
307
+ (set! to-state #f)
308
+ (set! includes #f)
309
+ (set! F #f)
310
+ (set! action-table #f)
311
+ (set! nstates #f)
312
+ (set! first-state #f)
313
+ (set! last-state #f)
314
+ (set! final-state #f)
315
+ (set! first-shift #f)
316
+ (set! last-shift #f)
317
+ (set! first-reduction #f)
318
+ (set! last-reduction #f)
319
+ (set! nshifts #f)
320
+ (set! maxrhs #f)
321
+ (set! ngotos #f)
322
+ (set! token-set-size #f)
323
+ (set! rule-precedences '()))
324
+
325
+
326
+ (define (pack-grammar no-of-rules no-of-items gram)
327
+ (set! nrules (+ no-of-rules 1))
328
+ (set! nitems no-of-items)
329
+ (set! rlhs (make-vector nrules #f))
330
+ (set! rrhs (make-vector nrules #f))
331
+ (set! ritem (make-vector (+ 1 nitems) #f))
332
+
333
+ (let loop ((p gram) (item-no 0) (rule-no 1))
334
+ (if (not (null? p))
335
+ (let ((nt (caar p)))
336
+ (let loop2 ((prods (cdar p)) (it-no2 item-no) (rl-no2 rule-no))
337
+ (if (null? prods)
338
+ (loop (cdr p) it-no2 rl-no2)
339
+ (begin
340
+ (vector-set! rlhs rl-no2 nt)
341
+ (vector-set! rrhs rl-no2 it-no2)
342
+ (let loop3 ((rhs (car prods)) (it-no3 it-no2))
343
+ (if (null? rhs)
344
+ (begin
345
+ (vector-set! ritem it-no3 (- rl-no2))
346
+ (loop2 (cdr prods) (+ it-no3 1) (+ rl-no2 1)))
347
+ (begin
348
+ (vector-set! ritem it-no3 (car rhs))
349
+ (loop3 (cdr rhs) (+ it-no3 1))))))))))))
350
+
351
+
352
+ (define (set-derives)
353
+ (define delts (make-vector (+ nrules 1) 0))
354
+ (define dset (make-vector nvars -1))
355
+
356
+ (let loop ((i 1) (j 0)) ; i = 0
357
+ (if (< i nrules)
358
+ (let ((lhs (vector-ref rlhs i)))
359
+ (if (>= lhs 0)
360
+ (begin
361
+ (vector-set! delts j (cons i (vector-ref dset lhs)))
362
+ (vector-set! dset lhs j)
363
+ (loop (+ i 1) (+ j 1)))
364
+ (loop (+ i 1) j)))))
365
+
366
+ (set! derives (make-vector nvars 0))
367
+
368
+ (let loop ((i 0))
369
+ (if (< i nvars)
370
+ (let ((q (let loop2 ((j (vector-ref dset i)) (s '()))
371
+ (if (< j 0)
372
+ s
373
+ (let ((x (vector-ref delts j)))
374
+ (loop2 (cdr x) (cons (car x) s)))))))
375
+ (vector-set! derives i q)
376
+ (loop (+ i 1))))))
377
+
378
+
379
+
380
+ (define (set-nullable)
381
+ (set! nullable (make-vector nvars #f))
382
+ (let ((squeue (make-vector nvars #f))
383
+ (rcount (make-vector (+ nrules 1) 0))
384
+ (rsets (make-vector nvars #f))
385
+ (relts (make-vector (+ nitems nvars 1) #f)))
386
+ (let loop ((r 0) (s2 0) (p 0))
387
+ (let ((*r (vector-ref ritem r)))
388
+ (if *r
389
+ (if (< *r 0)
390
+ (let ((symbol (vector-ref rlhs (- *r))))
391
+ (if (and (>= symbol 0)
392
+ (not (vector-ref nullable symbol)))
393
+ (begin
394
+ (vector-set! nullable symbol #t)
395
+ (vector-set! squeue s2 symbol)
396
+ (loop (+ r 1) (+ s2 1) p))))
397
+ (let loop2 ((r1 r) (any-tokens #f))
398
+ (let* ((symbol (vector-ref ritem r1)))
399
+ (if (> symbol 0)
400
+ (loop2 (+ r1 1) (or any-tokens (>= symbol nvars)))
401
+ (if (not any-tokens)
402
+ (let ((ruleno (- symbol)))
403
+ (let loop3 ((r2 r) (p2 p))
404
+ (let ((symbol (vector-ref ritem r2)))
405
+ (if (> symbol 0)
406
+ (begin
407
+ (vector-set! rcount ruleno
408
+ (+ (vector-ref rcount ruleno) 1))
409
+ (vector-set! relts p2
410
+ (cons (vector-ref rsets symbol)
411
+ ruleno))
412
+ (vector-set! rsets symbol p2)
413
+ (loop3 (+ r2 1) (+ p2 1)))
414
+ (loop (+ r2 1) s2 p2)))))
415
+ (loop (+ r1 1) s2 p))))))
416
+ (let loop ((s1 0) (s3 s2))
417
+ (if (< s1 s3)
418
+ (let loop2 ((p (vector-ref rsets (vector-ref squeue s1))) (s4 s3))
419
+ (if p
420
+ (let* ((x (vector-ref relts p))
421
+ (ruleno (cdr x))
422
+ (y (- (vector-ref rcount ruleno) 1)))
423
+ (vector-set! rcount ruleno y)
424
+ (if (= y 0)
425
+ (let ((symbol (vector-ref rlhs ruleno)))
426
+ (if (and (>= symbol 0)
427
+ (not (vector-ref nullable symbol)))
428
+ (begin
429
+ (vector-set! nullable symbol #t)
430
+ (vector-set! squeue s4 symbol)
431
+ (loop2 (car x) (+ s4 1)))
432
+ (loop2 (car x) s4)))
433
+ (loop2 (car x) s4))))
434
+ (loop (+ s1 1) s4)))))))))
435
+
436
+
437
+
438
+ (define (set-firsts)
439
+ (set! firsts (make-vector nvars '()))
440
+
441
+ ;; -- initialization
442
+ (let loop ((i 0))
443
+ (if (< i nvars)
444
+ (let loop2 ((sp (vector-ref derives i)))
445
+ (if (null? sp)
446
+ (loop (+ i 1))
447
+ (let ((sym (vector-ref ritem (vector-ref rrhs (car sp)))))
448
+ (if (< -1 sym nvars)
449
+ (vector-set! firsts i (sinsert sym (vector-ref firsts i))))
450
+ (loop2 (cdr sp)))))))
451
+
452
+ ;; -- reflexive and transitive closure
453
+ (let loop ((continue #t))
454
+ (if continue
455
+ (let loop2 ((i 0) (cont #f))
456
+ (if (>= i nvars)
457
+ (loop cont)
458
+ (let* ((x (vector-ref firsts i))
459
+ (y (let loop3 ((l x) (z x))
460
+ (if (null? l)
461
+ z
462
+ (loop3 (cdr l)
463
+ (sunion (vector-ref firsts (car l)) z))))))
464
+ (if (equal? x y)
465
+ (loop2 (+ i 1) cont)
466
+ (begin
467
+ (vector-set! firsts i y)
468
+ (loop2 (+ i 1) #t))))))))
469
+
470
+ (let loop ((i 0))
471
+ (if (< i nvars)
472
+ (begin
473
+ (vector-set! firsts i (sinsert i (vector-ref firsts i)))
474
+ (loop (+ i 1))))))
475
+
476
+
477
+
478
+
479
+ (define (set-fderives)
480
+ (set! fderives (make-vector nvars #f))
481
+
482
+ (set-firsts)
483
+
484
+ (let loop ((i 0))
485
+ (if (< i nvars)
486
+ (let ((x (let loop2 ((l (vector-ref firsts i)) (fd '()))
487
+ (if (null? l)
488
+ fd
489
+ (loop2 (cdr l)
490
+ (sunion (vector-ref derives (car l)) fd))))))
491
+ (vector-set! fderives i x)
492
+ (loop (+ i 1))))))
493
+
494
+
495
+ (define (closure core)
496
+ ;; Initialization
497
+ (define ruleset (make-vector nrules #f))
498
+
499
+ (let loop ((csp core))
500
+ (if (not (null? csp))
501
+ (let ((sym (vector-ref ritem (car csp))))
502
+ (if (< -1 sym nvars)
503
+ (let loop2 ((dsp (vector-ref fderives sym)))
504
+ (if (not (null? dsp))
505
+ (begin
506
+ (vector-set! ruleset (car dsp) #t)
507
+ (loop2 (cdr dsp))))))
508
+ (loop (cdr csp)))))
509
+
510
+ (let loop ((ruleno 1) (csp core) (itemsetv '())) ; ruleno = 0
511
+ (if (< ruleno nrules)
512
+ (if (vector-ref ruleset ruleno)
513
+ (let ((itemno (vector-ref rrhs ruleno)))
514
+ (let loop2 ((c csp) (itemsetv2 itemsetv))
515
+ (if (and (pair? c)
516
+ (< (car c) itemno))
517
+ (loop2 (cdr c) (cons (car c) itemsetv2))
518
+ (loop (+ ruleno 1) c (cons itemno itemsetv2)))))
519
+ (loop (+ ruleno 1) csp itemsetv))
520
+ (let loop2 ((c csp) (itemsetv2 itemsetv))
521
+ (if (pair? c)
522
+ (loop2 (cdr c) (cons (car c) itemsetv2))
523
+ (reverse itemsetv2))))))
524
+
525
+
526
+
527
+ (define (allocate-item-sets)
528
+ (set! kernel-base (make-vector nsyms 0))
529
+ (set! kernel-end (make-vector nsyms #f)))
530
+
531
+
532
+ (define (allocate-storage)
533
+ (allocate-item-sets)
534
+ (set! red-set (make-vector (+ nrules 1) 0)))
535
+
536
+ ; --
537
+
538
+
539
+ (define (initialize-states)
540
+ (let ((p (new-core)))
541
+ (set-core-number! p 0)
542
+ (set-core-acc-sym! p #f)
543
+ (set-core-nitems! p 1)
544
+ (set-core-items! p '(0))
545
+
546
+ (set! first-state (list p))
547
+ (set! last-state first-state)
548
+ (set! nstates 1)))
549
+
550
+
551
+
552
+ (define (generate-states)
553
+ (allocate-storage)
554
+ (set-fderives)
555
+ (initialize-states)
556
+ (let loop ((this-state first-state))
557
+ (if (pair? this-state)
558
+ (let* ((x (car this-state))
559
+ (is (closure (core-items x))))
560
+ (save-reductions x is)
561
+ (new-itemsets is)
562
+ (append-states)
563
+ (if (> nshifts 0)
564
+ (save-shifts x))
565
+ (loop (cdr this-state))))))
566
+
567
+
568
+ (define (new-itemsets itemset)
569
+ ;; - Initialization
570
+ (set! shift-symbol '())
571
+ (let loop ((i 0))
572
+ (if (< i nsyms)
573
+ (begin
574
+ (vector-set! kernel-end i '())
575
+ (loop (+ i 1)))))
576
+
577
+ (let loop ((isp itemset))
578
+ (if (pair? isp)
579
+ (let* ((i (car isp))
580
+ (sym (vector-ref ritem i)))
581
+ (if (>= sym 0)
582
+ (begin
583
+ (set! shift-symbol (sinsert sym shift-symbol))
584
+ (let ((x (vector-ref kernel-end sym)))
585
+ (if (null? x)
586
+ (begin
587
+ (vector-set! kernel-base sym (cons (+ i 1) x))
588
+ (vector-set! kernel-end sym (vector-ref kernel-base sym)))
589
+ (begin
590
+ (set-cdr! x (list (+ i 1)))
591
+ (vector-set! kernel-end sym (cdr x)))))))
592
+ (loop (cdr isp)))))
593
+
594
+ (set! nshifts (length shift-symbol)))
595
+
596
+
597
+
598
+ (define (get-state sym)
599
+ (let* ((isp (vector-ref kernel-base sym))
600
+ (n (length isp))
601
+ (key (let loop ((isp1 isp) (k 0))
602
+ (if (null? isp1)
603
+ (modulo k STATE-TABLE-SIZE)
604
+ (loop (cdr isp1) (+ k (car isp1))))))
605
+ (sp (vector-ref state-table key)))
606
+ (if (null? sp)
607
+ (let ((x (new-state sym)))
608
+ (vector-set! state-table key (list x))
609
+ (core-number x))
610
+ (let loop ((sp1 sp))
611
+ (if (and (= n (core-nitems (car sp1)))
612
+ (let loop2 ((i1 isp) (t (core-items (car sp1))))
613
+ (if (and (pair? i1)
614
+ (= (car i1)
615
+ (car t)))
616
+ (loop2 (cdr i1) (cdr t))
617
+ (null? i1))))
618
+ (core-number (car sp1))
619
+ (if (null? (cdr sp1))
620
+ (let ((x (new-state sym)))
621
+ (set-cdr! sp1 (list x))
622
+ (core-number x))
623
+ (loop (cdr sp1))))))))
624
+
625
+
626
+ (define (new-state sym)
627
+ (let* ((isp (vector-ref kernel-base sym))
628
+ (n (length isp))
629
+ (p (new-core)))
630
+ (set-core-number! p nstates)
631
+ (set-core-acc-sym! p sym)
632
+ (if (= sym nvars) (set! final-state nstates))
633
+ (set-core-nitems! p n)
634
+ (set-core-items! p isp)
635
+ (set-cdr! last-state (list p))
636
+ (set! last-state (cdr last-state))
637
+ (set! nstates (+ nstates 1))
638
+ p))
639
+
640
+
641
+ ; --
642
+
643
+ (define (append-states)
644
+ (set! shift-set
645
+ (let loop ((l (reverse shift-symbol)))
646
+ (if (null? l)
647
+ '()
648
+ (cons (get-state (car l)) (loop (cdr l)))))))
649
+
650
+ ; --
651
+
652
+ (define (save-shifts core)
653
+ (let ((p (new-shift)))
654
+ (set-shift-number! p (core-number core))
655
+ (set-shift-nshifts! p nshifts)
656
+ (set-shift-shifts! p shift-set)
657
+ (if last-shift
658
+ (begin
659
+ (set-cdr! last-shift (list p))
660
+ (set! last-shift (cdr last-shift)))
661
+ (begin
662
+ (set! first-shift (list p))
663
+ (set! last-shift first-shift)))))
664
+
665
+ (define (save-reductions core itemset)
666
+ (let ((rs (let loop ((l itemset))
667
+ (if (null? l)
668
+ '()
669
+ (let ((item (vector-ref ritem (car l))))
670
+ (if (< item 0)
671
+ (cons (- item) (loop (cdr l)))
672
+ (loop (cdr l))))))))
673
+ (if (pair? rs)
674
+ (let ((p (new-red)))
675
+ (set-red-number! p (core-number core))
676
+ (set-red-nreds! p (length rs))
677
+ (set-red-rules! p rs)
678
+ (if last-reduction
679
+ (begin
680
+ (set-cdr! last-reduction (list p))
681
+ (set! last-reduction (cdr last-reduction)))
682
+ (begin
683
+ (set! first-reduction (list p))
684
+ (set! last-reduction first-reduction)))))))
685
+
686
+
687
+ ; --
688
+
689
+ (define (lalr)
690
+ (set! token-set-size (+ 1 (quotient nterms (BITS-PER-WORD))))
691
+ (set-accessing-symbol)
692
+ (set-shift-table)
693
+ (set-reduction-table)
694
+ (set-max-rhs)
695
+ (initialize-LA)
696
+ (set-goto-map)
697
+ (initialize-F)
698
+ (build-relations)
699
+ (digraph includes)
700
+ (compute-lookaheads))
701
+
702
+ (define (set-accessing-symbol)
703
+ (set! acces-symbol (make-vector nstates #f))
704
+ (let loop ((l first-state))
705
+ (if (pair? l)
706
+ (let ((x (car l)))
707
+ (vector-set! acces-symbol (core-number x) (core-acc-sym x))
708
+ (loop (cdr l))))))
709
+
710
+ (define (set-shift-table)
711
+ (set! shift-table (make-vector nstates #f))
712
+ (let loop ((l first-shift))
713
+ (if (pair? l)
714
+ (let ((x (car l)))
715
+ (vector-set! shift-table (shift-number x) x)
716
+ (loop (cdr l))))))
717
+
718
+ (define (set-reduction-table)
719
+ (set! reduction-table (make-vector nstates #f))
720
+ (let loop ((l first-reduction))
721
+ (if (pair? l)
722
+ (let ((x (car l)))
723
+ (vector-set! reduction-table (red-number x) x)
724
+ (loop (cdr l))))))
725
+
726
+ (define (set-max-rhs)
727
+ (let loop ((p 0) (curmax 0) (length 0))
728
+ (let ((x (vector-ref ritem p)))
729
+ (if x
730
+ (if (>= x 0)
731
+ (loop (+ p 1) curmax (+ length 1))
732
+ (loop (+ p 1) (max curmax length) 0))
733
+ (set! maxrhs curmax)))))
734
+
735
+ (define (initialize-LA)
736
+ (define (last l)
737
+ (if (null? (cdr l))
738
+ (car l)
739
+ (last (cdr l))))
740
+
741
+ (set! consistent (make-vector nstates #f))
742
+ (set! lookaheads (make-vector (+ nstates 1) #f))
743
+
744
+ (let loop ((count 0) (i 0))
745
+ (if (< i nstates)
746
+ (begin
747
+ (vector-set! lookaheads i count)
748
+ (let ((rp (vector-ref reduction-table i))
749
+ (sp (vector-ref shift-table i)))
750
+ (if (and rp
751
+ (or (> (red-nreds rp) 1)
752
+ (and sp
753
+ (not
754
+ (< (vector-ref acces-symbol
755
+ (last (shift-shifts sp)))
756
+ nvars)))))
757
+ (loop (+ count (red-nreds rp)) (+ i 1))
758
+ (begin
759
+ (vector-set! consistent i #t)
760
+ (loop count (+ i 1))))))
761
+
762
+ (begin
763
+ (vector-set! lookaheads nstates count)
764
+ (let ((c (max count 1)))
765
+ (set! LA (make-vector c #f))
766
+ (do ((j 0 (+ j 1))) ((= j c)) (vector-set! LA j (new-set token-set-size)))
767
+ (set! LAruleno (make-vector c -1))
768
+ (set! lookback (make-vector c #f)))
769
+ (let loop ((i 0) (np 0))
770
+ (if (< i nstates)
771
+ (if (vector-ref consistent i)
772
+ (loop (+ i 1) np)
773
+ (let ((rp (vector-ref reduction-table i)))
774
+ (if rp
775
+ (let loop2 ((j (red-rules rp)) (np2 np))
776
+ (if (null? j)
777
+ (loop (+ i 1) np2)
778
+ (begin
779
+ (vector-set! LAruleno np2 (car j))
780
+ (loop2 (cdr j) (+ np2 1)))))
781
+ (loop (+ i 1) np))))))))))
782
+
783
+
784
+ (define (set-goto-map)
785
+ (set! goto-map (make-vector (+ nvars 1) 0))
786
+ (let ((temp-map (make-vector (+ nvars 1) 0)))
787
+ (let loop ((ng 0) (sp first-shift))
788
+ (if (pair? sp)
789
+ (let loop2 ((i (reverse (shift-shifts (car sp)))) (ng2 ng))
790
+ (if (pair? i)
791
+ (let ((symbol (vector-ref acces-symbol (car i))))
792
+ (if (< symbol nvars)
793
+ (begin
794
+ (vector-set! goto-map symbol
795
+ (+ 1 (vector-ref goto-map symbol)))
796
+ (loop2 (cdr i) (+ ng2 1)))
797
+ (loop2 (cdr i) ng2)))
798
+ (loop ng2 (cdr sp))))
799
+
800
+ (let loop ((k 0) (i 0))
801
+ (if (< i nvars)
802
+ (begin
803
+ (vector-set! temp-map i k)
804
+ (loop (+ k (vector-ref goto-map i)) (+ i 1)))
805
+
806
+ (begin
807
+ (do ((i 0 (+ i 1)))
808
+ ((>= i nvars))
809
+ (vector-set! goto-map i (vector-ref temp-map i)))
810
+
811
+ (set! ngotos ng)
812
+ (vector-set! goto-map nvars ngotos)
813
+ (vector-set! temp-map nvars ngotos)
814
+ (set! from-state (make-vector ngotos #f))
815
+ (set! to-state (make-vector ngotos #f))
816
+
817
+ (do ((sp first-shift (cdr sp)))
818
+ ((null? sp))
819
+ (let* ((x (car sp))
820
+ (state1 (shift-number x)))
821
+ (do ((i (shift-shifts x) (cdr i)))
822
+ ((null? i))
823
+ (let* ((state2 (car i))
824
+ (symbol (vector-ref acces-symbol state2)))
825
+ (if (< symbol nvars)
826
+ (let ((k (vector-ref temp-map symbol)))
827
+ (vector-set! temp-map symbol (+ k 1))
828
+ (vector-set! from-state k state1)
829
+ (vector-set! to-state k state2))))))))))))))
830
+
831
+
832
+ (define (map-goto state symbol)
833
+ (let loop ((low (vector-ref goto-map symbol))
834
+ (high (- (vector-ref goto-map (+ symbol 1)) 1)))
835
+ (if (> low high)
836
+ (begin
837
+ (display (list "Error in map-goto" state symbol)) (newline)
838
+ 0)
839
+ (let* ((middle (quotient (+ low high) 2))
840
+ (s (vector-ref from-state middle)))
841
+ (cond
842
+ ((= s state)
843
+ middle)
844
+ ((< s state)
845
+ (loop (+ middle 1) high))
846
+ (else
847
+ (loop low (- middle 1))))))))
848
+
849
+
850
+ (define (initialize-F)
851
+ (set! F (make-vector ngotos #f))
852
+ (do ((i 0 (+ i 1))) ((= i ngotos)) (vector-set! F i (new-set token-set-size)))
853
+
854
+ (let ((reads (make-vector ngotos #f)))
855
+
856
+ (let loop ((i 0) (rowp 0))
857
+ (if (< i ngotos)
858
+ (let* ((rowf (vector-ref F rowp))
859
+ (stateno (vector-ref to-state i))
860
+ (sp (vector-ref shift-table stateno)))
861
+ (if sp
862
+ (let loop2 ((j (shift-shifts sp)) (edges '()))
863
+ (if (pair? j)
864
+ (let ((symbol (vector-ref acces-symbol (car j))))
865
+ (if (< symbol nvars)
866
+ (if (vector-ref nullable symbol)
867
+ (loop2 (cdr j) (cons (map-goto stateno symbol)
868
+ edges))
869
+ (loop2 (cdr j) edges))
870
+ (begin
871
+ (set-bit rowf (- symbol nvars))
872
+ (loop2 (cdr j) edges))))
873
+ (if (pair? edges)
874
+ (vector-set! reads i (reverse edges))))))
875
+ (loop (+ i 1) (+ rowp 1)))))
876
+ (digraph reads)))
877
+
878
+ (define (add-lookback-edge stateno ruleno gotono)
879
+ (let ((k (vector-ref lookaheads (+ stateno 1))))
880
+ (let loop ((found #f) (i (vector-ref lookaheads stateno)))
881
+ (if (and (not found) (< i k))
882
+ (if (= (vector-ref LAruleno i) ruleno)
883
+ (loop #t i)
884
+ (loop found (+ i 1)))
885
+
886
+ (if (not found)
887
+ (begin (display "Error in add-lookback-edge : ")
888
+ (display (list stateno ruleno gotono)) (newline))
889
+ (vector-set! lookback i
890
+ (cons gotono (vector-ref lookback i))))))))
891
+
892
+
893
+ (define (transpose r-arg n)
894
+ (let ((new-end (make-vector n #f))
895
+ (new-R (make-vector n #f)))
896
+ (do ((i 0 (+ i 1)))
897
+ ((= i n))
898
+ (let ((x (list 'bidon)))
899
+ (vector-set! new-R i x)
900
+ (vector-set! new-end i x)))
901
+ (do ((i 0 (+ i 1)))
902
+ ((= i n))
903
+ (let ((sp (vector-ref r-arg i)))
904
+ (if (pair? sp)
905
+ (let loop ((sp2 sp))
906
+ (if (pair? sp2)
907
+ (let* ((x (car sp2))
908
+ (y (vector-ref new-end x)))
909
+ (set-cdr! y (cons i (cdr y)))
910
+ (vector-set! new-end x (cdr y))
911
+ (loop (cdr sp2))))))))
912
+ (do ((i 0 (+ i 1)))
913
+ ((= i n))
914
+ (vector-set! new-R i (cdr (vector-ref new-R i))))
915
+
916
+ new-R))
917
+
918
+
919
+
920
+ (define (build-relations)
921
+
922
+ (define (get-state stateno symbol)
923
+ (let loop ((j (shift-shifts (vector-ref shift-table stateno)))
924
+ (stno stateno))
925
+ (if (null? j)
926
+ stno
927
+ (let ((st2 (car j)))
928
+ (if (= (vector-ref acces-symbol st2) symbol)
929
+ st2
930
+ (loop (cdr j) st2))))))
931
+
932
+ (set! includes (make-vector ngotos #f))
933
+ (do ((i 0 (+ i 1)))
934
+ ((= i ngotos))
935
+ (let ((state1 (vector-ref from-state i))
936
+ (symbol1 (vector-ref acces-symbol (vector-ref to-state i))))
937
+ (let loop ((rulep (vector-ref derives symbol1))
938
+ (edges '()))
939
+ (if (pair? rulep)
940
+ (let ((*rulep (car rulep)))
941
+ (let loop2 ((rp (vector-ref rrhs *rulep))
942
+ (stateno state1)
943
+ (states (list state1)))
944
+ (let ((*rp (vector-ref ritem rp)))
945
+ (if (> *rp 0)
946
+ (let ((st (get-state stateno *rp)))
947
+ (loop2 (+ rp 1) st (cons st states)))
948
+ (begin
949
+
950
+ (if (not (vector-ref consistent stateno))
951
+ (add-lookback-edge stateno *rulep i))
952
+
953
+ (let loop2 ((done #f)
954
+ (stp (cdr states))
955
+ (rp2 (- rp 1))
956
+ (edgp edges))
957
+ (if (not done)
958
+ (let ((*rp (vector-ref ritem rp2)))
959
+ (if (< -1 *rp nvars)
960
+ (loop2 (not (vector-ref nullable *rp))
961
+ (cdr stp)
962
+ (- rp2 1)
963
+ (cons (map-goto (car stp) *rp) edgp))
964
+ (loop2 #t stp rp2 edgp)))
965
+
966
+ (loop (cdr rulep) edgp))))))))
967
+ (vector-set! includes i edges)))))
968
+ (set! includes (transpose includes ngotos)))
969
+
970
+
971
+
972
+ (define (compute-lookaheads)
973
+ (let ((n (vector-ref lookaheads nstates)))
974
+ (let loop ((i 0))
975
+ (if (< i n)
976
+ (let loop2 ((sp (vector-ref lookback i)))
977
+ (if (pair? sp)
978
+ (let ((LA-i (vector-ref LA i))
979
+ (F-j (vector-ref F (car sp))))
980
+ (bit-union LA-i F-j token-set-size)
981
+ (loop2 (cdr sp)))
982
+ (loop (+ i 1))))))))
983
+
984
+
985
+
986
+ (define (digraph relation)
987
+ (define infinity (+ ngotos 2))
988
+ (define INDEX (make-vector (+ ngotos 1) 0))
989
+ (define VERTICES (make-vector (+ ngotos 1) 0))
990
+ (define top 0)
991
+ (define R relation)
992
+
993
+ (define (traverse i)
994
+ (set! top (+ 1 top))
995
+ (vector-set! VERTICES top i)
996
+ (let ((height top))
997
+ (vector-set! INDEX i height)
998
+ (let ((rp (vector-ref R i)))
999
+ (if (pair? rp)
1000
+ (let loop ((rp2 rp))
1001
+ (if (pair? rp2)
1002
+ (let ((j (car rp2)))
1003
+ (if (= 0 (vector-ref INDEX j))
1004
+ (traverse j))
1005
+ (if (> (vector-ref INDEX i)
1006
+ (vector-ref INDEX j))
1007
+ (vector-set! INDEX i (vector-ref INDEX j)))
1008
+ (let ((F-i (vector-ref F i))
1009
+ (F-j (vector-ref F j)))
1010
+ (bit-union F-i F-j token-set-size))
1011
+ (loop (cdr rp2))))))
1012
+ (if (= (vector-ref INDEX i) height)
1013
+ (let loop ()
1014
+ (let ((j (vector-ref VERTICES top)))
1015
+ (set! top (- top 1))
1016
+ (vector-set! INDEX j infinity)
1017
+ (if (not (= i j))
1018
+ (begin
1019
+ (bit-union (vector-ref F i)
1020
+ (vector-ref F j)
1021
+ token-set-size)
1022
+ (loop)))))))))
1023
+
1024
+ (let loop ((i 0))
1025
+ (if (< i ngotos)
1026
+ (begin
1027
+ (if (and (= 0 (vector-ref INDEX i))
1028
+ (pair? (vector-ref R i)))
1029
+ (traverse i))
1030
+ (loop (+ i 1))))))
1031
+
1032
+
1033
+ ;; ----------------------------------------------------------------------
1034
+ ;; operator precedence management
1035
+ ;; ----------------------------------------------------------------------
1036
+
1037
+ ;; a vector of precedence descriptors where each element
1038
+ ;; is of the form (terminal type precedence)
1039
+ (define the-terminals/prec #f) ; terminal symbols with precedence
1040
+ ; the precedence is an integer >= 0
1041
+ (define (get-symbol-precedence sym)
1042
+ (caddr (vector-ref the-terminals/prec sym)))
1043
+ ; the operator type is either 'none, 'left, 'right, or 'nonassoc
1044
+ (define (get-symbol-assoc sym)
1045
+ (cadr (vector-ref the-terminals/prec sym)))
1046
+
1047
+ (define rule-precedences '())
1048
+ (define (add-rule-precedence! rule sym)
1049
+ (set! rule-precedences
1050
+ (cons (cons rule sym) rule-precedences)))
1051
+
1052
+ (define (get-rule-precedence ruleno)
1053
+ (cond
1054
+ ((assq ruleno rule-precedences)
1055
+ => (lambda (p)
1056
+ (get-symbol-precedence (cdr p))))
1057
+ (else
1058
+ ;; process the rule symbols from left to right
1059
+ (let loop ((i (vector-ref rrhs ruleno))
1060
+ (prec 0))
1061
+ (let ((item (vector-ref ritem i)))
1062
+ ;; end of rule
1063
+ (if (< item 0)
1064
+ prec
1065
+ (let ((i1 (+ i 1)))
1066
+ (if (>= item nvars)
1067
+ ;; it's a terminal symbol
1068
+ (loop i1 (get-symbol-precedence (- item nvars)))
1069
+ (loop i1 prec)))))))))
1070
+
1071
+ ;; ----------------------------------------------------------------------
1072
+ ;; Build the various tables
1073
+ ;; ----------------------------------------------------------------------
1074
+
1075
+ (define expected-conflicts 0)
1076
+
1077
+ (define (build-tables)
1078
+
1079
+ (define (resolve-conflict sym rule)
1080
+ (let ((sym-prec (get-symbol-precedence sym))
1081
+ (sym-assoc (get-symbol-assoc sym))
1082
+ (rule-prec (get-rule-precedence rule)))
1083
+ (cond
1084
+ ((> sym-prec rule-prec) 'shift)
1085
+ ((< sym-prec rule-prec) 'reduce)
1086
+ ((eq? sym-assoc 'left) 'reduce)
1087
+ ((eq? sym-assoc 'right) 'shift)
1088
+ (else 'none))))
1089
+
1090
+ (define conflict-messages '())
1091
+
1092
+ (define (add-conflict-message . l)
1093
+ (set! conflict-messages (cons l conflict-messages)))
1094
+
1095
+ (define (log-conflicts)
1096
+ (if (> (length conflict-messages) expected-conflicts)
1097
+ (for-each
1098
+ (lambda (message)
1099
+ (for-each display message)
1100
+ (newline))
1101
+ conflict-messages)))
1102
+
1103
+ ;; --- Add an action to the action table
1104
+ (define (add-action state symbol new-action)
1105
+ (let* ((state-actions (vector-ref action-table state))
1106
+ (actions (assv symbol state-actions)))
1107
+ (if (pair? actions)
1108
+ (let ((current-action (cadr actions)))
1109
+ (if (not (= new-action current-action))
1110
+ ;; -- there is a conflict
1111
+ (begin
1112
+ (if (and (<= current-action 0) (<= new-action 0))
1113
+ ;; --- reduce/reduce conflict
1114
+ (begin
1115
+ (add-conflict-message
1116
+ "%% Reduce/Reduce conflict (reduce " (- new-action) ", reduce " (- current-action)
1117
+ ") on '" (get-symbol (+ symbol nvars)) "' in state " state)
1118
+ (if (glr-driver?)
1119
+ (set-cdr! (cdr actions) (cons new-action (cddr actions)))
1120
+ (set-car! (cdr actions) (max current-action new-action))))
1121
+ ;; --- shift/reduce conflict
1122
+ ;; can we resolve the conflict using precedences?
1123
+ (case (resolve-conflict symbol (- current-action))
1124
+ ;; -- shift
1125
+ ((shift) (if (glr-driver?)
1126
+ (set-cdr! (cdr actions) (cons new-action (cddr actions)))
1127
+ (set-car! (cdr actions) new-action)))
1128
+ ;; -- reduce
1129
+ ((reduce) #f) ; well, nothing to do...
1130
+ ;; -- signal a conflict!
1131
+ (else (add-conflict-message
1132
+ "%% Shift/Reduce conflict (shift " new-action ", reduce " (- current-action)
1133
+ ") on '" (get-symbol (+ symbol nvars)) "' in state " state)
1134
+ (if (glr-driver?)
1135
+ (set-cdr! (cdr actions) (cons new-action (cddr actions)))
1136
+ (set-car! (cdr actions) new-action))))))))
1137
+
1138
+ (vector-set! action-table state (cons (list symbol new-action) state-actions)))
1139
+ ))
1140
+
1141
+ (define (add-action-for-all-terminals state action)
1142
+ (do ((i 1 (+ i 1)))
1143
+ ((= i nterms))
1144
+ (add-action state i action)))
1145
+
1146
+ (set! action-table (make-vector nstates '()))
1147
+
1148
+ (do ((i 0 (+ i 1))) ; i = state
1149
+ ((= i nstates))
1150
+ (let ((red (vector-ref reduction-table i)))
1151
+ (if (and red (>= (red-nreds red) 1))
1152
+ (if (and (= (red-nreds red) 1) (vector-ref consistent i))
1153
+ (if (glr-driver?)
1154
+ (add-action-for-all-terminals i (- (car (red-rules red))))
1155
+ (add-action i 'default (- (car (red-rules red)))))
1156
+ (let ((k (vector-ref lookaheads (+ i 1))))
1157
+ (let loop ((j (vector-ref lookaheads i)))
1158
+ (if (< j k)
1159
+ (let ((rule (- (vector-ref LAruleno j)))
1160
+ (lav (vector-ref LA j)))
1161
+ (let loop2 ((token 0) (x (vector-ref lav 0)) (y 1) (z 0))
1162
+ (if (< token nterms)
1163
+ (begin
1164
+ (let ((in-la-set? (modulo x 2)))
1165
+ (if (= in-la-set? 1)
1166
+ (add-action i token rule)))
1167
+ (if (= y (BITS-PER-WORD))
1168
+ (loop2 (+ token 1)
1169
+ (vector-ref lav (+ z 1))
1170
+ 1
1171
+ (+ z 1))
1172
+ (loop2 (+ token 1) (quotient x 2) (+ y 1) z)))))
1173
+ (loop (+ j 1)))))))))
1174
+
1175
+ (let ((shiftp (vector-ref shift-table i)))
1176
+ (if shiftp
1177
+ (let loop ((k (shift-shifts shiftp)))
1178
+ (if (pair? k)
1179
+ (let* ((state (car k))
1180
+ (symbol (vector-ref acces-symbol state)))
1181
+ (if (>= symbol nvars)
1182
+ (add-action i (- symbol nvars) state))
1183
+ (loop (cdr k))))))))
1184
+
1185
+ (add-action final-state 0 'accept)
1186
+ (log-conflicts))
1187
+
1188
+ (define (compact-action-table terms)
1189
+ (define (most-common-action acts)
1190
+ (let ((accums '()))
1191
+ (let loop ((l acts))
1192
+ (if (pair? l)
1193
+ (let* ((x (cadar l))
1194
+ (y (assv x accums)))
1195
+ (if (and (number? x) (< x 0))
1196
+ (if y
1197
+ (set-cdr! y (+ 1 (cdr y)))
1198
+ (set! accums (cons `(,x . 1) accums))))
1199
+ (loop (cdr l)))))
1200
+
1201
+ (let loop ((l accums) (max 0) (sym #f))
1202
+ (if (null? l)
1203
+ sym
1204
+ (let ((x (car l)))
1205
+ (if (> (cdr x) max)
1206
+ (loop (cdr l) (cdr x) (car x))
1207
+ (loop (cdr l) max sym)))))))
1208
+
1209
+ (define (translate-terms acts)
1210
+ (map (lambda (act)
1211
+ (cons (list-ref terms (car act))
1212
+ (cdr act)))
1213
+ acts))
1214
+
1215
+ (do ((i 0 (+ i 1)))
1216
+ ((= i nstates))
1217
+ (let ((acts (vector-ref action-table i)))
1218
+ (if (vector? (vector-ref reduction-table i))
1219
+ (let ((act (most-common-action acts)))
1220
+ (vector-set! action-table i
1221
+ (cons `(*default* ,(if act act '*error*))
1222
+ (translate-terms
1223
+ (lalr-filter (lambda (x)
1224
+ (not (and (= (length x) 2)
1225
+ (eq? (cadr x) act))))
1226
+ acts)))))
1227
+ (vector-set! action-table i
1228
+ (cons `(*default* *error*)
1229
+ (translate-terms acts)))))))
1230
+
1231
+
1232
+
1233
+ ;; --
1234
+
1235
+ (define (rewrite-grammar tokens grammar k)
1236
+
1237
+ (define eoi '*eoi*)
1238
+
1239
+ (define (check-terminal term terms)
1240
+ (cond
1241
+ ((not (valid-terminal? term))
1242
+ (lalr-error "invalid terminal: " term))
1243
+ ((member term terms)
1244
+ (lalr-error "duplicate definition of terminal: " term))))
1245
+
1246
+ (define (prec->type prec)
1247
+ (cdr (assq prec '((left: . left)
1248
+ (right: . right)
1249
+ (nonassoc: . nonassoc)))))
1250
+
1251
+ (cond
1252
+ ;; --- a few error conditions
1253
+ ((not (list? tokens))
1254
+ (lalr-error "Invalid token list: " tokens))
1255
+ ((not (pair? grammar))
1256
+ (lalr-error "Grammar definition must have a non-empty list of productions" '()))
1257
+
1258
+ (else
1259
+ ;; --- check the terminals
1260
+ (let loop1 ((lst tokens)
1261
+ (rev-terms '())
1262
+ (rev-terms/prec '())
1263
+ (prec-level 0))
1264
+ (if (pair? lst)
1265
+ (let ((term (car lst)))
1266
+ (cond
1267
+ ((pair? term)
1268
+ (if (and (memq (car term) '(left: right: nonassoc:))
1269
+ (not (null? (cdr term))))
1270
+ (let ((prec (+ prec-level 1))
1271
+ (optype (prec->type (car term))))
1272
+ (let loop-toks ((l (cdr term))
1273
+ (rev-terms rev-terms)
1274
+ (rev-terms/prec rev-terms/prec))
1275
+ (if (null? l)
1276
+ (loop1 (cdr lst) rev-terms rev-terms/prec prec)
1277
+ (let ((term (car l)))
1278
+ (check-terminal term rev-terms)
1279
+ (loop-toks
1280
+ (cdr l)
1281
+ (cons term rev-terms)
1282
+ (cons (list term optype prec) rev-terms/prec))))))
1283
+
1284
+ (lalr-error "invalid operator precedence specification: " term)))
1285
+
1286
+ (else
1287
+ (check-terminal term rev-terms)
1288
+ (loop1 (cdr lst)
1289
+ (cons term rev-terms)
1290
+ (cons (list term 'none 0) rev-terms/prec)
1291
+ prec-level))))
1292
+
1293
+ ;; --- check the grammar rules
1294
+ (let loop2 ((lst grammar) (rev-nonterm-defs '()))
1295
+ (if (pair? lst)
1296
+ (let ((def (car lst)))
1297
+ (if (not (pair? def))
1298
+ (lalr-error "Nonterminal definition must be a non-empty list" '())
1299
+ (let ((nonterm (car def)))
1300
+ (cond ((not (valid-nonterminal? nonterm))
1301
+ (lalr-error "Invalid nonterminal:" nonterm))
1302
+ ((or (member nonterm rev-terms)
1303
+ (assoc nonterm rev-nonterm-defs))
1304
+ (lalr-error "Nonterminal previously defined:" nonterm))
1305
+ (else
1306
+ (loop2 (cdr lst)
1307
+ (cons def rev-nonterm-defs)))))))
1308
+ (let* ((terms (cons eoi (cons 'error (reverse rev-terms))))
1309
+ (terms/prec (cons '(eoi none 0) (cons '(error none 0) (reverse rev-terms/prec))))
1310
+ (nonterm-defs (reverse rev-nonterm-defs))
1311
+ (nonterms (cons '*start* (map car nonterm-defs))))
1312
+ (if (= (length nonterms) 1)
1313
+ (lalr-error "Grammar must contain at least one nonterminal" '())
1314
+ (let loop-defs ((defs (cons `(*start* (,(cadr nonterms) ,eoi) : $1)
1315
+ nonterm-defs))
1316
+ (ruleno 0)
1317
+ (comp-defs '()))
1318
+ (if (pair? defs)
1319
+ (let* ((nonterm-def (car defs))
1320
+ (compiled-def (rewrite-nonterm-def
1321
+ nonterm-def
1322
+ ruleno
1323
+ terms nonterms)))
1324
+ (loop-defs (cdr defs)
1325
+ (+ ruleno (length compiled-def))
1326
+ (cons compiled-def comp-defs)))
1327
+
1328
+ (let ((compiled-nonterm-defs (reverse comp-defs)))
1329
+ (k terms
1330
+ terms/prec
1331
+ nonterms
1332
+ (map (lambda (x) (cons (caaar x) (map cdar x)))
1333
+ compiled-nonterm-defs)
1334
+ (apply append compiled-nonterm-defs))))))))))))))
1335
+
1336
+
1337
+ (define (rewrite-nonterm-def nonterm-def ruleno terms nonterms)
1338
+
1339
+ (define No-NT (length nonterms))
1340
+
1341
+ (define (encode x)
1342
+ (let ((PosInNT (pos-in-list x nonterms)))
1343
+ (if PosInNT
1344
+ PosInNT
1345
+ (let ((PosInT (pos-in-list x terms)))
1346
+ (if PosInT
1347
+ (+ No-NT PosInT)
1348
+ (lalr-error "undefined symbol : " x))))))
1349
+
1350
+ (define (process-prec-directive rhs ruleno)
1351
+ (let loop ((l rhs))
1352
+ (if (null? l)
1353
+ '()
1354
+ (let ((first (car l))
1355
+ (rest (cdr l)))
1356
+ (cond
1357
+ ((or (member first terms) (member first nonterms))
1358
+ (cons first (loop rest)))
1359
+ ((and (pair? first)
1360
+ (eq? (car first) 'prec:))
1361
+ (if (and (pair? (cdr first))
1362
+ (null? (cddr first))
1363
+ (member (cadr first) terms))
1364
+ (if (null? rest)
1365
+ (begin
1366
+ (add-rule-precedence! ruleno (pos-in-list (cadr first) terms))
1367
+ (loop rest))
1368
+ (lalr-error "prec: directive should be at end of rule: " rhs))
1369
+ (lalr-error "Invalid prec: directive: " first)))
1370
+ (else
1371
+ (lalr-error "Invalid terminal or nonterminal: " first)))))))
1372
+
1373
+ (define (check-error-production rhs)
1374
+ (let loop ((rhs rhs))
1375
+ (if (pair? rhs)
1376
+ (begin
1377
+ (if (and (eq? (car rhs) 'error)
1378
+ (or (null? (cdr rhs))
1379
+ (not (member (cadr rhs) terms))
1380
+ (not (null? (cddr rhs)))))
1381
+ (lalr-error "Invalid 'error' production. A single terminal symbol must follow the 'error' token.:" rhs))
1382
+ (loop (cdr rhs))))))
1383
+
1384
+
1385
+ (if (not (pair? (cdr nonterm-def)))
1386
+ (lalr-error "At least one production needed for nonterminal:" (car nonterm-def))
1387
+ (let ((name (symbol->string (car nonterm-def))))
1388
+ (let loop1 ((lst (cdr nonterm-def))
1389
+ (i 1)
1390
+ (rev-productions-and-actions '()))
1391
+ (if (not (pair? lst))
1392
+ (reverse rev-productions-and-actions)
1393
+ (let* ((rhs (process-prec-directive (car lst) (+ ruleno i -1)))
1394
+ (rest (cdr lst))
1395
+ (prod (map encode (cons (car nonterm-def) rhs))))
1396
+ ;; -- check for undefined tokens
1397
+ (for-each (lambda (x)
1398
+ (if (not (or (member x terms) (member x nonterms)))
1399
+ (lalr-error "Invalid terminal or nonterminal:" x)))
1400
+ rhs)
1401
+ ;; -- check 'error' productions
1402
+ (check-error-production rhs)
1403
+
1404
+ (if (and (pair? rest)
1405
+ (eq? (car rest) ':)
1406
+ (pair? (cdr rest)))
1407
+ (loop1 (cddr rest)
1408
+ (+ i 1)
1409
+ (cons (cons prod (cadr rest))
1410
+ rev-productions-and-actions))
1411
+ (let* ((rhs-length (length rhs))
1412
+ (action
1413
+ (cons 'vector
1414
+ (cons (list 'quote (string->symbol
1415
+ (string-append
1416
+ name
1417
+ "-"
1418
+ (number->string i))))
1419
+ (let loop-j ((j 1))
1420
+ (if (> j rhs-length)
1421
+ '()
1422
+ (cons (string->symbol
1423
+ (string-append
1424
+ "$"
1425
+ (number->string j)))
1426
+ (loop-j (+ j 1)))))))))
1427
+ (loop1 rest
1428
+ (+ i 1)
1429
+ (cons (cons prod action)
1430
+ rev-productions-and-actions))))))))))
1431
+
1432
+ (define (valid-nonterminal? x)
1433
+ (symbol? x))
1434
+
1435
+ (define (valid-terminal? x)
1436
+ (symbol? x)) ; DB
1437
+
1438
+ ;; ----------------------------------------------------------------------
1439
+ ;; Miscellaneous
1440
+ ;; ----------------------------------------------------------------------
1441
+ (define (pos-in-list x lst)
1442
+ (let loop ((lst lst) (i 0))
1443
+ (cond ((not (pair? lst)) #f)
1444
+ ((equal? (car lst) x) i)
1445
+ (else (loop (cdr lst) (+ i 1))))))
1446
+
1447
+ (define (sunion lst1 lst2) ; union of sorted lists
1448
+ (let loop ((L1 lst1)
1449
+ (L2 lst2))
1450
+ (cond ((null? L1) L2)
1451
+ ((null? L2) L1)
1452
+ (else
1453
+ (let ((x (car L1)) (y (car L2)))
1454
+ (cond
1455
+ ((> x y)
1456
+ (cons y (loop L1 (cdr L2))))
1457
+ ((< x y)
1458
+ (cons x (loop (cdr L1) L2)))
1459
+ (else
1460
+ (loop (cdr L1) L2))
1461
+ ))))))
1462
+
1463
+ (define (sinsert elem lst)
1464
+ (let loop ((l1 lst))
1465
+ (if (null? l1)
1466
+ (cons elem l1)
1467
+ (let ((x (car l1)))
1468
+ (cond ((< elem x)
1469
+ (cons elem l1))
1470
+ ((> elem x)
1471
+ (cons x (loop (cdr l1))))
1472
+ (else
1473
+ l1))))))
1474
+
1475
+ (define (lalr-filter p lst)
1476
+ (let loop ((l lst))
1477
+ (if (null? l)
1478
+ '()
1479
+ (let ((x (car l)) (y (cdr l)))
1480
+ (if (p x)
1481
+ (cons x (loop y))
1482
+ (loop y))))))
1483
+
1484
+ ;; ----------------------------------------------------------------------
1485
+ ;; Debugging tools ...
1486
+ ;; ----------------------------------------------------------------------
1487
+ (define the-terminals #f) ; names of terminal symbols
1488
+ (define the-nonterminals #f) ; non-terminals
1489
+
1490
+ (define (print-item item-no)
1491
+ (let loop ((i item-no))
1492
+ (let ((v (vector-ref ritem i)))
1493
+ (if (>= v 0)
1494
+ (loop (+ i 1))
1495
+ (let* ((rlno (- v))
1496
+ (nt (vector-ref rlhs rlno)))
1497
+ (display (vector-ref the-nonterminals nt)) (display " --> ")
1498
+ (let loop ((i (vector-ref rrhs rlno)))
1499
+ (let ((v (vector-ref ritem i)))
1500
+ (if (= i item-no)
1501
+ (display ". "))
1502
+ (if (>= v 0)
1503
+ (begin
1504
+ (display (get-symbol v))
1505
+ (display " ")
1506
+ (loop (+ i 1)))
1507
+ (begin
1508
+ (display " (rule ")
1509
+ (display (- v))
1510
+ (display ")")
1511
+ (newline))))))))))
1512
+
1513
+ (define (get-symbol n)
1514
+ (if (>= n nvars)
1515
+ (vector-ref the-terminals (- n nvars))
1516
+ (vector-ref the-nonterminals n)))
1517
+
1518
+
1519
+ (define (print-states)
1520
+ (define (print-action act)
1521
+ (cond
1522
+ ((eq? act '*error*)
1523
+ (display " : Error"))
1524
+ ((eq? act 'accept)
1525
+ (display " : Accept input"))
1526
+ ((< act 0)
1527
+ (display " : reduce using rule ")
1528
+ (display (- act)))
1529
+ (else
1530
+ (display " : shift and goto state ")
1531
+ (display act)))
1532
+ (newline)
1533
+ #t)
1534
+
1535
+ (define (print-actions acts)
1536
+ (let loop ((l acts))
1537
+ (if (null? l)
1538
+ #t
1539
+ (let ((sym (caar l))
1540
+ (act (cadar l)))
1541
+ (display " ")
1542
+ (cond
1543
+ ((eq? sym 'default)
1544
+ (display "default action"))
1545
+ (else
1546
+ (if (number? sym)
1547
+ (display (get-symbol (+ sym nvars)))
1548
+ (display sym))))
1549
+ (print-action act)
1550
+ (loop (cdr l))))))
1551
+
1552
+ (if (not action-table)
1553
+ (begin
1554
+ (display "No generated parser available!")
1555
+ (newline)
1556
+ #f)
1557
+ (begin
1558
+ (display "State table") (newline)
1559
+ (display "-----------") (newline) (newline)
1560
+
1561
+ (let loop ((l first-state))
1562
+ (if (null? l)
1563
+ #t
1564
+ (let* ((core (car l))
1565
+ (i (core-number core))
1566
+ (items (core-items core))
1567
+ (actions (vector-ref action-table i)))
1568
+ (display "state ") (display i) (newline)
1569
+ (newline)
1570
+ (for-each (lambda (x) (display " ") (print-item x))
1571
+ items)
1572
+ (newline)
1573
+ (print-actions actions)
1574
+ (newline)
1575
+ (loop (cdr l))))))))
1576
+
1577
+
1578
+
1579
+ ;; ----------------------------------------------------------------------
1580
+
1581
+ (define build-goto-table
1582
+ (lambda ()
1583
+ `(vector
1584
+ ,@(map
1585
+ (lambda (shifts)
1586
+ (list 'quote
1587
+ (if shifts
1588
+ (let loop ((l (shift-shifts shifts)))
1589
+ (if (null? l)
1590
+ '()
1591
+ (let* ((state (car l))
1592
+ (symbol (vector-ref acces-symbol state)))
1593
+ (if (< symbol nvars)
1594
+ (cons `(,symbol . ,state)
1595
+ (loop (cdr l)))
1596
+ (loop (cdr l))))))
1597
+ '())))
1598
+ (vector->list shift-table)))))
1599
+
1600
+
1601
+ (define build-reduction-table
1602
+ (lambda (gram/actions)
1603
+ `(vector
1604
+ '()
1605
+ ,@(map
1606
+ (lambda (p)
1607
+ (let ((act (cdr p)))
1608
+ `(lambda ,(if (eq? driver-name 'lr-driver)
1609
+ '(___stack ___sp ___goto-table ___push yypushback)
1610
+ '(___sp ___goto-table ___push))
1611
+ ,(let* ((nt (caar p)) (rhs (cdar p)) (n (length rhs)))
1612
+ `(let* (,@(if act
1613
+ (let loop ((i 1) (l rhs))
1614
+ (if (pair? l)
1615
+ (let ((rest (cdr l))
1616
+ (ns (number->string (+ (- n i) 1))))
1617
+ (cons
1618
+ `(tok ,(if (eq? driver-name 'lr-driver)
1619
+ `(vector-ref ___stack (- ___sp ,(- (* i 2) 1)))
1620
+ `(list-ref ___sp ,(+ (* (- i 1) 2) 1))))
1621
+ (cons
1622
+ `(,(string->symbol (string-append "$" ns))
1623
+ (if (lexical-token? tok) (lexical-token-value tok) tok))
1624
+ (cons
1625
+ `(,(string->symbol (string-append "@" ns))
1626
+ (if (lexical-token? tok) (lexical-token-source tok) tok))
1627
+ (loop (+ i 1) rest)))))
1628
+ '()))
1629
+ '()))
1630
+ ,(if (= nt 0)
1631
+ '$1
1632
+ `(___push ,n ,nt ,(cdr p) ,@(if (eq? driver-name 'lr-driver) '() '(___sp))
1633
+ ,(if (eq? driver-name 'lr-driver)
1634
+ `(vector-ref ___stack (- ___sp ,(length rhs)))
1635
+ `(list-ref ___sp ,(length rhs))))))))))
1636
+
1637
+ gram/actions))))
1638
+
1639
+
1640
+
1641
+ ;; Options
1642
+
1643
+ (define *valid-options*
1644
+ (list
1645
+ (cons 'out-table:
1646
+ (lambda (option)
1647
+ (and (list? option)
1648
+ (= (length option) 2)
1649
+ (string? (cadr option)))))
1650
+ (cons 'output:
1651
+ (lambda (option)
1652
+ (and (list? option)
1653
+ (= (length option) 3)
1654
+ (symbol? (cadr option))
1655
+ (string? (caddr option)))))
1656
+ (cons 'expect:
1657
+ (lambda (option)
1658
+ (and (list? option)
1659
+ (= (length option) 2)
1660
+ (integer? (cadr option))
1661
+ (>= (cadr option) 0))))
1662
+
1663
+ (cons 'driver:
1664
+ (lambda (option)
1665
+ (and (list? option)
1666
+ (= (length option) 2)
1667
+ (symbol? (cadr option))
1668
+ (memq (cadr option) '(lr glr)))))))
1669
+
1670
+
1671
+ (define (validate-options options)
1672
+ (for-each
1673
+ (lambda (option)
1674
+ (let ((p (assoc (car option) *valid-options*)))
1675
+ (if (or (not p)
1676
+ (not ((cdr p) option)))
1677
+ (lalr-error "Invalid option:" option))))
1678
+ options))
1679
+
1680
+
1681
+ (define (output-parser! options code)
1682
+ (let ((option (assq 'output: options)))
1683
+ (if option
1684
+ (let ((parser-name (cadr option))
1685
+ (file-name (caddr option)))
1686
+ (with-output-to-file file-name
1687
+ (lambda ()
1688
+ (pprint `(define ,parser-name ,code))
1689
+ (newline)))))))
1690
+
1691
+
1692
+ (define (output-table! options)
1693
+ (let ((option (assq 'out-table: options)))
1694
+ (if option
1695
+ (let ((file-name (cadr option)))
1696
+ (with-output-to-file file-name print-states)))))
1697
+
1698
+
1699
+ (define (set-expected-conflicts! options)
1700
+ (let ((option (assq 'expect: options)))
1701
+ (set! expected-conflicts (if option (cadr option) 0))))
1702
+
1703
+ (define (set-driver-name! options)
1704
+ (let ((option (assq 'driver: options)))
1705
+ (if option
1706
+ (let ((driver-type (cadr option)))
1707
+ (set! driver-name (if (eq? driver-type 'glr) 'glr-driver 'lr-driver))))))
1708
+
1709
+
1710
+ ;; -- arguments
1711
+
1712
+ (define (extract-arguments lst proc)
1713
+ (let loop ((options '())
1714
+ (tokens '())
1715
+ (rules '())
1716
+ (lst lst))
1717
+ (if (pair? lst)
1718
+ (let ((p (car lst)))
1719
+ (cond
1720
+ ((and (pair? p)
1721
+ (lalr-keyword? (car p))
1722
+ (assq (car p) *valid-options*))
1723
+ (loop (cons p options) tokens rules (cdr lst)))
1724
+ (else
1725
+ (proc options p (cdr lst)))))
1726
+ (lalr-error "Malformed lalr-parser form" lst))))
1727
+
1728
+
1729
+ (define (build-driver options tokens rules)
1730
+ (validate-options options)
1731
+ (set-expected-conflicts! options)
1732
+ (set-driver-name! options)
1733
+ (let* ((gram/actions (gen-tables! tokens rules))
1734
+ (code `(,driver-name ',action-table ,(build-goto-table) ,(build-reduction-table gram/actions))))
1735
+
1736
+ (output-table! options)
1737
+ (output-parser! options code)
1738
+ code))
1739
+
1740
+ (extract-arguments arguments build-driver))
1741
+
1742
+
1743
+
1744
+ ;;;
1745
+ ;;;; --
1746
+ ;;;; Implementation of the lr-driver
1747
+ ;;;
1748
+
1749
+
1750
+ (cond-expand
1751
+ (gambit
1752
+ (declare
1753
+ (standard-bindings)
1754
+ (fixnum)
1755
+ (block)
1756
+ (not safe)))
1757
+ (chicken
1758
+ (declare
1759
+ (uses extras)
1760
+ (usual-integrations)
1761
+ (fixnum)
1762
+ (not safe)))
1763
+ (else))
1764
+
1765
+
1766
+ ;;;
1767
+ ;;;; Source location utilities
1768
+ ;;;
1769
+
1770
+
1771
+ ;; This function assumes that src-location-1 and src-location-2 are source-locations
1772
+ ;; Returns #f if they are not locations for the same input
1773
+ (define (combine-locations src-location-1 src-location-2)
1774
+ (let ((offset-1 (source-location-offset src-location-1))
1775
+ (offset-2 (source-location-offset src-location-2))
1776
+ (length-1 (source-location-length src-location-1))
1777
+ (length-2 (source-location-length src-location-2)))
1778
+
1779
+ (cond ((not (equal? (source-location-input src-location-1)
1780
+ (source-location-input src-location-2)))
1781
+ #f)
1782
+ ((or (not (number? offset-1)) (not (number? offset-2))
1783
+ (not (number? length-1)) (not (number? length-2))
1784
+ (< offset-1 0) (< offset-2 0)
1785
+ (< length-1 0) (< length-2 0))
1786
+ (make-source-location (source-location-input src-location-1)
1787
+ (source-location-line src-location-1)
1788
+ (source-location-column src-location-1)
1789
+ -1 -1))
1790
+ ((<= offset-1 offset-2)
1791
+ (make-source-location (source-location-input src-location-1)
1792
+ (source-location-line src-location-1)
1793
+ (source-location-column src-location-1)
1794
+ offset-1
1795
+ (- (+ offset-2 length-2) offset-1)))
1796
+ (else
1797
+ (make-source-location (source-location-input src-location-1)
1798
+ (source-location-line src-location-1)
1799
+ (source-location-column src-location-1)
1800
+ offset-2
1801
+ (- (+ offset-1 length-1) offset-2))))))
1802
+
1803
+
1804
+ ;;;
1805
+ ;;;; LR-driver
1806
+ ;;;
1807
+
1808
+
1809
+ (define *max-stack-size* 500)
1810
+
1811
+ (define (lr-driver action-table goto-table reduction-table)
1812
+ (define ___atable action-table)
1813
+ (define ___gtable goto-table)
1814
+ (define ___rtable reduction-table)
1815
+
1816
+ (define ___lexerp #f)
1817
+ (define ___errorp #f)
1818
+
1819
+ (define ___stack #f)
1820
+ (define ___sp 0)
1821
+
1822
+ (define ___curr-input #f)
1823
+ (define ___reuse-input #f)
1824
+
1825
+ (define ___input #f)
1826
+ (define (___consume)
1827
+ (set! ___input (if ___reuse-input ___curr-input (___lexerp)))
1828
+ (set! ___reuse-input #f)
1829
+ (set! ___curr-input ___input))
1830
+
1831
+ (define (___pushback)
1832
+ (set! ___reuse-input #t))
1833
+
1834
+ (define (___initstack)
1835
+ (set! ___stack (make-vector *max-stack-size* 0))
1836
+ (set! ___sp 0))
1837
+
1838
+ (define (___growstack)
1839
+ (let ((new-stack (make-vector (* 2 (vector-length ___stack)) 0)))
1840
+ (let loop ((i (- (vector-length ___stack) 1)))
1841
+ (if (>= i 0)
1842
+ (begin
1843
+ (vector-set! new-stack i (vector-ref ___stack i))
1844
+ (loop (- i 1)))))
1845
+ (set! ___stack new-stack)))
1846
+
1847
+ (define (___checkstack)
1848
+ (if (>= ___sp (vector-length ___stack))
1849
+ (___growstack)))
1850
+
1851
+ (define (___push delta new-category lvalue tok)
1852
+ (set! ___sp (- ___sp (* delta 2)))
1853
+ (let* ((state (vector-ref ___stack ___sp))
1854
+ (new-state (cdr (assoc new-category (vector-ref ___gtable state)))))
1855
+ (set! ___sp (+ ___sp 2))
1856
+ (___checkstack)
1857
+ (vector-set! ___stack ___sp new-state)
1858
+ (vector-set! ___stack (- ___sp 1) (note-source-location lvalue tok))))
1859
+
1860
+ (define (___reduce st)
1861
+ ((vector-ref ___rtable st) ___stack ___sp ___gtable ___push ___pushback))
1862
+
1863
+ (define (___shift token attribute)
1864
+ (set! ___sp (+ ___sp 2))
1865
+ (___checkstack)
1866
+ (vector-set! ___stack (- ___sp 1) attribute)
1867
+ (vector-set! ___stack ___sp token))
1868
+
1869
+ (define (___action x l)
1870
+ (let ((y (assoc x l)))
1871
+ (if y (cadr y) (cadar l))))
1872
+
1873
+ (define (___recover tok)
1874
+ (let find-state ((sp ___sp))
1875
+ (if (< sp 0)
1876
+ (set! ___sp sp)
1877
+ (let* ((state (vector-ref ___stack sp))
1878
+ (act (assoc 'error (vector-ref ___atable state))))
1879
+ (if act
1880
+ (begin
1881
+ (set! ___sp sp)
1882
+ (___sync (cadr act) tok))
1883
+ (find-state (- sp 2)))))))
1884
+
1885
+ (define (___sync state tok)
1886
+ (let ((sync-set (map car (cdr (vector-ref ___atable state)))))
1887
+ (set! ___sp (+ ___sp 4))
1888
+ (___checkstack)
1889
+ (vector-set! ___stack (- ___sp 3) #f)
1890
+ (vector-set! ___stack (- ___sp 2) state)
1891
+ (let skip ()
1892
+ (let ((i (___category ___input)))
1893
+ (if (eq? i '*eoi*)
1894
+ (set! ___sp -1)
1895
+ (if (memq i sync-set)
1896
+ (let ((act (assoc i (vector-ref ___atable state))))
1897
+ (vector-set! ___stack (- ___sp 1) #f)
1898
+ (vector-set! ___stack ___sp (cadr act)))
1899
+ (begin
1900
+ (___consume)
1901
+ (skip))))))))
1902
+
1903
+ (define (___category tok)
1904
+ (if (lexical-token? tok)
1905
+ (lexical-token-category tok)
1906
+ tok))
1907
+
1908
+ (define (___run)
1909
+ (let loop ()
1910
+ (if ___input
1911
+ (let* ((state (vector-ref ___stack ___sp))
1912
+ (i (___category ___input))
1913
+ (act (___action i (vector-ref ___atable state))))
1914
+
1915
+ (cond ((not (symbol? i))
1916
+ (___errorp "Syntax error: invalid token: " ___input)
1917
+ #f)
1918
+
1919
+ ;; Input succesfully parsed
1920
+ ((eq? act 'accept)
1921
+ (vector-ref ___stack 1))
1922
+
1923
+ ;; Syntax error in input
1924
+ ((eq? act '*error*)
1925
+ (if (eq? i '*eoi*)
1926
+ (begin
1927
+ (___errorp "Syntax error: unexpected end of input")
1928
+ #f)
1929
+ (begin
1930
+ (___errorp "Syntax error: unexpected token : " ___input)
1931
+ (___recover i)
1932
+ (if (>= ___sp 0)
1933
+ (set! ___input #f)
1934
+ (begin
1935
+ (set! ___sp 0)
1936
+ (set! ___input '*eoi*)))
1937
+ (loop))))
1938
+
1939
+ ;; Shift current token on top of the stack
1940
+ ((>= act 0)
1941
+ (___shift act ___input)
1942
+ (set! ___input (if (eq? i '*eoi*) '*eoi* #f))
1943
+ (loop))
1944
+
1945
+ ;; Reduce by rule (- act)
1946
+ (else
1947
+ (___reduce (- act))
1948
+ (loop))))
1949
+
1950
+ ;; no lookahead, so check if there is a default action
1951
+ ;; that does not require the lookahead
1952
+ (let* ((state (vector-ref ___stack ___sp))
1953
+ (acts (vector-ref ___atable state))
1954
+ (defact (if (pair? acts) (cadar acts) #f)))
1955
+ (if (and (= 1 (length acts)) (< defact 0))
1956
+ (___reduce (- defact))
1957
+ (___consume))
1958
+ (loop)))))
1959
+
1960
+
1961
+ (lambda (lexerp errorp)
1962
+ (set! ___errorp errorp)
1963
+ (set! ___lexerp lexerp)
1964
+ (___initstack)
1965
+ (___run)))
1966
+
1967
+
1968
+ ;;;
1969
+ ;;;; Simple-minded GLR-driver
1970
+ ;;;
1971
+
1972
+
1973
+ (define (glr-driver action-table goto-table reduction-table)
1974
+ (define ___atable action-table)
1975
+ (define ___gtable goto-table)
1976
+ (define ___rtable reduction-table)
1977
+
1978
+ (define ___lexerp #f)
1979
+ (define ___errorp #f)
1980
+
1981
+ ;; -- Input handling
1982
+
1983
+ (define *input* #f)
1984
+ (define (initialize-lexer lexer)
1985
+ (set! ___lexerp lexer)
1986
+ (set! *input* #f))
1987
+ (define (consume)
1988
+ (set! *input* (___lexerp)))
1989
+
1990
+ (define (token-category tok)
1991
+ (if (lexical-token? tok)
1992
+ (lexical-token-category tok)
1993
+ tok))
1994
+
1995
+ (define (token-attribute tok)
1996
+ (if (lexical-token? tok)
1997
+ (lexical-token-value tok)
1998
+ tok))
1999
+
2000
+ ;; -- Processes (stacks) handling
2001
+
2002
+ (define *processes* '())
2003
+
2004
+ (define (initialize-processes)
2005
+ (set! *processes* '()))
2006
+ (define (add-process process)
2007
+ (set! *processes* (cons process *processes*)))
2008
+ (define (get-processes)
2009
+ (reverse *processes*))
2010
+
2011
+ (define (for-all-processes proc)
2012
+ (let ((processes (get-processes)))
2013
+ (initialize-processes)
2014
+ (for-each proc processes)))
2015
+
2016
+ ;; -- parses
2017
+ (define *parses* '())
2018
+ (define (get-parses)
2019
+ *parses*)
2020
+ (define (initialize-parses)
2021
+ (set! *parses* '()))
2022
+ (define (add-parse parse)
2023
+ (set! *parses* (cons parse *parses*)))
2024
+
2025
+
2026
+ (define (push delta new-category lvalue stack tok)
2027
+ (let* ((stack (drop stack (* delta 2)))
2028
+ (state (car stack))
2029
+ (new-state (cdr (assv new-category (vector-ref ___gtable state)))))
2030
+ (cons new-state (cons (note-source-location lvalue tok) stack))))
2031
+
2032
+ (define (reduce state stack)
2033
+ ((vector-ref ___rtable state) stack ___gtable push))
2034
+
2035
+ (define (shift state symbol stack)
2036
+ (cons state (cons symbol stack)))
2037
+
2038
+ (define (get-actions token action-list)
2039
+ (let ((pair (assoc token action-list)))
2040
+ (if pair
2041
+ (cdr pair)
2042
+ (cdar action-list)))) ;; get the default action
2043
+
2044
+
2045
+ (define (run)
2046
+ (let loop-tokens ()
2047
+ (consume)
2048
+ (let ((symbol (token-category *input*)))
2049
+ (for-all-processes
2050
+ (lambda (process)
2051
+ (let loop ((stacks (list process)) (active-stacks '()))
2052
+ (cond ((pair? stacks)
2053
+ (let* ((stack (car stacks))
2054
+ (state (car stack)))
2055
+ (let actions-loop ((actions (get-actions symbol (vector-ref ___atable state)))
2056
+ (active-stacks active-stacks))
2057
+ (if (pair? actions)
2058
+ (let ((action (car actions))
2059
+ (other-actions (cdr actions)))
2060
+ (cond ((eq? action '*error*)
2061
+ (actions-loop other-actions active-stacks))
2062
+ ((eq? action 'accept)
2063
+ (add-parse (car (take-right stack 2)))
2064
+ (actions-loop other-actions active-stacks))
2065
+ ((>= action 0)
2066
+ (let ((new-stack (shift action *input* stack)))
2067
+ (add-process new-stack))
2068
+ (actions-loop other-actions active-stacks))
2069
+ (else
2070
+ (let ((new-stack (reduce (- action) stack)))
2071
+ (actions-loop other-actions (cons new-stack active-stacks))))))
2072
+ (loop (cdr stacks) active-stacks)))))
2073
+ ((pair? active-stacks)
2074
+ (loop (reverse active-stacks) '())))))))
2075
+ (if (pair? (get-processes))
2076
+ (loop-tokens))))
2077
+
2078
+
2079
+ (lambda (lexerp errorp)
2080
+ (set! ___errorp errorp)
2081
+ (initialize-lexer lexerp)
2082
+ (initialize-processes)
2083
+ (initialize-parses)
2084
+ (add-process '(0))
2085
+ (run)
2086
+ (get-parses)))
2087
+
2088
+
2089
+ (define (drop l n)
2090
+ (cond ((and (> n 0) (pair? l))
2091
+ (drop (cdr l) (- n 1)))
2092
+ (else
2093
+ l)))
2094
+
2095
+ (define (take-right l n)
2096
+ (drop l (- (length l) n)))