diff options
author | patthoyts <patthoyts@users.sourceforge.net> | 2008-10-23 23:17:38 (GMT) |
---|---|---|
committer | patthoyts <patthoyts@users.sourceforge.net> | 2008-10-23 23:17:38 (GMT) |
commit | 6e17c8ff854c2c7d06c9bd399e3d24f3891d18e6 (patch) | |
tree | 1b0f765447e5e0034bf99da8e44a56664c0aa9da /library/http/http.tcl | |
parent | a5a02e5016e0e63058f91dbf21fd31419a9d00d1 (diff) | |
download | tcl-6e17c8ff854c2c7d06c9bd399e3d24f3891d18e6.zip tcl-6e17c8ff854c2c7d06c9bd399e3d24f3891d18e6.tar.gz tcl-6e17c8ff854c2c7d06c9bd399e3d24f3891d18e6.tar.bz2 |
Fixed a failure to read SHOUTcast streams with the new 2.7
package. Introduced a new intial state as the first response may not
be HTTP*.
Diffstat (limited to 'library/http/http.tcl')
-rw-r--r-- | library/http/http.tcl | 17 |
1 files changed, 10 insertions, 7 deletions
diff --git a/library/http/http.tcl b/library/http/http.tcl index 046329b..fab054f 100644 --- a/library/http/http.tcl +++ b/library/http/http.tcl @@ -8,12 +8,12 @@ # See the file "license.terms" for information on usage and redistribution of # this file, and for a DISCLAIMER OF ALL WARRANTIES. # -# RCS: @(#) $Id: http.tcl,v 1.71 2008/08/11 21:58:07 dgp Exp $ +# RCS: @(#) $Id: http.tcl,v 1.72 2008/10/23 23:17:38 patthoyts Exp $ package require Tcl 8.4 # Keep this in sync with pkgIndex.tcl and with the install directories # in Makefiles -package provide http 2.7.1 +package provide http 2.7.2 namespace eval http { # Allow resourcing to not clobber existing data @@ -319,7 +319,7 @@ proc http::geturl { url args } { -queryprogress {} -protocol 1.1 binary 0 - state header + state connecting meta {} coding {} currentsize 0 @@ -942,7 +942,12 @@ proc http::Event {sock token} { CloseSocket $sock return } - if {$state(state) eq "header"} { + if {$state(state) eq "connecting"} { + set state(state) "header" + if {[catch {gets $sock state(http)} n]} { + return [Finish $token $n] + } + } elseif {$state(state) eq "header"} { if {[catch {gets $sock line} n]} { return [Finish $token $n] } elseif {$n == 0} { @@ -985,7 +990,7 @@ proc http::Event {sock token} { fconfigure $state(-channel) -translation binary } } - if {[info exists state(-channel)] && + if {[info exists state(-channel)] && ![info exists state(-handler)]} { # Initiate a sequence of background fcopies fileevent $sock readable {} @@ -1019,8 +1024,6 @@ proc http::Event {sock token} { } } lappend state(meta) $key [string trim $value] - } elseif {[string match HTTP* $line]} { - set state(http) $line } } } else { |