From edi at agharta.de Mon Nov 14 14:31:41 2005 From: edi at agharta.de (Edi Weitz) Date: Mon, 14 Nov 2005 15:31:41 +0100 Subject: [tbnl-announce] Re: [tbnl-devel] tbnl patch In-Reply-To: <20051112174328.74480.qmail@web50613.mail.yahoo.com> (Jeff Caldwell's message of "Sat, 12 Nov 2005 09:43:28 -0800 (PST)") References: <20051112174328.74480.qmail@web50613.mail.yahoo.com> Message-ID: On Sat, 12 Nov 2005 09:43:28 -0800 (PST), Jeff Caldwell wrote: > Here is a tiny patch for tbnl. The motivation is that I'm working > with blocks of dispatch table entries that are added and withdrawn > as modules without restarting tbnl. I'd also like reflective access > to the dispatch table e.g. to show a web page of installed dispatch > handlers. Perhaps this would be something for the "contrib" directory of TBNL? > To affect the base distrubution as little as possible, I took the > loop through the dispatch table that funcalls each entry and moved > that loop into a defmethod. Now I can specialize on the method and > have my own dispatch mechanisms. Thanks Jeff, I've just made a new release with these changes. ChangeLog: Version 0.8.5 2005-11-14 Added generic function DISPATCH-REQUEST (thanks to Jeff Caldwell) Download: Cheers, Edi. From edi at agharta.de Fri Nov 18 15:50:42 2005 From: edi at agharta.de (Edi Weitz) Date: Fri, 18 Nov 2005 16:50:42 +0100 Subject: [tbnl-announce] New version 0.8.6 Message-ID: ChangeLog: Version 0.8.6 2005-11-18 Restored original stream-based code for multipart/form-data parsing (got lost somehow) Wrap REMOTE-ADDR with IGNORE-ERRORS (just in case) Download: Cheers, Edi. From edi at agharta.de Tue Nov 29 09:14:59 2005 From: edi at agharta.de (Edi Weitz) Date: Tue, 29 Nov 2005 10:14:59 +0100 Subject: [tbnl-announce] New version 0.8.7 (Was: Content length with multibyte character encodings) In-Reply-To: (Ignas Mikalajunas's message of "Tue, 29 Nov 2005 00:18:08 +0200") References: Message-ID: On Tue, 29 Nov 2005 00:18:08 +0200, Ignas Mikalajunas wrote: > Content length is calculated by calling (length content) which > produces wrong results with unicode characters in the string. Piso > on #lisp proposed a solution - using (length (string-to-octets > string :external-format :utf-8)) which translates to just (length > (string-to-octets string :external-format)) in the code. I won't do that because it's most likely a terrible performance hog if you convert each page to octets be default (assuming that most users already send octets). I also don't understand why (length (string-to-octets string :external-format :utf-8)) translates to (length (string-to-octets string :external-format)) > The true way to solve this would be using (file-string-length), > but the function is not working properly on sbcl yet. Huh? How is that supposed to work (even if it would work on SBCL)? *TBNL-STREAM* is a binary stream which accepts octets, isn't it? > So could you please fix the (send-output), IMHO there's nothing to "fix" because TBNL works as expected. The docs clearly say that you're supposed to send octets, see for example here: Note that the UTF-8 example that comes with TBNL sends a correct header. FWIW, I've just released a new version where you can manually set the CONTENT-LENGTH slot of the REPLY object. If it is not NIL TBNL won't bother to compute the content length so you can set it to any value you want. Note, though, that you'll run into trouble w.r.t. TBNL/Apache interaction if you set a wrong value there. > because with current setup browsers that strictly adhere to the > content-lenght (IE 6.0, Opera) would trim 1 character of the > responses body for each UTF-8 character in it. Nope, that's not how UTF-8 works. Cheers, Edi.