[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
with-output-to-string query
- To: Scott E. Fahlman <Fahlman@CMU-CS-C.ARPA>
- Subject: with-output-to-string query
- From: David A. Moon <Moon@SCRC-STONY-BROOK.ARPA>
- Date: Mon, 19 Aug 85 12:57 EDT
- Cc: common-lisp@SU-AI.ARPA
- In-reply-to: <FAHLMAN.12136200411.BABYL@CMU-CS-C.ARPA>
    Date: Sun, 18 Aug 1985  18:19 EDT
    From: "Scott E. Fahlman" <Fahlman@CMU-CS-C.ARPA>
	It seems clear to me that no one intended WITH-OUTPUT-TO-STRING to throw away
	characters if given a non-adjustable string to fill.  Since it can't return
	a value to say whether it filled the string, it should signal an error.  I
	think this is just looseness in the manual, not a real language issue.  If
	someone else disagrees they should speak up!
    I agree that it would be preferable in this case to signal an error --
    as I said in my earlier note, it is rather treacherous to just discard
    charaters without warning.  However, the curent text of the manual seems
    to say more or less clearly (though by indirection thropugh Vector-Push)
    that no error is signalled in this case
I don't see this implication in the text.  The only thing that is clear is
that it says the output is appended to the string.
This is getting awfully rabbinical!
					   , so to "clarify" the manual as
    Moon suggests is really a change, though one in a corner so obscure that
    it wouldn't bother people too much.  Perhaps the best resolution is for
    now to say that "it is an error" to overflow the string being written,
    and to change this to "signals an error" in Common Lisp 86 (or
    whenever).
Or leave it "is an error" for all time, allowing individual implementations
to choose between safety, efficiency, and compatible with past broken
implementations.  That seems like the best resolution to me.
Of course no matter what the resolution, it doesn't affect my implementation,
since all strings are adjustable, so I'm happy.