Skip to content

Commit

Permalink
fix 'error during bootstrap' printing (#39515)
Browse files Browse the repository at this point in the history
  • Loading branch information
vtjnash authored Feb 4, 2021
1 parent e213310 commit a07089e
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 25 deletions.
41 changes: 22 additions & 19 deletions src/jlapi.c
Original file line number Diff line number Diff line change
Expand Up @@ -163,15 +163,16 @@ JL_DLLEXPORT const char *jl_string_ptr(jl_value_t *s)
JL_DLLEXPORT jl_value_t *jl_call(jl_function_t *f, jl_value_t **args, int32_t nargs)
{
jl_value_t *v;
nargs++; // add f to args
JL_TRY {
jl_value_t **argv;
JL_GC_PUSHARGS(argv, nargs+1);
JL_GC_PUSHARGS(argv, nargs);
argv[0] = (jl_value_t*)f;
for(int i=1; i<nargs+1; i++)
argv[i] = args[i-1];
for (int i = 1; i < nargs; i++)
argv[i] = args[i - 1];
size_t last_age = jl_get_ptls_states()->world_age;
jl_get_ptls_states()->world_age = jl_get_world_counter();
v = jl_apply(argv, nargs+1);
v = jl_apply(argv, nargs);
jl_get_ptls_states()->world_age = last_age;
JL_GC_POP();
jl_exception_clear();
Expand All @@ -190,7 +191,7 @@ JL_DLLEXPORT jl_value_t *jl_call0(jl_function_t *f)
JL_GC_PUSH1(&f);
size_t last_age = jl_get_ptls_states()->world_age;
jl_get_ptls_states()->world_age = jl_get_world_counter();
v = jl_apply(&f, 1);
v = jl_apply_generic(f, NULL, 0);
jl_get_ptls_states()->world_age = last_age;
JL_GC_POP();
jl_exception_clear();
Expand All @@ -208,7 +209,8 @@ JL_DLLEXPORT jl_value_t *jl_call1(jl_function_t *f, jl_value_t *a)
JL_TRY {
jl_value_t **argv;
JL_GC_PUSHARGS(argv, 2);
argv[0] = f; argv[1] = a;
argv[0] = f;
argv[1] = a;
size_t last_age = jl_get_ptls_states()->world_age;
jl_get_ptls_states()->world_age = jl_get_world_counter();
v = jl_apply(argv, 2);
Expand All @@ -229,7 +231,9 @@ JL_DLLEXPORT jl_value_t *jl_call2(jl_function_t *f, jl_value_t *a, jl_value_t *b
JL_TRY {
jl_value_t **argv;
JL_GC_PUSHARGS(argv, 3);
argv[0] = f; argv[1] = a; argv[2] = b;
argv[0] = f;
argv[1] = a;
argv[2] = b;
size_t last_age = jl_get_ptls_states()->world_age;
jl_get_ptls_states()->world_age = jl_get_world_counter();
v = jl_apply(argv, 3);
Expand All @@ -251,7 +255,10 @@ JL_DLLEXPORT jl_value_t *jl_call3(jl_function_t *f, jl_value_t *a,
JL_TRY {
jl_value_t **argv;
JL_GC_PUSHARGS(argv, 4);
argv[0] = f; argv[1] = a; argv[2] = b; argv[3] = c;
argv[0] = f;
argv[1] = a;
argv[2] = b;
argv[3] = c;
size_t last_age = jl_get_ptls_states()->world_age;
jl_get_ptls_states()->world_age = jl_get_world_counter();
v = jl_apply(argv, 4);
Expand Down Expand Up @@ -496,25 +503,21 @@ static int exec_program(char *program)
// TODO: It is possible for this output
// to be mangled due to `jlbacktrace`
// printing directly to STDERR_FILENO.
jl_value_t *errs = jl_stderr_obj();
JL_GC_PUSH1(&errs);
volatile int shown_err = 0;
int shown_err = 0;
jl_printf(JL_STDERR, "error during bootstrap:\n");
JL_TRY {
jl_value_t *exc = jl_current_exception();
jl_value_t *showf = jl_get_function(jl_base_module, "show");
if (showf) {
jl_value_t *errs = jl_stderr_obj();
if (errs) {
jl_value_t *showf = jl_get_function(jl_base_module, "show");
if (showf != NULL) {
jl_call2(showf, errs, jl_current_exception());
if (jl_call2(showf, errs, exc)) {
jl_printf(JL_STDERR, "\n");
shown_err = 1;
}
}
}
JL_CATCH {
}
JL_GC_POP();
if (!shown_err) {
jl_static_show((JL_STREAM*)STDERR_FILENO, jl_current_exception());
jl_static_show((JL_STREAM*)STDERR_FILENO, exc);
jl_printf((JL_STREAM*)STDERR_FILENO, "\n");
}
jlbacktrace(); // written to STDERR_FILENO
Expand Down
12 changes: 6 additions & 6 deletions src/julia.h
Original file line number Diff line number Diff line change
Expand Up @@ -1737,12 +1737,12 @@ STATIC_INLINE jl_value_t *jl_apply(jl_value_t **args, uint32_t nargs)
return jl_apply_generic(args[0], &args[1], nargs - 1);
}

JL_DLLEXPORT jl_value_t *jl_call(jl_function_t *f, jl_value_t **args, int32_t nargs);
JL_DLLEXPORT jl_value_t *jl_call0(jl_function_t *f);
JL_DLLEXPORT jl_value_t *jl_call1(jl_function_t *f, jl_value_t *a);
JL_DLLEXPORT jl_value_t *jl_call2(jl_function_t *f, jl_value_t *a, jl_value_t *b);
JL_DLLEXPORT jl_value_t *jl_call3(jl_function_t *f, jl_value_t *a,
jl_value_t *b, jl_value_t *c);
JL_DLLEXPORT jl_value_t *jl_call(jl_function_t *f JL_MAYBE_UNROOTED, jl_value_t **args, int32_t nargs);
JL_DLLEXPORT jl_value_t *jl_call0(jl_function_t *f JL_MAYBE_UNROOTED);
JL_DLLEXPORT jl_value_t *jl_call1(jl_function_t *f JL_MAYBE_UNROOTED, jl_value_t *a JL_MAYBE_UNROOTED);
JL_DLLEXPORT jl_value_t *jl_call2(jl_function_t *f JL_MAYBE_UNROOTED, jl_value_t *a JL_MAYBE_UNROOTED, jl_value_t *b JL_MAYBE_UNROOTED);
JL_DLLEXPORT jl_value_t *jl_call3(jl_function_t *f JL_MAYBE_UNROOTED, jl_value_t *a JL_MAYBE_UNROOTED,
jl_value_t *b JL_MAYBE_UNROOTED, jl_value_t *c JL_MAYBE_UNROOTED);

// interfacing with Task runtime
JL_DLLEXPORT void jl_yield(void);
Expand Down

0 comments on commit a07089e

Please sign in to comment.