add fmt_pad and fmt_fill.
parent
84cd4773f4
commit
6629de6768
@ -0,0 +1,20 @@
|
||||
#include "fmt.h"
|
||||
|
||||
/* "foo" -> "foo "
|
||||
* Copy srclen characters from src. write padlen-srclen spaces, if
|
||||
* that is >= 0. Truncate only if total length is larger than maxlen.
|
||||
* Return number of characters written. */
|
||||
unsigned int fmt_fill(char* dest,const char* src,unsigned int srclen,unsigned int padlen,unsigned int maxlen) {
|
||||
int todo;
|
||||
char* olddest=dest;
|
||||
char* max=dest+maxlen;
|
||||
for (todo=srclen; todo>0; --todo) {
|
||||
if (dest>max) break;
|
||||
*dest=*src; ++dest; ++src;
|
||||
}
|
||||
for (todo=padlen-srclen; todo>0; --todo) {
|
||||
if (dest>max) break;
|
||||
*dest=' '; ++dest;
|
||||
}
|
||||
return dest-olddest;
|
||||
}
|
@ -0,0 +1,20 @@
|
||||
#include "fmt.h"
|
||||
|
||||
/* "foo" -> " foo"
|
||||
* write padlen-srclen spaces, if that is >= 0. Then copy srclen
|
||||
* characters from src. Truncate only if total length is larger than
|
||||
* maxlen. Return number of characters written. */
|
||||
unsigned int fmt_pad(char* dest,const char* src,unsigned int srclen,unsigned int padlen,unsigned int maxlen) {
|
||||
int todo;
|
||||
char* olddest=dest;
|
||||
char* max=dest+maxlen;
|
||||
for (todo=padlen-srclen; todo>0; --todo) {
|
||||
if (dest>max) break;
|
||||
*dest=' '; ++dest;
|
||||
}
|
||||
for (todo=srclen; todo>0; --todo) {
|
||||
if (dest>max) break;
|
||||
*dest=*src; ++dest; ++src;
|
||||
}
|
||||
return dest-olddest;
|
||||
}
|
Loading…
Reference in New Issue