drawterm/libc/dorfmt.c

60 lines
1.5 KiB
C
Raw Normal View History

2006-01-17 13:37:52 +01:00
/*
* The authors of this software are Rob Pike and Ken Thompson.
* Copyright (c) 2002 by Lucent Technologies.
* Permission to use, copy, modify, and distribute this software for any
* purpose without fee is hereby granted, provided that this entire notice
* is included in all copies of any software which is or includes a copy
* or modification of this software and in all copies of the supporting
* documentation for such software.
* THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR IMPLIED
* WARRANTY. IN PARTICULAR, NEITHER THE AUTHORS NOR LUCENT TECHNOLOGIES MAKE
* ANY REPRESENTATION OR WARRANTY OF ANY KIND CONCERNING THE MERCHANTABILITY
* OF THIS SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE.
*/
2006-01-17 14:22:03 +01:00
#include <u.h>
#include <libc.h>
2005-08-08 14:50:13 +02:00
#include "fmtdef.h"
/* format the output into f->to and return the number of characters fmted */
int
2006-01-17 13:37:52 +01:00
dorfmt(Fmt *f, const Rune *fmt)
2005-08-08 14:50:13 +02:00
{
Rune *rt, *rs;
int r;
char *t, *s;
int nfmt;
nfmt = f->nfmt;
for(;;){
if(f->runes){
rt = f->to;
rs = f->stop;
while((r = *fmt++) && r != '%'){
FMTRCHAR(f, rt, rs, r);
}
f->nfmt += rt - (Rune *)f->to;
f->to = rt;
if(!r)
return f->nfmt - nfmt;
f->stop = rs;
}else{
t = f->to;
s = f->stop;
while((r = *fmt++) && r != '%'){
FMTRUNE(f, t, f->stop, r);
}
f->nfmt += t - (char *)f->to;
f->to = t;
if(!r)
return f->nfmt - nfmt;
f->stop = s;
}
2006-01-17 13:37:52 +01:00
fmt = __fmtdispatch(f, (Rune*)fmt, 1);
2005-08-08 14:50:13 +02:00
if(fmt == nil)
return -1;
}
return 0; /* not reached */
}