win32 io bugfixes

darcs
erg 2006-09-11 00:51:25 +00:00
parent b645c7d5ae
commit 07af3690f2
5 changed files with 46 additions and 50 deletions

View File

@ -1,20 +0,0 @@
! Copyright (C) 2006 Mackenzie Straight, Doug Coleman.
IN: io
USING: compiler namespaces kernel win32-io-internals win32-stream win32-api
threads ;
: <file-reader> <win32-file-reader> ;
: <file-writer> <win32-file-writer> ;
: <server> make-win32-server ;
IN: io-internals
: io-multiplex ( ms -- )
dup -1 = [ drop INFINITE ] when cancel-timedout wait-for-io
swap [ schedule-thread-with ] [ drop ] if* ;
: init-io ( -- )
win32-init-stdio
init-winsock ;

View File

@ -0,0 +1,41 @@
! Copyright (C) 2006 Mackenzie Straight, Doug Coleman.
IN: io
USING: win32-api win32-io-internals win32-server win32-stream ;
USING: alien kernel io-internals namespaces threads ;
: <file-reader> ( path -- stream ) <win32-file-reader> ;
: <file-writer> ( path -- stream ) <win32-file-writer> ;
SYMBOL: serv
: accept ( server -- client )
[
duplex-stream-in
serv set
serv get update-timeout new-socket 64 <buffer>
[
serv get alloc-io-callback f swap init-overlapped
>r >r >r serv get win32-stream-handle r> r>
buffer-ptr <alien> 0 32 32 f r> AcceptEx
handle-socket-error!=0/f stop
] callcc1 drop
swap dup add-completion <win32-stream> <win32-duplex-stream>
dupd <win32-client-stream> swap buffer-free
] with-scope ;
: <client> ( host port -- stream )
client-sockaddr new-socket
[ swap "sockaddr-in" c-size connect handle-socket-error!=0/f ] keep
dup add-completion <win32-stream> <win32-duplex-stream> ;
: <server> ( port -- stream ) make-win32-server ;
IN: io-internals
: io-multiplex ( ms -- )
dup -1 = [ drop INFINITE ] when cancel-timedout wait-for-io
swap [ schedule-thread-with ] [ drop ] if* ;
: init-io ( -- )
win32-init-stdio
init-winsock ;

View File

@ -5,5 +5,5 @@ PROVIDE: library/io/windows {
"io-internals.factor"
"stream.factor"
"server.factor"
"io-last.factor"
"io.factor"
} ;

View File

@ -1,9 +1,9 @@
! Copyright (C) 2006 Mackenzie Straight, Doug Coleman.
IN: win32-stream
IN: win32-server
USING: alien errors generic kernel kernel-internals math namespaces
prettyprint sequences io strings threads win32-api
win32-io-internals io-internals ;
win32-io-internals io-internals win32-stream ;
TUPLE: win32-client-stream host port ;
@ -68,26 +68,3 @@ M: win32-client-stream client-stream-port ( win32-client-stream -- port )
r> set-sockaddr-in-addr
] keep ;
IN: io
SYMBOL: serv
: accept ( server -- client )
[
duplex-stream-in
serv set
serv get update-timeout new-socket 64 <buffer>
[
serv get alloc-io-callback f swap init-overlapped
>r >r >r serv get win32-stream-handle r> r>
buffer-ptr <alien> 0 32 32 f r> AcceptEx
handle-socket-error!=0/f stop
] callcc1 drop
swap dup add-completion <win32-stream> <win32-duplex-stream>
dupd <win32-client-stream> swap buffer-free
] with-scope ;
: <client> ( host port -- stream )
client-sockaddr new-socket
[ swap "sockaddr-in" c-size connect handle-socket-error!=0/f ] keep
dup add-completion <win32-stream> <win32-duplex-stream> ;

View File

@ -64,8 +64,7 @@ TUPLE: win32-duplex-stream ;
dup empty? [
2drop >string-or-f nip
] [
swapd over >r nappend r>
[ length - ] keep swap do-read-count
rot >r [ length - ] keep r> [ swap nappend ] keep swap do-read-count
] if
] if ;
@ -112,8 +111,7 @@ M: win32-stream-reader stream-read1 ( stream -- ch/f )
>r 1 r> consume-input >string-or-f first ;
M: win32-stream-reader stream-read ( n stream -- str/f )
>r [ <sbuf> ] keep r> -rot do-read-count ;
swap >r win32-buffer-size <sbuf> r> do-read-count ;
M: win32-stream-writer stream-close ( stream -- )
dup maybe-flush-output