X-Git-Url: http://git.archive.openwrt.org/?p=project%2Flibubox.git;a=blobdiff_plain;f=ustream.h;h=d9f98b78e86b1a7c22f6a8d918060422e59e1b3f;hp=c9e23e89f504a73e5d4cf484b64f9c2676317f1c;hb=dc69ce4799deb53797266d55311871b9c0062066;hpb=768a69b3cedfebde10825847e42f35ed4aee1856 diff --git a/ustream.h b/ustream.h index c9e23e8..d9f98b7 100644 --- a/ustream.h +++ b/ustream.h @@ -19,6 +19,7 @@ #ifndef __USTREAM_H #define __USTREAM_H +#include #include "uloop.h" struct ustream; @@ -48,6 +49,7 @@ struct ustream_buf_list { struct ustream { struct ustream_buf_list r, w; struct uloop_timeout state_change; + struct ustream *next; /* * notify_read: @@ -99,6 +101,14 @@ struct ustream { void (*set_read_blocked)(struct ustream *s); /* + * poll: (optional) + * defined by the upstream implementation, called to request polling for + * available data. + * returns true if data was fetched. + */ + bool (*poll)(struct ustream *s); + + /* * ustream user should set this if the input stream is expected * to contain string data. the core will keep all data 0-terminated. */ @@ -180,4 +190,12 @@ static inline void ustream_state_change(struct ustream *s) uloop_timeout_set(&s->state_change, 0); } +static inline bool ustream_poll(struct ustream *s) +{ + if (!s->poll) + return false; + + return s->poll(s); +} + #endif