substdi.c
author tomas@localhost
Thu, 01 Nov 2007 14:46:11 +0100
changeset 0 c045670f36e9
permissions -rw-r--r--
Imported queue-fix-1.4
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
0
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     1
#include "substdio.h"
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     2
#include "byte.h"
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     3
#include "error.h"
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     4
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     5
static int oneread(op,fd,buf,len)
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     6
register int (*op)();
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     7
register int fd;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     8
register char *buf;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
     9
register int len;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    10
{
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    11
  register int r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    12
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    13
  for (;;) {
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    14
    r = op(fd,buf,len);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    15
    if (r == -1) if (errno == error_intr) continue;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    16
    return r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    17
  }
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    18
}
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    19
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    20
static int getthis(s,buf,len)
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    21
register substdio *s;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    22
register char *buf;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    23
register int len;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    24
{
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    25
  register int r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    26
  register int q;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    27
 
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    28
  r = s->p;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    29
  q = r - len;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    30
  if (q > 0) { r = len; s->p = q; } else s->p = 0;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    31
  byte_copy(buf,r,s->x + s->n);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    32
  s->n += r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    33
  return r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    34
}
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    35
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    36
int substdio_feed(s)
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    37
register substdio *s;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    38
{
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    39
  register int r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    40
  register int q;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    41
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    42
  if (s->p) return s->p;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    43
  q = s->n;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    44
  r = oneread(s->op,s->fd,s->x,q);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    45
  if (r <= 0) return r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    46
  s->p = r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    47
  q -= r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    48
  s->n = q;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    49
  if (q > 0) /* damn, gotta shift */ byte_copyr(s->x + q,r,s->x);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    50
  return r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    51
}
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    52
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    53
int substdio_bget(s,buf,len)
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    54
register substdio *s;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    55
register char *buf;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    56
register int len;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    57
{
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    58
  register int r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    59
 
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    60
  if (s->p > 0) return getthis(s,buf,len);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    61
  r = s->n; if (r <= len) return oneread(s->op,s->fd,buf,r);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    62
  r = substdio_feed(s); if (r <= 0) return r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    63
  return getthis(s,buf,len);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    64
}
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    65
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    66
int substdio_get(s,buf,len)
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    67
register substdio *s;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    68
register char *buf;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    69
register int len;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    70
{
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    71
  register int r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    72
 
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    73
  if (s->p > 0) return getthis(s,buf,len);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    74
  if (s->n <= len) return oneread(s->op,s->fd,buf,len);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    75
  r = substdio_feed(s); if (r <= 0) return r;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    76
  return getthis(s,buf,len);
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    77
}
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    78
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    79
char *substdio_peek(s)
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    80
register substdio *s;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    81
{
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    82
  return s->x + s->n;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    83
}
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    84
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    85
void substdio_seek(s,len)
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    86
register substdio *s;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    87
register int len;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    88
{
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    89
  s->n += len;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    90
  s->p -= len;
c045670f36e9 Imported queue-fix-1.4
tomas@localhost
parents:
diff changeset
    91
}