/usr/share/lilypond/2.16.2/scm/document-functions.scm is in lilypond-data 2.16.2-3.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 | ;;;; This file is part of LilyPond, the GNU music typesetter.
;;;;
;;;; Copyright (C) 1998--2012 Han-Wen Nienhuys <hanwen@xs4all.nl>
;;;; Jan Nieuwenhuizen <janneke@gnu.org>
;;;;
;;;; LilyPond is free software: you can redistribute it and/or modify
;;;; it under the terms of the GNU General Public License as published by
;;;; the Free Software Foundation, either version 3 of the License, or
;;;; (at your option) any later version.
;;;;
;;;; LilyPond is distributed in the hope that it will be useful,
;;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
;;;; GNU General Public License for more details.
;;;;
;;;; You should have received a copy of the GNU General Public License
;;;; along with LilyPond. If not, see <http://www.gnu.org/licenses/>.
(use-modules
(ice-9 regex))
(define (dashify-underscores str)
(regexp-substitute/global #f "_" str 'pre "-" 'post))
(define (format-c-header c-h)
(regexp-substitute/global
#f ","
(regexp-substitute/global #f "(SCM|\\)|\\() *" (dashify-underscores c-h)
'pre "" 'post)
'pre " " 'post))
(define (document-scheme-function name c-header doc-string)
(string-append
"@defun " (symbol->string name) " " (format-c-header c-header) "\n"
doc-string
"\n@end defun\n\n"))
(define all-scheme-functions
(hash-fold
(lambda (key val prior)
(cons (cons key val) prior))
'() (ly:get-all-function-documentation)))
(define (all-scheme-functions-doc)
(let* ((fdocs (map (lambda (x)
(document-scheme-function (car x) (cadr x) (cddr x)))
all-scheme-functions))
(sfdocs (sort fdocs ly:string-ci<?)))
(make <texi-node>
#:name "Scheme functions"
#:desc "Primitive functions exported by LilyPond."
#:text
(apply string-append sfdocs))))
;; (dump-node (all-scheme-functions-doc) (current-output-port) 0 )
|