patch 4.0
This commit is contained in:
@ -18,29 +18,57 @@
|
||||
#include "sql/parser/parse_define.h"
|
||||
#include "sql/parser/parser_proxy_func.h"
|
||||
|
||||
// get memory from the thread obStringBuf, and not release untill thread quits
|
||||
void* parse_malloc(const size_t nbyte, void* malloc_pool)
|
||||
|
||||
void *malloc_parentheses_info(const size_t nbyte, void *malloc_pool)
|
||||
{
|
||||
void* ptr = NULL;
|
||||
size_t headlen = sizeof(int64_t);
|
||||
void *ptr = NULL;
|
||||
if (OB_ISNULL(malloc_pool)) {
|
||||
} else if (OB_UNLIKELY(nbyte <= 0)) {
|
||||
} else {
|
||||
if (OB_UNLIKELY(NULL == (ptr = parser_alloc_buffer(malloc_pool, headlen + nbyte)))) {
|
||||
if (OB_UNLIKELY(NULL == (ptr = parser_alloc_buffer(malloc_pool, nbyte)))) {
|
||||
} else {
|
||||
*(static_cast<int64_t*>(ptr)) = nbyte;
|
||||
ptr = static_cast<char*>(ptr) + headlen;
|
||||
MEMSET(ptr, 0, nbyte);
|
||||
}
|
||||
}
|
||||
return ptr;
|
||||
}
|
||||
|
||||
/* ptr must point to a memory allocated by parse_malloc.cpp */
|
||||
void* parse_realloc(void* ptr, size_t nbyte, void* malloc_pool)
|
||||
// get memory from the thread obStringBuf, and not release untill thread quits
|
||||
void *parse_malloc(const size_t nbyte, void *malloc_pool)
|
||||
{
|
||||
void* new_ptr = NULL;
|
||||
// need not to check nbyte
|
||||
void *ptr = NULL;
|
||||
size_t headlen = sizeof(int64_t);
|
||||
if (OB_ISNULL(malloc_pool)) {
|
||||
} else if (OB_UNLIKELY(nbyte <= 0)) {
|
||||
} else {
|
||||
if (OB_UNLIKELY(NULL == (ptr = parser_alloc_buffer(malloc_pool, headlen + nbyte)))) {
|
||||
} else {
|
||||
*(static_cast<int64_t *>(ptr)) = nbyte;
|
||||
ptr = static_cast<char *>(ptr) + headlen;
|
||||
MEMSET(ptr, 0, nbyte);
|
||||
}
|
||||
}
|
||||
return ptr;
|
||||
}
|
||||
|
||||
void *parser_alloc(void *malloc_pool, const int64_t alloc_size)
|
||||
{
|
||||
void *ptr = NULL;
|
||||
if (OB_ISNULL(malloc_pool)) {
|
||||
} else {
|
||||
if (OB_UNLIKELY(NULL == (ptr = parser_alloc_buffer(malloc_pool, alloc_size)))) {
|
||||
} else {
|
||||
MEMSET(ptr, 0, alloc_size);
|
||||
}
|
||||
}
|
||||
return ptr;
|
||||
}
|
||||
|
||||
/* ptr must point to a memory allocated by parse_malloc.cpp */
|
||||
void *parse_realloc(void *ptr, size_t nbyte, void *malloc_pool)
|
||||
{
|
||||
void *new_ptr = NULL;
|
||||
//need not to check nbyte
|
||||
if (OB_ISNULL(malloc_pool)) {
|
||||
} else {
|
||||
if (OB_UNLIKELY(NULL == ptr)) {
|
||||
@ -49,24 +77,24 @@ void* parse_realloc(void* ptr, size_t nbyte, void* malloc_pool)
|
||||
size_t headlen = sizeof(int64_t);
|
||||
if (OB_UNLIKELY(NULL == (new_ptr = parser_alloc_buffer(malloc_pool, headlen + nbyte)))) {
|
||||
} else {
|
||||
int64_t obyte = *(reinterpret_cast<int64_t*>(static_cast<char*>(ptr) - headlen));
|
||||
*(static_cast<int64_t*>(new_ptr)) = nbyte;
|
||||
new_ptr = static_cast<char*>(new_ptr) + headlen;
|
||||
int64_t obyte = *(reinterpret_cast<int64_t *>(static_cast<char *>(ptr) - headlen));
|
||||
*(static_cast<int64_t *>(new_ptr)) = nbyte;
|
||||
new_ptr = static_cast<char *>(new_ptr) + headlen;
|
||||
MEMMOVE(new_ptr, ptr, static_cast<int64_t>(nbyte) > obyte ? obyte : nbyte);
|
||||
parser_free_buffer(malloc_pool, static_cast<char*>(ptr) - headlen);
|
||||
parser_free_buffer(malloc_pool, static_cast<char *>(ptr) - headlen);
|
||||
}
|
||||
}
|
||||
}
|
||||
return new_ptr;
|
||||
}
|
||||
|
||||
char* parse_strndup(const char* str, size_t nbyte, void* malloc_pool)
|
||||
char *parse_strndup(const char *str, size_t nbyte, void *malloc_pool)
|
||||
{
|
||||
char* new_str = NULL;
|
||||
// need not to check nbyte
|
||||
char *new_str = NULL;
|
||||
//need not to check nbyte
|
||||
if (OB_ISNULL(str)) {
|
||||
} else {
|
||||
if (OB_LIKELY(NULL != (new_str = static_cast<char*>(parse_malloc(nbyte + 1, malloc_pool))))) {
|
||||
if (OB_LIKELY(NULL != (new_str = static_cast<char *>(parse_malloc(nbyte + 1, malloc_pool))))) {
|
||||
MEMMOVE(new_str, str, nbyte);
|
||||
new_str[nbyte] = '\0';
|
||||
} else {
|
||||
@ -75,9 +103,9 @@ char* parse_strndup(const char* str, size_t nbyte, void* malloc_pool)
|
||||
return new_str;
|
||||
}
|
||||
|
||||
char* parse_strdup(const char* str, void* malloc_pool, int64_t* out_len)
|
||||
char *parse_strdup(const char *str, void *malloc_pool, int64_t *out_len)
|
||||
{
|
||||
char* out_str = NULL;
|
||||
char *out_str = NULL;
|
||||
if (OB_ISNULL(str)) {
|
||||
} else if (OB_ISNULL(out_len)) {
|
||||
} else {
|
||||
@ -88,18 +116,20 @@ char* parse_strdup(const char* str, void* malloc_pool, int64_t* out_len)
|
||||
return out_str;
|
||||
}
|
||||
|
||||
char* parse_str_convert_utf8(
|
||||
const struct ObCharsetInfo* src_cs, const char* str, void* malloc_pool, int64_t* out_len, int* extra_errno)
|
||||
char *parse_str_convert_utf8(const struct ObCharsetInfo* src_cs, const char *str, void *malloc_pool, int64_t *out_len, int *extra_errno)
|
||||
{
|
||||
char* out_str = NULL;
|
||||
if (OB_ISNULL(str) || OB_ISNULL(out_len) || OB_ISNULL(extra_errno)) {
|
||||
char *out_str = NULL;
|
||||
if (OB_ISNULL(str)
|
||||
|| OB_ISNULL(out_len)
|
||||
|| OB_ISNULL(extra_errno)) {
|
||||
} else {
|
||||
uint errors;
|
||||
uint errors = 0;
|
||||
size_t str_len = STRLEN(str);
|
||||
size_t dst_len = str_len * 4;
|
||||
if (OB_ISNULL(out_str = static_cast<char*>(parse_malloc(dst_len + 1, malloc_pool)))) {
|
||||
if (OB_ISNULL(out_str = static_cast<char *>(parse_malloc(dst_len + 1, malloc_pool)))) {
|
||||
} else {
|
||||
*out_len = ob_convert(out_str, dst_len, &ob_charset_utf8mb4_general_ci, str, str_len, src_cs, &errors);
|
||||
*out_len = static_cast<int64_t>(
|
||||
ob_convert(out_str, dst_len, &ob_charset_utf8mb4_general_ci, str, str_len, src_cs, false, '?', &errors));
|
||||
out_str[*out_len] = '\0';
|
||||
if (0 != errors) {
|
||||
*extra_errno = OB_PARSER_ERR_ILLEGAL_NAME;
|
||||
@ -109,14 +139,14 @@ char* parse_str_convert_utf8(
|
||||
return out_str;
|
||||
}
|
||||
|
||||
char* strndup_with_prefix(const char* prefix, const char* str, size_t nbyte, void* malloc_pool)
|
||||
char *strndup_with_prefix(const char *prefix, const char *str, size_t nbyte, void *malloc_pool)
|
||||
{
|
||||
char* new_str = NULL;
|
||||
char *new_str = NULL;
|
||||
size_t prefix_len = strlen(prefix);
|
||||
// need not to check nbyte
|
||||
//need not to check nbyte
|
||||
if (OB_ISNULL(str)) {
|
||||
} else {
|
||||
if (OB_LIKELY(NULL != (new_str = static_cast<char*>(parse_malloc(nbyte + prefix_len, malloc_pool))))) {
|
||||
if (OB_LIKELY(NULL != (new_str = static_cast<char *>(parse_malloc(nbyte + prefix_len, malloc_pool))))) {
|
||||
MEMMOVE(new_str, prefix, prefix_len);
|
||||
MEMMOVE(new_str + prefix_len, str, nbyte);
|
||||
} else {
|
||||
@ -126,16 +156,16 @@ char* strndup_with_prefix(const char* prefix, const char* str, size_t nbyte, voi
|
||||
return new_str;
|
||||
}
|
||||
|
||||
char* strndup_with_prefix_and_postfix(
|
||||
const char* prefix, const char* postfix, const char* str, size_t nbyte, void* malloc_pool)
|
||||
char *strndup_with_prefix_and_postfix(const char *prefix,
|
||||
const char *postfix, const char* str, size_t nbyte, void *malloc_pool)
|
||||
{
|
||||
char* new_str = NULL;
|
||||
char *new_str = NULL;
|
||||
size_t prefix_len = strlen(prefix);
|
||||
size_t postfix_len = strlen(postfix);
|
||||
if (OB_ISNULL(str)) {
|
||||
} else {
|
||||
if (OB_LIKELY(
|
||||
NULL != (new_str = static_cast<char*>(parse_malloc(nbyte + prefix_len + postfix_len, malloc_pool))))) {
|
||||
if (OB_LIKELY(NULL != (new_str = static_cast<char *>(parse_malloc(
|
||||
nbyte + prefix_len + postfix_len, malloc_pool))))) {
|
||||
MEMMOVE(new_str, prefix, prefix_len);
|
||||
MEMMOVE(new_str + prefix_len, str, nbyte);
|
||||
MEMMOVE(new_str + prefix_len + nbyte, postfix, postfix_len);
|
||||
@ -145,21 +175,120 @@ char* strndup_with_prefix_and_postfix(
|
||||
return new_str;
|
||||
}
|
||||
|
||||
void parse_free(void* ptr)
|
||||
void parse_free(void *ptr)
|
||||
{
|
||||
UNUSED(ptr);
|
||||
/* do nothing, we don't really free the memory */
|
||||
}
|
||||
|
||||
char* cp_str_value(const char* src, const size_t nbyte, void* malloc_pool)
|
||||
char *cp_str_value(const char *src, const size_t nbyte, void *malloc_pool)
|
||||
{
|
||||
char* new_str = NULL;
|
||||
char *new_str = NULL;
|
||||
if (OB_ISNULL(src)) {
|
||||
} else {
|
||||
if (OB_LIKELY(NULL != (new_str = static_cast<char*>(parse_malloc(nbyte, malloc_pool))))) {
|
||||
if (OB_LIKELY(NULL != (new_str = static_cast<char *>(parse_malloc(nbyte, malloc_pool))))) {
|
||||
MEMCPY(new_str, src, nbyte);
|
||||
} else {
|
||||
}
|
||||
}
|
||||
return new_str;
|
||||
}
|
||||
|
||||
char *parse_strdup_with_replace_multi_byte_char(const char *str, int *connection_collation_,
|
||||
void *malloc_pool, int64_t *out_len)
|
||||
{
|
||||
char *out_str = NULL;
|
||||
if (OB_ISNULL(str) || OB_ISNULL(connection_collation_) || OB_ISNULL(out_len)) {
|
||||
} else if (OB_LIKELY(NULL != (out_str = static_cast<char *>(parse_malloc(strlen(str) + 1,
|
||||
malloc_pool))))) {
|
||||
int64_t len = 0;
|
||||
int64_t dup_len = strlen(str);
|
||||
for (int64_t i = 0; i < dup_len; ++i) {
|
||||
switch (*connection_collation_) {
|
||||
case 28/*CS_TYPE_GBK_CHINESE_CI*/:
|
||||
case 87/*CS_TYPE_GBK_BIN*/:
|
||||
case 248/*CS_TYPE_GB18030_CHINESE_CI*/:
|
||||
case 249/*CS_TYPE_GB18030_BIN*/: {
|
||||
if (i + 1 < dup_len) {
|
||||
if (str[i] == (char)0xa1 && str[i+1] == (char)0xa1) {//gbk multi byte space
|
||||
out_str[len++] = ' ';
|
||||
++i;
|
||||
} else if (str[i] == (char)0xa3 && str[i+1] == (char)0xa8) {
|
||||
//gbk multi byte left parenthesis
|
||||
out_str[len++] = '(';
|
||||
++i;
|
||||
} else if (str[i] == (char)0xa3 && str[i+1] == (char)0xa9) {
|
||||
//gbk multi byte right parenthesis
|
||||
out_str[len++] = ')';
|
||||
++i;
|
||||
} else {
|
||||
out_str[len++] = str[i];
|
||||
}
|
||||
} else {
|
||||
out_str[len++] = str[i];
|
||||
}
|
||||
break;
|
||||
}
|
||||
case 45/*CS_TYPE_UTF8MB4_GENERAL_CI*/:
|
||||
case 46/*CS_TYPE_UTF8MB4_BIN*/:
|
||||
case 63/*CS_TYPE_BINARY*/:
|
||||
case 224/*CS_TYPE_UTF8MB4_UNICODE_CI*/: {
|
||||
if (i + 2 < dup_len) {
|
||||
if (str[i] == (char)0xe3 && str[i+1] == (char)0x80 && str[i+2] == (char)0x80) {
|
||||
//utf8 multi byte space
|
||||
out_str[len++] = ' ';
|
||||
i = i + 2;
|
||||
} else if (str[i] == (char)0xef && str[i+1] == (char)0xbc && str[i+2] == (char)0x88) {
|
||||
//utf8 multi byte left parenthesis
|
||||
out_str[len++] = '(';
|
||||
i = i + 2;
|
||||
} else if (str[i] == (char)0xef && str[i+1] == (char)0xbc && str[i+2] == (char)0x89) {
|
||||
//utf8 multi byte right parenthesis
|
||||
out_str[len++] = ')';
|
||||
i = i + 2;
|
||||
} else {
|
||||
out_str[len++] = str[i];
|
||||
}
|
||||
} else {
|
||||
out_str[len++] = str[i];
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
out_str[len++] = str[i];
|
||||
}
|
||||
}
|
||||
if (len > 0) {
|
||||
out_str[len] = '\0';
|
||||
*out_len = len;
|
||||
}
|
||||
}
|
||||
return out_str;
|
||||
}
|
||||
|
||||
bool check_real_escape(const ObCharsetInfo *cs, char *str, int64_t str_len,
|
||||
int64_t *last_well_formed_len)
|
||||
{
|
||||
bool is_real_escape = true;
|
||||
if (NULL != cs && NULL != last_well_formed_len && cs->escape_with_backslash_is_dangerous) {
|
||||
char *cur_pos = str + str_len;
|
||||
char *last_check_pos = str + *last_well_formed_len;
|
||||
int error = 0;
|
||||
size_t expected_well_formed_len = cur_pos - last_check_pos;
|
||||
size_t real_well_formed_len = cs->cset->well_formed_len(
|
||||
cs, last_check_pos, cur_pos, UINT64_MAX, &error);
|
||||
if (error != 0) {
|
||||
*cur_pos = '\\';
|
||||
if (real_well_formed_len == expected_well_formed_len - 1
|
||||
&& cs->cset->ismbchar(cs, cur_pos - 1, cur_pos + 1)) {
|
||||
is_real_escape = false;
|
||||
*last_well_formed_len = str_len + 1;
|
||||
} else {
|
||||
*last_well_formed_len = str_len;
|
||||
}
|
||||
} else {
|
||||
*last_well_formed_len = str_len;
|
||||
}
|
||||
}
|
||||
return is_real_escape;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user