Merge pull request #168 from KeenS/pipe-reader

allow pipe syntax
This commit is contained in:
Yuichi Nishiwaki 2014-07-18 22:27:08 +09:00
commit 684f12f22d
1 changed files with 47 additions and 0 deletions

View File

@ -4,6 +4,7 @@
#include <ctype.h> #include <ctype.h>
#include <math.h> #include <math.h>
#include <stdlib.h>
#include "picrin.h" #include "picrin.h"
#include "picrin/error.h" #include "picrin/error.h"
#include "picrin/pair.h" #include "picrin/pair.h"
@ -354,6 +355,50 @@ read_string(pic_state *pic, struct pic_port *port, char c)
return pic_obj_value(str); return pic_obj_value(str);
} }
static pic_value
read_pipe(pic_state *pic, struct pic_port *port, char c)
{
char *buf;
size_t size, cnt;
pic_sym sym;
/* Currently supports only ascii chars */
char HEX_BUF[3];
size_t i = 0;
size = 256;
buf = pic_alloc(pic, size);
cnt = 0;
while ((c = next(port)) != '|') {
if (c == '\\') {
switch (c = next(port)) {
case 'a': c = '\a'; break;
case 'b': c = '\b'; break;
case 't': c = '\t'; break;
case 'n': c = '\n'; break;
case 'r': c = '\r'; break;
case 'x':
i = 0;
while ((HEX_BUF[i++] = next(port)) != ';') {
if (i >= sizeof HEX_BUF)
read_error(pic, "expected ';'");
}
c = (char)strtol(HEX_BUF, NULL, 16);
break;
}
}
buf[cnt++] = c;
if (cnt >= size) {
buf = pic_realloc(pic, buf, size *= 2);
}
}
buf[cnt] = '\0';
sym = pic_intern_cstr(pic, buf);
pic_free(pic, buf);
return pic_sym_value(sym);
}
static pic_value static pic_value
read_unsigned_blob(pic_state *pic, struct pic_port *port, char c) read_unsigned_blob(pic_state *pic, struct pic_port *port, char c)
{ {
@ -584,6 +629,8 @@ read_nullable(pic_state *pic, struct pic_port *port, char c)
return read_comma(pic, port, c); return read_comma(pic, port, c);
case '"': case '"':
return read_string(pic, port, c); return read_string(pic, port, c);
case '|':
return read_pipe(pic, port, c);
case '0': case '1': case '2': case '3': case '4': case '0': case '1': case '2': case '3': case '4':
case '5': case '6': case '7': case '8': case '9': case '5': case '6': case '7': case '8': case '9':
return read_number(pic, port, c); return read_number(pic, port, c);