X-Git-Url: http://git.marmaro.de/?a=blobdiff_plain;f=uip%2Fscansbr.c;h=df18258431101c3032e2ae23f9844a89208e3278;hb=cd665517f488ca62e71b7fd1db6df0813dee052a;hp=6a9278bbd539895d2f636d2c8a16abba032c45cc;hpb=d9c0d17aa110ec0e5db5f0928fead5a1ff60a9e2;p=mmh diff --git a/uip/scansbr.c b/uip/scansbr.c index 6a9278b..df18258 100644 --- a/uip/scansbr.c +++ b/uip/scansbr.c @@ -256,6 +256,8 @@ body:; while (state == BODY) { #ifdef LINUX_STDIO if (scnout->_IO_write_ptr == scnout->_IO_write_end) { +#elif defined(__DragonFly__) + if (((struct __FILE_public *)scnout)->_w <= 0) { #else if (scnout->_cnt <= 0) { #endif @@ -266,6 +268,10 @@ body:; state = m_getfld(state, name, scnout->_IO_write_ptr, (long)scnout->_IO_write_ptr-(long)scnout->_IO_write_end , inb); scnout->_IO_write_ptr += msg_count; +#elif defined(__DragonFly__) + state = m_getfld( state, name, ((struct __FILE_public *)scnout)->_p, -(((struct __FILE_public *)scnout)->_w), inb ); + ((struct __FILE_public *)scnout)->_w -= msg_count; + ((struct __FILE_public *)scnout)->_p += msg_count; #else state = m_getfld( state, name, scnout->_ptr, -(scnout->_cnt), inb ); scnout->_cnt -= msg_count;