LilyPond-Ruby 0.0.2.1 → 0.1.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (1112) 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/guile.rb +19 -0
  330. data/lib/lilypond/2.24.1/ccache/lily/accreg.go +0 -0
  331. data/lib/lilypond/2.24.1/ccache/lily/auto-beam.go +0 -0
  332. data/lib/lilypond/2.24.1/ccache/lily/autochange.go +0 -0
  333. data/lib/lilypond/2.24.1/ccache/lily/backend-library.go +0 -0
  334. data/lib/lilypond/2.24.1/ccache/lily/bar-line.go +0 -0
  335. data/lib/lilypond/2.24.1/ccache/lily/breath.go +0 -0
  336. data/lib/lilypond/2.24.1/ccache/lily/c++.go +0 -0
  337. data/lib/lilypond/2.24.1/ccache/lily/chord-entry.go +0 -0
  338. data/lib/lilypond/2.24.1/ccache/lily/chord-ignatzek-names.go +0 -0
  339. data/lib/lilypond/2.24.1/ccache/lily/chord-name.go +0 -0
  340. data/lib/lilypond/2.24.1/ccache/lily/clip-region.go +0 -0
  341. data/lib/lilypond/2.24.1/ccache/lily/color.go +0 -0
  342. data/lib/lilypond/2.24.1/ccache/lily/curried-definitions.go +0 -0
  343. data/lib/lilypond/2.24.1/ccache/lily/define-context-properties.go +0 -0
  344. data/lib/lilypond/2.24.1/ccache/lily/define-event-classes.go +0 -0
  345. data/lib/lilypond/2.24.1/ccache/lily/define-grob-interfaces.go +0 -0
  346. data/lib/lilypond/2.24.1/ccache/lily/define-grob-properties.go +0 -0
  347. data/lib/lilypond/2.24.1/ccache/lily/define-grobs.go +0 -0
  348. data/lib/lilypond/2.24.1/ccache/lily/define-markup-commands.go +0 -0
  349. data/lib/lilypond/2.24.1/ccache/lily/define-music-callbacks.go +0 -0
  350. data/lib/lilypond/2.24.1/ccache/lily/define-music-display-methods.go +0 -0
  351. data/lib/lilypond/2.24.1/ccache/lily/define-music-properties.go +0 -0
  352. data/lib/lilypond/2.24.1/ccache/lily/define-music-types.go +0 -0
  353. data/lib/lilypond/2.24.1/ccache/lily/define-note-names.go +0 -0
  354. data/lib/lilypond/2.24.1/ccache/lily/define-stencil-commands.go +0 -0
  355. data/lib/lilypond/2.24.1/ccache/lily/define-woodwind-diagrams.go +0 -0
  356. data/lib/lilypond/2.24.1/ccache/lily/display-lily.go +0 -0
  357. data/lib/lilypond/2.24.1/ccache/lily/display-woodwind-diagrams.go +0 -0
  358. data/lib/lilypond/2.24.1/ccache/lily/file-cache.go +0 -0
  359. data/lib/lilypond/2.24.1/ccache/lily/flag-styles.go +0 -0
  360. data/lib/lilypond/2.24.1/ccache/lily/font-encodings.go +0 -0
  361. data/lib/lilypond/2.24.1/ccache/lily/font.go +0 -0
  362. data/lib/lilypond/2.24.1/ccache/lily/framework-cairo.go +0 -0
  363. data/lib/lilypond/2.24.1/ccache/lily/framework-ps.go +0 -0
  364. data/lib/lilypond/2.24.1/ccache/lily/framework-svg.go +0 -0
  365. data/lib/lilypond/2.24.1/ccache/lily/fret-diagrams.go +0 -0
  366. data/lib/lilypond/2.24.1/ccache/lily/graphviz.go +0 -0
  367. data/lib/lilypond/2.24.1/ccache/lily/harp-pedals.go +0 -0
  368. data/lib/lilypond/2.24.1/ccache/lily/layout-beam.go +0 -0
  369. data/lib/lilypond/2.24.1/ccache/lily/layout-slur.go +0 -0
  370. data/lib/lilypond/2.24.1/ccache/lily/lily-library.go +0 -0
  371. data/lib/lilypond/2.24.1/ccache/lily/lily.go +0 -0
  372. data/lib/lilypond/2.24.1/ccache/lily/ly-syntax-constructors.go +0 -0
  373. data/lib/lilypond/2.24.1/ccache/lily/markup-macros.go +0 -0
  374. data/lib/lilypond/2.24.1/ccache/lily/markup.go +0 -0
  375. data/lib/lilypond/2.24.1/ccache/lily/midi.go +0 -0
  376. data/lib/lilypond/2.24.1/ccache/lily/modal-transforms.go +0 -0
  377. data/lib/lilypond/2.24.1/ccache/lily/music-functions.go +0 -0
  378. data/lib/lilypond/2.24.1/ccache/lily/output-lib.go +0 -0
  379. data/lib/lilypond/2.24.1/ccache/lily/output-ps.go +0 -0
  380. data/lib/lilypond/2.24.1/ccache/lily/output-svg.go +0 -0
  381. data/lib/lilypond/2.24.1/ccache/lily/page.go +0 -0
  382. data/lib/lilypond/2.24.1/ccache/lily/paper-system.go +0 -0
  383. data/lib/lilypond/2.24.1/ccache/lily/paper.go +0 -0
  384. data/lib/lilypond/2.24.1/ccache/lily/parser-clef.go +0 -0
  385. data/lib/lilypond/2.24.1/ccache/lily/parser-ly-from-scheme.go +0 -0
  386. data/lib/lilypond/2.24.1/ccache/lily/part-combiner.go +0 -0
  387. data/lib/lilypond/2.24.1/ccache/lily/predefined-fretboards.go +0 -0
  388. data/lib/lilypond/2.24.1/ccache/lily/ps-to-png.go +0 -0
  389. data/lib/lilypond/2.24.1/ccache/lily/scheme-engravers.go +0 -0
  390. data/lib/lilypond/2.24.1/ccache/lily/scheme-performers.go +0 -0
  391. data/lib/lilypond/2.24.1/ccache/lily/script.go +0 -0
  392. data/lib/lilypond/2.24.1/ccache/lily/skyline.go +0 -0
  393. data/lib/lilypond/2.24.1/ccache/lily/song-util.go +0 -0
  394. data/lib/lilypond/2.24.1/ccache/lily/song.go +0 -0
  395. data/lib/lilypond/2.24.1/ccache/lily/stencil.go +0 -0
  396. data/lib/lilypond/2.24.1/ccache/lily/tablature.go +0 -0
  397. data/lib/lilypond/2.24.1/ccache/lily/time-signature-settings.go +0 -0
  398. data/lib/lilypond/2.24.1/ccache/lily/time-signature.go +0 -0
  399. data/lib/lilypond/2.24.1/ccache/lily/titling.go +0 -0
  400. data/lib/lilypond/2.24.1/ccache/lily/to-xml.go +0 -0
  401. data/lib/lilypond/2.24.1/ccache/lily/translation-functions.go +0 -0
  402. data/lib/lilypond/builder.rb +161 -0
  403. data/lib/lilypond-ruby.rb +18 -3
  404. data/share/emacs/site-lisp/lilypond-font-lock.el +208 -0
  405. data/share/emacs/site-lisp/lilypond-indent.el +605 -0
  406. data/share/emacs/site-lisp/lilypond-init.el +21 -0
  407. data/share/emacs/site-lisp/lilypond-mode.el +1204 -0
  408. data/share/emacs/site-lisp/lilypond-song.el +556 -0
  409. data/share/emacs/site-lisp/lilypond-what-beat.el +279 -0
  410. data/share/emacs/site-lisp/lilypond-words.el +1428 -0
  411. data/share/guile/2.2/guile-procedures.txt +8860 -0
  412. data/share/guile/2.2/ice-9/and-let-star.scm +73 -0
  413. data/share/guile/2.2/ice-9/arrays.scm +70 -0
  414. data/share/guile/2.2/ice-9/atomic.scm +38 -0
  415. data/share/guile/2.2/ice-9/binary-ports.scm +53 -0
  416. data/share/guile/2.2/ice-9/boot-9.scm +4131 -0
  417. data/share/guile/2.2/ice-9/buffered-input.scm +109 -0
  418. data/share/guile/2.2/ice-9/calling.scm +326 -0
  419. data/share/guile/2.2/ice-9/channel.scm +170 -0
  420. data/share/guile/2.2/ice-9/command-line.scm +477 -0
  421. data/share/guile/2.2/ice-9/common-list.scm +278 -0
  422. data/share/guile/2.2/ice-9/control.scm +110 -0
  423. data/share/guile/2.2/ice-9/curried-definitions.scm +57 -0
  424. data/share/guile/2.2/ice-9/debug.scm +25 -0
  425. data/share/guile/2.2/ice-9/deprecated.scm +93 -0
  426. data/share/guile/2.2/ice-9/documentation.scm +203 -0
  427. data/share/guile/2.2/ice-9/eval-string.scm +90 -0
  428. data/share/guile/2.2/ice-9/eval.scm +723 -0
  429. data/share/guile/2.2/ice-9/expect.scm +171 -0
  430. data/share/guile/2.2/ice-9/fdes-finalizers.scm +25 -0
  431. data/share/guile/2.2/ice-9/format.scm +1626 -0
  432. data/share/guile/2.2/ice-9/ftw.scm +564 -0
  433. data/share/guile/2.2/ice-9/futures.scm +308 -0
  434. data/share/guile/2.2/ice-9/gap-buffer.scm +283 -0
  435. data/share/guile/2.2/ice-9/getopt-long.scm +371 -0
  436. data/share/guile/2.2/ice-9/hash-table.scm +45 -0
  437. data/share/guile/2.2/ice-9/hcons.scm +80 -0
  438. data/share/guile/2.2/ice-9/history.scm +65 -0
  439. data/share/guile/2.2/ice-9/i18n.scm +531 -0
  440. data/share/guile/2.2/ice-9/iconv.scm +95 -0
  441. data/share/guile/2.2/ice-9/lineio.scm +115 -0
  442. data/share/guile/2.2/ice-9/list.scm +36 -0
  443. data/share/guile/2.2/ice-9/local-eval.scm +261 -0
  444. data/share/guile/2.2/ice-9/ls.scm +94 -0
  445. data/share/guile/2.2/ice-9/mapping.scm +118 -0
  446. data/share/guile/2.2/ice-9/match.scm +59 -0
  447. data/share/guile/2.2/ice-9/match.upstream.scm +917 -0
  448. data/share/guile/2.2/ice-9/networking.scm +94 -0
  449. data/share/guile/2.2/ice-9/null.scm +34 -0
  450. data/share/guile/2.2/ice-9/occam-channel.scm +261 -0
  451. data/share/guile/2.2/ice-9/optargs.scm +381 -0
  452. data/share/guile/2.2/ice-9/peg/cache.scm +45 -0
  453. data/share/guile/2.2/ice-9/peg/codegen.scm +359 -0
  454. data/share/guile/2.2/ice-9/peg/simplify-tree.scm +97 -0
  455. data/share/guile/2.2/ice-9/peg/string-peg.scm +273 -0
  456. data/share/guile/2.2/ice-9/peg/using-parsers.scm +116 -0
  457. data/share/guile/2.2/ice-9/peg.scm +42 -0
  458. data/share/guile/2.2/ice-9/poe.scm +116 -0
  459. data/share/guile/2.2/ice-9/poll.scm +172 -0
  460. data/share/guile/2.2/ice-9/popen.scm +178 -0
  461. data/share/guile/2.2/ice-9/ports.scm +566 -0
  462. data/share/guile/2.2/ice-9/posix.scm +75 -0
  463. data/share/guile/2.2/ice-9/pretty-print.scm +483 -0
  464. data/share/guile/2.2/ice-9/psyntax-pp.scm +3542 -0
  465. data/share/guile/2.2/ice-9/psyntax.scm +3326 -0
  466. data/share/guile/2.2/ice-9/q.scm +153 -0
  467. data/share/guile/2.2/ice-9/quasisyntax.scm +136 -0
  468. data/share/guile/2.2/ice-9/r5rs.scm +45 -0
  469. data/share/guile/2.2/ice-9/r6rs-libraries.scm +242 -0
  470. data/share/guile/2.2/ice-9/rdelim.scm +208 -0
  471. data/share/guile/2.2/ice-9/receive.scm +26 -0
  472. data/share/guile/2.2/ice-9/regex.scm +229 -0
  473. data/share/guile/2.2/ice-9/runq.scm +241 -0
  474. data/share/guile/2.2/ice-9/rw.scm +27 -0
  475. data/share/guile/2.2/ice-9/safe-r5rs.scm +145 -0
  476. data/share/guile/2.2/ice-9/safe.scm +34 -0
  477. data/share/guile/2.2/ice-9/sandbox.scm +1399 -0
  478. data/share/guile/2.2/ice-9/save-stack.scm +58 -0
  479. data/share/guile/2.2/ice-9/scm-style-repl.scm +279 -0
  480. data/share/guile/2.2/ice-9/serialize.scm +114 -0
  481. data/share/guile/2.2/ice-9/session.scm +530 -0
  482. data/share/guile/2.2/ice-9/slib.scm +33 -0
  483. data/share/guile/2.2/ice-9/stack-catch.scm +47 -0
  484. data/share/guile/2.2/ice-9/streams.scm +168 -0
  485. data/share/guile/2.2/ice-9/string-fun.scm +280 -0
  486. data/share/guile/2.2/ice-9/suspendable-ports.scm +788 -0
  487. data/share/guile/2.2/ice-9/syncase.scm +37 -0
  488. data/share/guile/2.2/ice-9/textual-ports.scm +70 -0
  489. data/share/guile/2.2/ice-9/threads.scm +392 -0
  490. data/share/guile/2.2/ice-9/time.scm +58 -0
  491. data/share/guile/2.2/ice-9/top-repl.scm +78 -0
  492. data/share/guile/2.2/ice-9/unicode.scm +26 -0
  493. data/share/guile/2.2/ice-9/vlist.scm +595 -0
  494. data/share/guile/2.2/ice-9/weak-vector.scm +31 -0
  495. data/share/guile/2.2/language/brainfuck/compile-scheme.scm +123 -0
  496. data/share/guile/2.2/language/brainfuck/compile-tree-il.scm +184 -0
  497. data/share/guile/2.2/language/brainfuck/parse.scm +95 -0
  498. data/share/guile/2.2/language/brainfuck/spec.scm +43 -0
  499. data/share/guile/2.2/language/bytecode/spec.scm +42 -0
  500. data/share/guile/2.2/language/bytecode.scm +104 -0
  501. data/share/guile/2.2/language/cps/closure-conversion.scm +848 -0
  502. data/share/guile/2.2/language/cps/compile-bytecode.scm +610 -0
  503. data/share/guile/2.2/language/cps/constructors.scm +106 -0
  504. data/share/guile/2.2/language/cps/contification.scm +448 -0
  505. data/share/guile/2.2/language/cps/cse.scm +414 -0
  506. data/share/guile/2.2/language/cps/dce.scm +363 -0
  507. data/share/guile/2.2/language/cps/effects-analysis.scm +597 -0
  508. data/share/guile/2.2/language/cps/elide-values.scm +88 -0
  509. data/share/guile/2.2/language/cps/handle-interrupts.scm +69 -0
  510. data/share/guile/2.2/language/cps/intmap.scm +765 -0
  511. data/share/guile/2.2/language/cps/intset.scm +830 -0
  512. data/share/guile/2.2/language/cps/licm.scm +308 -0
  513. data/share/guile/2.2/language/cps/optimize.scm +135 -0
  514. data/share/guile/2.2/language/cps/peel-loops.scm +287 -0
  515. data/share/guile/2.2/language/cps/primitives.scm +141 -0
  516. data/share/guile/2.2/language/cps/prune-bailouts.scm +86 -0
  517. data/share/guile/2.2/language/cps/prune-top-level-scopes.scm +63 -0
  518. data/share/guile/2.2/language/cps/reify-primitives.scm +179 -0
  519. data/share/guile/2.2/language/cps/renumber.scm +217 -0
  520. data/share/guile/2.2/language/cps/rotate-loops.scm +239 -0
  521. data/share/guile/2.2/language/cps/self-references.scm +79 -0
  522. data/share/guile/2.2/language/cps/simplify.scm +274 -0
  523. data/share/guile/2.2/language/cps/slot-allocation.scm +1058 -0
  524. data/share/guile/2.2/language/cps/spec.scm +51 -0
  525. data/share/guile/2.2/language/cps/specialize-numbers.scm +724 -0
  526. data/share/guile/2.2/language/cps/specialize-primcalls.scm +87 -0
  527. data/share/guile/2.2/language/cps/split-rec.scm +174 -0
  528. data/share/guile/2.2/language/cps/type-checks.scm +72 -0
  529. data/share/guile/2.2/language/cps/type-fold.scm +455 -0
  530. data/share/guile/2.2/language/cps/types.scm +1826 -0
  531. data/share/guile/2.2/language/cps/utils.scm +550 -0
  532. data/share/guile/2.2/language/cps/verify.scm +304 -0
  533. data/share/guile/2.2/language/cps/with-cps.scm +145 -0
  534. data/share/guile/2.2/language/cps.scm +358 -0
  535. data/share/guile/2.2/language/ecmascript/array.scm +121 -0
  536. data/share/guile/2.2/language/ecmascript/base.scm +251 -0
  537. data/share/guile/2.2/language/ecmascript/compile-tree-il.scm +576 -0
  538. data/share/guile/2.2/language/ecmascript/function.scm +78 -0
  539. data/share/guile/2.2/language/ecmascript/impl.scm +169 -0
  540. data/share/guile/2.2/language/ecmascript/parse.scm +352 -0
  541. data/share/guile/2.2/language/ecmascript/spec.scm +37 -0
  542. data/share/guile/2.2/language/ecmascript/tokenize.scm +513 -0
  543. data/share/guile/2.2/language/elisp/bindings.scm +107 -0
  544. data/share/guile/2.2/language/elisp/boot.el +617 -0
  545. data/share/guile/2.2/language/elisp/compile-tree-il.scm +812 -0
  546. data/share/guile/2.2/language/elisp/falias.scm +47 -0
  547. data/share/guile/2.2/language/elisp/lexer.scm +430 -0
  548. data/share/guile/2.2/language/elisp/parser.scm +222 -0
  549. data/share/guile/2.2/language/elisp/runtime/function-slot.scm +63 -0
  550. data/share/guile/2.2/language/elisp/runtime/value-slot.scm +24 -0
  551. data/share/guile/2.2/language/elisp/runtime.scm +153 -0
  552. data/share/guile/2.2/language/elisp/spec.scm +43 -0
  553. data/share/guile/2.2/language/scheme/compile-tree-il.scm +33 -0
  554. data/share/guile/2.2/language/scheme/decompile-tree-il.scm +796 -0
  555. data/share/guile/2.2/language/scheme/spec.scm +63 -0
  556. data/share/guile/2.2/language/tree-il/analyze.scm +1568 -0
  557. data/share/guile/2.2/language/tree-il/canonicalize.scm +82 -0
  558. data/share/guile/2.2/language/tree-il/compile-cps.scm +1149 -0
  559. data/share/guile/2.2/language/tree-il/debug.scm +246 -0
  560. data/share/guile/2.2/language/tree-il/effects.scm +591 -0
  561. data/share/guile/2.2/language/tree-il/fix-letrec.scm +314 -0
  562. data/share/guile/2.2/language/tree-il/optimize.scm +43 -0
  563. data/share/guile/2.2/language/tree-il/peval.scm +1669 -0
  564. data/share/guile/2.2/language/tree-il/primitives.scm +630 -0
  565. data/share/guile/2.2/language/tree-il/spec.scm +46 -0
  566. data/share/guile/2.2/language/tree-il.scm +630 -0
  567. data/share/guile/2.2/language/value/spec.scm +30 -0
  568. data/share/guile/2.2/oop/goops/accessors.scm +72 -0
  569. data/share/guile/2.2/oop/goops/active-slot.scm +63 -0
  570. data/share/guile/2.2/oop/goops/composite-slot.scm +83 -0
  571. data/share/guile/2.2/oop/goops/describe.scm +189 -0
  572. data/share/guile/2.2/oop/goops/internal.scm +30 -0
  573. data/share/guile/2.2/oop/goops/save.scm +874 -0
  574. data/share/guile/2.2/oop/goops/simple.scm +30 -0
  575. data/share/guile/2.2/oop/goops/stklos.scm +74 -0
  576. data/share/guile/2.2/oop/goops.scm +3176 -0
  577. data/share/guile/2.2/rnrs/arithmetic/bitwise.scm +92 -0
  578. data/share/guile/2.2/rnrs/arithmetic/fixnums.scm +291 -0
  579. data/share/guile/2.2/rnrs/arithmetic/flonums.scm +203 -0
  580. data/share/guile/2.2/rnrs/base.scm +291 -0
  581. data/share/guile/2.2/rnrs/bytevectors.scm +83 -0
  582. data/share/guile/2.2/rnrs/conditions.scm +225 -0
  583. data/share/guile/2.2/rnrs/control.scm +22 -0
  584. data/share/guile/2.2/rnrs/enums.scm +152 -0
  585. data/share/guile/2.2/rnrs/eval.scm +39 -0
  586. data/share/guile/2.2/rnrs/exceptions.scm +276 -0
  587. data/share/guile/2.2/rnrs/files.scm +96 -0
  588. data/share/guile/2.2/rnrs/hashtables.scm +190 -0
  589. data/share/guile/2.2/rnrs/io/ports.scm +554 -0
  590. data/share/guile/2.2/rnrs/io/simple.scm +167 -0
  591. data/share/guile/2.2/rnrs/lists.scm +55 -0
  592. data/share/guile/2.2/rnrs/mutable-pairs.scm +23 -0
  593. data/share/guile/2.2/rnrs/mutable-strings.scm +23 -0
  594. data/share/guile/2.2/rnrs/programs.scm +22 -0
  595. data/share/guile/2.2/rnrs/r5rs.scm +34 -0
  596. data/share/guile/2.2/rnrs/records/inspection.scm +81 -0
  597. data/share/guile/2.2/rnrs/records/procedural.scm +289 -0
  598. data/share/guile/2.2/rnrs/records/syntactic.scm +248 -0
  599. data/share/guile/2.2/rnrs/sorting.scm +27 -0
  600. data/share/guile/2.2/rnrs/syntax-case.scm +68 -0
  601. data/share/guile/2.2/rnrs/unicode.scm +104 -0
  602. data/share/guile/2.2/rnrs.scm +289 -0
  603. data/share/guile/2.2/scripts/api-diff.scm +179 -0
  604. data/share/guile/2.2/scripts/autofrisk.scm +218 -0
  605. data/share/guile/2.2/scripts/compile.scm +273 -0
  606. data/share/guile/2.2/scripts/disassemble.scm +38 -0
  607. data/share/guile/2.2/scripts/display-commentary.scm +67 -0
  608. data/share/guile/2.2/scripts/doc-snarf.scm +439 -0
  609. data/share/guile/2.2/scripts/frisk.scm +290 -0
  610. data/share/guile/2.2/scripts/generate-autoload.scm +144 -0
  611. data/share/guile/2.2/scripts/help.scm +188 -0
  612. data/share/guile/2.2/scripts/lint.scm +318 -0
  613. data/share/guile/2.2/scripts/list.scm +91 -0
  614. data/share/guile/2.2/scripts/punify.scm +87 -0
  615. data/share/guile/2.2/scripts/read-rfc822.scm +131 -0
  616. data/share/guile/2.2/scripts/read-scheme-source.scm +282 -0
  617. data/share/guile/2.2/scripts/read-text-outline.scm +253 -0
  618. data/share/guile/2.2/scripts/scan-api.scm +223 -0
  619. data/share/guile/2.2/scripts/snarf-check-and-output-texi.scm +303 -0
  620. data/share/guile/2.2/scripts/snarf-guile-m4-docs.scm +86 -0
  621. data/share/guile/2.2/scripts/summarize-guile-TODO.scm +213 -0
  622. data/share/guile/2.2/scripts/use2dot.scm +110 -0
  623. data/share/guile/2.2/srfi/srfi-1.scm +1061 -0
  624. data/share/guile/2.2/srfi/srfi-10.scm +89 -0
  625. data/share/guile/2.2/srfi/srfi-11.scm +146 -0
  626. data/share/guile/2.2/srfi/srfi-111.scm +37 -0
  627. data/share/guile/2.2/srfi/srfi-13.scm +132 -0
  628. data/share/guile/2.2/srfi/srfi-14.scm +99 -0
  629. data/share/guile/2.2/srfi/srfi-16.scm +51 -0
  630. data/share/guile/2.2/srfi/srfi-17.scm +174 -0
  631. data/share/guile/2.2/srfi/srfi-18.scm +382 -0
  632. data/share/guile/2.2/srfi/srfi-19.scm +1470 -0
  633. data/share/guile/2.2/srfi/srfi-2.scm +31 -0
  634. data/share/guile/2.2/srfi/srfi-26.scm +66 -0
  635. data/share/guile/2.2/srfi/srfi-27.scm +96 -0
  636. data/share/guile/2.2/srfi/srfi-28.scm +34 -0
  637. data/share/guile/2.2/srfi/srfi-31.scm +35 -0
  638. data/share/guile/2.2/srfi/srfi-34.scm +84 -0
  639. data/share/guile/2.2/srfi/srfi-35.scm +351 -0
  640. data/share/guile/2.2/srfi/srfi-37.scm +234 -0
  641. data/share/guile/2.2/srfi/srfi-38.scm +207 -0
  642. data/share/guile/2.2/srfi/srfi-39.scm +55 -0
  643. data/share/guile/2.2/srfi/srfi-4/gnu.scm +80 -0
  644. data/share/guile/2.2/srfi/srfi-4.scm +118 -0
  645. data/share/guile/2.2/srfi/srfi-41.scm +505 -0
  646. data/share/guile/2.2/srfi/srfi-42/ec.scm +1053 -0
  647. data/share/guile/2.2/srfi/srfi-42.scm +66 -0
  648. data/share/guile/2.2/srfi/srfi-43.scm +1077 -0
  649. data/share/guile/2.2/srfi/srfi-45.scm +93 -0
  650. data/share/guile/2.2/srfi/srfi-6.scm +29 -0
  651. data/share/guile/2.2/srfi/srfi-60.scm +73 -0
  652. data/share/guile/2.2/srfi/srfi-64/testing.scm +1040 -0
  653. data/share/guile/2.2/srfi/srfi-64.scm +55 -0
  654. data/share/guile/2.2/srfi/srfi-67/compare.scm +686 -0
  655. data/share/guile/2.2/srfi/srfi-67.scm +88 -0
  656. data/share/guile/2.2/srfi/srfi-69.scm +336 -0
  657. data/share/guile/2.2/srfi/srfi-71.scm +267 -0
  658. data/share/guile/2.2/srfi/srfi-8.scm +31 -0
  659. data/share/guile/2.2/srfi/srfi-88.scm +53 -0
  660. data/share/guile/2.2/srfi/srfi-9/gnu.scm +168 -0
  661. data/share/guile/2.2/srfi/srfi-9.scm +351 -0
  662. data/share/guile/2.2/srfi/srfi-98.scm +44 -0
  663. data/share/guile/2.2/statprof.scm +988 -0
  664. data/share/guile/2.2/sxml/apply-templates.scm +102 -0
  665. data/share/guile/2.2/sxml/fold.scm +250 -0
  666. data/share/guile/2.2/sxml/match.scm +75 -0
  667. data/share/guile/2.2/sxml/simple.scm +408 -0
  668. data/share/guile/2.2/sxml/ssax/input-parse.scm +180 -0
  669. data/share/guile/2.2/sxml/ssax.scm +265 -0
  670. data/share/guile/2.2/sxml/sxml-match.ss +1181 -0
  671. data/share/guile/2.2/sxml/transform.scm +298 -0
  672. data/share/guile/2.2/sxml/upstream/SSAX.scm +3235 -0
  673. data/share/guile/2.2/sxml/upstream/SXML-tree-trans.scm +249 -0
  674. data/share/guile/2.2/sxml/upstream/SXPath-old.scm +1216 -0
  675. data/share/guile/2.2/sxml/upstream/assert.scm +35 -0
  676. data/share/guile/2.2/sxml/upstream/input-parse.scm +326 -0
  677. data/share/guile/2.2/sxml/xpath.scm +493 -0
  678. data/share/guile/2.2/system/base/ck.scm +55 -0
  679. data/share/guile/2.2/system/base/compile.scm +282 -0
  680. data/share/guile/2.2/system/base/lalr.scm +51 -0
  681. data/share/guile/2.2/system/base/lalr.upstream.scm +2096 -0
  682. data/share/guile/2.2/system/base/language.scm +119 -0
  683. data/share/guile/2.2/system/base/message.scm +238 -0
  684. data/share/guile/2.2/system/base/pmatch.scm +68 -0
  685. data/share/guile/2.2/system/base/syntax.scm +299 -0
  686. data/share/guile/2.2/system/base/target.scm +152 -0
  687. data/share/guile/2.2/system/base/types.scm +561 -0
  688. data/share/guile/2.2/system/foreign-object.scm +91 -0
  689. data/share/guile/2.2/system/foreign.scm +200 -0
  690. data/share/guile/2.2/system/repl/command.scm +946 -0
  691. data/share/guile/2.2/system/repl/common.scm +263 -0
  692. data/share/guile/2.2/system/repl/coop-server.scm +200 -0
  693. data/share/guile/2.2/system/repl/debug.scm +210 -0
  694. data/share/guile/2.2/system/repl/describe.scm +347 -0
  695. data/share/guile/2.2/system/repl/error-handling.scm +183 -0
  696. data/share/guile/2.2/system/repl/repl.scm +233 -0
  697. data/share/guile/2.2/system/repl/server.scm +332 -0
  698. data/share/guile/2.2/system/syntax.scm +33 -0
  699. data/share/guile/2.2/system/vm/assembler.scm +2614 -0
  700. data/share/guile/2.2/system/vm/coverage.scm +351 -0
  701. data/share/guile/2.2/system/vm/debug.scm +766 -0
  702. data/share/guile/2.2/system/vm/disassembler.scm +658 -0
  703. data/share/guile/2.2/system/vm/dwarf.scm +1852 -0
  704. data/share/guile/2.2/system/vm/elf.scm +1042 -0
  705. data/share/guile/2.2/system/vm/frame.scm +485 -0
  706. data/share/guile/2.2/system/vm/inspect.scm +188 -0
  707. data/share/guile/2.2/system/vm/linker.scm +732 -0
  708. data/share/guile/2.2/system/vm/loader.scm +27 -0
  709. data/share/guile/2.2/system/vm/program.scm +312 -0
  710. data/share/guile/2.2/system/vm/trace.scm +121 -0
  711. data/share/guile/2.2/system/vm/trap-state.scm +302 -0
  712. data/share/guile/2.2/system/vm/traps.scm +608 -0
  713. data/share/guile/2.2/system/vm/vm.scm +32 -0
  714. data/share/guile/2.2/system/xref.scm +369 -0
  715. data/share/guile/2.2/texinfo/docbook.scm +240 -0
  716. data/share/guile/2.2/texinfo/html.scm +279 -0
  717. data/share/guile/2.2/texinfo/indexing.scm +75 -0
  718. data/share/guile/2.2/texinfo/plain-text.scm +322 -0
  719. data/share/guile/2.2/texinfo/reflection.scm +585 -0
  720. data/share/guile/2.2/texinfo/serialize.scm +300 -0
  721. data/share/guile/2.2/texinfo/string-utils.scm +410 -0
  722. data/share/guile/2.2/texinfo.scm +1263 -0
  723. data/share/guile/2.2/web/client.scm +513 -0
  724. data/share/guile/2.2/web/http.scm +2043 -0
  725. data/share/guile/2.2/web/request.scm +326 -0
  726. data/share/guile/2.2/web/response.scm +379 -0
  727. data/share/guile/2.2/web/server/http.scm +183 -0
  728. data/share/guile/2.2/web/server.scm +397 -0
  729. data/share/guile/2.2/web/uri.scm +552 -0
  730. data/share/lilypond/2.24.1/fontconfig/0bd3dc0958fa2205aaaa8ebb13e2872b-le64.cache-8 +0 -0
  731. data/share/lilypond/2.24.1/fontconfig/188ac73a183f12857f63bb60a4a6d603-le64.cache-8 +0 -0
  732. data/share/lilypond/2.24.1/fontconfig/32b6488e5b8292a2e95c79d947e009e8-le64.cache-8 +0 -0
  733. data/share/lilypond/2.24.1/fontconfig/3830d5c3ddfd5cd38a049b759396e72e-le64.cache-8 +0 -0
  734. data/share/lilypond/2.24.1/fontconfig/3f7329c5293ffd510edef78f73874cfd-le64.cache-8 +0 -0
  735. data/share/lilypond/2.24.1/fontconfig/4c599c202bc5c08e2d34565a40eac3b2-le64.cache-8 +0 -0
  736. data/share/lilypond/2.24.1/fontconfig/57e423e26b20ab21d0f2f29c145174c3-le64.cache-8 +0 -0
  737. data/share/lilypond/2.24.1/fontconfig/7ef2298fde41cc6eeb7af42e48b7d293-le64.cache-8 +0 -0
  738. data/share/lilypond/2.24.1/fontconfig/826f6b6ef79022e2eac8af26bf4b62f2-le64.cache-8 +0 -0
  739. data/share/lilypond/2.24.1/fontconfig/945677eb7aeaf62f1d50efc3fb3ec7d8-le64.cache-8 +0 -0
  740. data/share/lilypond/2.24.1/fontconfig/95530828ff6c81d309f8258d8d02a23e-le64.cache-8 +0 -0
  741. data/share/lilypond/2.24.1/fontconfig/CACHEDIR.TAG +4 -0
  742. data/share/lilypond/2.24.1/fontconfig/bf3b770c553c462765856025a94f1ce6-le64.cache-8 +0 -0
  743. data/share/lilypond/2.24.1/fontconfig/c855463f699352c367813e37f3f70ea7-le64.cache-8 +0 -0
  744. data/share/lilypond/2.24.1/fontconfig/d3e5c4ee2ceb1fc347f91d4cefc53bc0-le64.cache-8 +0 -0
  745. data/share/lilypond/2.24.1/fontconfig/d589a48862398ed80a3d6066f4f56f4c-le64.cache-8 +0 -0
  746. data/share/lilypond/2.24.1/fontconfig/d82eb4fd963d448e2fcb7d7b793b5df3-le64.cache-8 +0 -0
  747. data/share/lilypond/2.24.1/fontconfig/e13b20fdb08344e0e664864cc2ede53d-le64.cache-8 +0 -0
  748. data/share/lilypond/2.24.1/fontconfig/e52a45a1c8c8fe895fc0fc8c4e6999b8-le64.cache-8 +0 -0
  749. data/share/lilypond/2.24.1/fontconfig/f1f2465696798768e9653f19e17ccdc8-le64.cache-8 +0 -0
  750. data/share/lilypond/2.24.1/fonts/00-lilypond-fonts.conf +99 -0
  751. data/share/lilypond/2.24.1/fonts/99-lilypond-fonts.conf +28 -0
  752. data/share/lilypond/2.24.1/fonts/otf/C059-BdIta.otf +0 -0
  753. data/share/lilypond/2.24.1/fonts/otf/C059-Bold.otf +0 -0
  754. data/share/lilypond/2.24.1/fonts/otf/C059-Italic.otf +0 -0
  755. data/share/lilypond/2.24.1/fonts/otf/C059-Roman.otf +0 -0
  756. data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Bold.otf +0 -0
  757. data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-BoldItalic.otf +0 -0
  758. data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Italic.otf +0 -0
  759. data/share/lilypond/2.24.1/fonts/otf/NimbusMonoPS-Regular.otf +0 -0
  760. data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Bold.otf +0 -0
  761. data/share/lilypond/2.24.1/fonts/otf/NimbusSans-BoldItalic.otf +0 -0
  762. data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Italic.otf +0 -0
  763. data/share/lilypond/2.24.1/fonts/otf/NimbusSans-Regular.otf +0 -0
  764. data/share/lilypond/2.24.1/fonts/otf/emmentaler-11.otf +0 -0
  765. data/share/lilypond/2.24.1/fonts/otf/emmentaler-13.otf +0 -0
  766. data/share/lilypond/2.24.1/fonts/otf/emmentaler-14.otf +0 -0
  767. data/share/lilypond/2.24.1/fonts/otf/emmentaler-16.otf +0 -0
  768. data/share/lilypond/2.24.1/fonts/otf/emmentaler-18.otf +0 -0
  769. data/share/lilypond/2.24.1/fonts/otf/emmentaler-20.otf +0 -0
  770. data/share/lilypond/2.24.1/fonts/otf/emmentaler-23.otf +0 -0
  771. data/share/lilypond/2.24.1/fonts/otf/emmentaler-26.otf +0 -0
  772. data/share/lilypond/2.24.1/fonts/otf/emmentaler-brace.otf +0 -0
  773. data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-bold.otf +0 -0
  774. data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-bolditalic.otf +0 -0
  775. data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-italic.otf +0 -0
  776. data/share/lilypond/2.24.1/fonts/otf/texgyrecursor-regular.otf +0 -0
  777. data/share/lilypond/2.24.1/fonts/otf/texgyreheros-bold.otf +0 -0
  778. data/share/lilypond/2.24.1/fonts/otf/texgyreheros-bolditalic.otf +0 -0
  779. data/share/lilypond/2.24.1/fonts/otf/texgyreheros-italic.otf +0 -0
  780. data/share/lilypond/2.24.1/fonts/otf/texgyreheros-regular.otf +0 -0
  781. data/share/lilypond/2.24.1/fonts/otf/texgyreschola-bold.otf +0 -0
  782. data/share/lilypond/2.24.1/fonts/otf/texgyreschola-bolditalic.otf +0 -0
  783. data/share/lilypond/2.24.1/fonts/otf/texgyreschola-italic.otf +0 -0
  784. data/share/lilypond/2.24.1/fonts/otf/texgyreschola-regular.otf +0 -0
  785. data/share/lilypond/2.24.1/fonts/source/common-modules-and-initialization.mf +26 -0
  786. data/share/lilypond/2.24.1/fonts/source/debugging-settings.mf +14 -0
  787. data/share/lilypond/2.24.1/fonts/source/declare-autometric-parameters.mf +9 -0
  788. data/share/lilypond/2.24.1/fonts/source/feta-accidentals.mf +58 -0
  789. data/share/lilypond/2.24.1/fonts/source/feta-accordion.mf +575 -0
  790. data/share/lilypond/2.24.1/fonts/source/feta-alphabet-generic.mf +16 -0
  791. data/share/lilypond/2.24.1/fonts/source/feta-alphabet11.mf +6 -0
  792. data/share/lilypond/2.24.1/fonts/source/feta-alphabet13.mf +6 -0
  793. data/share/lilypond/2.24.1/fonts/source/feta-alphabet14.mf +6 -0
  794. data/share/lilypond/2.24.1/fonts/source/feta-alphabet16.mf +6 -0
  795. data/share/lilypond/2.24.1/fonts/source/feta-alphabet18.mf +6 -0
  796. data/share/lilypond/2.24.1/fonts/source/feta-alphabet20.mf +6 -0
  797. data/share/lilypond/2.24.1/fonts/source/feta-alphabet23.mf +6 -0
  798. data/share/lilypond/2.24.1/fonts/source/feta-alphabet26.mf +6 -0
  799. data/share/lilypond/2.24.1/fonts/source/feta-arrow.mf +114 -0
  800. data/share/lilypond/2.24.1/fonts/source/feta-arrowheads.mf +171 -0
  801. data/share/lilypond/2.24.1/fonts/source/feta-autometric.mf +303 -0
  802. data/share/lilypond/2.24.1/fonts/source/feta-braces-a.mf +6 -0
  803. data/share/lilypond/2.24.1/fonts/source/feta-braces-b.mf +6 -0
  804. data/share/lilypond/2.24.1/fonts/source/feta-braces-c.mf +6 -0
  805. data/share/lilypond/2.24.1/fonts/source/feta-braces-d.mf +6 -0
  806. data/share/lilypond/2.24.1/fonts/source/feta-braces-e.mf +6 -0
  807. data/share/lilypond/2.24.1/fonts/source/feta-braces-f.mf +6 -0
  808. data/share/lilypond/2.24.1/fonts/source/feta-braces-g.mf +6 -0
  809. data/share/lilypond/2.24.1/fonts/source/feta-braces-generic.mf +47 -0
  810. data/share/lilypond/2.24.1/fonts/source/feta-braces-h.mf +6 -0
  811. data/share/lilypond/2.24.1/fonts/source/feta-braces-i.mf +6 -0
  812. data/share/lilypond/2.24.1/fonts/source/feta-braces.mf +125 -0
  813. data/share/lilypond/2.24.1/fonts/source/feta-brackettips.mf +100 -0
  814. data/share/lilypond/2.24.1/fonts/source/feta-clefs.mf +963 -0
  815. data/share/lilypond/2.24.1/fonts/source/feta-dots.mf +37 -0
  816. data/share/lilypond/2.24.1/fonts/source/feta-dynamics.mf +891 -0
  817. data/share/lilypond/2.24.1/fonts/source/feta-flags-generic.mf +17 -0
  818. data/share/lilypond/2.24.1/fonts/source/feta-flags.mf +926 -0
  819. data/share/lilypond/2.24.1/fonts/source/feta-flags11.mf +6 -0
  820. data/share/lilypond/2.24.1/fonts/source/feta-flags13.mf +6 -0
  821. data/share/lilypond/2.24.1/fonts/source/feta-flags14.mf +6 -0
  822. data/share/lilypond/2.24.1/fonts/source/feta-flags16.mf +6 -0
  823. data/share/lilypond/2.24.1/fonts/source/feta-flags18.mf +6 -0
  824. data/share/lilypond/2.24.1/fonts/source/feta-flags20.mf +6 -0
  825. data/share/lilypond/2.24.1/fonts/source/feta-flags23.mf +6 -0
  826. data/share/lilypond/2.24.1/fonts/source/feta-flags26.mf +6 -0
  827. data/share/lilypond/2.24.1/fonts/source/feta-flats.mf +668 -0
  828. data/share/lilypond/2.24.1/fonts/source/feta-macros.mf +506 -0
  829. data/share/lilypond/2.24.1/fonts/source/feta-naturals.mf +223 -0
  830. data/share/lilypond/2.24.1/fonts/source/feta-noteheads-generic.mf +17 -0
  831. data/share/lilypond/2.24.1/fonts/source/feta-noteheads.mf +2642 -0
  832. data/share/lilypond/2.24.1/fonts/source/feta-noteheads11.mf +6 -0
  833. data/share/lilypond/2.24.1/fonts/source/feta-noteheads13.mf +6 -0
  834. data/share/lilypond/2.24.1/fonts/source/feta-noteheads14.mf +6 -0
  835. data/share/lilypond/2.24.1/fonts/source/feta-noteheads16.mf +6 -0
  836. data/share/lilypond/2.24.1/fonts/source/feta-noteheads18.mf +6 -0
  837. data/share/lilypond/2.24.1/fonts/source/feta-noteheads20.mf +6 -0
  838. data/share/lilypond/2.24.1/fonts/source/feta-noteheads23.mf +6 -0
  839. data/share/lilypond/2.24.1/fonts/source/feta-noteheads26.mf +6 -0
  840. data/share/lilypond/2.24.1/fonts/source/feta-numbers.mf +1677 -0
  841. data/share/lilypond/2.24.1/fonts/source/feta-other-generic.mf +27 -0
  842. data/share/lilypond/2.24.1/fonts/source/feta-params.mf +323 -0
  843. data/share/lilypond/2.24.1/fonts/source/feta-parenthesis.mf +63 -0
  844. data/share/lilypond/2.24.1/fonts/source/feta-pedals.mf +355 -0
  845. data/share/lilypond/2.24.1/fonts/source/feta-rests.mf +890 -0
  846. data/share/lilypond/2.24.1/fonts/source/feta-scripts.mf +2206 -0
  847. data/share/lilypond/2.24.1/fonts/source/feta-sharps.mf +524 -0
  848. data/share/lilypond/2.24.1/fonts/source/feta-sori-koron.mf +325 -0
  849. data/share/lilypond/2.24.1/fonts/source/feta-ties.mf +72 -0
  850. data/share/lilypond/2.24.1/fonts/source/feta-timesignatures.mf +119 -0
  851. data/share/lilypond/2.24.1/fonts/source/feta-trills.mf +321 -0
  852. data/share/lilypond/2.24.1/fonts/source/feta11.mf +6 -0
  853. data/share/lilypond/2.24.1/fonts/source/feta13.mf +6 -0
  854. data/share/lilypond/2.24.1/fonts/source/feta14.mf +6 -0
  855. data/share/lilypond/2.24.1/fonts/source/feta16.mf +6 -0
  856. data/share/lilypond/2.24.1/fonts/source/feta18.mf +6 -0
  857. data/share/lilypond/2.24.1/fonts/source/feta20.mf +7 -0
  858. data/share/lilypond/2.24.1/fonts/source/feta23.mf +6 -0
  859. data/share/lilypond/2.24.1/fonts/source/feta26.mf +6 -0
  860. data/share/lilypond/2.24.1/fonts/source/parmesan-accidentals.mf +483 -0
  861. data/share/lilypond/2.24.1/fonts/source/parmesan-clefs.mf +1636 -0
  862. data/share/lilypond/2.24.1/fonts/source/parmesan-custodes.mf +503 -0
  863. data/share/lilypond/2.24.1/fonts/source/parmesan-dots.mf +62 -0
  864. data/share/lilypond/2.24.1/fonts/source/parmesan-flags.mf +319 -0
  865. data/share/lilypond/2.24.1/fonts/source/parmesan-macros.mf +225 -0
  866. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads-generic.mf +16 -0
  867. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads.mf +2191 -0
  868. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads11.mf +6 -0
  869. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads13.mf +6 -0
  870. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads14.mf +6 -0
  871. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads16.mf +6 -0
  872. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads18.mf +6 -0
  873. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads20.mf +6 -0
  874. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads23.mf +6 -0
  875. data/share/lilypond/2.24.1/fonts/source/parmesan-noteheads26.mf +6 -0
  876. data/share/lilypond/2.24.1/fonts/source/parmesan-other-generic.mf +24 -0
  877. data/share/lilypond/2.24.1/fonts/source/parmesan-rests.mf +428 -0
  878. data/share/lilypond/2.24.1/fonts/source/parmesan-scripts.mf +284 -0
  879. data/share/lilypond/2.24.1/fonts/source/parmesan-timesignatures.mf +402 -0
  880. data/share/lilypond/2.24.1/fonts/source/parmesan11.mf +6 -0
  881. data/share/lilypond/2.24.1/fonts/source/parmesan13.mf +6 -0
  882. data/share/lilypond/2.24.1/fonts/source/parmesan14.mf +6 -0
  883. data/share/lilypond/2.24.1/fonts/source/parmesan16.mf +6 -0
  884. data/share/lilypond/2.24.1/fonts/source/parmesan18.mf +6 -0
  885. data/share/lilypond/2.24.1/fonts/source/parmesan20.mf +6 -0
  886. data/share/lilypond/2.24.1/fonts/source/parmesan23.mf +6 -0
  887. data/share/lilypond/2.24.1/fonts/source/parmesan26.mf +6 -0
  888. data/share/lilypond/2.24.1/fonts/svg/emmentaler-11.svg +2525 -0
  889. data/share/lilypond/2.24.1/fonts/svg/emmentaler-11.woff +0 -0
  890. data/share/lilypond/2.24.1/fonts/svg/emmentaler-13.svg +2530 -0
  891. data/share/lilypond/2.24.1/fonts/svg/emmentaler-13.woff +0 -0
  892. data/share/lilypond/2.24.1/fonts/svg/emmentaler-14.svg +2526 -0
  893. data/share/lilypond/2.24.1/fonts/svg/emmentaler-14.woff +0 -0
  894. data/share/lilypond/2.24.1/fonts/svg/emmentaler-16.svg +2523 -0
  895. data/share/lilypond/2.24.1/fonts/svg/emmentaler-16.woff +0 -0
  896. data/share/lilypond/2.24.1/fonts/svg/emmentaler-18.svg +2519 -0
  897. data/share/lilypond/2.24.1/fonts/svg/emmentaler-18.woff +0 -0
  898. data/share/lilypond/2.24.1/fonts/svg/emmentaler-20.svg +2512 -0
  899. data/share/lilypond/2.24.1/fonts/svg/emmentaler-20.woff +0 -0
  900. data/share/lilypond/2.24.1/fonts/svg/emmentaler-23.svg +2506 -0
  901. data/share/lilypond/2.24.1/fonts/svg/emmentaler-23.woff +0 -0
  902. data/share/lilypond/2.24.1/fonts/svg/emmentaler-26.svg +2510 -0
  903. data/share/lilypond/2.24.1/fonts/svg/emmentaler-26.woff +0 -0
  904. data/share/lilypond/2.24.1/fonts/svg/emmentaler-brace.svg +1757 -0
  905. data/share/lilypond/2.24.1/fonts/svg/emmentaler-brace.woff +0 -0
  906. data/share/lilypond/2.24.1/ly/Welcome_to_LilyPond.ly +45 -0
  907. data/share/lilypond/2.24.1/ly/arabic.ly +185 -0
  908. data/share/lilypond/2.24.1/ly/articulate.ly +1013 -0
  909. data/share/lilypond/2.24.1/ly/bagpipe.ly +368 -0
  910. data/share/lilypond/2.24.1/ly/base-tkit.ly +135 -0
  911. data/share/lilypond/2.24.1/ly/catalan.ly +23 -0
  912. data/share/lilypond/2.24.1/ly/chord-modifiers-init.ly +63 -0
  913. data/share/lilypond/2.24.1/ly/chord-repetition-init.ly +60 -0
  914. data/share/lilypond/2.24.1/ly/context-mods-init.ly +119 -0
  915. data/share/lilypond/2.24.1/ly/declarations-init.ly +167 -0
  916. data/share/lilypond/2.24.1/ly/deutsch.ly +23 -0
  917. data/share/lilypond/2.24.1/ly/drumpitch-init.ly +366 -0
  918. data/share/lilypond/2.24.1/ly/dynamic-scripts-init.ly +54 -0
  919. data/share/lilypond/2.24.1/ly/english.ly +23 -0
  920. data/share/lilypond/2.24.1/ly/engraver-init.ly +1619 -0
  921. data/share/lilypond/2.24.1/ly/espanol.ly +23 -0
  922. data/share/lilypond/2.24.1/ly/event-listener.ly +241 -0
  923. data/share/lilypond/2.24.1/ly/festival.ly +38 -0
  924. data/share/lilypond/2.24.1/ly/generate-documentation.ly +7 -0
  925. data/share/lilypond/2.24.1/ly/grace-init.ly +56 -0
  926. data/share/lilypond/2.24.1/ly/graphviz-init.ly +174 -0
  927. data/share/lilypond/2.24.1/ly/gregorian.ly +268 -0
  928. data/share/lilypond/2.24.1/ly/guile-debugger.ly +55 -0
  929. data/share/lilypond/2.24.1/ly/hel-arabic.ly +307 -0
  930. data/share/lilypond/2.24.1/ly/init.ly +96 -0
  931. data/share/lilypond/2.24.1/ly/italiano.ly +23 -0
  932. data/share/lilypond/2.24.1/ly/lilypond-book-preamble.ly +47 -0
  933. data/share/lilypond/2.24.1/ly/lyrics-tkit.ly +68 -0
  934. data/share/lilypond/2.24.1/ly/makam.ly +166 -0
  935. data/share/lilypond/2.24.1/ly/midi-init.ly +59 -0
  936. data/share/lilypond/2.24.1/ly/music-functions-init.ly +2254 -0
  937. data/share/lilypond/2.24.1/ly/nederlands.ly +23 -0
  938. data/share/lilypond/2.24.1/ly/norsk.ly +23 -0
  939. data/share/lilypond/2.24.1/ly/paper-defaults-init.ly +188 -0
  940. data/share/lilypond/2.24.1/ly/performer-init.ly +398 -0
  941. data/share/lilypond/2.24.1/ly/persian.ly +335 -0
  942. data/share/lilypond/2.24.1/ly/piano-tkit.ly +61 -0
  943. data/share/lilypond/2.24.1/ly/portugues.ly +23 -0
  944. data/share/lilypond/2.24.1/ly/predefined-fretboards-init.ly +78 -0
  945. data/share/lilypond/2.24.1/ly/predefined-guitar-fretboards.ly +506 -0
  946. data/share/lilypond/2.24.1/ly/predefined-guitar-ninth-fretboards.ly +75 -0
  947. data/share/lilypond/2.24.1/ly/predefined-mandolin-fretboards.ly +876 -0
  948. data/share/lilypond/2.24.1/ly/predefined-ukulele-fretboards.ly +1285 -0
  949. data/share/lilypond/2.24.1/ly/property-init.ly +858 -0
  950. data/share/lilypond/2.24.1/ly/satb.ly +214 -0
  951. data/share/lilypond/2.24.1/ly/scale-definitions-init.ly +117 -0
  952. data/share/lilypond/2.24.1/ly/scheme-sandbox.ly +39 -0
  953. data/share/lilypond/2.24.1/ly/script-init.ly +94 -0
  954. data/share/lilypond/2.24.1/ly/spanners-init.ly +146 -0
  955. data/share/lilypond/2.24.1/ly/ssaattbb.ly +335 -0
  956. data/share/lilypond/2.24.1/ly/staff-tkit.ly +182 -0
  957. data/share/lilypond/2.24.1/ly/string-tunings-init.ly +94 -0
  958. data/share/lilypond/2.24.1/ly/suomi.ly +23 -0
  959. data/share/lilypond/2.24.1/ly/svenska.ly +23 -0
  960. data/share/lilypond/2.24.1/ly/swing.ly +362 -0
  961. data/share/lilypond/2.24.1/ly/text-replacements.ly +150 -0
  962. data/share/lilypond/2.24.1/ly/titling-init.ly +150 -0
  963. data/share/lilypond/2.24.1/ly/toc-init.ly +182 -0
  964. data/share/lilypond/2.24.1/ly/turkish-makam.ly +609 -0
  965. data/share/lilypond/2.24.1/ly/vlaams.ly +23 -0
  966. data/share/lilypond/2.24.1/ly/vocal-tkit.ly +103 -0
  967. data/share/lilypond/2.24.1/ly/voice-tkit.ly +34 -0
  968. data/share/lilypond/2.24.1/ps/encodingdefs.ps +2611 -0
  969. data/share/lilypond/2.24.1/ps/lilyponddefs.ps +49 -0
  970. data/share/lilypond/2.24.1/ps/music-drawing-routines.ps +329 -0
  971. data/share/lilypond/2.24.1/python/__pycache__/book_base.cpython-310.pyc +0 -0
  972. data/share/lilypond/2.24.1/python/__pycache__/book_docbook.cpython-310.pyc +0 -0
  973. data/share/lilypond/2.24.1/python/__pycache__/book_html.cpython-310.pyc +0 -0
  974. data/share/lilypond/2.24.1/python/__pycache__/book_latex.cpython-310.pyc +0 -0
  975. data/share/lilypond/2.24.1/python/__pycache__/book_snippets.cpython-310.pyc +0 -0
  976. data/share/lilypond/2.24.1/python/__pycache__/book_texinfo.cpython-310.pyc +0 -0
  977. data/share/lilypond/2.24.1/python/__pycache__/convertrules.cpython-310.pyc +0 -0
  978. data/share/lilypond/2.24.1/python/__pycache__/langdefs.cpython-310.pyc +0 -0
  979. data/share/lilypond/2.24.1/python/__pycache__/lilylib.cpython-310.pyc +0 -0
  980. data/share/lilypond/2.24.1/python/__pycache__/midi.cpython-310.pyc +0 -0
  981. data/share/lilypond/2.24.1/python/__pycache__/musicexp.cpython-310.pyc +0 -0
  982. data/share/lilypond/2.24.1/python/__pycache__/musicxml.cpython-310.pyc +0 -0
  983. data/share/lilypond/2.24.1/python/__pycache__/musicxml2ly_conversion.cpython-310.pyc +0 -0
  984. data/share/lilypond/2.24.1/python/__pycache__/utilities.cpython-310.pyc +0 -0
  985. data/share/lilypond/2.24.1/python/book_base.py +331 -0
  986. data/share/lilypond/2.24.1/python/book_docbook.py +154 -0
  987. data/share/lilypond/2.24.1/python/book_html.py +178 -0
  988. data/share/lilypond/2.24.1/python/book_latex.py +373 -0
  989. data/share/lilypond/2.24.1/python/book_snippets.py +1052 -0
  990. data/share/lilypond/2.24.1/python/book_texinfo.py +437 -0
  991. data/share/lilypond/2.24.1/python/convertrules.py +4764 -0
  992. data/share/lilypond/2.24.1/python/langdefs.py +131 -0
  993. data/share/lilypond/2.24.1/python/lilylib.py +141 -0
  994. data/share/lilypond/2.24.1/python/midi.py +212 -0
  995. data/share/lilypond/2.24.1/python/musicexp.py +2781 -0
  996. data/share/lilypond/2.24.1/python/musicxml.py +1905 -0
  997. data/share/lilypond/2.24.1/python/musicxml2ly_conversion.py +80 -0
  998. data/share/lilypond/2.24.1/python/utilities.py +280 -0
  999. data/share/lilypond/2.24.1/scm/lily/accreg.scm +579 -0
  1000. data/share/lilypond/2.24.1/scm/lily/auto-beam.scm +163 -0
  1001. data/share/lilypond/2.24.1/scm/lily/autochange.scm +100 -0
  1002. data/share/lilypond/2.24.1/scm/lily/backend-library.scm +593 -0
  1003. data/share/lilypond/2.24.1/scm/lily/bar-line.scm +1281 -0
  1004. data/share/lilypond/2.24.1/scm/lily/breath.scm +74 -0
  1005. data/share/lilypond/2.24.1/scm/lily/c++.scm +174 -0
  1006. data/share/lilypond/2.24.1/scm/lily/chord-entry.scm +278 -0
  1007. data/share/lilypond/2.24.1/scm/lily/chord-ignatzek-names.scm +304 -0
  1008. data/share/lilypond/2.24.1/scm/lily/chord-name.scm +217 -0
  1009. data/share/lilypond/2.24.1/scm/lily/clip-region.scm +87 -0
  1010. data/share/lilypond/2.24.1/scm/lily/color.scm +757 -0
  1011. data/share/lilypond/2.24.1/scm/lily/curried-definitions.scm +68 -0
  1012. data/share/lilypond/2.24.1/scm/lily/define-context-properties.scm +939 -0
  1013. data/share/lilypond/2.24.1/scm/lily/define-event-classes.scm +142 -0
  1014. data/share/lilypond/2.24.1/scm/lily/define-grob-interfaces.scm +640 -0
  1015. data/share/lilypond/2.24.1/scm/lily/define-grob-properties.scm +1647 -0
  1016. data/share/lilypond/2.24.1/scm/lily/define-grobs.scm +4027 -0
  1017. data/share/lilypond/2.24.1/scm/lily/define-markup-commands.scm +5737 -0
  1018. data/share/lilypond/2.24.1/scm/lily/define-music-callbacks.scm +257 -0
  1019. data/share/lilypond/2.24.1/scm/lily/define-music-display-methods.scm +1350 -0
  1020. data/share/lilypond/2.24.1/scm/lily/define-music-properties.scm +242 -0
  1021. data/share/lilypond/2.24.1/scm/lily/define-music-types.scm +983 -0
  1022. data/share/lilypond/2.24.1/scm/lily/define-note-names.scm +1421 -0
  1023. data/share/lilypond/2.24.1/scm/lily/define-stencil-commands.scm +71 -0
  1024. data/share/lilypond/2.24.1/scm/lily/define-woodwind-diagrams.scm +1215 -0
  1025. data/share/lilypond/2.24.1/scm/lily/display-lily.scm +315 -0
  1026. data/share/lilypond/2.24.1/scm/lily/display-woodwind-diagrams.scm +1985 -0
  1027. data/share/lilypond/2.24.1/scm/lily/document-backend.scm +307 -0
  1028. data/share/lilypond/2.24.1/scm/lily/document-context-mods.scm +98 -0
  1029. data/share/lilypond/2.24.1/scm/lily/document-functions.scm +169 -0
  1030. data/share/lilypond/2.24.1/scm/lily/document-identifiers.scm +76 -0
  1031. data/share/lilypond/2.24.1/scm/lily/document-markup.scm +158 -0
  1032. data/share/lilypond/2.24.1/scm/lily/document-music.scm +146 -0
  1033. data/share/lilypond/2.24.1/scm/lily/document-outside-staff-priorities.scm +40 -0
  1034. data/share/lilypond/2.24.1/scm/lily/document-paper-sizes.scm +71 -0
  1035. data/share/lilypond/2.24.1/scm/lily/document-translation.scm +318 -0
  1036. data/share/lilypond/2.24.1/scm/lily/document-type-predicates.scm +85 -0
  1037. data/share/lilypond/2.24.1/scm/lily/documentation-generate.scm +259 -0
  1038. data/share/lilypond/2.24.1/scm/lily/documentation-lib.scm +207 -0
  1039. data/share/lilypond/2.24.1/scm/lily/file-cache.scm +28 -0
  1040. data/share/lilypond/2.24.1/scm/lily/flag-styles.scm +249 -0
  1041. data/share/lilypond/2.24.1/scm/lily/font-encodings.scm +1242 -0
  1042. data/share/lilypond/2.24.1/scm/lily/font.scm +303 -0
  1043. data/share/lilypond/2.24.1/scm/lily/framework-cairo.scm +26 -0
  1044. data/share/lilypond/2.24.1/scm/lily/framework-ps.scm +896 -0
  1045. data/share/lilypond/2.24.1/scm/lily/framework-svg.scm +172 -0
  1046. data/share/lilypond/2.24.1/scm/lily/fret-diagrams.scm +1261 -0
  1047. data/share/lilypond/2.24.1/scm/lily/graphviz.scm +78 -0
  1048. data/share/lilypond/2.24.1/scm/lily/guile-debugger.scm +90 -0
  1049. data/share/lilypond/2.24.1/scm/lily/harp-pedals.scm +172 -0
  1050. data/share/lilypond/2.24.1/scm/lily/hyphenate-internal-words.scm +51 -0
  1051. data/share/lilypond/2.24.1/scm/lily/layout-beam.scm +73 -0
  1052. data/share/lilypond/2.24.1/scm/lily/layout-slur.scm +45 -0
  1053. data/share/lilypond/2.24.1/scm/lily/lily-library.scm +1446 -0
  1054. data/share/lilypond/2.24.1/scm/lily/lily-sort.scm +116 -0
  1055. data/share/lilypond/2.24.1/scm/lily/lily.scm +929 -0
  1056. data/share/lilypond/2.24.1/scm/lily/ly-syntax-constructors.scm +374 -0
  1057. data/share/lilypond/2.24.1/scm/lily/markup-macros.scm +493 -0
  1058. data/share/lilypond/2.24.1/scm/lily/markup.scm +126 -0
  1059. data/share/lilypond/2.24.1/scm/lily/midi.scm +258 -0
  1060. data/share/lilypond/2.24.1/scm/lily/modal-transforms.scm +337 -0
  1061. data/share/lilypond/2.24.1/scm/lily/music-functions.scm +2878 -0
  1062. data/share/lilypond/2.24.1/scm/lily/output-lib.scm +3377 -0
  1063. data/share/lilypond/2.24.1/scm/lily/output-ps.scm +335 -0
  1064. data/share/lilypond/2.24.1/scm/lily/output-svg.scm +684 -0
  1065. data/share/lilypond/2.24.1/scm/lily/page.scm +321 -0
  1066. data/share/lilypond/2.24.1/scm/lily/paper-system.scm +271 -0
  1067. data/share/lilypond/2.24.1/scm/lily/paper.scm +376 -0
  1068. data/share/lilypond/2.24.1/scm/lily/parser-clef.scm +205 -0
  1069. data/share/lilypond/2.24.1/scm/lily/parser-ly-from-scheme.scm +170 -0
  1070. data/share/lilypond/2.24.1/scm/lily/part-combiner.scm +998 -0
  1071. data/share/lilypond/2.24.1/scm/lily/predefined-fretboards.scm +54 -0
  1072. data/share/lilypond/2.24.1/scm/lily/ps-to-png.scm +182 -0
  1073. data/share/lilypond/2.24.1/scm/lily/scheme-engravers.scm +1813 -0
  1074. data/share/lilypond/2.24.1/scm/lily/scheme-performers.scm +126 -0
  1075. data/share/lilypond/2.24.1/scm/lily/script.scm +416 -0
  1076. data/share/lilypond/2.24.1/scm/lily/skyline.scm +25 -0
  1077. data/share/lilypond/2.24.1/scm/lily/song-util.scm +191 -0
  1078. data/share/lilypond/2.24.1/scm/lily/song.scm +853 -0
  1079. data/share/lilypond/2.24.1/scm/lily/stencil.scm +998 -0
  1080. data/share/lilypond/2.24.1/scm/lily/tablature.scm +392 -0
  1081. data/share/lilypond/2.24.1/scm/lily/time-signature-settings.scm +473 -0
  1082. data/share/lilypond/2.24.1/scm/lily/time-signature.scm +35 -0
  1083. data/share/lilypond/2.24.1/scm/lily/titling.scm +99 -0
  1084. data/share/lilypond/2.24.1/scm/lily/to-xml.scm +254 -0
  1085. data/share/lilypond/2.24.1/scm/lily/translation-functions.scm +1169 -0
  1086. data/share/lilypond/2.24.1/vim/compiler/lilypond.vim +36 -0
  1087. data/share/lilypond/2.24.1/vim/ftdetect/lilypond.vim +4 -0
  1088. data/share/lilypond/2.24.1/vim/ftplugin/lilypond.vim +91 -0
  1089. data/share/lilypond/2.24.1/vim/indent/lilypond.vim +79 -0
  1090. data/share/lilypond/2.24.1/vim/syntax/lilypond-words +1408 -0
  1091. data/share/lilypond/2.24.1/vim/syntax/lilypond-words.vim +3 -0
  1092. data/share/lilypond/2.24.1/vim/syntax/lilypond.vim +104 -0
  1093. data/share/locale/ca/LC_MESSAGES/lilypond.mo +0 -0
  1094. data/share/locale/cs/LC_MESSAGES/lilypond.mo +0 -0
  1095. data/share/locale/da/LC_MESSAGES/lilypond.mo +0 -0
  1096. data/share/locale/de/LC_MESSAGES/lilypond.mo +0 -0
  1097. data/share/locale/el/LC_MESSAGES/lilypond.mo +0 -0
  1098. data/share/locale/eo/LC_MESSAGES/lilypond.mo +0 -0
  1099. data/share/locale/es/LC_MESSAGES/lilypond.mo +0 -0
  1100. data/share/locale/fi/LC_MESSAGES/lilypond.mo +0 -0
  1101. data/share/locale/fr/LC_MESSAGES/lilypond.mo +0 -0
  1102. data/share/locale/it/LC_MESSAGES/lilypond.mo +0 -0
  1103. data/share/locale/ja/LC_MESSAGES/lilypond.mo +0 -0
  1104. data/share/locale/nl/LC_MESSAGES/lilypond.mo +0 -0
  1105. data/share/locale/ru/LC_MESSAGES/lilypond.mo +0 -0
  1106. data/share/locale/sv/LC_MESSAGES/lilypond.mo +0 -0
  1107. data/share/locale/tr/LC_MESSAGES/lilypond.mo +0 -0
  1108. data/share/locale/uk/LC_MESSAGES/lilypond.mo +0 -0
  1109. data/share/locale/vi/LC_MESSAGES/lilypond.mo +0 -0
  1110. data/share/locale/zh_CN/LC_MESSAGES/lilypond.mo +0 -0
  1111. data/share/locale/zh_TW/LC_MESSAGES/lilypond.mo +0 -0
  1112. metadata +1135 -4
@@ -0,0 +1,1470 @@
1
+ ;;; srfi-19.scm --- Time/Date Library
2
+
3
+ ;; Copyright (C) 2001-2003, 2005-2011, 2014, 2016-2018
4
+ ;; Free Software Foundation, Inc.
5
+ ;;
6
+ ;; This library is free software; you can redistribute it and/or
7
+ ;; modify it under the terms of the GNU Lesser General Public
8
+ ;; License as published by the Free Software Foundation; either
9
+ ;; version 3 of the License, or (at your option) any later version.
10
+ ;;
11
+ ;; This library is distributed in the hope that it will be useful,
12
+ ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
13
+ ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14
+ ;; Lesser General Public License for more details.
15
+ ;;
16
+ ;; You should have received a copy of the GNU Lesser General Public
17
+ ;; License along with this library; if not, write to the Free Software
18
+ ;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
19
+
20
+ ;;; Author: Rob Browning <rlb@cs.utexas.edu>
21
+ ;;; Originally from SRFI reference implementation by Will Fitzgerald.
22
+
23
+ ;;; Commentary:
24
+
25
+ ;; This module is fully documented in the Guile Reference Manual.
26
+
27
+ ;;; Code:
28
+
29
+ ;; FIXME: I haven't checked a decent amount of this code for potential
30
+ ;; performance improvements, but I suspect that there may be some
31
+ ;; substantial ones to be realized, esp. in the later "parsing" half
32
+ ;; of the file, by rewriting the code with use of more Guile native
33
+ ;; functions that do more work in a "chunk".
34
+ ;;
35
+ ;; FIXME: mkoeppe: Time zones are treated a little simplistic in
36
+ ;; SRFI-19; they are only a numeric offset. Thus, printing time zones
37
+ ;; (LOCALE-PRINT-TIME-ZONE) can't be implemented sensibly. The
38
+ ;; functions taking an optional TZ-OFFSET should be extended to take a
39
+ ;; symbolic time-zone (like "CET"); this string should be stored in
40
+ ;; the DATE structure.
41
+
42
+ (define-module (srfi srfi-19)
43
+ #:use-module (srfi srfi-1)
44
+ #:use-module (srfi srfi-6)
45
+ #:use-module (srfi srfi-8)
46
+ #:use-module (srfi srfi-9)
47
+ #:autoload (ice-9 rdelim) (read-line)
48
+ #:use-module (ice-9 i18n)
49
+ #:replace (current-time)
50
+ #:export (;; Constants
51
+ time-duration
52
+ time-monotonic
53
+ time-process
54
+ time-tai
55
+ time-thread
56
+ time-utc
57
+ ;; Current time and clock resolution
58
+ current-date
59
+ current-julian-day
60
+ current-modified-julian-day
61
+ time-resolution
62
+ ;; Time object and accessors
63
+ make-time
64
+ time?
65
+ time-type
66
+ time-nanosecond
67
+ time-second
68
+ set-time-type!
69
+ set-time-nanosecond!
70
+ set-time-second!
71
+ copy-time
72
+ ;; Time comparison procedures
73
+ time<=?
74
+ time<?
75
+ time=?
76
+ time>=?
77
+ time>?
78
+ ;; Time arithmetic procedures
79
+ time-difference
80
+ time-difference!
81
+ add-duration
82
+ add-duration!
83
+ subtract-duration
84
+ subtract-duration!
85
+ ;; Date object and accessors
86
+ make-date
87
+ date?
88
+ date-nanosecond
89
+ date-second
90
+ date-minute
91
+ date-hour
92
+ date-day
93
+ date-month
94
+ date-year
95
+ date-zone-offset
96
+ date-year-day
97
+ date-week-day
98
+ date-week-number
99
+ ;; Time/Date/Julian Day/Modified Julian Day converters
100
+ date->julian-day
101
+ date->modified-julian-day
102
+ date->time-monotonic
103
+ date->time-tai
104
+ date->time-utc
105
+ julian-day->date
106
+ julian-day->time-monotonic
107
+ julian-day->time-tai
108
+ julian-day->time-utc
109
+ modified-julian-day->date
110
+ modified-julian-day->time-monotonic
111
+ modified-julian-day->time-tai
112
+ modified-julian-day->time-utc
113
+ time-monotonic->date
114
+ time-monotonic->julian-day
115
+ time-monotonic->modified-julian-day
116
+ time-monotonic->time-tai
117
+ time-monotonic->time-tai!
118
+ time-monotonic->time-utc
119
+ time-monotonic->time-utc!
120
+ time-tai->date
121
+ time-tai->julian-day
122
+ time-tai->modified-julian-day
123
+ time-tai->time-monotonic
124
+ time-tai->time-monotonic!
125
+ time-tai->time-utc
126
+ time-tai->time-utc!
127
+ time-utc->date
128
+ time-utc->julian-day
129
+ time-utc->modified-julian-day
130
+ time-utc->time-monotonic
131
+ time-utc->time-monotonic!
132
+ time-utc->time-tai
133
+ time-utc->time-tai!
134
+ ;; Date to string/string to date converters.
135
+ date->string
136
+ string->date))
137
+
138
+ (cond-expand-provide (current-module) '(srfi-19))
139
+
140
+ (define time-tai 'time-tai)
141
+ (define time-utc 'time-utc)
142
+ (define time-monotonic 'time-monotonic)
143
+ (define time-thread 'time-thread)
144
+ (define time-process 'time-process)
145
+ (define time-duration 'time-duration)
146
+
147
+ ;; FIXME: do we want to add gc time?
148
+ ;; (define time-gc 'time-gc)
149
+
150
+ ;;-- LOCALE dependent constants
151
+
152
+ ;; See date->string
153
+ (define locale-date-time-format "~a ~b ~d ~H:~M:~S~z ~Y")
154
+ (define locale-short-date-format "~m/~d/~y")
155
+ (define locale-time-format "~H:~M:~S")
156
+ (define iso-8601-date-time-format "~Y-~m-~dT~H:~M:~S~z")
157
+
158
+ ;;-- Miscellaneous Constants.
159
+ ;;-- only the utc-epoch-in-jd might need changing if
160
+ ;; a different epoch is used.
161
+
162
+ (define nano 1000000000) ; nanoseconds in a second
163
+ (define sid 86400) ; seconds in a day
164
+ (define sihd 43200) ; seconds in a half day
165
+ (define utc-epoch-in-jd 4881175/2) ; julian day number for 'the epoch'
166
+
167
+ ;; FIXME: should this be something other than misc-error?
168
+ (define (time-error caller type value)
169
+ (if value
170
+ (throw 'misc-error caller "TIME-ERROR type ~A: ~S" (list type value) #f)
171
+ (throw 'misc-error caller "TIME-ERROR type ~A" (list type) #f)))
172
+
173
+ ;; A table of leap seconds
174
+ ;; See ftp://maia.usno.navy.mil/ser7/tai-utc.dat
175
+ ;; and update as necessary.
176
+ ;; this procedures reads the file in the above
177
+ ;; format and creates the leap second table
178
+ ;; it also calls the almost standard, but not R5 procedures read-line
179
+ ;; & open-input-string
180
+ ;; ie (set! leap-second-table (read-tai-utc-date "tai-utc.dat"))
181
+
182
+ (define (read-tai-utc-data filename)
183
+ (define (convert-jd jd)
184
+ (* (- (inexact->exact jd) utc-epoch-in-jd) sid))
185
+ (define (convert-sec sec)
186
+ (inexact->exact sec))
187
+ (let ((port (open-input-file filename))
188
+ (table '()))
189
+ (let loop ((line (read-line port)))
190
+ (if (not (eof-object? line))
191
+ (begin
192
+ (let* ((data (read (open-input-string
193
+ (string-append "(" line ")"))))
194
+ (year (car data))
195
+ (jd (cadddr (cdr data)))
196
+ (secs (cadddr (cdddr data))))
197
+ (if (>= year 1972)
198
+ (set! table (cons
199
+ (cons (convert-jd jd) (convert-sec secs))
200
+ table)))
201
+ (loop (read-line port))))))
202
+ table))
203
+
204
+ ;; each entry is (tai seconds since epoch . # seconds to subtract for utc)
205
+ ;; note they go higher to lower, and end in 1972.
206
+ (define leap-second-table
207
+ '((1483228800 . 37)
208
+ (1435708800 . 36)
209
+ (1341100800 . 35)
210
+ (1230768000 . 34)
211
+ (1136073600 . 33)
212
+ (915148800 . 32)
213
+ (867715200 . 31)
214
+ (820454400 . 30)
215
+ (773020800 . 29)
216
+ (741484800 . 28)
217
+ (709948800 . 27)
218
+ (662688000 . 26)
219
+ (631152000 . 25)
220
+ (567993600 . 24)
221
+ (489024000 . 23)
222
+ (425865600 . 22)
223
+ (394329600 . 21)
224
+ (362793600 . 20)
225
+ (315532800 . 19)
226
+ (283996800 . 18)
227
+ (252460800 . 17)
228
+ (220924800 . 16)
229
+ (189302400 . 15)
230
+ (157766400 . 14)
231
+ (126230400 . 13)
232
+ (94694400 . 12)
233
+ (78796800 . 11)
234
+ (63072000 . 10)))
235
+
236
+ (define (read-leap-second-table filename)
237
+ (set! leap-second-table (read-tai-utc-data filename)))
238
+
239
+
240
+ (define (utc->tai utc-seconds)
241
+ (let loop ((table leap-second-table))
242
+ (cond ((null? table)
243
+ utc-seconds)
244
+ ((>= utc-seconds (caar table))
245
+ (+ utc-seconds (cdar table)))
246
+ (else
247
+ (loop (cdr table))))))
248
+
249
+ (define (tai->utc tai-seconds)
250
+ (let loop ((table leap-second-table))
251
+ (cond ((null? table)
252
+ tai-seconds)
253
+ ((>= tai-seconds (+ (caar table) (cdar table)))
254
+ (- tai-seconds (cdar table)))
255
+ (else
256
+ (loop (cdr table))))))
257
+
258
+
259
+ ;;; the TIME structure; creates the accessors, too.
260
+
261
+ (define-record-type time
262
+ (make-time-unnormalized type nanosecond second)
263
+ time?
264
+ (type time-type set-time-type!)
265
+ (nanosecond time-nanosecond set-time-nanosecond!)
266
+ (second time-second set-time-second!))
267
+
268
+ (define (copy-time time)
269
+ (make-time (time-type time) (time-nanosecond time) (time-second time)))
270
+
271
+ (define (split-real r)
272
+ (if (integer? r)
273
+ (values (inexact->exact r) 0)
274
+ (let ((l (truncate r)))
275
+ (values (inexact->exact l) (- r l)))))
276
+
277
+ (define (time-normalize! t)
278
+ (let ((s (time-second t))
279
+ (ns (time-nanosecond t)))
280
+ (when (>= (abs (time-nanosecond t))
281
+ nano)
282
+ (let ((s* (+ s (inexact->exact
283
+ (truncate-quotient ns nano))))
284
+ (ns* (truncate-remainder ns nano)))
285
+ (set-time-second! t s*)
286
+ (set-time-nanosecond! t ns*)))
287
+ (cond ((and (positive? s) (negative? ns))
288
+ (set-time-second! t (- s 1))
289
+ (set-time-nanosecond! t (+ ns nano)))
290
+ ((and (negative? s) (positive? ns))
291
+ (set-time-second! t (+ s 1))
292
+ (set-time-nanosecond! t (- ns nano))))
293
+ t))
294
+
295
+ (define (make-time type nanosecond second)
296
+ (time-normalize! (make-time-unnormalized type nanosecond second)))
297
+
298
+ ;;; current-time
299
+
300
+ ;;; specific time getters.
301
+
302
+ (define (current-time-utc)
303
+ ;; Resolution is microseconds.
304
+ (let ((tod (gettimeofday)))
305
+ (make-time time-utc (* (cdr tod) 1000) (car tod))))
306
+
307
+ (define (current-time-tai)
308
+ ;; Resolution is microseconds.
309
+ (let* ((tod (gettimeofday))
310
+ (sec (car tod))
311
+ (usec (cdr tod)))
312
+ (make-time time-tai
313
+ (* usec 1000)
314
+ (utc->tai sec))))
315
+
316
+ ;;(define (current-time-ms-time time-type proc)
317
+ ;; (let ((current-ms (proc)))
318
+ ;; (make-time time-type
319
+ ;; (quotient current-ms 10000)
320
+ ;; (* (remainder current-ms 1000) 10000))))
321
+
322
+ ;; -- we define it to be the same as TAI.
323
+ ;; A different implemention of current-time-monotonic
324
+ ;; will require rewriting all of the time-monotonic converters,
325
+ ;; of course.
326
+
327
+ (define (current-time-monotonic)
328
+ ;; Guile monotonic and TAI times are the same.
329
+ (let ((tai (current-time-tai)))
330
+ (make-time time-monotonic
331
+ (time-nanosecond tai)
332
+ (time-second tai))))
333
+
334
+ (define (current-time-thread)
335
+ (time-error 'current-time-thread 'unsupported-clock-type 'time-thread))
336
+
337
+ (define ns-per-guile-tick (/ 1000000000 internal-time-units-per-second))
338
+
339
+ (define (current-time-process)
340
+ (let ((run-time (get-internal-run-time)))
341
+ (make-time
342
+ time-process
343
+ (* (remainder run-time internal-time-units-per-second)
344
+ ns-per-guile-tick)
345
+ (quotient run-time internal-time-units-per-second))))
346
+
347
+ ;;(define (current-time-gc)
348
+ ;; (current-time-ms-time time-gc current-gc-milliseconds))
349
+
350
+ (define (current-time . clock-type)
351
+ (let ((clock-type (if (null? clock-type) time-utc (car clock-type))))
352
+ (cond
353
+ ((eq? clock-type time-tai) (current-time-tai))
354
+ ((eq? clock-type time-utc) (current-time-utc))
355
+ ((eq? clock-type time-monotonic) (current-time-monotonic))
356
+ ((eq? clock-type time-thread) (current-time-thread))
357
+ ((eq? clock-type time-process) (current-time-process))
358
+ ;; ((eq? clock-type time-gc) (current-time-gc))
359
+ (else (time-error 'current-time 'invalid-clock-type clock-type)))))
360
+
361
+ ;; -- Time Resolution
362
+ ;; This is the resolution of the clock in nanoseconds.
363
+ ;; This will be implementation specific.
364
+
365
+ (define (time-resolution . clock-type)
366
+ (let ((clock-type (if (null? clock-type) time-utc (car clock-type))))
367
+ (case clock-type
368
+ ((time-tai) 1000)
369
+ ((time-utc) 1000)
370
+ ((time-monotonic) 1000)
371
+ ((time-process) ns-per-guile-tick)
372
+ ;; ((eq? clock-type time-thread) 1000)
373
+ ;; ((eq? clock-type time-gc) 10000)
374
+ (else (time-error 'time-resolution 'invalid-clock-type clock-type)))))
375
+
376
+ ;; -- Time comparisons
377
+
378
+ (define (time-compare-check t1 t2 caller)
379
+ (unless (and (time? t1) (time? t2)
380
+ (eq? (time-type t1) (time-type t2)))
381
+ (time-error caller 'incompatible-time-types (cons t1 t2))))
382
+
383
+ (define (time=? t1 t2)
384
+ ;; Arrange tests for speed and presume that t1 and t2 are actually times.
385
+ ;; also presume it will be rare to check two times of different types.
386
+ (time-compare-check t1 t2 'time=?)
387
+ (and (= (time-second t1) (time-second t2))
388
+ (= (time-nanosecond t1) (time-nanosecond t2))))
389
+
390
+ (define (time>? t1 t2)
391
+ (time-compare-check t1 t2 'time>?)
392
+ (or (> (time-second t1) (time-second t2))
393
+ (and (= (time-second t1) (time-second t2))
394
+ (> (time-nanosecond t1) (time-nanosecond t2)))))
395
+
396
+ (define (time<? t1 t2)
397
+ (time-compare-check t1 t2 'time<?)
398
+ (or (< (time-second t1) (time-second t2))
399
+ (and (= (time-second t1) (time-second t2))
400
+ (< (time-nanosecond t1) (time-nanosecond t2)))))
401
+
402
+ (define (time>=? t1 t2)
403
+ (time-compare-check t1 t2 'time>=?)
404
+ (or (> (time-second t1) (time-second t2))
405
+ (and (= (time-second t1) (time-second t2))
406
+ (>= (time-nanosecond t1) (time-nanosecond t2)))))
407
+
408
+ (define (time<=? t1 t2)
409
+ (time-compare-check t1 t2 'time<=?)
410
+ (or (< (time-second t1) (time-second t2))
411
+ (and (= (time-second t1) (time-second t2))
412
+ (<= (time-nanosecond t1) (time-nanosecond t2)))))
413
+
414
+ ;; -- Time arithmetic
415
+
416
+ ;; XXX In the following comparison procedures, the SRFI-19 reference
417
+ ;; implementation raises an error in case of unequal time types.
418
+
419
+ (define (time-difference! time1 time2)
420
+ (time-compare-check time1 time2 'time-difference!)
421
+ (let ((sec-diff (- (time-second time1) (time-second time2)))
422
+ (nsec-diff (- (time-nanosecond time1) (time-nanosecond time2))))
423
+ (set-time-type! time1 time-duration)
424
+ (set-time-second! time1 sec-diff)
425
+ (set-time-nanosecond! time1 nsec-diff)
426
+ (time-normalize! time1)))
427
+
428
+ (define (time-difference time1 time2)
429
+ (let ((result (copy-time time1)))
430
+ (time-difference! result time2)))
431
+
432
+ (define (add-duration! t duration)
433
+ (if (not (eq? (time-type duration) time-duration))
434
+ (time-error 'add-duration! 'not-duration duration)
435
+ (let ((sec-plus (+ (time-second t) (time-second duration)))
436
+ (nsec-plus (+ (time-nanosecond t) (time-nanosecond duration))))
437
+ (set-time-second! t sec-plus)
438
+ (set-time-nanosecond! t nsec-plus)
439
+ (time-normalize! t))))
440
+
441
+ (define (add-duration t duration)
442
+ (let ((result (copy-time t)))
443
+ (add-duration! result duration)))
444
+
445
+ (define (subtract-duration! t duration)
446
+ (if (not (eq? (time-type duration) time-duration))
447
+ (time-error 'subtract-duration! 'not-duration duration)
448
+ (let ((sec-minus (- (time-second t) (time-second duration)))
449
+ (nsec-minus (- (time-nanosecond t) (time-nanosecond duration))))
450
+ (set-time-second! t sec-minus)
451
+ (set-time-nanosecond! t nsec-minus)
452
+ (time-normalize! t))))
453
+
454
+ (define (subtract-duration time1 duration)
455
+ (let ((result (copy-time time1)))
456
+ (subtract-duration! result duration)))
457
+
458
+ ;; -- Converters between types.
459
+
460
+ (define (priv:time-tai->time-utc! time-in time-out caller)
461
+ (if (not (eq? (time-type time-in) time-tai))
462
+ (time-error caller 'incompatible-time-types time-in))
463
+ (set-time-type! time-out time-utc)
464
+ (set-time-nanosecond! time-out (time-nanosecond time-in))
465
+ (set-time-second! time-out (tai->utc (time-second time-in)))
466
+ time-out)
467
+
468
+ (define (time-tai->time-utc time-in)
469
+ (priv:time-tai->time-utc! time-in (make-time-unnormalized #f #f #f) 'time-tai->time-utc))
470
+
471
+
472
+ (define (time-tai->time-utc! time-in)
473
+ (priv:time-tai->time-utc! time-in time-in 'time-tai->time-utc!))
474
+
475
+ (define (priv:time-utc->time-tai! time-in time-out caller)
476
+ (if (not (eq? (time-type time-in) time-utc))
477
+ (time-error caller 'incompatible-time-types time-in))
478
+ (set-time-type! time-out time-tai)
479
+ (set-time-nanosecond! time-out (time-nanosecond time-in))
480
+ (set-time-second! time-out (utc->tai (time-second time-in)))
481
+ time-out)
482
+
483
+ (define (time-utc->time-tai time-in)
484
+ (priv:time-utc->time-tai! time-in (make-time-unnormalized #f #f #f) 'time-utc->time-tai))
485
+
486
+ (define (time-utc->time-tai! time-in)
487
+ (priv:time-utc->time-tai! time-in time-in 'time-utc->time-tai!))
488
+
489
+ ;; -- these depend on time-monotonic having the same definition as time-tai!
490
+ (define (time-monotonic->time-utc time-in)
491
+ (if (not (eq? (time-type time-in) time-monotonic))
492
+ (time-error 'time-monotonic->time-utc
493
+ 'incompatible-time-types time-in))
494
+ (let ((ntime (copy-time time-in)))
495
+ (set-time-type! ntime time-tai)
496
+ (priv:time-tai->time-utc! ntime ntime 'time-monotonic->time-utc)))
497
+
498
+ (define (time-monotonic->time-utc! time-in)
499
+ (if (not (eq? (time-type time-in) time-monotonic))
500
+ (time-error 'time-monotonic->time-utc!
501
+ 'incompatible-time-types time-in))
502
+ (set-time-type! time-in time-tai)
503
+ (priv:time-tai->time-utc! time-in time-in 'time-monotonic->time-utc))
504
+
505
+ (define (time-monotonic->time-tai time-in)
506
+ (if (not (eq? (time-type time-in) time-monotonic))
507
+ (time-error 'time-monotonic->time-tai
508
+ 'incompatible-time-types time-in))
509
+ (let ((ntime (copy-time time-in)))
510
+ (set-time-type! ntime time-tai)
511
+ ntime))
512
+
513
+ (define (time-monotonic->time-tai! time-in)
514
+ (if (not (eq? (time-type time-in) time-monotonic))
515
+ (time-error 'time-monotonic->time-tai!
516
+ 'incompatible-time-types time-in))
517
+ (set-time-type! time-in time-tai)
518
+ time-in)
519
+
520
+ (define (time-utc->time-monotonic time-in)
521
+ (if (not (eq? (time-type time-in) time-utc))
522
+ (time-error 'time-utc->time-monotonic
523
+ 'incompatible-time-types time-in))
524
+ (let ((ntime (priv:time-utc->time-tai! time-in (make-time-unnormalized #f #f #f)
525
+ 'time-utc->time-monotonic)))
526
+ (set-time-type! ntime time-monotonic)
527
+ ntime))
528
+
529
+ (define (time-utc->time-monotonic! time-in)
530
+ (if (not (eq? (time-type time-in) time-utc))
531
+ (time-error 'time-utc->time-monotonic!
532
+ 'incompatible-time-types time-in))
533
+ (let ((ntime (priv:time-utc->time-tai! time-in time-in
534
+ 'time-utc->time-monotonic!)))
535
+ (set-time-type! ntime time-monotonic)
536
+ ntime))
537
+
538
+ (define (time-tai->time-monotonic time-in)
539
+ (if (not (eq? (time-type time-in) time-tai))
540
+ (time-error 'time-tai->time-monotonic
541
+ 'incompatible-time-types time-in))
542
+ (let ((ntime (copy-time time-in)))
543
+ (set-time-type! ntime time-monotonic)
544
+ ntime))
545
+
546
+ (define (time-tai->time-monotonic! time-in)
547
+ (if (not (eq? (time-type time-in) time-tai))
548
+ (time-error 'time-tai->time-monotonic!
549
+ 'incompatible-time-types time-in))
550
+ (set-time-type! time-in time-monotonic)
551
+ time-in)
552
+
553
+ ;; -- Date Structures
554
+
555
+ ;; FIXME: to be really safe, perhaps we should normalize the
556
+ ;; seconds/nanoseconds/minutes coming in to make-date...
557
+
558
+ (define-record-type date
559
+ (make-date nanosecond second minute
560
+ hour day month
561
+ year
562
+ zone-offset)
563
+ date?
564
+ (nanosecond date-nanosecond set-date-nanosecond!)
565
+ (second date-second set-date-second!)
566
+ (minute date-minute set-date-minute!)
567
+ (hour date-hour set-date-hour!)
568
+ (day date-day set-date-day!)
569
+ (month date-month set-date-month!)
570
+ (year date-year set-date-year!)
571
+ (zone-offset date-zone-offset set-date-zone-offset!))
572
+
573
+ ;; gives the julian day which starts at noon.
574
+ (define (encode-julian-day-number day month year)
575
+ (let* ((a (quotient (- 14 month) 12))
576
+ (y (- (+ year 4800) a (if (negative? year) -1 0)))
577
+ (m (- (+ month (* 12 a)) 3)))
578
+ (+ day
579
+ (quotient (+ (* 153 m) 2) 5)
580
+ (* 365 y)
581
+ (floor-quotient y 4)
582
+ (- (floor-quotient y 100))
583
+ (floor-quotient y 400)
584
+ -32045)))
585
+
586
+ ;; gives the seconds/date/month/year
587
+ (define (decode-julian-day-number jdn)
588
+ (let* ((days (inexact->exact (floor jdn)))
589
+ (a (+ days 32044))
590
+ (b (floor-quotient (+ (* 4 a) 3) 146097))
591
+ (c (- a (floor-quotient (* 146097 b) 4)))
592
+ (d (floor-quotient (+ (* 4 c) 3) 1461))
593
+ (e (- c (floor-quotient (* 1461 d) 4)))
594
+ (m (floor-quotient (+ (* 5 e) 2) 153))
595
+ (y (+ (* 100 b) d -4800 (quotient m 10))))
596
+ (values ; seconds date month year
597
+ (* (- jdn days) sid)
598
+ (+ e (- (quotient (+ (* 153 m) 2) 5)) 1)
599
+ (+ m 3 (* -12 (quotient m 10)))
600
+ (if (>= 0 y) (- y 1) y))))
601
+
602
+ ;; relies on the fact that we named our time zone accessor
603
+ ;; differently from MzScheme's....
604
+ ;; This should be written to be OS specific.
605
+
606
+ (define (local-tz-offset utc-time)
607
+ ;; SRFI 19 uses seconds East, but 'tm:gmtoff' returns seconds West.
608
+ (- (tm:gmtoff (localtime (time-second utc-time)))))
609
+
610
+ ;; special thing -- ignores nanos
611
+ (define (time->julian-day-number seconds tz-offset)
612
+ (+ (/ (+ seconds tz-offset sihd)
613
+ sid)
614
+ utc-epoch-in-jd))
615
+
616
+ (define (tai-before-leap-second? second)
617
+ (any (lambda (x)
618
+ (= second (+ (car x) (cdr x) -1)))
619
+ leap-second-table))
620
+
621
+ (define* (time-utc->date time #:optional (tz-offset
622
+ (local-tz-offset time)))
623
+ (if (not (eq? (time-type time) time-utc))
624
+ (time-error 'time-utc->date 'incompatible-time-types time))
625
+ (let* ((nanoseconds (+ (time-nanosecond time)
626
+ (* nano (time-second time))))
627
+ (jdn (time->julian-day-number (floor-quotient nanoseconds nano)
628
+ tz-offset)))
629
+ (call-with-values (lambda () (decode-julian-day-number jdn))
630
+ (lambda (secs date month year)
631
+ ;; secs is a real because jdn is a real in Guile;
632
+ ;; but it is conceptionally an integer.
633
+ (let* ((int-secs (inexact->exact (round secs)))
634
+ (hours (quotient int-secs (* 60 60)))
635
+ (rem (remainder int-secs (* 60 60)))
636
+ (minutes (quotient rem 60))
637
+ (seconds (remainder rem 60)))
638
+ (make-date (floor-remainder nanoseconds nano)
639
+ seconds
640
+ minutes
641
+ hours
642
+ date
643
+ month
644
+ year
645
+ tz-offset))))))
646
+
647
+ (define (time-tai->date time . tz-offset)
648
+ (if (not (eq? (time-type time) time-tai))
649
+ (time-error 'time-tai->date 'incompatible-time-types time))
650
+ (if (tai-before-leap-second? (time-second time))
651
+ ;; If it's *right* before the leap, we must handle this case to
652
+ ;; avoid the information lost when converting to UTC. We subtract
653
+ ;; a second before conversion, and then effectively add it back
654
+ ;; after conversion by setting the second field to 60.
655
+ (let ((d (apply time-utc->date
656
+ (subtract-duration! (time-tai->time-utc time)
657
+ (make-time time-duration 0 1))
658
+ tz-offset)))
659
+ (set-date-second! d 60)
660
+ d)
661
+ (apply time-utc->date (time-tai->time-utc time) tz-offset)))
662
+
663
+ (define (time-monotonic->date time . tz-offset)
664
+ (if (not (eq? (time-type time) time-monotonic))
665
+ (time-error 'time-monotonic->date 'incompatible-time-types time))
666
+ (apply time-tai->date (time-monotonic->time-tai time) tz-offset))
667
+
668
+ (define (date->time-utc date)
669
+ (let* ((jdays (- (encode-julian-day-number (date-day date)
670
+ (date-month date)
671
+ (date-year date))
672
+ utc-epoch-in-jd))
673
+ ;; jdays is an integer plus 1/2,
674
+ (jdays-1/2 (inexact->exact (- jdays 1/2))))
675
+ (make-time
676
+ time-utc
677
+ (date-nanosecond date)
678
+ (+ (* jdays-1/2 24 60 60)
679
+ (* (date-hour date) 60 60)
680
+ (* (date-minute date) 60)
681
+ (date-second date)
682
+ (- (date-zone-offset date))))))
683
+
684
+ (define (date->time-tai d)
685
+ (if (= (date-second d) 60)
686
+ (subtract-duration! (time-utc->time-tai! (date->time-utc d))
687
+ (make-time time-duration 0 1))
688
+ (time-utc->time-tai! (date->time-utc d))))
689
+
690
+ (define (date->time-monotonic d)
691
+ (if (= (date-second d) 60)
692
+ (subtract-duration! (time-utc->time-monotonic! (date->time-utc d))
693
+ (make-time time-duration 0 1))
694
+ (time-utc->time-monotonic! (date->time-utc d))))
695
+
696
+ (define (leap-year? year)
697
+ (let ((y (if (negative? year) (+ year 1) year)))
698
+ (and (zero? (modulo y 4))
699
+ (or (not (zero? (modulo y 100)))
700
+ (zero? (modulo y 400))))))
701
+
702
+ ;; Map 1-based month number M to number of days in the year before the
703
+ ;; start of month M (in a non-leap year).
704
+ (define month-assoc '((1 . 0) (2 . 31) (3 . 59) (4 . 90)
705
+ (5 . 120) (6 . 151) (7 . 181) (8 . 212)
706
+ (9 . 243) (10 . 273) (11 . 304) (12 . 334)))
707
+
708
+ (define (year-day day month year)
709
+ (let ((days-pr (assoc month month-assoc)))
710
+ (if (not days-pr)
711
+ (time-error 'date-year-day 'invalid-month-specification month))
712
+ (if (and (leap-year? year) (> month 2))
713
+ (+ day (cdr days-pr) 1)
714
+ (+ day (cdr days-pr)))))
715
+
716
+ (define (date-year-day date)
717
+ (year-day (date-day date) (date-month date) (date-year date)))
718
+
719
+ ;; from calendar faq
720
+ (define (week-day day month year)
721
+ (let* ((yy (if (negative? year) (+ year 1) year))
722
+ (a (quotient (- 14 month) 12))
723
+ (y (- yy a))
724
+ (m (+ month (* 12 a) -2)))
725
+ (modulo (+ day
726
+ y
727
+ (floor-quotient y 4)
728
+ (- (floor-quotient y 100))
729
+ (floor-quotient y 400)
730
+ (floor-quotient (* 31 m) 12))
731
+ 7)))
732
+
733
+ (define (date-week-day date)
734
+ (week-day (date-day date) (date-month date) (date-year date)))
735
+
736
+ (define (days-before-first-week date day-of-week-starting-week)
737
+ (let* ((first-day (make-date 0 0 0 0
738
+ 1
739
+ 1
740
+ (date-year date)
741
+ #f))
742
+ (fdweek-day (date-week-day first-day)))
743
+ (modulo (- day-of-week-starting-week fdweek-day)
744
+ 7)))
745
+
746
+ ;; The "-1" here is a fix for the reference implementation, to make a new
747
+ ;; week start on the given day-of-week-starting-week. date-year-day returns
748
+ ;; a day starting from 1 for 1st Jan.
749
+ ;;
750
+ (define (date-week-number date day-of-week-starting-week)
751
+ (floor-quotient (- (date-year-day date)
752
+ 1
753
+ (days-before-first-week date day-of-week-starting-week))
754
+ 7))
755
+
756
+ (define (current-date . tz-offset)
757
+ (let ((time (current-time time-utc)))
758
+ (time-utc->date
759
+ time
760
+ (if (null? tz-offset)
761
+ (local-tz-offset time)
762
+ (car tz-offset)))))
763
+
764
+ ;; given a 'two digit' number, find the year within 50 years +/-
765
+ (define (natural-year n)
766
+ (let* ((current-year (date-year (current-date)))
767
+ (current-century (* (quotient current-year 100) 100)))
768
+ (cond
769
+ ((>= n 100) n)
770
+ ((< n 0) n)
771
+ ((<= (- (+ current-century n) current-year) 50) (+ current-century n))
772
+ (else (+ (- current-century 100) n)))))
773
+
774
+ (define (date->julian-day date)
775
+ (let ((nanosecond (date-nanosecond date))
776
+ (second (date-second date))
777
+ (minute (date-minute date))
778
+ (hour (date-hour date))
779
+ (day (date-day date))
780
+ (month (date-month date))
781
+ (year (date-year date))
782
+ (offset (date-zone-offset date)))
783
+ (+ (encode-julian-day-number day month year)
784
+ (- 1/2)
785
+ (+ (/ (+ (- offset)
786
+ (* hour 60 60)
787
+ (* minute 60)
788
+ second
789
+ (/ nanosecond nano))
790
+ sid)))))
791
+
792
+ (define (date->modified-julian-day date)
793
+ (- (date->julian-day date)
794
+ 4800001/2))
795
+
796
+ (define (time-utc->julian-day time)
797
+ (if (not (eq? (time-type time) time-utc))
798
+ (time-error 'time-utc->julian-day 'incompatible-time-types time))
799
+ (+ (/ (+ (time-second time) (/ (time-nanosecond time) nano))
800
+ sid)
801
+ utc-epoch-in-jd))
802
+
803
+ (define (time-utc->modified-julian-day time)
804
+ (- (time-utc->julian-day time)
805
+ 4800001/2))
806
+
807
+ (define (time-tai->julian-day time)
808
+ (if (not (eq? (time-type time) time-tai))
809
+ (time-error 'time-tai->julian-day 'incompatible-time-types time))
810
+ (+ (/ (+ (tai->utc (time-second time))
811
+ (/ (time-nanosecond time) nano))
812
+ sid)
813
+ utc-epoch-in-jd))
814
+
815
+ (define (time-tai->modified-julian-day time)
816
+ (- (time-tai->julian-day time)
817
+ 4800001/2))
818
+
819
+ ;; this is the same as time-tai->julian-day
820
+ (define (time-monotonic->julian-day time)
821
+ (if (not (eq? (time-type time) time-monotonic))
822
+ (time-error 'time-monotonic->julian-day 'incompatible-time-types time))
823
+ (+ (/ (+ (tai->utc (time-second time))
824
+ (/ (time-nanosecond time) nano))
825
+ sid)
826
+ utc-epoch-in-jd))
827
+
828
+ (define (time-monotonic->modified-julian-day time)
829
+ (- (time-monotonic->julian-day time)
830
+ 4800001/2))
831
+
832
+ (define (julian-day->time-utc jdn)
833
+ (let ((secs (* sid (- jdn utc-epoch-in-jd))))
834
+ (receive (seconds parts)
835
+ (split-real secs)
836
+ (make-time time-utc
837
+ (* parts nano)
838
+ seconds))))
839
+
840
+ (define (julian-day->time-tai jdn)
841
+ (time-utc->time-tai! (julian-day->time-utc jdn)))
842
+
843
+ (define (julian-day->time-monotonic jdn)
844
+ (time-utc->time-monotonic! (julian-day->time-utc jdn)))
845
+
846
+ (define (julian-day->date jdn . tz-offset)
847
+ (let* ((time (julian-day->time-utc jdn))
848
+ (offset (if (null? tz-offset)
849
+ (local-tz-offset time)
850
+ (car tz-offset))))
851
+ (time-utc->date time offset)))
852
+
853
+ (define (modified-julian-day->date jdn . tz-offset)
854
+ (apply julian-day->date (+ jdn 4800001/2)
855
+ tz-offset))
856
+
857
+ (define (modified-julian-day->time-utc jdn)
858
+ (julian-day->time-utc (+ jdn 4800001/2)))
859
+
860
+ (define (modified-julian-day->time-tai jdn)
861
+ (julian-day->time-tai (+ jdn 4800001/2)))
862
+
863
+ (define (modified-julian-day->time-monotonic jdn)
864
+ (julian-day->time-monotonic (+ jdn 4800001/2)))
865
+
866
+ (define (current-julian-day)
867
+ (time-utc->julian-day (current-time time-utc)))
868
+
869
+ (define (current-modified-julian-day)
870
+ (time-utc->modified-julian-day (current-time time-utc)))
871
+
872
+ ;; returns a string rep. of number N, of minimum LENGTH, padded with
873
+ ;; character PAD-WITH. If PAD-WITH is #f, no padding is done, and it's
874
+ ;; as if number->string was used. if string is longer than or equal
875
+ ;; in length to LENGTH, it's as if number->string was used.
876
+
877
+ (define (padding n pad-with length)
878
+ (let* ((str (number->string n))
879
+ (str-len (string-length str)))
880
+ (if (or (>= str-len length)
881
+ (not pad-with))
882
+ str
883
+ (string-append (make-string (- length str-len) pad-with) str))))
884
+
885
+ (define (last-n-digits i n)
886
+ (abs (remainder i (expt 10 n))))
887
+
888
+ (define (locale-abbr-weekday n) (locale-day-short (+ 1 n)))
889
+ (define (locale-long-weekday n) (locale-day (+ 1 n)))
890
+ (define locale-abbr-month locale-month-short)
891
+ (define locale-long-month locale-month)
892
+
893
+ (define (date-reverse-lookup needle haystack-ref haystack-len
894
+ same?)
895
+ ;; Lookup NEEDLE (a string) using HAYSTACK-REF (a one argument procedure
896
+ ;; that returns a string corresponding to the given index) by passing it
897
+ ;; indices lower than HAYSTACK-LEN.
898
+ (let loop ((index 1))
899
+ (cond ((> index haystack-len) #f)
900
+ ((same? needle (haystack-ref index))
901
+ index)
902
+ (else (loop (+ index 1))))))
903
+
904
+ (define (locale-abbr-weekday->index string)
905
+ (date-reverse-lookup string locale-day-short 7 string=?))
906
+
907
+ (define (locale-long-weekday->index string)
908
+ (date-reverse-lookup string locale-day 7 string=?))
909
+
910
+ (define (locale-abbr-month->index string)
911
+ (date-reverse-lookup string locale-abbr-month 12 string=?))
912
+
913
+ (define (locale-long-month->index string)
914
+ (date-reverse-lookup string locale-long-month 12 string=?))
915
+
916
+
917
+ ;; FIXME: mkoeppe: Put a symbolic time zone in the date structs.
918
+ ;; Print it here instead of the numerical offset if available.
919
+ (define (locale-print-time-zone date port)
920
+ (tz-printer (date-zone-offset date) port))
921
+
922
+ (define (locale-am-string/pm hr)
923
+ (if (> hr 11) (locale-pm-string) (locale-am-string)))
924
+
925
+ (define (tz-printer offset port)
926
+ (cond
927
+ ((= offset 0) (display "Z" port))
928
+ ((negative? offset) (display "-" port))
929
+ (else (display "+" port)))
930
+ (if (not (= offset 0))
931
+ (let ((hours (abs (quotient offset (* 60 60))))
932
+ (minutes (abs (quotient (remainder offset (* 60 60)) 60))))
933
+ (display (padding hours #\0 2) port)
934
+ (display (padding minutes #\0 2) port))))
935
+
936
+ ;; A table of output formatting directives.
937
+ ;; the first time is the format char.
938
+ ;; the second is a procedure that takes the date, a padding character
939
+ ;; (which might be #f), and the output port.
940
+ ;;
941
+ (define directives
942
+ (list
943
+ (cons #\~ (lambda (date pad-with port)
944
+ (display #\~ port)))
945
+ (cons #\a (lambda (date pad-with port)
946
+ (display (locale-abbr-weekday (date-week-day date))
947
+ port)))
948
+ (cons #\A (lambda (date pad-with port)
949
+ (display (locale-long-weekday (date-week-day date))
950
+ port)))
951
+ (cons #\b (lambda (date pad-with port)
952
+ (display (locale-abbr-month (date-month date))
953
+ port)))
954
+ (cons #\B (lambda (date pad-with port)
955
+ (display (locale-long-month (date-month date))
956
+ port)))
957
+ (cons #\c (lambda (date pad-with port)
958
+ (display (date->string date locale-date-time-format) port)))
959
+ (cons #\d (lambda (date pad-with port)
960
+ (display (padding (date-day date)
961
+ #\0 2)
962
+ port)))
963
+ (cons #\D (lambda (date pad-with port)
964
+ (display (date->string date "~m/~d/~y") port)))
965
+ (cons #\e (lambda (date pad-with port)
966
+ (display (padding (date-day date)
967
+ #\Space 2)
968
+ port)))
969
+ (cons #\f (lambda (date pad-with port)
970
+ (receive (s ns) (floor/ (+ (* (date-second date) nano)
971
+ (date-nanosecond date))
972
+ nano)
973
+ (display (number->string s) port)
974
+ (display (locale-decimal-point) port)
975
+ (let ((str (padding ns #\0 9)))
976
+ (display (substring str 0 1) port)
977
+ (display (string-trim-right str #\0 1) port)))))
978
+ (cons #\h (lambda (date pad-with port)
979
+ (display (date->string date "~b") port)))
980
+ (cons #\H (lambda (date pad-with port)
981
+ (display (padding (date-hour date)
982
+ pad-with 2)
983
+ port)))
984
+ (cons #\I (lambda (date pad-with port)
985
+ (let ((hr (date-hour date)))
986
+ (if (> hr 12)
987
+ (display (padding (- hr 12)
988
+ pad-with 2)
989
+ port)
990
+ (display (padding hr
991
+ pad-with 2)
992
+ port)))))
993
+ (cons #\j (lambda (date pad-with port)
994
+ (display (padding (date-year-day date)
995
+ pad-with 3)
996
+ port)))
997
+ (cons #\k (lambda (date pad-with port)
998
+ (display (padding (date-hour date)
999
+ #\Space 2)
1000
+ port)))
1001
+ (cons #\l (lambda (date pad-with port)
1002
+ (let ((hr (if (> (date-hour date) 12)
1003
+ (- (date-hour date) 12) (date-hour date))))
1004
+ (display (padding hr #\Space 2)
1005
+ port))))
1006
+ (cons #\m (lambda (date pad-with port)
1007
+ (display (padding (date-month date)
1008
+ pad-with 2)
1009
+ port)))
1010
+ (cons #\M (lambda (date pad-with port)
1011
+ (display (padding (date-minute date)
1012
+ pad-with 2)
1013
+ port)))
1014
+ (cons #\n (lambda (date pad-with port)
1015
+ (newline port)))
1016
+ (cons #\N (lambda (date pad-with port)
1017
+ (display (padding (date-nanosecond date)
1018
+ pad-with 9)
1019
+ port)))
1020
+ (cons #\p (lambda (date pad-with port)
1021
+ (display (locale-am-string/pm (date-hour date)) port)))
1022
+ (cons #\r (lambda (date pad-with port)
1023
+ (display (date->string date "~I:~M:~S ~p") port)))
1024
+ (cons #\s (lambda (date pad-with port)
1025
+ (display (time-second (date->time-utc date)) port)))
1026
+ (cons #\S (lambda (date pad-with port)
1027
+ (if (> (date-nanosecond date)
1028
+ nano)
1029
+ (display (padding (+ (date-second date) 1)
1030
+ pad-with 2)
1031
+ port)
1032
+ (display (padding (date-second date)
1033
+ pad-with 2)
1034
+ port))))
1035
+ (cons #\t (lambda (date pad-with port)
1036
+ (display #\Tab port)))
1037
+ (cons #\T (lambda (date pad-with port)
1038
+ (display (date->string date "~H:~M:~S") port)))
1039
+ (cons #\U (lambda (date pad-with port)
1040
+ (if (> (days-before-first-week date 0) 0)
1041
+ (display (padding (+ (date-week-number date 0) 1)
1042
+ #\0 2) port)
1043
+ (display (padding (date-week-number date 0)
1044
+ #\0 2) port))))
1045
+ (cons #\V (lambda (date pad-with port)
1046
+ (display (padding (date-week-number date 1)
1047
+ #\0 2) port)))
1048
+ (cons #\w (lambda (date pad-with port)
1049
+ (display (date-week-day date) port)))
1050
+ (cons #\x (lambda (date pad-with port)
1051
+ (display (date->string date locale-short-date-format) port)))
1052
+ (cons #\X (lambda (date pad-with port)
1053
+ (display (date->string date locale-time-format) port)))
1054
+ (cons #\W (lambda (date pad-with port)
1055
+ (if (> (days-before-first-week date 1) 0)
1056
+ (display (padding (+ (date-week-number date 1) 1)
1057
+ #\0 2) port)
1058
+ (display (padding (date-week-number date 1)
1059
+ #\0 2) port))))
1060
+ (cons #\y (lambda (date pad-with port)
1061
+ (display (padding (last-n-digits
1062
+ (date-year date) 2)
1063
+ pad-with
1064
+ 2)
1065
+ port)))
1066
+ (cons #\Y (lambda (date pad-with port)
1067
+ (let* ((yy (date-year date))
1068
+ (y (if (negative? yy) (+ yy 1) yy)))
1069
+ (unless (<= 0 y 9999)
1070
+ (display (if (negative? y) #\- #\+) port))
1071
+ (display (padding (abs y) pad-with 4) port))))
1072
+ (cons #\z (lambda (date pad-with port)
1073
+ (tz-printer (date-zone-offset date) port)))
1074
+ (cons #\Z (lambda (date pad-with port)
1075
+ (locale-print-time-zone date port)))
1076
+ (cons #\1 (lambda (date pad-with port)
1077
+ (display (date->string date "~Y-~m-~d") port)))
1078
+ (cons #\2 (lambda (date pad-with port)
1079
+ (display (date->string date "~H:~M:~S~z") port)))
1080
+ (cons #\3 (lambda (date pad-with port)
1081
+ (display (date->string date "~H:~M:~S") port)))
1082
+ (cons #\4 (lambda (date pad-with port)
1083
+ (display (date->string date "~Y-~m-~dT~H:~M:~S~z") port)))
1084
+ (cons #\5 (lambda (date pad-with port)
1085
+ (display (date->string date "~Y-~m-~dT~H:~M:~S") port)))))
1086
+
1087
+
1088
+ (define (get-formatter char)
1089
+ (let ((associated (assoc char directives)))
1090
+ (if associated (cdr associated) #f)))
1091
+
1092
+ (define (date-printer date index format-string str-len port)
1093
+ (if (< index str-len)
1094
+ (let ((current-char (string-ref format-string index)))
1095
+ (if (not (char=? current-char #\~))
1096
+ (begin
1097
+ (display current-char port)
1098
+ (date-printer date (+ index 1) format-string str-len port))
1099
+ (if (= (+ index 1) str-len) ; bad format string.
1100
+ (time-error 'date-printer 'bad-date-format-string
1101
+ format-string)
1102
+ (let ((pad-char? (string-ref format-string (+ index 1))))
1103
+ (cond
1104
+ ((char=? pad-char? #\-)
1105
+ (if (= (+ index 2) str-len) ; bad format string.
1106
+ (time-error 'date-printer
1107
+ 'bad-date-format-string
1108
+ format-string)
1109
+ (let ((formatter (get-formatter
1110
+ (string-ref format-string
1111
+ (+ index 2)))))
1112
+ (if (not formatter)
1113
+ (time-error 'date-printer
1114
+ 'bad-date-format-string
1115
+ format-string)
1116
+ (begin
1117
+ (formatter date #f port)
1118
+ (date-printer date
1119
+ (+ index 3)
1120
+ format-string
1121
+ str-len
1122
+ port))))))
1123
+
1124
+ ((char=? pad-char? #\_)
1125
+ (if (= (+ index 2) str-len) ; bad format string.
1126
+ (time-error 'date-printer
1127
+ 'bad-date-format-string
1128
+ format-string)
1129
+ (let ((formatter (get-formatter
1130
+ (string-ref format-string
1131
+ (+ index 2)))))
1132
+ (if (not formatter)
1133
+ (time-error 'date-printer
1134
+ 'bad-date-format-string
1135
+ format-string)
1136
+ (begin
1137
+ (formatter date #\Space port)
1138
+ (date-printer date
1139
+ (+ index 3)
1140
+ format-string
1141
+ str-len
1142
+ port))))))
1143
+ (else
1144
+ (let ((formatter (get-formatter
1145
+ (string-ref format-string
1146
+ (+ index 1)))))
1147
+ (if (not formatter)
1148
+ (time-error 'date-printer
1149
+ 'bad-date-format-string
1150
+ format-string)
1151
+ (begin
1152
+ (formatter date #\0 port)
1153
+ (date-printer date
1154
+ (+ index 2)
1155
+ format-string
1156
+ str-len
1157
+ port))))))))))))
1158
+
1159
+
1160
+ (define (date->string date . format-string)
1161
+ (let ((str-port (open-output-string))
1162
+ (fmt-str (if (null? format-string) "~c" (car format-string))))
1163
+ (date-printer date 0 fmt-str (string-length fmt-str) str-port)
1164
+ (get-output-string str-port)))
1165
+
1166
+ (define (char->int ch)
1167
+ (case ch
1168
+ ((#\0) 0)
1169
+ ((#\1) 1)
1170
+ ((#\2) 2)
1171
+ ((#\3) 3)
1172
+ ((#\4) 4)
1173
+ ((#\5) 5)
1174
+ ((#\6) 6)
1175
+ ((#\7) 7)
1176
+ ((#\8) 8)
1177
+ ((#\9) 9)
1178
+ (else (time-error 'char->int 'bad-date-template-string
1179
+ (list "Non-integer character" ch)))))
1180
+
1181
+ ;; read an integer upto n characters long on port; upto -> #f is any length
1182
+ (define (integer-reader upto port)
1183
+ (let loop ((accum 0) (nchars 0))
1184
+ (let ((ch (peek-char port)))
1185
+ (if (or (eof-object? ch)
1186
+ (not (char-numeric? ch))
1187
+ (and upto (>= nchars upto)))
1188
+ accum
1189
+ (loop (+ (* accum 10) (char->int (read-char port)))
1190
+ (+ nchars 1))))))
1191
+
1192
+ (define (make-integer-reader upto)
1193
+ (lambda (port)
1194
+ (integer-reader upto port)))
1195
+
1196
+ ;; read an fractional integer upto n characters long on port; upto -> #f if any length
1197
+ ;;
1198
+ ;; The return value is normalized to upto decimal places. For example, if upto is 9 and
1199
+ ;; the string read is "123", the return value is 123000000.
1200
+ (define (fractional-integer-reader upto port)
1201
+ (define (accum-int port accum nchars)
1202
+ (let ((ch (peek-char port)))
1203
+ (if (or (eof-object? ch)
1204
+ (not (char-numeric? ch))
1205
+ (and upto (>= nchars upto)))
1206
+ (* accum (expt 10 (- upto nchars)))
1207
+ (accum-int port (+ (* accum 10) (char->int (read-char port))) (+ nchars 1)))))
1208
+ (accum-int port 0 0))
1209
+
1210
+ (define (make-fractional-integer-reader upto)
1211
+ (lambda (port)
1212
+ (fractional-integer-reader upto port)))
1213
+
1214
+ ;; read *exactly* n characters and convert to integer; could be padded
1215
+ (define (integer-reader-exact n port)
1216
+ (let ((padding-ok #t))
1217
+ (define (accum-int port accum nchars)
1218
+ (let ((ch (peek-char port)))
1219
+ (cond
1220
+ ((>= nchars n) accum)
1221
+ ((eof-object? ch)
1222
+ (time-error 'string->date 'bad-date-template-string
1223
+ "Premature ending to integer read."))
1224
+ ((char-numeric? ch)
1225
+ (set! padding-ok #f)
1226
+ (accum-int port
1227
+ (+ (* accum 10) (char->int (read-char port)))
1228
+ (+ nchars 1)))
1229
+ (padding-ok
1230
+ (read-char port) ; consume padding
1231
+ (accum-int port accum (+ nchars 1)))
1232
+ (else ; padding where it shouldn't be
1233
+ (time-error 'string->date 'bad-date-template-string
1234
+ "Non-numeric characters in integer read.")))))
1235
+ (accum-int port 0 0)))
1236
+
1237
+
1238
+ (define (make-integer-exact-reader n)
1239
+ (lambda (port)
1240
+ (integer-reader-exact n port)))
1241
+
1242
+ (define (zone-reader port)
1243
+ (let ((offset 0)
1244
+ (positive? #f))
1245
+ (let ((ch (read-char port)))
1246
+ (if (eof-object? ch)
1247
+ (time-error 'string->date 'bad-date-template-string
1248
+ (list "Invalid time zone +/-" ch)))
1249
+ (if (or (char=? ch #\Z) (char=? ch #\z))
1250
+ 0
1251
+ (begin
1252
+ (cond
1253
+ ((char=? ch #\+) (set! positive? #t))
1254
+ ((char=? ch #\-) (set! positive? #f))
1255
+ (else
1256
+ (time-error 'string->date 'bad-date-template-string
1257
+ (list "Invalid time zone +/-" ch))))
1258
+ (let ((ch (read-char port)))
1259
+ (if (eof-object? ch)
1260
+ (time-error 'string->date 'bad-date-template-string
1261
+ (list "Invalid time zone number" ch)))
1262
+ (set! offset (* (char->int ch)
1263
+ 10 60 60)))
1264
+ (let ((ch (read-char port)))
1265
+ (if (eof-object? ch)
1266
+ (time-error 'string->date 'bad-date-template-string
1267
+ (list "Invalid time zone number" ch)))
1268
+ (set! offset (+ offset (* (char->int ch)
1269
+ 60 60))))
1270
+ (let ((ch (read-char port)))
1271
+ (if (eof-object? ch)
1272
+ (time-error 'string->date 'bad-date-template-string
1273
+ (list "Invalid time zone number" ch)))
1274
+ (set! offset (+ offset (* (char->int ch)
1275
+ 10 60))))
1276
+ (let ((ch (read-char port)))
1277
+ (if (eof-object? ch)
1278
+ (time-error 'string->date 'bad-date-template-string
1279
+ (list "Invalid time zone number" ch)))
1280
+ (set! offset (+ offset (* (char->int ch)
1281
+ 60))))
1282
+ (if positive? offset (- offset)))))))
1283
+
1284
+ ;; looking at a char, read the char string, run thru indexer, return index
1285
+ (define (locale-reader port indexer)
1286
+
1287
+ (define (read-char-string result)
1288
+ (let ((ch (peek-char port)))
1289
+ (if (char-alphabetic? ch)
1290
+ (read-char-string (cons (read-char port) result))
1291
+ (list->string (reverse! result)))))
1292
+
1293
+ (let* ((str (read-char-string '()))
1294
+ (index (indexer str)))
1295
+ (if index index (time-error 'string->date
1296
+ 'bad-date-template-string
1297
+ (list "Invalid string for " indexer)))))
1298
+
1299
+ (define (make-locale-reader indexer)
1300
+ (lambda (port)
1301
+ (locale-reader port indexer)))
1302
+
1303
+ (define (make-char-id-reader char)
1304
+ (lambda (port)
1305
+ (if (char=? char (read-char port))
1306
+ char
1307
+ (time-error 'string->date
1308
+ 'bad-date-template-string
1309
+ "Invalid character match."))))
1310
+
1311
+ ;; A List of formatted read directives.
1312
+ ;; Each entry is a list.
1313
+ ;; 1. the character directive;
1314
+ ;; a procedure, which takes a character as input & returns
1315
+ ;; 2. #t as soon as a character on the input port is acceptable
1316
+ ;; for input,
1317
+ ;; 3. a port reader procedure that knows how to read the current port
1318
+ ;; for a value. Its one parameter is the port.
1319
+ ;; 4. an optional action procedure, that takes the value (from 3.) and
1320
+ ;; some object (here, always the date) and (probably) side-effects it.
1321
+ ;; If no action is required, as with ~A, this element may be #f.
1322
+
1323
+ (define read-directives
1324
+ (let ((ireader4 (make-integer-reader 4))
1325
+ (ireader2 (make-integer-reader 2))
1326
+ (fireader9 (make-fractional-integer-reader 9))
1327
+ (eireader2 (make-integer-exact-reader 2))
1328
+ (locale-reader-abbr-weekday (make-locale-reader
1329
+ locale-abbr-weekday->index))
1330
+ (locale-reader-long-weekday (make-locale-reader
1331
+ locale-long-weekday->index))
1332
+ (locale-reader-abbr-month (make-locale-reader
1333
+ locale-abbr-month->index))
1334
+ (locale-reader-long-month (make-locale-reader
1335
+ locale-long-month->index))
1336
+ (char-fail (lambda (ch) #t)))
1337
+
1338
+ (list
1339
+ (list #\~ char-fail (make-char-id-reader #\~) #f)
1340
+ (list #\a char-alphabetic? locale-reader-abbr-weekday #f)
1341
+ (list #\A char-alphabetic? locale-reader-long-weekday #f)
1342
+ (list #\b char-alphabetic? locale-reader-abbr-month
1343
+ (lambda (val object)
1344
+ (set-date-month! object val)))
1345
+ (list #\B char-alphabetic? locale-reader-long-month
1346
+ (lambda (val object)
1347
+ (set-date-month! object val)))
1348
+ (list #\d char-numeric? ireader2 (lambda (val object)
1349
+ (set-date-day!
1350
+ object val)))
1351
+ (list #\e char-fail eireader2 (lambda (val object)
1352
+ (set-date-day! object val)))
1353
+ (list #\h char-alphabetic? locale-reader-abbr-month
1354
+ (lambda (val object)
1355
+ (set-date-month! object val)))
1356
+ (list #\H char-numeric? ireader2 (lambda (val object)
1357
+ (set-date-hour! object val)))
1358
+ (list #\k char-fail eireader2 (lambda (val object)
1359
+ (set-date-hour! object val)))
1360
+ (list #\m char-numeric? ireader2 (lambda (val object)
1361
+ (set-date-month! object val)))
1362
+ (list #\M char-numeric? ireader2 (lambda (val object)
1363
+ (set-date-minute!
1364
+ object val)))
1365
+ (list #\N char-numeric? fireader9 (lambda (val object)
1366
+ (set-date-nanosecond!
1367
+ object val)))
1368
+ (list #\S char-numeric? ireader2 (lambda (val object)
1369
+ (set-date-second! object val)))
1370
+ (list #\y char-fail eireader2
1371
+ (lambda (val object)
1372
+ (set-date-year! object (natural-year val))))
1373
+
1374
+ ;; XXX FIXME: Support the extended year format used by
1375
+ ;; 'date->string' when the year is not in the range 0-9999.
1376
+ (list #\Y char-numeric? ireader4 (lambda (val object)
1377
+ (set-date-year! object val)))
1378
+
1379
+ (list #\z (lambda (c)
1380
+ (or (char=? c #\Z)
1381
+ (char=? c #\z)
1382
+ (char=? c #\+)
1383
+ (char=? c #\-)))
1384
+ zone-reader (lambda (val object)
1385
+ (set-date-zone-offset! object val))))))
1386
+
1387
+ (define (priv:string->date date index format-string str-len port template-string)
1388
+ (define (skip-until port skipper)
1389
+ (let ((ch (peek-char port)))
1390
+ (if (eof-object? ch)
1391
+ (time-error 'string->date 'bad-date-format-string template-string)
1392
+ (if (not (skipper ch))
1393
+ (begin (read-char port) (skip-until port skipper))))))
1394
+ (if (< index str-len)
1395
+ (let ((current-char (string-ref format-string index)))
1396
+ (if (not (char=? current-char #\~))
1397
+ (let ((port-char (read-char port)))
1398
+ (if (or (eof-object? port-char)
1399
+ (not (char=? current-char port-char)))
1400
+ (time-error 'string->date
1401
+ 'bad-date-format-string template-string))
1402
+ (priv:string->date date
1403
+ (+ index 1)
1404
+ format-string
1405
+ str-len
1406
+ port
1407
+ template-string))
1408
+ ;; otherwise, it's an escape, we hope
1409
+ (if (> (+ index 1) str-len)
1410
+ (time-error 'string->date
1411
+ 'bad-date-format-string template-string)
1412
+ (let* ((format-char (string-ref format-string (+ index 1)))
1413
+ (format-info (assoc format-char read-directives)))
1414
+ (if (not format-info)
1415
+ (time-error 'string->date
1416
+ 'bad-date-format-string template-string)
1417
+ (begin
1418
+ (let ((skipper (cadr format-info))
1419
+ (reader (caddr format-info))
1420
+ (actor (cadddr format-info)))
1421
+ (skip-until port skipper)
1422
+ (let ((val (reader port)))
1423
+ (if (eof-object? val)
1424
+ (time-error 'string->date
1425
+ 'bad-date-format-string
1426
+ template-string)
1427
+ (if actor (actor val date))))
1428
+ (priv:string->date date
1429
+ (+ index 2)
1430
+ format-string
1431
+ str-len
1432
+ port
1433
+ template-string))))))))))
1434
+
1435
+ (define (string->date input-string template-string)
1436
+ (define (date-ok? date)
1437
+ (and (date-nanosecond date)
1438
+ (date-second date)
1439
+ (date-minute date)
1440
+ (date-hour date)
1441
+ (date-day date)
1442
+ (date-month date)
1443
+ (date-year date)
1444
+ (date-zone-offset date)))
1445
+ (let ((newdate (make-date 0 0 0 0 #f #f #f #f)))
1446
+ (priv:string->date newdate
1447
+ 0
1448
+ template-string
1449
+ (string-length template-string)
1450
+ (open-input-string input-string)
1451
+ template-string)
1452
+ (if (not (date-zone-offset newdate))
1453
+ (begin
1454
+ ;; this is necessary to get DST right -- as far as we can
1455
+ ;; get it right (think of the double/missing hour in the
1456
+ ;; night when we are switching between normal time and DST).
1457
+ (set-date-zone-offset! newdate
1458
+ (local-tz-offset
1459
+ (make-time time-utc 0 0)))
1460
+ (set-date-zone-offset! newdate
1461
+ (local-tz-offset
1462
+ (date->time-utc newdate)))))
1463
+ (if (date-ok? newdate)
1464
+ newdate
1465
+ (time-error
1466
+ 'string->date
1467
+ 'bad-date-format-string
1468
+ (list "Incomplete date read. " newdate template-string)))))
1469
+
1470
+ ;;; srfi-19.scm ends here