add cescape stuff and two tests
parent
a8f6a1c121
commit
056760c5f1
@ -0,0 +1,25 @@
|
||||
|
||||
#include <string.h>
|
||||
#include "buffer.h"
|
||||
#include "textcode.h"
|
||||
|
||||
void cescape(const char* c) {
|
||||
char* buf=alloca(strlen(c)*5+1);
|
||||
buffer_put(buffer_1,buf,fmt_cescape(buf,c,strlen(c)));
|
||||
buffer_putnlflush(buffer_1);
|
||||
}
|
||||
|
||||
main(int argc,char* argv[]) {
|
||||
int i;
|
||||
for (i=1; i<argc; ++i) {
|
||||
cescape(argv[i]);
|
||||
}
|
||||
if (argc<2) {
|
||||
char src[1024];
|
||||
int len=read(0,src,sizeof(src)-1);
|
||||
if (len==-1) return(1);
|
||||
src[len]=0;
|
||||
cescape(src);
|
||||
}
|
||||
return 0;
|
||||
}
|
@ -0,0 +1,21 @@
|
||||
#include "array.h"
|
||||
#include "textcode.h"
|
||||
#include <assert.h>
|
||||
|
||||
array a;
|
||||
|
||||
int main() {
|
||||
char buf[256];
|
||||
int i;
|
||||
for (i=0; i<256; ++i) buf[i]=i;
|
||||
|
||||
fmt_to_array(fmt_uuencoded,&a,buf,256);
|
||||
assert(!array_failed(&a));
|
||||
write(1,array_start(&a),array_bytes(&a));
|
||||
array_trunc(&a);
|
||||
|
||||
fmt_to_array(fmt_base64,&a,buf,256);
|
||||
assert(!array_failed(&a));
|
||||
write(1,array_start(&a),array_bytes(&a)); write(1,"\n",1);
|
||||
array_trunc(&a);
|
||||
}
|
@ -0,0 +1,46 @@
|
||||
#include "fmt.h"
|
||||
#include "textcode.h"
|
||||
#include "str.h"
|
||||
#include "haveinline.h"
|
||||
|
||||
unsigned long fmt_cescape(char* dest,const char* src,unsigned long len) {
|
||||
register const unsigned char* s=(const unsigned char*) src;
|
||||
unsigned long written=0,i;
|
||||
char c;
|
||||
for (i=0; i<len; ++i) {
|
||||
switch (s[i]) {
|
||||
case '\a': c='a'; goto doescape;
|
||||
case '\b': c='b'; goto doescape;
|
||||
case '\e': c='e'; goto doescape;
|
||||
case '\f': c='f'; goto doescape;
|
||||
case '\n': c='n'; goto doescape;
|
||||
case '\r': c='r'; goto doescape;
|
||||
case '\t': c='t'; goto doescape;
|
||||
case '\v': c='v'; goto doescape;
|
||||
case '\\':
|
||||
c='\\';
|
||||
doescape:
|
||||
if (dest) {
|
||||
dest[written]='\\';
|
||||
dest[written+1]=c;
|
||||
}
|
||||
written+=2;
|
||||
break;
|
||||
default:
|
||||
if (s[i]<' ') {
|
||||
if (dest) {
|
||||
dest[written]='\\';
|
||||
dest[written+1]='x';
|
||||
dest[written+2]=fmt_tohex(s[i]>>4);
|
||||
dest[written+3]=fmt_tohex(s[i]&0xf);
|
||||
}
|
||||
written+=4;
|
||||
} else {
|
||||
if (dest) dest[written]=s[i];
|
||||
++written;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
return written;
|
||||
}
|
@ -0,0 +1,42 @@
|
||||
#include "fmt.h"
|
||||
#include "textcode.h"
|
||||
#include "scan.h"
|
||||
|
||||
unsigned long scan_cescape(const char *src,char *dest,unsigned long *destlen) {
|
||||
register const unsigned char* s=(const unsigned char*) src;
|
||||
unsigned long written=0,i;
|
||||
char c;
|
||||
for (i=0; s[i]; ++i) {
|
||||
if ((c=s[i])=='\\') {
|
||||
switch (s[i+1]) {
|
||||
case 'a': c='\a'; break;
|
||||
case 'b': c='\b'; break;
|
||||
case 'e': c='\e'; break;
|
||||
case 'f': c='\f'; break;
|
||||
case 'n': c='\n'; break;
|
||||
case 'r': c='\r'; break;
|
||||
case 't': c='\t'; break;
|
||||
case 'v': c='\v';
|
||||
case '\\': break;
|
||||
case 'x':
|
||||
{
|
||||
unsigned char a,b;
|
||||
a=scan_fromhex(s[i+2]);
|
||||
b=scan_fromhex(s[i+3]);
|
||||
if (a<16 && b<16) {
|
||||
c=(a<<4)+b;
|
||||
i+=2;
|
||||
}
|
||||
}
|
||||
break;
|
||||
default:
|
||||
--i;
|
||||
}
|
||||
++i;
|
||||
}
|
||||
dest[written]=c;
|
||||
++written;
|
||||
}
|
||||
*destlen=written;
|
||||
return i;
|
||||
}
|
Loading…
Reference in New Issue