#include using namespace std; #include "functor_json.h" #include "functioncolumn.h" using namespace execplan; #include "rowgroup.h" using namespace rowgroup; #include "joblisttypes.h" using namespace joblist; #include "jsonhelpers.h" using namespace funcexp::helpers; namespace funcexp { CalpontSystemCatalog::ColType Func_json_normalize::operationType( FunctionParm& fp, CalpontSystemCatalog::ColType& /*resultType*/) { return fp[0]->data()->resultType(); } string Func_json_normalize::getStrVal(rowgroup::Row& row, FunctionParm& fp, bool& isNull, execplan::CalpontSystemCatalog::ColType& /*type*/) { json_engine_t je; MEM_ROOT_DYNAMIC_ARRAY array; int je_stack[JSON_DEPTH_LIMIT], buffer_array[JSON_DEPTH_LIMIT]; mem_root_dynamic_array_init(NULL, PSI_INSTRUMENT_MEM | MY_INIT_BUFFER_USED | MY_BUFFER_NO_RESIZE, &je.stack, sizeof(int), &je_stack, JSON_DEPTH_LIMIT, 0, MYF(0)); mem_root_dynamic_array_init(NULL, PSI_INSTRUMENT_MEM | MY_INIT_BUFFER_USED | MY_BUFFER_NO_RESIZE, &array, sizeof(int), &buffer_array, JSON_DEPTH_LIMIT, 0, MYF(0)); const auto js_ns = fp[0]->data()->getStrVal(row, isNull); if (isNull) return ""; const string_view js = js_ns.unsafeStringRef(); using DynamicString = unique_ptr; DynamicString str{new DYNAMIC_STRING(), dynstr_free}; if (init_dynamic_string(str.get(), NULL, 0, 0)) goto error; if (json_normalize(str.get(), js.data(), js.size(), getCharset(fp[0]), NULL, &je, &array)) goto error; return str->str; error: isNull = true; return ""; } } // namespace funcexp