Artifact 6d238db8e0d95d63f970f06cbfedf760221a9ba3:
- File fmt/fmt-gauche.scm — part of check-in [80c8c83034] at 2016-07-07 18:11:39 on branch trunk — initial import (user: ovenpasta@pizzahack.eu size: 1744)
0000: 3b 3b 3b 3b 20 66 6d 74 2d 67 61 75 63 68 65 2e ;;;; fmt-gauche. 0010: 73 63 6d 20 2d 2d 20 47 61 75 63 68 65 20 66 6d scm -- Gauche fm 0020: 74 20 65 78 74 65 6e 73 69 6f 6e 0a 3b 3b 0a 3b t extension.;;.; 0030: 3b 20 43 6f 70 79 72 69 67 68 74 20 28 63 29 20 ; Copyright (c) 0040: 32 30 30 36 2d 32 30 31 31 20 41 6c 65 78 20 53 2006-2011 Alex S 0050: 68 69 6e 6e 2e 20 20 41 6c 6c 20 72 69 67 68 74 hinn. All right 0060: 73 20 72 65 73 65 72 76 65 64 2e 0a 3b 3b 20 42 s reserved..;; B 0070: 53 44 2d 73 74 79 6c 65 20 6c 69 63 65 6e 73 65 SD-style license 0080: 3a 20 68 74 74 70 3a 2f 2f 73 79 6e 74 68 63 6f : http://synthco 0090: 64 65 2e 63 6f 6d 2f 6c 69 63 65 6e 73 65 2e 74 de.com/license.t 00a0: 78 74 0a 0a 28 64 65 66 69 6e 65 2d 6d 6f 64 75 xt..(define-modu 00b0: 6c 65 20 74 65 78 74 2e 66 6d 74 0a 20 20 28 75 le text.fmt. (u 00c0: 73 65 20 73 72 66 69 2d 31 29 0a 20 20 28 75 73 se srfi-1). (us 00d0: 65 20 73 72 66 69 2d 36 29 0a 20 20 28 75 73 65 e srfi-6). (use 00e0: 20 73 72 66 69 2d 31 33 29 0a 20 20 28 65 78 70 srfi-13). (exp 00f0: 6f 72 74 0a 20 20 20 6e 65 77 2d 66 6d 74 2d 73 ort. new-fmt-s 0100: 74 61 74 65 0a 20 20 20 66 6d 74 20 66 6d 74 2d tate. fmt fmt- 0110: 73 74 61 72 74 20 66 6d 74 2d 69 66 20 66 6d 74 start fmt-if fmt 0120: 2d 63 61 70 74 75 72 65 20 66 6d 74 2d 6c 65 74 -capture fmt-let 0130: 20 66 6d 74 2d 62 69 6e 64 20 66 6d 74 2d 6e 75 fmt-bind fmt-nu 0140: 6c 6c 0a 20 20 20 66 6d 74 2d 72 65 66 20 66 6d ll. fmt-ref fm 0150: 74 2d 73 65 74 21 20 66 6d 74 2d 61 64 64 2d 70 t-set! fmt-add-p 0160: 72 6f 70 65 72 74 69 65 73 21 20 66 6d 74 2d 73 roperties! fmt-s 0170: 65 74 2d 70 72 6f 70 65 72 74 79 21 0a 20 20 20 et-property!. 0180: 66 6d 74 2d 63 6f 6c 20 66 6d 74 2d 73 65 74 2d fmt-col fmt-set- 0190: 63 6f 6c 21 20 66 6d 74 2d 72 6f 77 20 66 6d 74 col! fmt-row fmt 01a0: 2d 73 65 74 2d 72 6f 77 21 0a 20 20 20 66 6d 74 -set-row!. fmt 01b0: 2d 72 61 64 69 78 20 66 6d 74 2d 73 65 74 2d 72 -radix fmt-set-r 01c0: 61 64 69 78 21 20 66 6d 74 2d 70 72 65 63 69 73 adix! fmt-precis 01d0: 69 6f 6e 20 66 6d 74 2d 73 65 74 2d 70 72 65 63 ion fmt-set-prec 01e0: 69 73 69 6f 6e 21 0a 20 20 20 66 6d 74 2d 70 72 ision!. fmt-pr 01f0: 6f 70 65 72 74 69 65 73 20 66 6d 74 2d 73 65 74 operties fmt-set 0200: 2d 70 72 6f 70 65 72 74 69 65 73 21 20 66 6d 74 -properties! fmt 0210: 2d 77 69 64 74 68 20 66 6d 74 2d 73 65 74 2d 77 -width fmt-set-w 0220: 69 64 74 68 21 0a 20 20 20 66 6d 74 2d 77 72 69 idth!. fmt-wri 0230: 74 65 72 20 66 6d 74 2d 73 65 74 2d 77 72 69 74 ter fmt-set-writ 0240: 65 72 21 20 66 6d 74 2d 70 6f 72 74 20 66 6d 74 er! fmt-port fmt 0250: 2d 73 65 74 2d 70 6f 72 74 21 0a 20 20 20 66 6d -set-port!. fm 0260: 74 2d 64 65 63 69 6d 61 6c 2d 73 65 70 20 66 6d t-decimal-sep fm 0270: 74 2d 73 65 74 2d 64 65 63 69 6d 61 6c 2d 73 65 t-set-decimal-se 0280: 70 21 0a 20 20 20 66 6d 74 2d 66 69 6c 65 20 66 p!. fmt-file f 0290: 6d 74 2d 74 72 79 2d 66 69 74 20 63 61 74 20 61 mt-try-fit cat a 02a0: 70 70 6c 79 2d 63 61 74 20 6e 6c 20 66 6c 20 6e pply-cat nl fl n 02b0: 6c 2d 73 74 72 0a 20 20 20 66 6d 74 2d 6a 6f 69 l-str. fmt-joi 02c0: 6e 20 66 6d 74 2d 6a 6f 69 6e 2f 6c 61 73 74 20 n fmt-join/last 02d0: 66 6d 74 2d 6a 6f 69 6e 2f 64 6f 74 0a 20 20 20 fmt-join/dot. 02e0: 66 6d 74 2d 6a 6f 69 6e 2f 70 72 65 66 69 78 20 fmt-join/prefix 02f0: 66 6d 74 2d 6a 6f 69 6e 2f 73 75 66 66 69 78 20 fmt-join/suffix 0300: 66 6d 74 2d 6a 6f 69 6e 2f 72 61 6e 67 65 0a 20 fmt-join/range. 0310: 20 20 70 61 64 20 70 61 64 2f 72 69 67 68 74 20 pad pad/right 0320: 70 61 64 2f 6c 65 66 74 20 70 61 64 2f 62 6f 74 pad/left pad/bot 0330: 68 20 74 72 69 6d 20 74 72 69 6d 2f 6c 65 66 74 h trim trim/left 0340: 20 74 72 69 6d 2f 62 6f 74 68 20 74 72 69 6d 2f trim/both trim/ 0350: 6c 65 6e 67 74 68 0a 20 20 20 66 69 74 20 66 69 length. fit fi 0360: 74 2f 6c 65 66 74 20 66 69 74 2f 62 6f 74 68 20 t/left fit/both 0370: 74 61 62 2d 74 6f 20 73 70 61 63 65 2d 74 6f 20 tab-to space-to 0380: 77 72 74 20 77 72 74 2f 75 6e 73 68 61 72 65 64 wrt wrt/unshared 0390: 20 64 73 70 0a 20 20 20 70 72 65 74 74 79 20 70 dsp. pretty p 03a0: 72 65 74 74 79 2f 75 6e 73 68 61 72 65 64 20 73 retty/unshared s 03b0: 6c 61 73 68 69 66 69 65 64 20 6d 61 79 62 65 2d lashified maybe- 03c0: 73 6c 61 73 68 69 66 69 65 64 0a 20 20 20 6e 75 slashified. nu 03d0: 6d 20 6e 75 6d 2f 73 69 20 6e 75 6d 2f 66 69 74 m num/si num/fit 03e0: 20 6e 75 6d 2f 63 6f 6d 6d 61 20 72 61 64 69 78 num/comma radix 03f0: 20 66 69 78 20 64 65 63 69 6d 61 6c 2d 61 6c 69 fix decimal-ali 0400: 67 6e 20 65 6c 6c 69 70 73 65 73 0a 20 20 20 75 gn ellipses. u 0410: 70 63 61 73 65 20 64 6f 77 6e 63 61 73 65 20 74 pcase downcase t 0420: 69 74 6c 65 63 61 73 65 20 70 61 64 2d 63 68 61 itlecase pad-cha 0430: 72 20 63 6f 6d 6d 61 2d 63 68 61 72 20 64 65 63 r comma-char dec 0440: 69 6d 61 6c 2d 63 68 61 72 0a 20 20 20 77 69 74 imal-char. wit 0450: 68 2d 77 69 64 74 68 20 77 72 61 70 2d 6c 69 6e h-width wrap-lin 0460: 65 73 20 66 6f 6c 64 2d 6c 69 6e 65 73 20 6a 75 es fold-lines ju 0470: 73 74 69 66 79 0a 20 20 20 6d 61 6b 65 2d 73 74 stify. make-st 0480: 72 69 6e 67 2d 66 6d 74 2d 74 72 61 6e 73 66 6f ring-fmt-transfo 0490: 72 6d 65 72 0a 20 20 20 6d 61 6b 65 2d 73 70 61 rmer. make-spa 04a0: 63 65 20 6d 61 6b 65 2d 6e 6c 2d 73 70 61 63 65 ce make-nl-space 04b0: 20 64 69 73 70 6c 61 79 2d 74 6f 2d 73 74 72 69 display-to-stri 04c0: 6e 67 20 77 72 69 74 65 2d 74 6f 2d 73 74 72 69 ng write-to-stri 04d0: 6e 67 0a 20 20 20 66 6d 74 2d 63 6f 6c 75 6d 6e ng. fmt-column 04e0: 73 20 63 6f 6c 75 6d 6e 61 72 20 74 61 62 75 6c s columnar tabul 04f0: 61 72 20 6c 69 6e 65 2d 6e 75 6d 62 65 72 73 0a ar line-numbers. 0500: 20 20 20 29 29 0a 28 73 65 6c 65 63 74 2d 6d 6f )).(select-mo 0510: 64 75 6c 65 20 74 65 78 74 2e 66 6d 74 29 0a 0a dule text.fmt).. 0520: 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b ;;;;;;;;;;;;;;;; 0530: 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b ;;;;;;;;;;;;;;;; 0540: 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b ;;;;;;;;;;;;;;;; 0550: 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b 3b ;;;;;;;;;;;;;;;; 0560: 3b 3b 3b 3b 3b 3b 3b 3b 0a 3b 3b 20 53 52 46 49 ;;;;;;;;.;; SRFI 0570: 2d 36 39 20 63 6f 6d 70 61 74 69 62 6c 65 20 68 -69 compatible h 0580: 61 73 68 74 61 62 6c 65 73 0a 0a 28 64 65 66 69 ashtables..(defi 0590: 6e 65 20 28 6d 61 6b 65 2d 65 71 3f 2d 74 61 62 ne (make-eq?-tab 05a0: 6c 65 29 0a 20 20 28 6d 61 6b 65 2d 68 61 73 68 le). (make-hash 05b0: 2d 74 61 62 6c 65 20 27 65 71 3f 29 29 0a 28 64 -table 'eq?)).(d 05c0: 65 66 69 6e 65 20 68 61 73 68 2d 74 61 62 6c 65 efine hash-table 05d0: 2d 72 65 66 2f 64 65 66 61 75 6c 74 20 68 61 73 -ref/default has 05e0: 68 2d 74 61 62 6c 65 2d 67 65 74 29 0a 28 64 65 h-table-get).(de 05f0: 66 69 6e 65 20 68 61 73 68 2d 74 61 62 6c 65 2d fine hash-table- 0600: 73 65 74 21 20 68 61 73 68 2d 74 61 62 6c 65 2d set! hash-table- 0610: 70 75 74 21 29 0a 28 64 65 66 69 6e 65 20 28 68 put!).(define (h 0620: 61 73 68 2d 74 61 62 6c 65 2d 77 61 6c 6b 20 74 ash-table-walk t 0630: 61 62 20 70 72 6f 63 29 20 28 68 61 73 68 2d 74 ab proc) (hash-t 0640: 61 62 6c 65 2d 66 6f 72 2d 65 61 63 68 20 74 61 able-for-each ta 0650: 62 20 70 72 6f 63 29 29 0a 0a 28 64 65 66 69 6e b proc))..(defin 0660: 65 20 28 6d 61 6e 74 69 73 73 61 2b 65 78 70 6f e (mantissa+expo 0670: 6e 65 6e 74 20 6e 75 6d 29 0a 20 20 28 6c 65 74 nent num). (let 0680: 20 28 28 76 65 63 20 28 64 65 63 6f 64 65 2d 66 ((vec (decode-f 0690: 6c 6f 61 74 20 6e 75 6d 29 29 29 0a 20 20 20 20 loat num))). 06a0: 28 6c 69 73 74 20 28 76 65 63 74 6f 72 2d 72 65 (list (vector-re 06b0: 66 20 76 65 63 20 30 29 20 28 76 65 63 74 6f 72 f vec 0) (vector 06c0: 2d 72 65 66 20 76 65 63 20 31 29 29 29 29 0a 0a -ref vec 1))))..