fix bug in (case)

reducing use of strlen
This commit is contained in:
JeffBezanson 2009-03-13 14:54:48 +00:00
parent 0643a4f3a2
commit dceced2bb0
3 changed files with 26 additions and 26 deletions

View File

@ -14,6 +14,11 @@ static void outs(char *s, ios_t *f)
ios_puts(s, f);
HPOS += u8_strwidth(s);
}
static void outsn(char *s, ios_t *f, size_t n)
{
ios_write(f, s, n);
HPOS += u8_strwidth(s);
}
static int outindent(int n, ios_t *f)
{
// move back to left margin if we get too indented
@ -269,7 +274,7 @@ static void print_pair(ios_t *f, value_t v, int princ)
cd = cdr_(v);
if (!iscons(cd) || ptrhash_has(&printconses, (void*)cd)) {
if (cd != NIL) {
outs(" . ", f);
outsn(" . ", f, 3);
fl_print_child(f, cd, princ);
}
outc(')', f);
@ -340,7 +345,7 @@ void fl_print_child(ios_t *f, value_t v, int princ)
if (princ)
outs(name, f);
else if (ismanaged(v)) {
outs("#:", f);
outsn("#:", f, 2);
outs(name, f);
}
else
@ -348,20 +353,20 @@ void fl_print_child(ios_t *f, value_t v, int princ)
break;
case TAG_BUILTIN:
if (v == FL_T) {
outs("#t", f);
outsn("#t", f, 2);
break;
}
if (v == FL_F) {
outs("#f", f);
outsn("#f", f, 2);
break;
}
if (v == NIL) {
outs("()", f);
outsn("()", f, 2);
break;
}
if (isbuiltin(v)) {
if (!princ)
outs("#.", f);
outsn("#.", f, 2);
outs(builtin_names[uintval(v)], f);
break;
}
@ -434,8 +439,8 @@ static void print_string(ios_t *f, char *str, size_t sz)
outc('"', f);
while (i < sz) {
u8_escape(buf, sizeof(buf), str, &i, sz, 1, 0);
outs(buf, f);
size_t n = u8_escape(buf, sizeof(buf), str, &i, sz, 1, 0);
outsn(buf, f, n-1);
}
outc('"', f);
}
@ -467,7 +472,7 @@ static void cvalue_printdata(ios_t *f, void *data, size_t len, value_t type,
size_t nb = u8_toutf8(seq, sizeof(seq), &wc, 1);
seq[nb] = '\0';
// TODO: better multibyte handling
if (!princ) outs("#\\", f);
if (!princ) outsn("#\\", f, 2);
outs(seq, f);
}
else if (weak) {
@ -530,9 +535,9 @@ static void cvalue_printdata(ios_t *f, void *data, size_t len, value_t type,
}
else if (d == 0) {
if (1/d < 0)
outs("-0.0", f);
outsn("-0.0", f, 4);
else
outs("0.0", f);
outsn("0.0", f, 3);
if (type == floatsym && !princ && !weak)
outc('f', f);
}
@ -540,7 +545,7 @@ static void cvalue_printdata(ios_t *f, void *data, size_t len, value_t type,
snprint_real(buf, sizeof(buf), d, 0, ndec, 3, 10);
int hasdec = (strpbrk(buf, ".eE") != NULL);
outs(buf, f);
if (!hasdec) outs(".0", f);
if (!hasdec) outsn(".0", f, 2);
if (type == floatsym && !princ && !weak)
outc('f', f);
}
@ -589,7 +594,7 @@ static void cvalue_printdata(ios_t *f, void *data, size_t len, value_t type,
}
size_t i;
if (!weak) {
outs("#array(", f);
outsn("#array(", f, 7);
fl_print_child(f, eltype, princ);
if (cnt > 0)
outc(' ', f);
@ -613,7 +618,7 @@ static void cvalue_printdata(ios_t *f, void *data, size_t len, value_t type,
value_t syms = car(cdr_(type));
assert(isvector(syms));
if (!weak) {
outs("#enum(", f);
outsn("#enum(", f, 6);
fl_print_child(f, syms, princ);
outc(' ', f);
}

View File

@ -189,9 +189,7 @@
(define (expand x) (macroexpand x))
(define = eqv?)
(define eql eqv?)
(define (/= a b) (not (eqv? a b)))
(define != /=)
(define (> a b) (< b a))
(define (<= a b) (not (< b a)))
(define (>= a b) (not (< a b)))
@ -422,7 +420,7 @@
(define (vals->cond key v)
(cond ((eq? v 'else) 'else)
((null? v) #f)
((atom? v) `(eqv? ,key ,v))
((atom? v) `(eqv? ,key ,(quote-value v)))
((null? (cdr v)) `(eqv? ,key ,(quote-value (car v))))
(else `(memv ,key ',v))))
(let ((g (gensym)))

View File

@ -12,30 +12,27 @@ static char hexdig[] = "0123456789abcdef";
void hexdump(ios_t *dest, char *buffer, size_t len, size_t startoffs)
{
size_t offs=0;
size_t i, pos, nc;
size_t i, pos;
char ch, linebuffer[16];
char hexc[4];
static char *spc50 = " ";
hexc[2] = hexc[3] = ' ';
do {
ios_printf(dest, "%.8x ", offs+startoffs);
pos = 10;
for(i=0; i < 16 && (offs+i) < len; i++) {
ch = buffer[offs + i];
for(i=0; i < 16 && offs < len; i++, offs++) {
ch = buffer[offs];
linebuffer[i] = (ch<32 || ch>=0x7f) ? '.' : ch;
hexc[0] = hexdig[((unsigned char)ch)>>4];
hexc[1] = hexdig[ch&0x0f];
nc = (i==7 || i==15) ? 4 : 3;
ios_write(dest, hexc, nc);
pos += nc;
pos += ios_write(dest, hexc, (i==7 || i==15) ? 4 : 3);
}
for(; i < 16; i++)
linebuffer[i] = ' ';
for(i=0; i < 60-pos; i++)
ios_putc(' ', dest);
ios_write(dest, spc50, 60-pos);
ios_putc('|', dest);
ios_write(dest, linebuffer, 16);
ios_write(dest, "|\n", 2);
offs += 16;
} while (offs < len);
}