2018-09-27 19:52:54 +02:00
|
|
|
#ifdef _MSV_VER
|
|
|
|
#include <platform.h>
|
|
|
|
#endif
|
|
|
|
|
2018-10-04 04:47:20 +02:00
|
|
|
#include "util/order_parser.h"
|
2018-09-29 13:35:49 +02:00
|
|
|
|
2018-10-04 10:49:53 +02:00
|
|
|
#include <errno.h>
|
2018-09-28 20:50:24 +02:00
|
|
|
#include <stdio.h>
|
|
|
|
|
2018-10-04 04:47:20 +02:00
|
|
|
typedef struct parser_state {
|
|
|
|
FILE * F;
|
|
|
|
} parser_state;
|
|
|
|
|
|
|
|
static void handle_order(void *userData, const char *str) {
|
|
|
|
parser_state * state = (parser_state*)userData;
|
|
|
|
fputs(str, state->F);
|
|
|
|
fputc('\n', state->F);
|
|
|
|
}
|
|
|
|
|
|
|
|
int parsefile(FILE *F) {
|
|
|
|
OP_Parser parser;
|
|
|
|
char buf[1024];
|
|
|
|
int done = 0, err = 0;
|
|
|
|
parser_state state = { NULL };
|
|
|
|
|
|
|
|
state.F = stdout;
|
|
|
|
|
|
|
|
parser = OP_ParserCreate();
|
|
|
|
OP_SetOrderHandler(parser, handle_order);
|
|
|
|
OP_SetUserData(parser, &state);
|
|
|
|
|
|
|
|
while (!done) {
|
|
|
|
size_t len = (int)fread(buf, 1, sizeof(buf), F);
|
|
|
|
if (ferror(F)) {
|
|
|
|
/* TODO: error message */
|
|
|
|
err = errno;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
done = feof(F);
|
|
|
|
if (OP_Parse(parser, buf, len, done) == OP_STATUS_ERROR) {
|
|
|
|
/* TODO: error message */
|
|
|
|
err = (int)OP_GetErrorCode(parser);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
OP_ParserFree(parser);
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
2018-09-27 19:52:54 +02:00
|
|
|
int main(int argc, char **argv) {
|
2018-09-28 20:50:24 +02:00
|
|
|
FILE * F = stdin;
|
2018-10-04 10:49:53 +02:00
|
|
|
if (argc > 1) {
|
2018-09-28 20:50:24 +02:00
|
|
|
const char *filename = argv[1];
|
|
|
|
F = fopen(filename, "r");
|
|
|
|
if (!F) {
|
|
|
|
perror(filename);
|
|
|
|
return -1;
|
|
|
|
}
|
2018-10-04 04:47:20 +02:00
|
|
|
}
|
|
|
|
parsefile(F);
|
|
|
|
if (F != stdin) {
|
2018-09-28 20:50:24 +02:00
|
|
|
fclose(F);
|
|
|
|
}
|
2018-09-27 19:52:54 +02:00
|
|
|
return 0;
|
|
|
|
}
|