mirror of
https://github.com/janet-lang/janet
synced 2025-01-26 07:06:51 +00:00
Add more dynamic bindings for printing.
This commit is contained in:
parent
d9a4ef05ac
commit
802a2d6b71
@ -60,7 +60,7 @@ void janet_printf(const char *format, ...) {
|
|||||||
va_start(args, format);
|
va_start(args, format);
|
||||||
janet_formatb(&buffer, format, args);
|
janet_formatb(&buffer, format, args);
|
||||||
va_end(args);
|
va_end(args);
|
||||||
fwrite(buffer.data, buffer.count, 1, stdout);
|
fwrite(buffer.data, buffer.count, 1, janet_dynfile("out", stdout));
|
||||||
janet_buffer_deinit(&buffer);
|
janet_buffer_deinit(&buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -275,19 +275,21 @@ static Janet janet_core_hash(int32_t argc, Janet *argv) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static Janet janet_core_getline(int32_t argc, Janet *argv) {
|
static Janet janet_core_getline(int32_t argc, Janet *argv) {
|
||||||
|
FILE *in = janet_dynfile("in", stdin);
|
||||||
|
FILE *out = janet_dynfile("out", stdout);
|
||||||
janet_arity(argc, 0, 2);
|
janet_arity(argc, 0, 2);
|
||||||
JanetBuffer *buf = (argc >= 2) ? janet_getbuffer(argv, 1) : janet_buffer(10);
|
JanetBuffer *buf = (argc >= 2) ? janet_getbuffer(argv, 1) : janet_buffer(10);
|
||||||
if (argc >= 1) {
|
if (argc >= 1) {
|
||||||
const char *prompt = (const char *) janet_getstring(argv, 0);
|
const char *prompt = (const char *) janet_getstring(argv, 0);
|
||||||
printf("%s", prompt);
|
fprintf(out, "%s", prompt);
|
||||||
fflush(stdout);
|
fflush(out);
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
buf->count = 0;
|
buf->count = 0;
|
||||||
int c;
|
int c;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
c = fgetc(stdin);
|
c = fgetc(in);
|
||||||
if (feof(stdin) || c < 0) {
|
if (feof(in) || c < 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
janet_buffer_push_u8(buf, (uint8_t) c);
|
janet_buffer_push_u8(buf, (uint8_t) c);
|
||||||
|
@ -28,6 +28,7 @@
|
|||||||
/* Run a string */
|
/* Run a string */
|
||||||
int janet_dobytes(JanetTable *env, const uint8_t *bytes, int32_t len, const char *sourcePath, Janet *out) {
|
int janet_dobytes(JanetTable *env, const uint8_t *bytes, int32_t len, const char *sourcePath, Janet *out) {
|
||||||
JanetParser parser;
|
JanetParser parser;
|
||||||
|
FILE *errf = janet_dynfile("err", stderr);
|
||||||
int errflags = 0, done = 0;
|
int errflags = 0, done = 0;
|
||||||
int32_t index = 0;
|
int32_t index = 0;
|
||||||
Janet ret = janet_wrap_nil();
|
Janet ret = janet_wrap_nil();
|
||||||
@ -55,7 +56,7 @@ int janet_dobytes(JanetTable *env, const uint8_t *bytes, int32_t len, const char
|
|||||||
done = 1;
|
done = 1;
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
fprintf(stderr, "compile error in %s: %s\n", sourcePath,
|
fprintf(errf, "compile error in %s: %s\n", sourcePath,
|
||||||
(const char *)cres.error);
|
(const char *)cres.error);
|
||||||
errflags |= 0x02;
|
errflags |= 0x02;
|
||||||
done = 1;
|
done = 1;
|
||||||
@ -69,7 +70,7 @@ int janet_dobytes(JanetTable *env, const uint8_t *bytes, int32_t len, const char
|
|||||||
break;
|
break;
|
||||||
case JANET_PARSE_ERROR:
|
case JANET_PARSE_ERROR:
|
||||||
errflags |= 0x04;
|
errflags |= 0x04;
|
||||||
fprintf(stderr, "parse error in %s: %s\n",
|
fprintf(errf, "parse error in %s: %s\n",
|
||||||
sourcePath, janet_parser_error(&parser));
|
sourcePath, janet_parser_error(&parser));
|
||||||
done = 1;
|
done = 1;
|
||||||
break;
|
break;
|
||||||
|
@ -32,11 +32,12 @@ Janet janet_line_getter(int32_t argc, Janet *argv) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void simpleline(JanetBuffer *buffer) {
|
static void simpleline(JanetBuffer *buffer) {
|
||||||
|
FILE *in = janet_dynfile("in", stdin);
|
||||||
buffer->count = 0;
|
buffer->count = 0;
|
||||||
int c;
|
int c;
|
||||||
for (;;) {
|
for (;;) {
|
||||||
c = fgetc(stdin);
|
c = fgetc(in);
|
||||||
if (feof(stdin) || c < 0) {
|
if (feof(in) || c < 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
janet_buffer_push_u8(buffer, (uint8_t) c);
|
janet_buffer_push_u8(buffer, (uint8_t) c);
|
||||||
@ -56,7 +57,9 @@ void janet_line_deinit() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void janet_line_get(const char *p, JanetBuffer *buffer) {
|
void janet_line_get(const char *p, JanetBuffer *buffer) {
|
||||||
fputs(p, stdout);
|
FILE *out = janet_dynfile("out", stdout);
|
||||||
|
fputs(p, out);
|
||||||
|
fflush(p, out);
|
||||||
simpleline(buffer);
|
simpleline(buffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -450,6 +453,7 @@ void janet_line_get(const char *p, JanetBuffer *buffer) {
|
|||||||
prompt = p;
|
prompt = p;
|
||||||
buffer->count = 0;
|
buffer->count = 0;
|
||||||
historyi = 0;
|
historyi = 0;
|
||||||
|
FILE *out = janet_dynfile("out", stdout);
|
||||||
if (!isatty(STDIN_FILENO) || !checktermsupport()) {
|
if (!isatty(STDIN_FILENO) || !checktermsupport()) {
|
||||||
simpleline(buffer);
|
simpleline(buffer);
|
||||||
return;
|
return;
|
||||||
@ -463,12 +467,12 @@ void janet_line_get(const char *p, JanetBuffer *buffer) {
|
|||||||
if (sigint_flag) {
|
if (sigint_flag) {
|
||||||
raise(SIGINT);
|
raise(SIGINT);
|
||||||
} else {
|
} else {
|
||||||
fputc('\n', stdout);
|
fputc('\n', out);
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
norawmode();
|
norawmode();
|
||||||
fputc('\n', stdout);
|
fputc('\n', out);
|
||||||
janet_buffer_ensure(buffer, len + 1, 2);
|
janet_buffer_ensure(buffer, len + 1, 2);
|
||||||
memcpy(buffer->data, buf, len);
|
memcpy(buffer->data, buf, len);
|
||||||
buffer->data[len] = '\n';
|
buffer->data[len] = '\n';
|
||||||
|
Loading…
Reference in New Issue
Block a user