2004-08-12 17:36:36 -04:00
|
|
|
#include "factor.h"
|
|
|
|
|
|
|
|
PORT* untag_port(CELL tagged)
|
|
|
|
{
|
|
|
|
PORT* p;
|
|
|
|
type_check(PORT_TYPE,tagged);
|
|
|
|
p = (PORT*)UNTAG(tagged);
|
|
|
|
/* after image load & save, ports are no longer valid */
|
|
|
|
if(p->fd == -1)
|
|
|
|
general_error(ERROR_PORT_EXPIRED,tagged);
|
|
|
|
return p;
|
|
|
|
}
|
|
|
|
|
2004-08-15 21:50:44 -04:00
|
|
|
PORT* port(CELL fd)
|
2004-08-12 17:36:36 -04:00
|
|
|
{
|
|
|
|
PORT* port = allot_object(PORT_TYPE,sizeof(PORT));
|
|
|
|
port->fd = fd;
|
2004-08-12 23:40:28 -04:00
|
|
|
port->buffer = NULL;
|
2004-08-15 21:50:44 -04:00
|
|
|
port->line = F;
|
2004-08-12 17:36:36 -04:00
|
|
|
port->buf_mode = B_NONE;
|
|
|
|
port->buf_fill = 0;
|
|
|
|
port->buf_pos = 0;
|
2004-08-15 21:50:44 -04:00
|
|
|
|
|
|
|
if(fcntl(port->fd,F_SETFL,O_NONBLOCK,1) == -1)
|
|
|
|
io_error(port,__FUNCTION__);
|
|
|
|
|
|
|
|
return port;
|
2004-08-12 17:36:36 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void primitive_portp(void)
|
|
|
|
{
|
|
|
|
drepl(tag_boolean(typep(PORT_TYPE,dpeek())));
|
|
|
|
}
|
|
|
|
|
|
|
|
void init_buffer(PORT* port, int mode)
|
|
|
|
{
|
|
|
|
if(port->buf_mode == B_NONE)
|
|
|
|
port->buffer = string(BUF_SIZE,'\0');
|
|
|
|
|
|
|
|
if(port->buf_mode != mode)
|
|
|
|
{
|
|
|
|
port->buf_fill = port->buf_pos = 0;
|
|
|
|
port->buf_mode = mode;
|
2004-08-15 21:50:44 -04:00
|
|
|
|
|
|
|
if(mode == B_READ_LINE)
|
|
|
|
port->line = tag_object(sbuf(LINE_SIZE));
|
|
|
|
}
|
|
|
|
else if(port->buf_mode == B_READ_LINE)
|
|
|
|
{
|
|
|
|
if(port->line == F)
|
|
|
|
port->line = tag_object(sbuf(LINE_SIZE));
|
|
|
|
else
|
|
|
|
untag_sbuf(port->line)->top = 0;
|
2004-08-12 17:36:36 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void fixup_port(PORT* port)
|
|
|
|
{
|
|
|
|
port->fd = -1;
|
|
|
|
if(port->buffer != 0)
|
2004-08-12 23:40:28 -04:00
|
|
|
port->buffer = fixup_untagged_string(port->buffer);
|
2004-08-15 21:50:44 -04:00
|
|
|
fixup(&port->line);
|
2004-08-12 17:36:36 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
void collect_port(PORT* port)
|
|
|
|
{
|
|
|
|
if(port->buffer != 0)
|
2004-08-12 23:40:28 -04:00
|
|
|
port->buffer = copy_untagged_string(port->buffer);
|
2004-08-15 21:50:44 -04:00
|
|
|
copy_object(&port->line);
|
2004-08-12 17:36:36 -04:00
|
|
|
}
|