From 1ef90acb3814d85d59e5d1502d0ced6287b83408 Mon Sep 17 00:00:00 2001 From: Muh Muhten Date: Thu, 7 Feb 2019 23:05:18 -0500 Subject: [PATCH] Bind data imports properly when already resolved --- src/linker.c | 42 +++++++++++++++++++++++++++--------------- tests/jq.test | 4 ++++ 2 files changed, 31 insertions(+), 15 deletions(-) diff --git a/src/linker.c b/src/linker.c index aa1ff13718..c222bc161a 100644 --- a/src/linker.c +++ b/src/linker.c @@ -275,26 +275,38 @@ static int process_dependencies(jq_state *jq, jv jq_origin, jv lib_origin, block jv_free(lib_origin); return 1; } - uint64_t state_idx = 0; - for (; state_idx < lib_state->ct; ++state_idx) { - if (strcmp(lib_state->names[state_idx],jv_string_value(resolved)) == 0) - break; - } - if (state_idx < lib_state->ct) { // Found - jv_free(resolved); - // Bind the library to the program - bk = block_bind_library(lib_state->defs[state_idx], bk, OP_IS_CALL_PSEUDO, as_str); - } else { // Not found. Add it to the table before binding. - block dep_def_block = gen_noop(); + + if (is_data) { + // Can't reuse data libs because the wrong name is bound + block dep_def_block; nerrors += load_library(jq, resolved, is_data, raw, as_str, &dep_def_block, lib_state); - // resolved has been freed if (nerrors == 0) { - // Bind the library to the program + // Bind as both $data::data and $data for backward compatibility vs common sense bk = block_bind_library(dep_def_block, bk, OP_IS_CALL_PSEUDO, as_str); - if (is_data) - bk = block_bind_library(dep_def_block, bk, OP_IS_CALL_PSEUDO, NULL); + bk = block_bind_library(dep_def_block, bk, OP_IS_CALL_PSEUDO, NULL); + } + } else { + uint64_t state_idx = 0; + for (; state_idx < lib_state->ct; ++state_idx) { + if (strcmp(lib_state->names[state_idx],jv_string_value(resolved)) == 0) + break; + } + + if (state_idx < lib_state->ct) { // Found + jv_free(resolved); + // Bind the library to the program + bk = block_bind_library(lib_state->defs[state_idx], bk, OP_IS_CALL_PSEUDO, as_str); + } else { // Not found. Add it to the table before binding. + block dep_def_block = gen_noop(); + nerrors += load_library(jq, resolved, is_data, raw, as_str, &dep_def_block, lib_state); + // resolved has been freed + if (nerrors == 0) { + // Bind the library to the program + bk = block_bind_library(dep_def_block, bk, OP_IS_CALL_PSEUDO, as_str); + } } } + jv_free(as); } jv_free(lib_origin); diff --git a/tests/jq.test b/tests/jq.test index 1572043e14..cbdc0bf017 100644 --- a/tests/jq.test +++ b/tests/jq.test @@ -1392,6 +1392,10 @@ include "c"; [a, c] null [0,"acmehbah"] +import "data" as $e; import "data" as $d; [$d[].this,$e[].that,$d::d[].this,$e::e[].that]|join(";") +null +"is a test;is too;is a test;is too" + %%FAIL module (.+1); 0 jq: error: Module metadata must be constant at , line 1: