Cross-platform (linux/Win32) nonblocking C++ IO on stdin/stdout/stderr

I'm trying to find the best solution for nonblocking IO via stdin/stdout with the following characteristics:

  • As long as there is enough data, read in n-sized chunks.
  • If there's not enough data, read in a partial chunk.
  • If there is no data available, block until there is some (even though it may be smaller than n).

The goal is to allow efficient transfer for large datasets while processing 'control' codes immediately (instead of having them linger in some partially-filled buffer somewhere).

I know I can achieve this by using threads and a istream::get() loop, or by writing a bunch of platform-specific code (since you can't select() on file handles in windows)... ((There is also istream::readsome() which seems promising, but the only results I can find on google were of people saying it doesn't actually work well.))

Since I haven't done much coding w/ these APIs, perhaps there is a better way.

Answers


Maybe boost::asio can be of use for you?


Need Your Help

JavaScript iCal Library

javascript ruby-on-rails ember.js icalendar

I am trying to write an application that will use Ember to post to a Rails app with a Postgres database backend. The application has a front end that deals with users calendars and keeping track of

Many to Many Query Buider Symfony2

symfony orm many-to-many query-builder

I have two entities. Category and Product. They mapped ManyToMany.