misc-modules.texi 61 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802
  1. @c -*-texinfo-*-
  2. @c This is part of the GNU Guile Reference Manual.
  3. @c Copyright (C) 1996, 1997, 2000, 2001, 2002, 2003, 2004, 2006, 2009,
  4. @c 2010, 2011, 2012 Free Software Foundation, Inc.
  5. @c See the file guile.texi for copying conditions.
  6. @node Pretty Printing
  7. @section Pretty Printing
  8. @c FIXME::martin: Review me!
  9. @cindex pretty printing
  10. The module @code{(ice-9 pretty-print)} provides the procedure
  11. @code{pretty-print}, which provides nicely formatted output of Scheme
  12. objects. This is especially useful for deeply nested or complex data
  13. structures, such as lists and vectors.
  14. The module is loaded by entering the following:
  15. @lisp
  16. (use-modules (ice-9 pretty-print))
  17. @end lisp
  18. This makes the procedure @code{pretty-print} available. As an example
  19. how @code{pretty-print} will format the output, see the following:
  20. @lisp
  21. (pretty-print '(define (foo) (lambda (x)
  22. (cond ((zero? x) #t) ((negative? x) -x) (else
  23. (if (= x 1) 2 (* x x x)))))))
  24. @print{}
  25. (define (foo)
  26. (lambda (x)
  27. (cond ((zero? x) #t)
  28. ((negative? x) -x)
  29. (else (if (= x 1) 2 (* x x x))))))
  30. @end lisp
  31. @deffn {Scheme Procedure} pretty-print obj [port] [keyword-options]
  32. Print the textual representation of the Scheme object @var{obj} to
  33. @var{port}. @var{port} defaults to the current output port, if not
  34. given.
  35. The further @var{keyword-options} are keywords and parameters as
  36. follows,
  37. @table @asis
  38. @item @nicode{#:display?} @var{flag}
  39. If @var{flag} is true then print using @code{display}. The default is
  40. @code{#f} which means use @code{write} style. @xref{Scheme Write}.
  41. @item @nicode{#:per-line-prefix} @var{string}
  42. Print the given @var{string} as a prefix on each line. The default is
  43. no prefix.
  44. @item @nicode{#:width} @var{columns}
  45. Print within the given @var{columns}. The default is 79.
  46. @item @nicode{#:max-expr-width} @var{columns}
  47. The maximum width of an expression. The default is 50.
  48. @end table
  49. @end deffn
  50. @cindex truncated printing
  51. Also exported by the @code{(ice-9 pretty-print)} module is
  52. @code{truncated-print}, a procedure to print Scheme datums, truncating
  53. the output to a certain number of characters. This is useful when you
  54. need to present an arbitrary datum to the user, but you only have one
  55. line in which to do so.
  56. @lisp
  57. (define exp '(a b #(c d e) f . g))
  58. (truncated-print exp #:width 10) (newline)
  59. @print{} (a b . #)
  60. (truncated-print exp #:width 15) (newline)
  61. @print{} (a b # f . g)
  62. (truncated-print exp #:width 18) (newline)
  63. @print{} (a b #(c ...) . #)
  64. (truncated-print exp #:width 20) (newline)
  65. @print{} (a b #(c d e) f . g)
  66. (truncated-print "The quick brown fox" #:width 20) (newline)
  67. @print{} "The quick brown..."
  68. (truncated-print (current-module) #:width 20) (newline)
  69. @print{} #<directory (gui...>
  70. @end lisp
  71. @code{truncated-print} will not output a trailing newline. If an expression does
  72. not fit in the given width, it will be truncated -- possibly
  73. ellipsized@footnote{On Unicode-capable ports, the ellipsis is represented by
  74. character `HORIZONTAL ELLIPSIS' (U+2026), otherwise it is represented by three
  75. dots.}, or in the worst case, displayed as @nicode{#}.
  76. @deffn {Scheme Procedure} truncated-print obj [port] [keyword-options]
  77. Print @var{obj}, truncating the output, if necessary, to make it fit
  78. into @var{width} characters. By default, @var{obj} will be printed using
  79. @code{write}, though that behavior can be overridden via the
  80. @var{display?} keyword argument.
  81. The default behaviour is to print depth-first, meaning that the entire
  82. remaining width will be available to each sub-expression of @var{obj} --
  83. e.g., if @var{obj} is a vector, each member of @var{obj}. One can attempt to
  84. ``ration'' the available width, trying to allocate it equally to each
  85. sub-expression, via the @var{breadth-first?} keyword argument.
  86. The further @var{keyword-options} are keywords and parameters as
  87. follows,
  88. @table @asis
  89. @item @nicode{#:display?} @var{flag}
  90. If @var{flag} is true then print using @code{display}. The default is
  91. @code{#f} which means use @code{write} style. @pxref{Scheme Write}.
  92. @item @nicode{#:width} @var{columns}
  93. Print within the given @var{columns}. The default is 79.
  94. @item @nicode{#:breadth-first?} @var{flag}
  95. If @var{flag} is true, then allocate the available width breadth-first
  96. among elements of a compound data structure (list, vector, pair,
  97. etc.). The default is @code{#f} which means that any element is
  98. allowed to consume all of the available width.
  99. @end table
  100. @end deffn
  101. @node Formatted Output
  102. @section Formatted Output
  103. @cindex formatted output
  104. @c For reference, in this section escapes like ~a are given in
  105. @c @nicode, to give code font in TeX etc, but leave them unadorned in
  106. @c Info.
  107. @c
  108. @c The idea is to reduce clutter around what's shown, and avoid any
  109. @c possible confusion over whether the ` ' quotes are part of what
  110. @c should be entered. (In particular for instance of course ' is
  111. @c meaningful in a format string, introducing a char parameter).
  112. The @code{format} function is a powerful way to print numbers, strings
  113. and other objects together with literal text under the control of a
  114. format string. This function is available from
  115. @example
  116. (use-modules (ice-9 format))
  117. @end example
  118. A format string is generally more compact and easier than using just
  119. the standard procedures like @code{display}, @code{write} and
  120. @code{newline}. Parameters in the output string allow various output
  121. styles, and parameters can be taken from the arguments for runtime
  122. flexibility.
  123. @code{format} is similar to the Common Lisp procedure of the same
  124. name, but it's not identical and doesn't have quite all the features
  125. found in Common Lisp.
  126. C programmers will note the similarity between @code{format} and
  127. @code{printf}, though escape sequences are marked with @nicode{~}
  128. instead of @nicode{%}, and are more powerful.
  129. @sp 1
  130. @deffn {Scheme Procedure} format dest fmt arg @dots{}
  131. Write output specified by the @var{fmt} string to @var{dest}.
  132. @var{dest} can be an output port, @code{#t} for
  133. @code{current-output-port} (@pxref{Default Ports}), or @code{#f} to
  134. return the output as a string.
  135. @var{fmt} can contain literal text to be output, and @nicode{~}
  136. escapes. Each escape has the form
  137. @example
  138. ~ [param [, param@dots{}] [:] [@@] code
  139. @end example
  140. @nicode{code} is a character determining the escape sequence. The
  141. @nicode{:} and @nicode{@@} characters are optional modifiers, one or
  142. both of which change the way various codes operate. Optional
  143. parameters are accepted by some codes too. Parameters have the
  144. following forms,
  145. @table @asis
  146. @item @nicode{[+/-]number}
  147. An integer, with optional @nicode{+} or @nicode{-}.
  148. @item @nicode{'} (apostrophe)
  149. The following character in the format string, for instance @nicode{'z}
  150. for @nicode{z}.
  151. @item @nicode{v}
  152. The next function argument as the parameter. @nicode{v} stands for
  153. ``variable'', a parameter can be calculated at runtime and included in
  154. the arguments. Upper case @nicode{V} can be used too.
  155. @item @nicode{#}
  156. The number of arguments remaining. (See @nicode{~*} below for some
  157. usages.)
  158. @end table
  159. Parameters are separated by commas (@nicode{,}). A parameter can be
  160. left empty to keep its default value when supplying later parameters.
  161. @sp 1
  162. The following escapes are available. The code letters are not
  163. case-sensitive, upper and lower case are the same.
  164. @table @asis
  165. @item @nicode{~a}
  166. @itemx @nicode{~s}
  167. Object output. Parameters: @var{minwidth}, @var{padinc},
  168. @var{minpad}, @var{padchar}.
  169. @nicode{~a} outputs an argument like @code{display}, @nicode{~s}
  170. outputs an argument like @code{write} (@pxref{Scheme Write}).
  171. @example
  172. (format #t "~a" "foo") @print{} foo
  173. (format #t "~s" "foo") @print{} "foo"
  174. @end example
  175. @nicode{~:a} and @nicode{~:s} put objects that don't have an external
  176. representation in quotes like a string.
  177. @example
  178. (format #t "~:a" car) @print{} "#<primitive-procedure car>"
  179. @end example
  180. If the output is less than @var{minwidth} characters (default 0), it's
  181. padded on the right with @var{padchar} (default space). @nicode{~@@a}
  182. and @nicode{~@@s} put the padding on the left instead.
  183. @example
  184. (format #f "~5a" 'abc) @result{} "abc "
  185. (format #f "~5,,,'-@@a" 'abc) @result{} "--abc"
  186. @end example
  187. @var{minpad} is a minimum for the padding then plus a multiple of
  188. @var{padinc}. Ie.@: the padding is @math{@var{minpad} + @var{N} *
  189. @var{padinc}}, where @var{n} is the smallest integer making the total
  190. object plus padding greater than or equal to @var{minwidth}. The
  191. default @var{minpad} is 0 and the default @var{padinc} is 1 (imposing
  192. no minimum or multiple).
  193. @example
  194. (format #f "~5,1,4a" 'abc) @result{} "abc "
  195. @end example
  196. @item @nicode{~c}
  197. Character. Parameter: @var{charnum}.
  198. Output a character. The default is to simply output, as per
  199. @code{write-char} (@pxref{Venerable Port Interfaces}). @nicode{~@@c}
  200. prints in @code{write} style. @nicode{~:c} prints control characters
  201. (ASCII 0 to 31) in @nicode{^X} form.
  202. @example
  203. (format #t "~c" #\z) @print{} z
  204. (format #t "~@@c" #\z) @print{} #\z
  205. (format #t "~:c" #\newline) @print{} ^J
  206. @end example
  207. If the @var{charnum} parameter is given then an argument is not taken
  208. but instead the character is @code{(integer->char @var{charnum})}
  209. (@pxref{Characters}). This can be used for instance to output
  210. characters given by their ASCII code.
  211. @example
  212. (format #t "~65c") @print{} A
  213. @end example
  214. @item @nicode{~d}
  215. @itemx @nicode{~x}
  216. @itemx @nicode{~o}
  217. @itemx @nicode{~b}
  218. Integer. Parameters: @var{minwidth}, @var{padchar}, @var{commachar},
  219. @var{commawidth}.
  220. Output an integer argument as a decimal, hexadecimal, octal or binary
  221. integer (respectively), in a locale-independent way.
  222. @example
  223. (format #t "~d" 123) @print{} 123
  224. @end example
  225. @nicode{~@@d} etc shows a @nicode{+} sign is shown on positive
  226. numbers.
  227. @c FIXME: "+" is not shown on zero, unlike in Common Lisp. Should
  228. @c that be changed in the code, or is it too late and should just be
  229. @c documented that way?
  230. @example
  231. (format #t "~@@b" 12) @print{} +1100
  232. @end example
  233. If the output is less than the @var{minwidth} parameter (default no
  234. minimum), it's padded on the left with the @var{padchar} parameter
  235. (default space).
  236. @example
  237. (format #t "~5,'*d" 12) @print{} ***12
  238. (format #t "~5,'0d" 12) @print{} 00012
  239. (format #t "~3d" 1234) @print{} 1234
  240. @end example
  241. @nicode{~:d} adds commas (or the @var{commachar} parameter) every
  242. three digits (or the @var{commawidth} parameter many). However, when
  243. your intent is to write numbers in a way that follows typographical
  244. conventions, using @nicode{~h} is recommended.
  245. @example
  246. (format #t "~:d" 1234567) @print{} 1,234,567
  247. (format #t "~10,'*,'/,2:d" 12345) @print{} ***1/23/45
  248. @end example
  249. Hexadecimal @nicode{~x} output is in lower case, but the @nicode{~(}
  250. and @nicode{~)} case conversion directives described below can be used
  251. to get upper case.
  252. @example
  253. (format #t "~x" 65261) @print{} feed
  254. (format #t "~:@@(~x~)" 65261) @print{} FEED
  255. @end example
  256. @item @nicode{~r}
  257. Integer in words, roman numerals, or a specified radix. Parameters:
  258. @var{radix}, @var{minwidth}, @var{padchar}, @var{commachar},
  259. @var{commawidth}.
  260. With no parameters output is in words as a cardinal like ``ten'', or
  261. @nicode{~:r} prints an ordinal like ``tenth''.
  262. @example
  263. (format #t "~r" 9) @print{} nine ;; cardinal
  264. (format #t "~r" -9) @print{} minus nine ;; cardinal
  265. (format #t "~:r" 9) @print{} ninth ;; ordinal
  266. @end example
  267. And also with no parameters, @nicode{~@@r} gives roman numerals and
  268. @nicode{~:@@r} gives old roman numerals. In old roman numerals
  269. there's no ``subtraction'', so 9 is @nicode{VIIII} instead of
  270. @nicode{IX}. In both cases only positive numbers can be output.
  271. @example
  272. (format #t "~@@r" 89) @print{} LXXXIX ;; roman
  273. (format #t "~:@@r" 89) @print{} LXXXVIIII ;; old roman
  274. @end example
  275. When a parameter is given it means numeric output in the specified
  276. @var{radix}. The modifiers and parameters following the radix are the
  277. same as described for @nicode{~d} etc above.
  278. @example
  279. (format #f "~3r" 27) @result{} "1000" ;; base 3
  280. (format #f "~3,5r" 26) @result{} " 222" ;; base 3 width 5
  281. @end example
  282. @item @nicode{~f}
  283. Fixed-point float. Parameters: @var{width}, @var{decimals},
  284. @var{scale}, @var{overflowchar}, @var{padchar}.
  285. Output a number or number string in fixed-point format, ie.@: with a
  286. decimal point.
  287. @example
  288. (format #t "~f" 5) @print{} 5.0
  289. (format #t "~f" "123") @print{} 123.0
  290. (format #t "~f" "1e-1") @print{} 0.1
  291. @end example
  292. @nicode{~@@f} prints a @nicode{+} sign on positive numbers (including
  293. zero).
  294. @example
  295. (format #t "~@@f" 0) @print{} +0.0
  296. @end example
  297. If the output is less than @var{width} characters it's padded on the
  298. left with @var{padchar} (space by default). If the output equals or
  299. exceeds @var{width} then there's no padding. The default for
  300. @var{width} is no padding.
  301. @example
  302. (format #f "~6f" -1.5) @result{} " -1.5"
  303. (format #f "~6,,,,'*f" 23) @result{} "**23.0"
  304. (format #f "~6f" 1234567.0) @result{} "1234567.0"
  305. @end example
  306. @var{decimals} is how many digits to print after the decimal point,
  307. with the value rounded or padded with zeros as necessary. (The
  308. default is to output as many decimals as required.)
  309. @example
  310. (format #t "~1,2f" 3.125) @print{} 3.13
  311. (format #t "~1,2f" 1.5) @print{} 1.50
  312. @end example
  313. @var{scale} is a power of 10 applied to the value, moving the decimal
  314. point that many places. A positive @var{scale} increases the value
  315. shown, a negative decreases it.
  316. @example
  317. (format #t "~,,2f" 1234) @print{} 123400.0
  318. (format #t "~,,-2f" 1234) @print{} 12.34
  319. @end example
  320. If @var{overflowchar} and @var{width} are both given and if the output
  321. would exceed @var{width}, then that many @var{overflowchar}s are
  322. printed instead of the value.
  323. @example
  324. (format #t "~6,,,'xf" 12345) @print{} 12345.
  325. (format #t "~5,,,'xf" 12345) @print{} xxxxx
  326. @end example
  327. @item @nicode{~h}
  328. Localized number@footnote{The @nicode{~h} format specifier first
  329. appeared in Guile version 2.0.6.}. Parameters: @var{width},
  330. @var{decimals}, @var{padchar}.
  331. Like @nicode{~f}, output an exact or floating point number, but do so
  332. according to the current locale, or according to the given locale object
  333. when the @code{:} modifier is used (@pxref{Number Input and Output,
  334. @code{number->locale-string}}).
  335. @example
  336. (format #t "~h" 12345.5678) ; with "C" as the current locale
  337. @print{} 12345.5678
  338. (format #t "~14,,'*:h" 12345.5678
  339. (make-locale LC_ALL "en_US"))
  340. @print{} ***12,345.5678
  341. (format #t "~,2:h" 12345.5678
  342. (make-locale LC_NUMERIC "fr_FR"))
  343. @print{} 12 345,56
  344. @end example
  345. @item @nicode{~e}
  346. Exponential float. Parameters: @var{width}, @var{mantdigits},
  347. @var{expdigits}, @var{intdigits}, @var{overflowchar}, @var{padchar},
  348. @var{expchar}.
  349. Output a number or number string in exponential notation.
  350. @example
  351. (format #t "~e" 5000.25) @print{} 5.00025E+3
  352. (format #t "~e" "123.4") @print{} 1.234E+2
  353. (format #t "~e" "1e4") @print{} 1.0E+4
  354. @end example
  355. @nicode{~@@e} prints a @nicode{+} sign on positive numbers (including
  356. zero). (This is for the mantissa, a @nicode{+} or @nicode{-} sign is
  357. always shown on the exponent.)
  358. @example
  359. (format #t "~@@e" 5000.0) @print{} +5.0E+3
  360. @end example
  361. If the output is less than @var{width} characters it's padded on the
  362. left with @var{padchar} (space by default). The default for
  363. @var{width} is to output with no padding.
  364. @example
  365. (format #f "~10e" 1234.0) @result{} " 1.234E+3"
  366. (format #f "~10,,,,,'*e" 0.5) @result{} "****5.0E-1"
  367. @end example
  368. @c FIXME: Describe what happens when the number is bigger than WIDTH.
  369. @c There seems to be a bit of dodginess about this, or some deviation
  370. @c from Common Lisp.
  371. @var{mantdigits} is the number of digits shown in the mantissa after
  372. the decimal point. The value is rounded or trailing zeros are added
  373. as necessary. The default @var{mantdigits} is to show as much as
  374. needed by the value.
  375. @example
  376. (format #f "~,3e" 11111.0) @result{} "1.111E+4"
  377. (format #f "~,8e" 123.0) @result{} "1.23000000E+2"
  378. @end example
  379. @var{expdigits} is the minimum number of digits shown for the
  380. exponent, with leading zeros added if necessary. The default for
  381. @var{expdigits} is to show only as many digits as required. At least
  382. 1 digit is always shown.
  383. @example
  384. (format #f "~,,1e" 1.0e99) @result{} "1.0E+99"
  385. (format #f "~,,6e" 1.0e99) @result{} "1.0E+000099"
  386. @end example
  387. @var{intdigits} (default 1) is the number of digits to show before the
  388. decimal point in the mantissa. @var{intdigits} can be zero, in which
  389. case the integer part is a single @nicode{0}, or it can be negative,
  390. in which case leading zeros are shown after the decimal point.
  391. @c FIXME: When INTDIGITS is 0, Common Lisp format apparently only
  392. @c shows the single 0 digit if it fits in WIDTH. format.scm seems to
  393. @c show it always. Is it meant to?
  394. @example
  395. (format #t "~,,,3e" 12345.0) @print{} 123.45E+2
  396. (format #t "~,,,0e" 12345.0) @print{} 0.12345E+5
  397. (format #t "~,,,-3e" 12345.0) @print{} 0.00012345E+8
  398. @end example
  399. @c FIXME: MANTDIGITS with negative INTDIGITS doesn't match CL spec,
  400. @c believe the spec says it ought to still show mantdigits+1 sig
  401. @c figures, i.e. leading zeros don't count towards MANTDIGITS, but it
  402. @c seems to just treat MANTDIGITS as how many digits after the
  403. @c decimal point.
  404. If @var{overflowchar} is given then @var{width} is a hard limit. If
  405. the output would exceed @var{width} then instead that many
  406. @var{overflowchar}s are printed.
  407. @example
  408. (format #f "~6,,,,'xe" 100.0) @result{} "1.0E+2"
  409. (format #f "~3,,,,'xe" 100.0) @result{} "xxx"
  410. @end example
  411. @var{expchar} is the exponent marker character (default @nicode{E}).
  412. @example
  413. (format #t "~,,,,,,'ee" 100.0) @print{} 1.0e+2
  414. @end example
  415. @item @nicode{~g}
  416. General float. Parameters: @var{width}, @var{mantdigits},
  417. @var{expdigits}, @var{intdigits}, @var{overflowchar}, @var{padchar},
  418. @var{expchar}.
  419. Output a number or number string in either exponential format the same
  420. as @nicode{~e}, or fixed-point format like @nicode{~f} but aligned
  421. where the mantissa would have been and followed by padding where the
  422. exponent would have been.
  423. @c FIXME: The default MANTDIGITS is apparently max(needed,min(n,7))
  424. @c where 10^(n-1)<=abs(x)<=10^n. But the Common Lisp spec seems to
  425. @c ask for "needed" to be without leading or trailing zeros, whereas
  426. @c format.scm seems to include trailing zeros, ending up with it
  427. @c using fixed format for bigger values than it should.
  428. Fixed-point is used when the absolute value is 0.1 or more and it
  429. takes no more space than the mantissa in exponential format, ie.@:
  430. basically up to @var{mantdigits} digits.
  431. @example
  432. (format #f "~12,4,2g" 999.0) @result{} " 999.0 "
  433. (format #f "~12,4,2g" "100000") @result{} " 1.0000E+05"
  434. @end example
  435. The parameters are interpreted as per @nicode{~e} above. When
  436. fixed-point is used, the @var{decimals} parameter to @nicode{~f} is
  437. established from @var{mantdigits}, so as to give a total
  438. @math{@var{mantdigits}+1} figures.
  439. @item @nicode{~$}
  440. Monetary style fixed-point float. Parameters: @var{decimals},
  441. @var{intdigits}, @var{width}, @var{padchar}.
  442. @c For reference, fmtdoc.txi from past versions of slib showed the
  443. @c INTDIGITS parameter as SCALE. That looks like a typo, in the code
  444. @c and in the Common Lisp spec it's a minimum digits for the integer
  445. @c part, it isn't a power of 10 like in ~f.
  446. Output a number or number string in fixed-point format, ie.@: with a
  447. decimal point. @var{decimals} is the number of decimal places to
  448. show, default 2.
  449. @example
  450. (format #t "~$" 5) @print{} 5.00
  451. (format #t "~4$" "2.25") @print{} 2.2500
  452. (format #t "~4$" "1e-2") @print{} 0.0100
  453. @end example
  454. @nicode{~@@$} prints a @nicode{+} sign on positive numbers (including
  455. zero).
  456. @example
  457. (format #t "~@@$" 0) @print{} +0.00
  458. @end example
  459. @var{intdigits} is a minimum number of digits to show in the integer
  460. part of the value (default 1).
  461. @example
  462. (format #t "~,3$" 9.5) @print{} 009.50
  463. (format #t "~,0$" 0.125) @print{} .13
  464. @end example
  465. If the output is less than @var{width} characters (default 0), it's
  466. padded on the left with @var{padchar} (default space). @nicode{~:$}
  467. puts the padding after the sign.
  468. @example
  469. (format #f "~,,8$" -1.5) @result{} " -1.50"
  470. (format #f "~,,8:$" -1.5) @result{} "- 1.50"
  471. (format #f "~,,8,'.:@@$" 3) @result{} "+...3.00"
  472. @end example
  473. Note that floating point for dollar amounts is generally not a good
  474. idea, because a cent @math{0.01} cannot be represented exactly in the
  475. binary floating point Guile uses, which leads to slowly accumulating
  476. rounding errors. Keeping values as cents (or fractions of a cent) in
  477. integers then printing with the scale option in @nicode{~f} may be a
  478. better approach.
  479. @c For reference, fractions don't work with ~$ (or any of the float
  480. @c conversions) currently. If they did work then we could perhaps
  481. @c suggest keeping dollar amounts as rationals, which would of course
  482. @c give exact cents. An integer as cents is probably still a better
  483. @c recommendation though, since it forces one to think about where
  484. @c and when rounding can or should occur.
  485. @item @nicode{~i}
  486. Complex fixed-point float. Parameters: @var{width}, @var{decimals},
  487. @var{scale}, @var{overflowchar}, @var{padchar}.
  488. @c For reference, in Common Lisp ~i is an indent, but slib fmtdoc.txi
  489. @c described it as complex number output, so we keep that.
  490. Output the argument as a complex number, with both real and imaginary
  491. part shown (even if one or both are zero).
  492. The parameters and modifiers are the same as for fixed-point
  493. @nicode{~f} described above. The real and imaginary parts are both
  494. output with the same given parameters and modifiers, except that for
  495. the imaginary part the @nicode{@@} modifier is always enabled, so as
  496. to print a @nicode{+} sign between the real and imaginary parts.
  497. @example
  498. (format #t "~i" 1) @print{} 1.0+0.0i
  499. @end example
  500. @item @nicode{~p}
  501. Plural. No parameters.
  502. Output nothing if the argument is 1, or @samp{s} for any other
  503. value.
  504. @example
  505. (format #t "enter name~p" 1) @print{} enter name
  506. (format #t "enter name~p" 2) @print{} enter names
  507. @end example
  508. @nicode{~@@p} prints @samp{y} for 1 or @samp{ies} otherwise.
  509. @example
  510. (format #t "pupp~@@p" 1) @print{} puppy
  511. (format #t "pupp~@@p" 2) @print{} puppies
  512. @end example
  513. @nicode{~:p} re-uses the preceding argument instead of taking a new
  514. one, which can be convenient when printing some sort of count.
  515. @example
  516. (format #t "~d cat~:p" 9) @print{} 9 cats
  517. (format #t "~d pupp~:@@p" 5) @print{} 5 puppies
  518. @end example
  519. @nicode{~p} is designed for English plurals and there's no attempt to
  520. support other languages. @nicode{~[} conditionals (below) may be able
  521. to help. When using @code{gettext} to translate messages
  522. @code{ngettext} is probably best though
  523. (@pxref{Internationalization}).
  524. @item @nicode{~y}
  525. Structured printing. Parameters: @var{width}.
  526. @nicode{~y} outputs an argument using @code{pretty-print}
  527. (@pxref{Pretty Printing}). The result will be formatted to fit within
  528. @var{width} columns (79 by default), consuming multiple lines if
  529. necessary.
  530. @nicode{~@@y} outputs an argument using @code{truncated-print}
  531. (@pxref{Pretty Printing}). The resulting code will be formatted to fit
  532. within @var{width} columns (79 by default), on a single line. The
  533. output will be truncated if necessary.
  534. @nicode{~:@@y} is like @nicode{~@@y}, except the @var{width} parameter
  535. is interpreted to be the maximum column to which to output. That is to
  536. say, if you are at column 10, and @nicode{~60:@@y} is seen, the datum
  537. will be truncated to 50 columns.
  538. @item @nicode{~?}
  539. @itemx @nicode{~k}
  540. Sub-format. No parameters.
  541. Take a format string argument and a second argument which is a list of
  542. arguments for that string, and output the result.
  543. @example
  544. (format #t "~?" "~d ~d" '(1 2)) @print{} 1 2
  545. @end example
  546. @nicode{~@@?} takes arguments for the sub-format directly rather than
  547. in a list.
  548. @example
  549. (format #t "~@@? ~s" "~d ~d" 1 2 "foo") @print{} 1 2 "foo"
  550. @end example
  551. @nicode{~?} and @nicode{~k} are the same, @nicode{~k} is provided for
  552. T-Scheme compatibility.
  553. @item @nicode{~*}
  554. Argument jumping. Parameter: @var{N}.
  555. Move forward @var{N} arguments (default 1) in the argument list.
  556. @nicode{~:*} moves backwards. (@var{N} cannot be negative.)
  557. @example
  558. (format #f "~d ~2*~d" 1 2 3 4) @result{} "1 4"
  559. (format #f "~d ~:*~d" 6) @result{} "6 6"
  560. @end example
  561. @nicode{~@@*} moves to argument number @var{N}. The first argument is
  562. number 0 (and that's the default for @var{N}).
  563. @example
  564. (format #f "~d~d again ~@@*~d~d" 1 2) @result{} "12 again 12"
  565. (format #f "~d~d~d ~1@@*~d~d" 1 2 3) @result{} "123 23"
  566. @end example
  567. A @nicode{#} move to the end followed by a @nicode{:} modifier move
  568. back can be used for an absolute position relative to the end of the
  569. argument list, a reverse of what the @nicode{@@} modifier does.
  570. @example
  571. (format #t "~#*~2:*~a" 'a 'b 'c 'd) @print{} c
  572. @end example
  573. At the end of the format string the current argument position doesn't
  574. matter, any further arguments are ignored.
  575. @item @nicode{~t}
  576. Advance to a column position. Parameters: @var{colnum}, @var{colinc},
  577. @var{padchar}.
  578. Output @var{padchar} (space by default) to move to the given
  579. @var{colnum} column. The start of the line is column 0, the default
  580. for @var{colnum} is 1.
  581. @example
  582. (format #f "~tX") @result{} " X"
  583. (format #f "~3tX") @result{} " X"
  584. @end example
  585. If the current column is already past @var{colnum}, then the move is
  586. to there plus a multiple of @var{colinc}, ie.@: column
  587. @math{@var{colnum} + @var{N} * @var{colinc}} for the smallest @var{N}
  588. which makes that value greater than or equal to the current column.
  589. The default @var{colinc} is 1 (which means no further move).
  590. @example
  591. (format #f "abcd~2,5,'.tx") @result{} "abcd...x"
  592. @end example
  593. @nicode{~@@t} takes @var{colnum} as an offset from the current column.
  594. @var{colnum} many pad characters are output, then further padding to
  595. make the current column a multiple of @var{colinc}, if it isn't
  596. already so.
  597. @example
  598. (format #f "a~3,5'*@@tx") @result{} "a****x"
  599. @end example
  600. @nicode{~t} is implemented using @code{port-column} (@pxref{Textual
  601. I/O}), so it works even there has been other output before
  602. @code{format}.
  603. @item @nicode{~~}
  604. Tilde character. Parameter: @var{n}.
  605. Output a tilde character @nicode{~}, or @var{n} many if a parameter is
  606. given. Normally @nicode{~} introduces an escape sequence, @nicode{~~}
  607. is the way to output a literal tilde.
  608. @item @nicode{~%}
  609. Newline. Parameter: @var{n}.
  610. Output a newline character, or @var{n} many if a parameter is given.
  611. A newline (or a few newlines) can of course be output just by
  612. including them in the format string.
  613. @item @nicode{~&}
  614. Start a new line. Parameter: @var{n}.
  615. Output a newline if not already at the start of a line. With a
  616. parameter, output that many newlines, but with the first only if not
  617. already at the start of a line. So for instance 3 would be a newline
  618. if not already at the start of a line, and 2 further newlines.
  619. @item @nicode{~_}
  620. Space character. Parameter: @var{n}.
  621. @c For reference, in Common Lisp ~_ is a conditional newline, but
  622. @c slib fmtdoc.txi described it as a space, so we keep that.
  623. Output a space character, or @var{n} many if a parameter is given.
  624. With a variable parameter this is one way to insert runtime calculated
  625. padding (@nicode{~t} or the various field widths can do similar
  626. things).
  627. @example
  628. (format #f "~v_foo" 4) @result{} " foo"
  629. @end example
  630. @item @nicode{~/}
  631. Tab character. Parameter: @var{n}.
  632. Output a tab character, or @var{n} many if a parameter is given.
  633. @item @nicode{~|}
  634. Formfeed character. Parameter: @var{n}.
  635. Output a formfeed character, or @var{n} many if a parameter is given.
  636. @item @nicode{~!}
  637. Force output. No parameters.
  638. At the end of output, call @code{force-output} to flush any buffers on
  639. the destination (@pxref{Buffering}). @nicode{~!} can occur anywhere in
  640. the format string, but the force is done at the end of output.
  641. When output is to a string (destination @code{#f}), @nicode{~!} does
  642. nothing.
  643. @item @nicode{~newline} (ie.@: newline character)
  644. Continuation line. No parameters.
  645. Skip this newline and any following whitespace in the format string,
  646. ie.@: don't send it to the output. This can be used to break up a
  647. long format string for readability, but not print the extra
  648. whitespace.
  649. @example
  650. (format #f "abc~
  651. ~d def~
  652. ~d" 1 2) @result{} "abc1 def2"
  653. @end example
  654. @nicode{~:newline} skips the newline but leaves any further whitespace
  655. to be printed normally.
  656. @nicode{~@@newline} prints the newline then skips following
  657. whitespace.
  658. @item @nicode{~(} @nicode{~)}
  659. Case conversion. No parameters.
  660. Between @nicode{~(} and @nicode{~)} the case of all output is changed.
  661. The modifiers on @nicode{~(} control the conversion.
  662. @itemize @w{}
  663. @item
  664. @nicode{~(} --- lower case.
  665. @c
  666. @c FIXME: The : and @ modifiers are not yet documented because the
  667. @c code applies string-capitalize and string-capitalize-first to each
  668. @c separate format:out-str call, which has various subtly doubtful
  669. @c effects. And worse they're applied to individual characters,
  670. @c including literal characters in the format string, which has the
  671. @c silly effect of being always an upcase.
  672. @c
  673. @c The Common Lisp spec is apparently for the capitalization to be
  674. @c applied in one hit to the whole of the output between ~( and ~).
  675. @c (This can no doubt be implemented without accumulating all that
  676. @c text, just by keeping a state or the previous char to tell whether
  677. @c within a word.)
  678. @c
  679. @c @item
  680. @c @nicode{:} --- first letter of each word upper case, the rest lower
  681. @c case, as per the @code{string-capitalize} function (@pxref{Alphabetic
  682. @c Case Mapping}).
  683. @c @item
  684. @c @nicode{@@} --- first letter of just the first word upper case, the
  685. @c rest lower case.
  686. @c
  687. @item
  688. @nicode{~:@@(} --- upper case.
  689. @end itemize
  690. For example,
  691. @example
  692. (format #t "~(Hello~)") @print{} hello
  693. (format #t "~:@@(Hello~)") @print{} HELLO
  694. @end example
  695. In the future it's intended the modifiers @nicode{:} and @nicode{@@}
  696. alone will capitalize the first letters of words, as per Common Lisp
  697. @code{format}, but the current implementation of this is flawed and
  698. not recommended for use.
  699. Case conversions do not nest, currently. This might change in the
  700. future, but if it does then it will be to Common Lisp style where the
  701. outermost conversion has priority, overriding inner ones (making those
  702. fairly pointless).
  703. @item @nicode{~@{} @nicode{~@}}
  704. Iteration. Parameter: @var{maxreps} (for @nicode{~@{}).
  705. The format between @nicode{~@{} and @nicode{~@}} is iterated. The
  706. modifiers to @nicode{~@{} determine how arguments are taken. The
  707. default is a list argument with each iteration successively consuming
  708. elements from it. This is a convenient way to output a whole list.
  709. @example
  710. (format #t "~@{~d~@}" '(1 2 3)) @print{} 123
  711. (format #t "~@{~s=~d ~@}" '("x" 1 "y" 2)) @print{} "x"=1 "y"=2
  712. @end example
  713. @nicode{~:@{} takes a single argument which is a list of lists, each
  714. of those contained lists gives the arguments for the iterated format.
  715. @c @print{} on a new line here to avoid overflowing page width in DVI
  716. @example
  717. (format #t "~:@{~dx~d ~@}" '((1 2) (3 4) (5 6)))
  718. @print{} 1x2 3x4 5x6
  719. @end example
  720. @nicode{~@@@{} takes arguments directly, with each iteration
  721. successively consuming arguments.
  722. @example
  723. (format #t "~@@@{~d~@}" 1 2 3) @print{} 123
  724. (format #t "~@@@{~s=~d ~@}" "x" 1 "y" 2) @print{} "x"=1 "y"=2
  725. @end example
  726. @nicode{~:@@@{} takes list arguments, one argument for each iteration,
  727. using that list for the format.
  728. @c @print{} on a new line here to avoid overflowing page width in DVI
  729. @example
  730. (format #t "~:@@@{~dx~d ~@}" '(1 2) '(3 4) '(5 6))
  731. @print{} 1x2 3x4 5x6
  732. @end example
  733. Iterating stops when there are no more arguments or when the
  734. @var{maxreps} parameter to @nicode{~@{} is reached (default no
  735. maximum).
  736. @example
  737. (format #t "~2@{~d~@}" '(1 2 3 4)) @print{} 12
  738. @end example
  739. If the format between @nicode{~@{} and @nicode{~@}} is empty, then a
  740. format string argument is taken (before iteration argument(s)) and
  741. used instead. This allows a sub-format (like @nicode{~?} above) to be
  742. iterated.
  743. @example
  744. (format #t "~@{~@}" "~d" '(1 2 3)) @print{} 123
  745. @end example
  746. @c FIXME: What is the @nicode{:} modifier to ~} meant to do? The
  747. @c Common Lisp spec says it's a minimum of 1 iteration, but the
  748. @c format.scm code seems to merely make it have MAXREPS default to 1.
  749. Iterations can be nested, an inner iteration operates in the same way
  750. as described, but of course on the arguments the outer iteration
  751. provides it. This can be used to work into nested list structures.
  752. For example in the following the inner @nicode{~@{~d~@}x} is applied
  753. to @code{(1 2)} then @code{(3 4 5)} etc.
  754. @example
  755. (format #t "~@{~@{~d~@}x~@}" '((1 2) (3 4 5))) @print{} 12x345x
  756. @end example
  757. See also @nicode{~^} below for escaping from iteration.
  758. @item @nicode{~[} @nicode{~;} @nicode{~]}
  759. Conditional. Parameter: @var{selector}.
  760. A conditional block is delimited by @nicode{~[} and @nicode{~]}, and
  761. @nicode{~;} separates clauses within the block. @nicode{~[} takes an
  762. integer argument and that number clause is used. The first clause is
  763. number 0.
  764. @example
  765. (format #f "~[peach~;banana~;mango~]" 1) @result{} "banana"
  766. @end example
  767. The @var{selector} parameter can be used for the clause number,
  768. instead of taking an argument.
  769. @example
  770. (format #f "~2[peach~;banana~;mango~]") @result{} "mango"
  771. @end example
  772. If the clause number is out of range then nothing is output. Or the
  773. last clause can be @nicode{~:;} to use that for a number out of range.
  774. @example
  775. (format #f "~[banana~;mango~]" 99) @result{} ""
  776. (format #f "~[banana~;mango~:;fruit~]" 99) @result{} "fruit"
  777. @end example
  778. @nicode{~:[} treats the argument as a flag, and expects two clauses.
  779. The first is used if the argument is @code{#f} or the second
  780. otherwise.
  781. @example
  782. (format #f "~:[false~;not false~]" #f) @result{} "false"
  783. (format #f "~:[false~;not false~]" 'abc) @result{} "not false"
  784. (let ((n 3))
  785. (format #t "~d gnu~:[s are~; is~] here" n (= 1 n)))
  786. @print{} 3 gnus are here
  787. @end example
  788. @nicode{~@@[} also treats the argument as a flag, and expects one
  789. clause. If the argument is @code{#f} then no output is produced and
  790. the argument is consumed, otherwise the clause is used and the
  791. argument is not consumed, it's left for the clause. This can be used
  792. for instance to suppress output if @code{#f} means something not
  793. available.
  794. @example
  795. (format #f "~@@[temperature=~d~]" 27) @result{} "temperature=27"
  796. (format #f "~@@[temperature=~d~]" #f) @result{} ""
  797. @end example
  798. @item @nicode{~^}
  799. Escape. Parameters: @var{val1}, @var{val2}, @var{val3}.
  800. Stop formatting if there are no more arguments. This can be used for
  801. instance to have a format string adapt to a variable number of
  802. arguments.
  803. @example
  804. (format #t "~d~^ ~d" 1) @print{} 1
  805. (format #t "~d~^ ~d" 1 2) @print{} 1 2
  806. @end example
  807. Within a @nicode{~@{} @nicode{~@}} iteration, @nicode{~^} stops the
  808. current iteration step if there are no more arguments to that step,
  809. but continuing with possible further steps and the rest of the format.
  810. This can be used for instance to avoid a separator on the last
  811. iteration, or to adapt to variable length argument lists.
  812. @example
  813. (format #f "~@{~d~^/~@} go" '(1 2 3)) @result{} "1/2/3 go"
  814. (format #f "~:@{ ~d~^~d~@} go" '((1) (2 3))) @result{} " 1 23 go"
  815. @end example
  816. @c For reference, format.scm doesn't implement that Common Lisp ~:^
  817. @c modifier which stops the entire iterating of ~:{ or ~@:{.
  818. @c FIXME: Believe the Common Lisp spec is for ~^ within ~[ ~]
  819. @c conditional to terminate the whole format (or iteration step if in
  820. @c an iteration). But format.scm seems to terminate just the
  821. @c conditional form.
  822. @c
  823. @c (format #f "~[abc~^def~;ghi~] blah" 0)
  824. @c @result{} "abc blah" ;; looks wrong
  825. @c FIXME: Believe the Common Lisp spec is for ~^ within ~( ~) to end
  826. @c that case conversion and then also terminate the whole format (or
  827. @c iteration step if in an iteration). But format.scm doesn't seem
  828. @c to do that quite right.
  829. @c
  830. @c (format #f "~d ~^ ~d" 1) @result{} "1 "
  831. @c (format #f "~(~d ~^ ~d~)" 1) @result{} ERROR
  832. Within a @nicode{~?} sub-format, @nicode{~^} operates just on that
  833. sub-format. If it terminates the sub-format then the originating
  834. format will still continue.
  835. @example
  836. (format #t "~? items" "~d~^ ~d" '(1)) @print{} 1 items
  837. (format #t "~? items" "~d~^ ~d" '(1 2)) @print{} 1 2 items
  838. @end example
  839. The parameters to @nicode{~^} (which are numbers) change the condition
  840. used to terminate. For a single parameter, termination is when that
  841. value is zero (notice this makes plain @nicode{~^} equivalent to
  842. @nicode{~#^}). For two parameters, termination is when those two are
  843. equal. For three parameters, termination is when @math{@var{val1}
  844. @le{} @var{val2}} and @math{@var{val2} @le{} @var{val3}}.
  845. @c FIXME: Good examples of these?
  846. @item @nicode{~q}
  847. Inquiry message. Insert a copyright message into the output.
  848. @nicode{~:q} inserts the format implementation version.
  849. @end table
  850. @sp 1
  851. It's an error if there are not enough arguments for the escapes in the
  852. format string, but any excess arguments are ignored.
  853. Iterations @nicode{~@{} @nicode{~@}} and conditionals @nicode{~[}
  854. @nicode{~;} @nicode{~]} can be nested, but must be properly nested,
  855. meaning the inner form must be entirely within the outer form. So
  856. it's not possible, for instance, to try to conditionalize the endpoint
  857. of an iteration.
  858. @example
  859. (format #t "~@{ ~[ ... ~] ~@}" ...) ;; good
  860. (format #t "~@{ ~[ ... ~@} ... ~]" ...) ;; bad
  861. @end example
  862. The same applies to case conversions @nicode{~(} @nicode{~)}, they
  863. must properly nest with respect to iterations and conditionals (though
  864. currently a case conversion cannot nest within another case
  865. conversion).
  866. When a sub-format (@nicode{~?}) is used, that sub-format string must
  867. be self-contained. It cannot for instance give a @nicode{~@{} to
  868. begin an iteration form and have the @nicode{~@}} up in the
  869. originating format, or similar.
  870. @end deffn
  871. @sp 1
  872. Guile contains a @code{format} procedure even when the module
  873. @code{(ice-9 format)} is not loaded. The default @code{format} is
  874. @code{simple-format} (@pxref{Simple Output}), it doesn't support all
  875. escape sequences documented in this section, and will signal an error if
  876. you try to use one of them. The reason for two versions is that the
  877. full @code{format} is fairly large and requires some time to load.
  878. @code{simple-format} is often adequate too.
  879. @node File Tree Walk
  880. @section File Tree Walk
  881. @cindex file tree walk
  882. @cindex file system traversal
  883. @cindex directory traversal
  884. The functions in this section traverse a tree of files and
  885. directories. They come in two flavors: the first one is a high-level
  886. functional interface, and the second one is similar to the C @code{ftw}
  887. and @code{nftw} routines (@pxref{Working with Directory Trees,,, libc,
  888. GNU C Library Reference Manual}).
  889. @example
  890. (use-modules (ice-9 ftw))
  891. @end example
  892. @sp 1
  893. @deffn {Scheme Procedure} file-system-tree file-name [enter? [stat]]
  894. Return a tree of the form @code{(@var{file-name} @var{stat}
  895. @var{children} ...)} where @var{stat} is the result of @code{(@var{stat}
  896. @var{file-name})} and @var{children} are similar structures for each
  897. file contained in @var{file-name} when it designates a directory.
  898. The optional @var{enter?} predicate is invoked as @code{(@var{enter?}
  899. @var{name} @var{stat})} and should return true to allow recursion into
  900. directory @var{name}; the default value is a procedure that always
  901. returns @code{#t}. When a directory does not match @var{enter?}, it
  902. nonetheless appears in the resulting tree, only with zero children.
  903. The @var{stat} argument is optional and defaults to @code{lstat}, as for
  904. @code{file-system-fold} (see below.)
  905. The example below shows how to obtain a hierarchical listing of the
  906. files under the @file{module/language} directory in the Guile source
  907. tree, discarding their @code{stat} info:
  908. @example
  909. (use-modules (ice-9 match))
  910. (define remove-stat
  911. ;; Remove the `stat' object the `file-system-tree' provides
  912. ;; for each file in the tree.
  913. (match-lambda
  914. ((name stat) ; flat file
  915. name)
  916. ((name stat children ...) ; directory
  917. (list name (map remove-stat children)))))
  918. (let ((dir (string-append (assq-ref %guile-build-info 'top_srcdir)
  919. "/module/language")))
  920. (remove-stat (file-system-tree dir)))
  921. @result{}
  922. ("language"
  923. (("value" ("spec.go" "spec.scm"))
  924. ("scheme"
  925. ("spec.go"
  926. "spec.scm"
  927. "compile-tree-il.scm"
  928. "decompile-tree-il.scm"
  929. "decompile-tree-il.go"
  930. "compile-tree-il.go"))
  931. ("tree-il"
  932. ("spec.go"
  933. "fix-letrec.go"
  934. "inline.go"
  935. "fix-letrec.scm"
  936. "compile-glil.go"
  937. "spec.scm"
  938. "optimize.scm"
  939. "primitives.scm"
  940. @dots{}))
  941. @dots{}))
  942. @end example
  943. @end deffn
  944. @cindex file system combinator
  945. It is often desirable to process directories entries directly, rather
  946. than building up a tree of entries in memory, like
  947. @code{file-system-tree} does. The following procedure, a
  948. @dfn{combinator}, is designed to allow directory entries to be processed
  949. directly as a directory tree is traversed; in fact,
  950. @code{file-system-tree} is implemented in terms of it.
  951. @deffn {Scheme Procedure} file-system-fold enter? leaf down up skip error init file-name [stat]
  952. Traverse the directory at @var{file-name}, recursively, and return the
  953. result of the successive applications of the @var{leaf}, @var{down},
  954. @var{up}, and @var{skip} procedures as described below.
  955. Enter sub-directories only when @code{(@var{enter?} @var{path}
  956. @var{stat} @var{result})} returns true. When a sub-directory is
  957. entered, call @code{(@var{down} @var{path} @var{stat} @var{result})},
  958. where @var{path} is the path of the sub-directory and @var{stat} the
  959. result of @code{(false-if-exception (@var{stat} @var{path}))}; when it is
  960. left, call @code{(@var{up} @var{path} @var{stat} @var{result})}.
  961. For each file in a directory, call @code{(@var{leaf} @var{path}
  962. @var{stat} @var{result})}.
  963. When @var{enter?} returns @code{#f}, or when an unreadable directory is
  964. encountered, call @code{(@var{skip} @var{path} @var{stat}
  965. @var{result})}.
  966. When @var{file-name} names a flat file, @code{(@var{leaf} @var{path}
  967. @var{stat} @var{init})} is returned.
  968. When an @code{opendir} or @var{stat} call fails, call @code{(@var{error}
  969. @var{path} @var{stat} @var{errno} @var{result})}, with @var{errno} being
  970. the operating system error number that was raised---e.g.,
  971. @code{EACCES}---and @var{stat} either @code{#f} or the result of the
  972. @var{stat} call for that entry, when available.
  973. The special @file{.} and @file{..} entries are not passed to these
  974. procedures. The @var{path} argument to the procedures is a full file
  975. name---e.g., @code{"../foo/bar/gnu"}; if @var{file-name} is an absolute
  976. file name, then @var{path} is also an absolute file name. Files and
  977. directories, as identified by their device/inode number pair, are
  978. traversed only once.
  979. The optional @var{stat} argument defaults to @code{lstat}, which means
  980. that symbolic links are not followed; the @code{stat} procedure can be
  981. used instead when symbolic links are to be followed (@pxref{File System,
  982. stat}).
  983. The example below illustrates the use of @code{file-system-fold}:
  984. @example
  985. (define (total-file-size file-name)
  986. "Return the size in bytes of the files under FILE-NAME (similar
  987. to `du --apparent-size' with GNU Coreutils.)"
  988. (define (enter? name stat result)
  989. ;; Skip version control directories.
  990. (not (member (basename name) '(".git" ".svn" "CVS"))))
  991. (define (leaf name stat result)
  992. ;; Return RESULT plus the size of the file at NAME.
  993. (+ result (stat:size stat)))
  994. ;; Count zero bytes for directories.
  995. (define (down name stat result) result)
  996. (define (up name stat result) result)
  997. ;; Likewise for skipped directories.
  998. (define (skip name stat result) result)
  999. ;; Ignore unreadable files/directories but warn the user.
  1000. (define (error name stat errno result)
  1001. (format (current-error-port) "warning: ~a: ~a~%"
  1002. name (strerror errno))
  1003. result)
  1004. (file-system-fold enter? leaf down up skip error
  1005. 0 ; initial counter is zero bytes
  1006. file-name))
  1007. (total-file-size ".")
  1008. @result{} 8217554
  1009. (total-file-size "/dev/null")
  1010. @result{} 0
  1011. @end example
  1012. @end deffn
  1013. The alternative C-like functions are described below.
  1014. @deffn {Scheme Procedure} scandir name [select? [entry<?]]
  1015. Return the list of the names of files contained in directory @var{name}
  1016. that match predicate @var{select?} (by default, all files). The
  1017. returned list of file names is sorted according to @var{entry<?}, which
  1018. defaults to @code{string-locale<?} such that file names are sorted in
  1019. the locale's alphabetical order (@pxref{Text Collation}). Return
  1020. @code{#f} when @var{name} is unreadable or is not a directory.
  1021. This procedure is modeled after the C library function of the same name
  1022. (@pxref{Scanning Directory Content,,, libc, GNU C Library Reference
  1023. Manual}).
  1024. @end deffn
  1025. @deffn {Scheme Procedure} ftw startname proc ['hash-size n]
  1026. Walk the file system tree descending from @var{startname}, calling
  1027. @var{proc} for each file and directory.
  1028. Hard links and symbolic links are followed. A file or directory is
  1029. reported to @var{proc} only once, and skipped if seen again in another
  1030. place. One consequence of this is that @code{ftw} is safe against
  1031. circularly linked directory structures.
  1032. Each @var{proc} call is @code{(@var{proc} filename statinfo flag)} and
  1033. it should return @code{#t} to continue, or any other value to stop.
  1034. @var{filename} is the item visited, being @var{startname} plus a
  1035. further path and the name of the item. @var{statinfo} is the return
  1036. from @code{stat} (@pxref{File System}) on @var{filename}. @var{flag}
  1037. is one of the following symbols,
  1038. @table @code
  1039. @item regular
  1040. @var{filename} is a file, this includes special files like devices,
  1041. named pipes, etc.
  1042. @item directory
  1043. @var{filename} is a directory.
  1044. @item invalid-stat
  1045. An error occurred when calling @code{stat}, so nothing is known.
  1046. @var{statinfo} is @code{#f} in this case.
  1047. @item directory-not-readable
  1048. @var{filename} is a directory, but one which cannot be read and hence
  1049. won't be recursed into.
  1050. @item symlink
  1051. @var{filename} is a dangling symbolic link. Symbolic links are
  1052. normally followed and their target reported, the link itself is
  1053. reported if the target does not exist.
  1054. @end table
  1055. The return value from @code{ftw} is @code{#t} if it ran to completion,
  1056. or otherwise the non-@code{#t} value from @var{proc} which caused the
  1057. stop.
  1058. Optional argument symbol @code{hash-size} and an integer can be given
  1059. to set the size of the hash table used to track items already visited.
  1060. (@pxref{Hash Table Reference})
  1061. @c Actually, it's probably safe to escape from ftw, just need to
  1062. @c check it.
  1063. @c
  1064. In the current implementation, returning non-@code{#t} from @var{proc}
  1065. is the only valid way to terminate @code{ftw}. @var{proc} must not
  1066. use @code{throw} or similar to escape.
  1067. @end deffn
  1068. @deffn {Scheme Procedure} nftw startname proc ['chdir] ['depth] ['hash-size n] ['mount] ['physical]
  1069. Walk the file system tree starting at @var{startname}, calling
  1070. @var{proc} for each file and directory. @code{nftw} has extra
  1071. features over the basic @code{ftw} described above.
  1072. Like @code{ftw}, hard links and symbolic links are followed. A file
  1073. or directory is reported to @var{proc} only once, and skipped if seen
  1074. again in another place. One consequence of this is that @code{nftw}
  1075. is safe against circular linked directory structures.
  1076. Each @var{proc} call is @code{(@var{proc} filename statinfo flag
  1077. base level)} and it should return @code{#t} to continue, or any
  1078. other value to stop.
  1079. @var{filename} is the item visited, being @var{startname} plus a
  1080. further path and the name of the item. @var{statinfo} is the return
  1081. from @code{stat} on @var{filename} (@pxref{File System}). @var{base}
  1082. is an integer offset into @var{filename} which is where the basename
  1083. for this item begins. @var{level} is an integer giving the directory
  1084. nesting level, starting from 0 for the contents of @var{startname} (or
  1085. that item itself if it's a file). @var{flag} is one of the following
  1086. symbols,
  1087. @table @code
  1088. @item regular
  1089. @var{filename} is a file, including special files like devices, named
  1090. pipes, etc.
  1091. @item directory
  1092. @var{filename} is a directory.
  1093. @item directory-processed
  1094. @var{filename} is a directory, and its contents have all been visited.
  1095. This flag is given instead of @code{directory} when the @code{depth}
  1096. option below is used.
  1097. @item invalid-stat
  1098. An error occurred when applying @code{stat} to @var{filename}, so
  1099. nothing is known about it. @var{statinfo} is @code{#f} in this case.
  1100. @item directory-not-readable
  1101. @var{filename} is a directory, but one which cannot be read and hence
  1102. won't be recursed into.
  1103. @item stale-symlink
  1104. @var{filename} is a dangling symbolic link. Links are normally
  1105. followed and their target reported, the link itself is reported if its
  1106. target does not exist.
  1107. @item symlink
  1108. When the @code{physical} option described below is used, this
  1109. indicates @var{filename} is a symbolic link whose target exists (and
  1110. is not being followed).
  1111. @end table
  1112. The following optional arguments can be given to modify the way
  1113. @code{nftw} works. Each is passed as a symbol (and @code{hash-size}
  1114. takes a following integer value).
  1115. @table @asis
  1116. @item @code{chdir}
  1117. Change to the directory containing the item before calling @var{proc}.
  1118. When @code{nftw} returns the original current directory is restored.
  1119. Under this option, generally the @var{base} parameter to each
  1120. @var{proc} call should be used to pick out the base part of the
  1121. @var{filename}. The @var{filename} is still a path but with a changed
  1122. directory it won't be valid (unless the @var{startname} directory was
  1123. absolute).
  1124. @item @code{depth}
  1125. Visit files ``depth first'', meaning @var{proc} is called for the
  1126. contents of each directory before it's called for the directory
  1127. itself. Normally a directory is reported first, then its contents.
  1128. Under this option, the @var{flag} to @var{proc} for a directory is
  1129. @code{directory-processed} instead of @code{directory}.
  1130. @item @code{hash-size @var{n}}
  1131. Set the size of the hash table used to track items already visited.
  1132. (@pxref{Hash Table Reference})
  1133. @item @code{mount}
  1134. Don't cross a mount point, meaning only visit items on the same
  1135. file system as @var{startname} (ie.@: the same @code{stat:dev}).
  1136. @item @code{physical}
  1137. Don't follow symbolic links, instead report them to @var{proc} as
  1138. @code{symlink}. Dangling links (those whose target doesn't exist) are
  1139. still reported as @code{stale-symlink}.
  1140. @end table
  1141. The return value from @code{nftw} is @code{#t} if it ran to
  1142. completion, or otherwise the non-@code{#t} value from @var{proc} which
  1143. caused the stop.
  1144. @c For reference, one reason not to escape is that the current
  1145. @c directory is not saved and restored with dynamic-wind. Maybe
  1146. @c changing that would be enough to allow escaping.
  1147. @c
  1148. In the current implementation, returning non-@code{#t} from @var{proc}
  1149. is the only valid way to terminate @code{ftw}. @var{proc} must not
  1150. use @code{throw} or similar to escape.
  1151. @end deffn
  1152. @node Queues
  1153. @section Queues
  1154. @cindex queues
  1155. @tindex Queues
  1156. @noindent
  1157. The functions in this section are provided by
  1158. @example
  1159. (use-modules (ice-9 q))
  1160. @end example
  1161. This module implements queues holding arbitrary scheme objects and
  1162. designed for efficient first-in / first-out operations.
  1163. @code{make-q} creates a queue, and objects are entered and removed
  1164. with @code{enq!} and @code{deq!}. @code{q-push!} and @code{q-pop!}
  1165. can be used too, treating the front of the queue like a stack.
  1166. @sp 1
  1167. @deffn {Scheme Procedure} make-q
  1168. Return a new queue.
  1169. @end deffn
  1170. @deffn {Scheme Procedure} q? obj
  1171. Return @code{#t} if @var{obj} is a queue, or @code{#f} if not.
  1172. Note that queues are not a distinct class of objects but are
  1173. implemented with cons cells. For that reason certain list structures
  1174. can get @code{#t} from @code{q?}.
  1175. @end deffn
  1176. @deffn {Scheme Procedure} enq! q obj
  1177. Add @var{obj} to the rear of @var{q}, and return @var{q}.
  1178. @end deffn
  1179. @deffn {Scheme Procedure} deq! q
  1180. @deffnx {Scheme Procedure} q-pop! q
  1181. Remove and return the front element from @var{q}. If @var{q} is
  1182. empty, a @code{q-empty} exception is thrown.
  1183. @code{deq!} and @code{q-pop!} are the same operation, the two names
  1184. just let an application match @code{enq!} with @code{deq!}, or
  1185. @code{q-push!} with @code{q-pop!}.
  1186. @end deffn
  1187. @deffn {Scheme Procedure} q-push! q obj
  1188. Add @var{obj} to the front of @var{q}, and return @var{q}.
  1189. @end deffn
  1190. @deffn {Scheme Procedure} q-length q
  1191. Return the number of elements in @var{q}.
  1192. @end deffn
  1193. @deffn {Scheme Procedure} q-empty? q
  1194. Return true if @var{q} is empty.
  1195. @end deffn
  1196. @deffn {Scheme Procedure} q-empty-check q
  1197. Throw a @code{q-empty} exception if @var{q} is empty.
  1198. @end deffn
  1199. @deffn {Scheme Procedure} q-front q
  1200. Return the first element of @var{q} (without removing it). If @var{q}
  1201. is empty, a @code{q-empty} exception is thrown.
  1202. @end deffn
  1203. @deffn {Scheme Procedure} q-rear q
  1204. Return the last element of @var{q} (without removing it). If @var{q}
  1205. is empty, a @code{q-empty} exception is thrown.
  1206. @end deffn
  1207. @deffn {Scheme Procedure} q-remove! q obj
  1208. Remove all occurrences of @var{obj} from @var{q}, and return @var{q}.
  1209. @var{obj} is compared to queue elements using @code{eq?}.
  1210. @end deffn
  1211. @sp 1
  1212. @cindex @code{q-empty}
  1213. The @code{q-empty} exceptions described above are thrown just as
  1214. @code{(throw 'q-empty)}, there's no message etc like an error throw.
  1215. A queue is implemented as a cons cell, the @code{car} containing a
  1216. list of queued elements, and the @code{cdr} being the last cell in
  1217. that list (for ease of enqueuing).
  1218. @example
  1219. (@var{list} . @var{last-cell})
  1220. @end example
  1221. @noindent
  1222. If the queue is empty, @var{list} is the empty list and
  1223. @var{last-cell} is @code{#f}.
  1224. An application can directly access the queue list if desired, for
  1225. instance to search the elements or to insert at a specific point.
  1226. @deffn {Scheme Procedure} sync-q! q
  1227. Recompute the @var{last-cell} field in @var{q}.
  1228. All the operations above maintain @var{last-cell} as described, so
  1229. normally there's no need for @code{sync-q!}. But if an application
  1230. modifies the queue @var{list} then it must either maintain
  1231. @var{last-cell} similarly, or call @code{sync-q!} to recompute it.
  1232. @end deffn
  1233. @node Streams
  1234. @section Streams
  1235. @cindex streams
  1236. This section documents Guile's legacy stream module. For a more
  1237. complete and portable stream library, @pxref{SRFI-41}.
  1238. A stream represents a sequence of values, each of which is calculated
  1239. only when required. This allows large or even infinite sequences to
  1240. be represented and manipulated with familiar operations like ``car'',
  1241. ``cdr'', ``map'' or ``fold''. In such manipulations only as much as
  1242. needed is actually held in memory at any one time. The functions in
  1243. this section are available from
  1244. @example
  1245. (use-modules (ice-9 streams))
  1246. @end example
  1247. Streams are implemented using promises (@pxref{Delayed Evaluation}),
  1248. which is how the underlying calculation of values is made only when
  1249. needed, and the values then retained so the calculation is not
  1250. repeated.
  1251. @noindent
  1252. Here is a simple example producing a stream of all odd numbers,
  1253. @example
  1254. (define odds (make-stream (lambda (state)
  1255. (cons state (+ state 2)))
  1256. 1))
  1257. (stream-car odds) @result{} 1
  1258. (stream-car (stream-cdr odds)) @result{} 3
  1259. @end example
  1260. @noindent
  1261. @code{stream-map} could be used to derive a stream of odd squares,
  1262. @example
  1263. (define (square n) (* n n))
  1264. (define oddsquares (stream-map square odds))
  1265. @end example
  1266. These are infinite sequences, so it's not possible to convert them to
  1267. a list, but they could be printed (infinitely) with for example
  1268. @example
  1269. (stream-for-each (lambda (n sq)
  1270. (format #t "~a squared is ~a\n" n sq))
  1271. odds oddsquares)
  1272. @print{}
  1273. 1 squared is 1
  1274. 3 squared is 9
  1275. 5 squared is 25
  1276. 7 squared is 49
  1277. @dots{}
  1278. @end example
  1279. @sp 1
  1280. @deffn {Scheme Procedure} make-stream proc initial-state
  1281. Return a new stream, formed by calling @var{proc} successively.
  1282. Each call is @code{(@var{proc} @var{state})}, it should return a pair,
  1283. the @code{car} being the value for the stream, and the @code{cdr}
  1284. being the new @var{state} for the next call. For the first call
  1285. @var{state} is the given @var{initial-state}. At the end of the
  1286. stream, @var{proc} should return some non-pair object.
  1287. @end deffn
  1288. @deffn {Scheme Procedure} stream-car stream
  1289. Return the first element from @var{stream}. @var{stream} must not be
  1290. empty.
  1291. @end deffn
  1292. @deffn {Scheme Procedure} stream-cdr stream
  1293. Return a stream which is the second and subsequent elements of
  1294. @var{stream}. @var{stream} must not be empty.
  1295. @end deffn
  1296. @deffn {Scheme Procedure} stream-null? stream
  1297. Return true if @var{stream} is empty.
  1298. @end deffn
  1299. @deffn {Scheme Procedure} list->stream list
  1300. @deffnx {Scheme Procedure} vector->stream vector
  1301. Return a stream with the contents of @var{list} or @var{vector}.
  1302. @var{list} or @var{vector} should not be modified subsequently, since
  1303. it's unspecified whether changes there will be reflected in the stream
  1304. returned.
  1305. @end deffn
  1306. @deffn {Scheme Procedure} port->stream port readproc
  1307. Return a stream which is the values obtained by reading from @var{port}
  1308. using @var{readproc}. Each read call is @code{(@var{readproc}
  1309. @var{port})}, and it should return an EOF object (@pxref{Binary I/O}) at
  1310. the end of input.
  1311. For example a stream of characters from a file,
  1312. @example
  1313. (port->stream (open-input-file "/foo/bar.txt") read-char)
  1314. @end example
  1315. @end deffn
  1316. @deffn {Scheme Procedure} stream->list stream
  1317. Return a list which is the entire contents of @var{stream}.
  1318. @end deffn
  1319. @deffn {Scheme Procedure} stream->reversed-list stream
  1320. Return a list which is the entire contents of @var{stream}, but in
  1321. reverse order.
  1322. @end deffn
  1323. @deffn {Scheme Procedure} stream->list&length stream
  1324. Return two values (@pxref{Multiple Values}), being firstly a list
  1325. which is the entire contents of @var{stream}, and secondly the number
  1326. of elements in that list.
  1327. @end deffn
  1328. @deffn {Scheme Procedure} stream->reversed-list&length stream
  1329. Return two values (@pxref{Multiple Values}) being firstly a list which
  1330. is the entire contents of @var{stream}, but in reverse order, and
  1331. secondly the number of elements in that list.
  1332. @end deffn
  1333. @deffn {Scheme Procedure} stream->vector stream
  1334. Return a vector which is the entire contents of @var{stream}.
  1335. @end deffn
  1336. @defun stream-fold proc init stream1 stream2 @dots{}
  1337. Apply @var{proc} successively over the elements of the given streams,
  1338. from first to last until the end of the shortest stream is reached.
  1339. Return the result from the last @var{proc} call.
  1340. Each call is @code{(@var{proc} elem1 elem2 @dots{} prev)}, where each
  1341. @var{elem} is from the corresponding @var{stream}. @var{prev} is the
  1342. return from the previous @var{proc} call, or the given @var{init} for
  1343. the first call.
  1344. @end defun
  1345. @defun stream-for-each proc stream1 stream2 @dots{}
  1346. Call @var{proc} on the elements from the given @var{stream}s. The
  1347. return value is unspecified.
  1348. Each call is @code{(@var{proc} elem1 elem2 @dots{})}, where each
  1349. @var{elem} is from the corresponding @var{stream}.
  1350. @code{stream-for-each} stops when it reaches the end of the shortest
  1351. @var{stream}.
  1352. @end defun
  1353. @defun stream-map proc stream1 stream2 @dots{}
  1354. Return a new stream which is the results of applying @var{proc} to the
  1355. elements of the given @var{stream}s.
  1356. Each call is @code{(@var{proc} elem1 elem2 @dots{})}, where each
  1357. @var{elem} is from the corresponding @var{stream}. The new stream
  1358. ends when the end of the shortest given @var{stream} is reached.
  1359. @end defun
  1360. @node Buffered Input
  1361. @section Buffered Input
  1362. @cindex Buffered input
  1363. @cindex Line continuation
  1364. The following functions are provided by
  1365. @example
  1366. (use-modules (ice-9 buffered-input))
  1367. @end example
  1368. A buffered input port allows a reader function to return chunks of
  1369. characters which are to be handed out on reading the port. A notion
  1370. of further input for an application level logical expression is
  1371. maintained too, and passed through to the reader.
  1372. @deffn {Scheme Procedure} make-buffered-input-port reader
  1373. Create an input port which returns characters obtained from the given
  1374. @var{reader} function. @var{reader} is called (@var{reader} cont),
  1375. and should return a string or an EOF object.
  1376. The new port gives precisely the characters returned by @var{reader},
  1377. nothing is added, so if any newline characters or other separators are
  1378. desired they must come from the reader function.
  1379. The @var{cont} parameter to @var{reader} is @code{#f} for initial
  1380. input, or @code{#t} when continuing an expression. This is an
  1381. application level notion, set with
  1382. @code{set-buffered-input-continuation?!} below. If the user has
  1383. entered a partial expression then it allows @var{reader} for instance
  1384. to give a different prompt to show more is required.
  1385. @end deffn
  1386. @deffn {Scheme Procedure} make-line-buffered-input-port reader
  1387. @cindex Line buffered input
  1388. Create an input port which returns characters obtained from the
  1389. specified @var{reader} function, similar to
  1390. @code{make-buffered-input-port} above, but where @var{reader} is
  1391. expected to be a line-oriented.
  1392. @var{reader} is called (@var{reader} cont), and should return a string
  1393. or an EOF object as above. Each string is a line of input without a
  1394. newline character, the port code inserts a newline after each string.
  1395. @end deffn
  1396. @deffn {Scheme Procedure} set-buffered-input-continuation?! port cont
  1397. Set the input continuation flag for a given buffered input
  1398. @var{port}.
  1399. An application uses this by calling with a @var{cont} flag of
  1400. @code{#f} when beginning to read a new logical expression. For
  1401. example with the Scheme @code{read} function (@pxref{Scheme Read}),
  1402. @example
  1403. (define my-port (make-buffered-input-port my-reader))
  1404. (set-buffered-input-continuation?! my-port #f)
  1405. (let ((obj (read my-port)))
  1406. ...
  1407. @end example
  1408. @end deffn
  1409. @c Local Variables:
  1410. @c TeX-master: "guile.texi"
  1411. @c End: