On Jun 10, 2011, at 7:35 PM, jodischla...@gmx.de wrote:

> I want the TCPServer to return some data block to each client that connects. 
> I basically just want to put the bytes of the NSData object one after another 
> on the outputstream that is connected to the socket.
> Problem: I would have to save the position in the data for each client to 
> return the correct bytes to the client. At that point I thought that's what 
> streams are for. To save your current position in a blob of bytes that should 
> be read in order.
> Solution: Create a new NSInputStream (independent from the input stream of 
> the TCPServer. That's why I talked about the data input stream, the input 
> stream that reads the bytes of the data object) for each incoming connection. 
> Guessing that after the NSInputStream based on the data is open it won't have 
> any problems reading the data I only wait for the output stream to have space 
> available and whenever it has I read some bytes from the data input stream 
> and write them on the server output stream. I completely ignore the server 
> input stream (except for logging the received data, when searching for bugs).

When the client can accept data, you can just read from the input stream.  If 
you get a zero-length read, then the input stream is exhausted.  You may not 
get an event for that.  In fact, the input stream need not be scheduled on a 
run loop and, if it's not, the delegate won't get any calls.  The events and 
the delegate are for asynchronous events in the stream, and there are none for 
a stream based on a data object.

Regards,
Ken

_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
http://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com

This email sent to arch...@mail-archive.com

Reply via email to