mirror of
https://github.com/MariaDB/server.git
synced 2025-08-08 11:22:35 +03:00
Merge branch '10.4' into 10.5
This commit is contained in:
@@ -1890,24 +1890,31 @@ static int *GetIntArgPtr(PGLOBAL g, UDF_ARGS *args, uint& n)
|
||||
/*********************************************************************************/
|
||||
int IsArgJson(UDF_ARGS *args, uint i)
|
||||
{
|
||||
int n = 0;
|
||||
const char *pat = args->attributes[i];
|
||||
int n = 0;
|
||||
|
||||
if (*pat == '@') {
|
||||
pat++;
|
||||
|
||||
if (*pat == '\'' || *pat == '"')
|
||||
pat++;
|
||||
|
||||
} // endif pat
|
||||
|
||||
if (i >= args->arg_count || args->arg_type[i] != STRING_RESULT) {
|
||||
} else if (!strnicmp(args->attributes[i], "Bson_", 5) ||
|
||||
!strnicmp(args->attributes[i], "Json_", 5)) {
|
||||
} else if (!strnicmp(pat, "Bson_", 5) || !strnicmp(pat, "Json_", 5)) {
|
||||
if (!args->args[i] || strchr("[{ \t\r\n", *args->args[i]))
|
||||
n = 1; // arg should be is a json item
|
||||
// else
|
||||
// n = 2; // A file name may have been returned
|
||||
|
||||
} else if (!strnicmp(args->attributes[i], "Bbin_", 5)) {
|
||||
} else if (!strnicmp(pat, "Bbin_", 5)) {
|
||||
if (args->lengths[i] == sizeof(BSON))
|
||||
n = 3; // arg is a binary json item
|
||||
// else
|
||||
// n = 2; // A file name may have been returned
|
||||
|
||||
} else if (!strnicmp(args->attributes[i], "Bfile_", 6) ||
|
||||
!strnicmp(args->attributes[i], "Jfile_", 6)) {
|
||||
} else if (!strnicmp(pat, "Bfile_", 6) || !strnicmp(pat, "Jfile_", 6)) {
|
||||
n = 2; // arg is a json file name
|
||||
#if 0
|
||||
} else if (args->lengths[i]) {
|
||||
|
Reference in New Issue
Block a user