diff --git a/velox/functions/sparksql/specialforms/FromJson.cpp b/velox/functions/sparksql/specialforms/FromJson.cpp index f424c3e028136..0d59ee5858166 100644 --- a/velox/functions/sparksql/specialforms/FromJson.cpp +++ b/velox/functions/sparksql/specialforms/FromJson.cpp @@ -375,6 +375,7 @@ struct ParseJsonTypedImpl { /// - Map: Keys must be `VARCHAR` type. /// - Row: Partial parsing is supported, but JSON arrays cannot be parsed into a /// ROW type. +template class FromJsonFunction final : public exec::VectorFunction { public: void apply( @@ -389,21 +390,13 @@ class FromJsonFunction final : public exec::VectorFunction { context.ensureWritable(rows, outputType, result); result->clearNulls(rows); if (args[0]->isConstantEncoding()) { - VELOX_DYNAMIC_TYPE_DISPATCH( - parseJsonConstant, - result->typeKind(), - args[0], - context, - rows, - *result); + parseJsonConstant(args[0], context, rows, *result); } else { - VELOX_DYNAMIC_TYPE_DISPATCH( - parseJsonFlat, result->typeKind(), args[0], context, rows, *result); + parseJsonFlat(args[0], context, rows, *result); } } private: - template void parseJsonConstant( VectorPtr& input, exec::EvalCtx& context, @@ -432,7 +425,7 @@ class FromJsonFunction final : public exec::VectorFunction { context.applyToSelectedNoThrow(rows, [&](auto row) { writer.setOffset(row); if (error != simdjson::SUCCESS || - paseJsonOneRow(jsonDoc, writer) != simdjson::SUCCESS) { + paseJsonOneRow(jsonDoc, writer) != simdjson::SUCCESS) { writer.commitNull(); } }); @@ -441,7 +434,6 @@ class FromJsonFunction final : public exec::VectorFunction { writer.finish(); } - template void parseJsonFlat( VectorPtr& input, exec::EvalCtx& context, @@ -473,14 +465,13 @@ class FromJsonFunction final : public exec::VectorFunction { simdjson::ondemand::document doc; auto error = simdjsonParse(paddedInput).get(doc); if (error != simdjson::SUCCESS || - paseJsonOneRow(doc, writer) != simdjson::SUCCESS) { + paseJsonOneRow(doc, writer) != simdjson::SUCCESS) { writer.commitNull(); } }); writer.finish(); } - template static simdjson::error_code paseJsonOneRow( simdjson::ondemand::document& doc, exec::VectorWriter& writer) { @@ -560,10 +551,19 @@ exec::ExprPtr FromJsonCallToSpecialForm::constructSpecialForm( VELOX_UNSUPPORTED("Unsupported type {}.", type->toString()); } + std::shared_ptr func; + if (type->kind() == TypeKind::ARRAY) { + func = std::make_shared>(); + } else if (type->kind() == TypeKind::MAP) { + func = std::make_shared>(); + } else { + func = std::make_shared>(); + } + return std::make_shared( type, std::move(args), - std::make_shared(), + func, exec::VectorFunctionMetadata{}, kFromJson, trackCpuUsage);