You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-07-29 08:21:15 +03:00
Merge pull request #1624 from mariadb-corporation/develop-bar-MCOL-4422
MCOL-4422 Remove mariadb.h and my_sys.h dependency from collation.h
This commit is contained in:
@ -1,9 +1,101 @@
|
||||
// These are the common headers needed to use the MariaDB collation library
|
||||
/*
|
||||
Copyright (C) 2020 MariaDB Corporation
|
||||
|
||||
// This must be included after any boost headers, or anything that includes
|
||||
// boost headers. <mariadb.h> and boost are not friends.
|
||||
#include <mariadb.h>
|
||||
#undef set_bits // mariadb.h defines set_bits, which is incompatible with boost
|
||||
#include <my_sys.h>
|
||||
#include <m_ctype.h>
|
||||
#include <myisampack.h>
|
||||
This program is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU General Public License
|
||||
as published by the Free Software Foundation; version 2 of
|
||||
the License.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||
MA 02110-1301, USA. */
|
||||
#ifndef COLLATION_H_INCLUDED
|
||||
#define COLLATION_H_INCLUDED
|
||||
|
||||
|
||||
/*
|
||||
Redefine definitions used by MariaDB m_ctype.h.
|
||||
This is needed to avoid including <mariadb.h> and <my_sys.h>,
|
||||
which conflict with many MCS and boost headers.
|
||||
*/
|
||||
|
||||
#ifndef FALSE
|
||||
#define FALSE (0)
|
||||
#endif
|
||||
|
||||
#ifndef TRUE
|
||||
#define TRUE (1)
|
||||
#endif
|
||||
|
||||
#ifndef DBUG_ASSERT
|
||||
#define DBUG_ASSERT(x) idbassert(x)
|
||||
#define DBUG_ASSERT_TEMPORARILY_DEFINED
|
||||
#endif
|
||||
|
||||
#ifndef MYSQL_PLUGIN_IMPORT
|
||||
#if (defined(_WIN32) && defined(MYSQL_DYNAMIC_PLUGIN))
|
||||
#define MYSQL_PLUGIN_IMPORT __declspec(dllimport)
|
||||
#else
|
||||
#define MYSQL_PLUGIN_IMPORT
|
||||
#endif
|
||||
#endif
|
||||
|
||||
typedef long long int longlong;
|
||||
typedef unsigned long long int ulonglong;
|
||||
typedef uint32_t uint32;
|
||||
typedef uint16_t uint16;
|
||||
typedef char my_bool;
|
||||
typedef unsigned char uchar;
|
||||
|
||||
#if defined(__GNUC__) && !defined(_lint)
|
||||
typedef char pchar; /* Mixed prototypes can take char */
|
||||
typedef char puchar; /* Mixed prototypes can take char */
|
||||
typedef char pbool; /* Mixed prototypes can take char */
|
||||
typedef short pshort; /* Mixed prototypes can take short int */
|
||||
typedef float pfloat; /* Mixed prototypes can take float */
|
||||
#else
|
||||
typedef int pchar; /* Mixed prototypes can't take char */
|
||||
typedef uint puchar; /* Mixed prototypes can't take char */
|
||||
typedef int pbool; /* Mixed prototypes can't take char */
|
||||
typedef int pshort; /* Mixed prototypes can't take short int */
|
||||
typedef double pfloat; /* Mixed prototypes can't take float */
|
||||
#endif
|
||||
|
||||
typedef const struct charset_info_st CHARSET_INFO;
|
||||
extern "C" MYSQL_PLUGIN_IMPORT CHARSET_INFO *default_charset_info;
|
||||
|
||||
#include "m_ctype.h"
|
||||
|
||||
#undef FALSE
|
||||
#undef TRUE
|
||||
|
||||
#ifdef DBUG_ASSERT_TEMPORARILY_DEFINED
|
||||
#undef DBUG_ASSERT
|
||||
#endif
|
||||
|
||||
|
||||
namespace datatypes
|
||||
{
|
||||
|
||||
// A reference to MariaDB CHARSET_INFO.
|
||||
|
||||
class Charset
|
||||
{
|
||||
protected:
|
||||
const struct charset_info_st & mCharset;
|
||||
public:
|
||||
Charset(CHARSET_INFO & cs) :mCharset(cs) { }
|
||||
Charset(uint32_t charsetNumber);
|
||||
CHARSET_INFO & getCharset() const { return mCharset; }
|
||||
};
|
||||
|
||||
|
||||
} // end of namespace datatypes
|
||||
|
||||
#endif
|
||||
|
29
utils/common/mariadb_my_sys.h
Normal file
29
utils/common/mariadb_my_sys.h
Normal file
@ -0,0 +1,29 @@
|
||||
/*
|
||||
Copyright (C) 2020 MariaDB Corporation
|
||||
|
||||
This program is free software; you can redistribute it and/or
|
||||
modify it under the terms of the GNU General Public License
|
||||
as published by the Free Software Foundation; version 2 of
|
||||
the License.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, write to the Free Software
|
||||
Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
|
||||
MA 02110-1301, USA. */
|
||||
#ifndef MARIADB_MY_SYS_H_INCLUDED
|
||||
#define MARIADB_MY_SYS_H_INCLUDED
|
||||
|
||||
// These are the common headers needed to use the MariaDB mysys library.
|
||||
|
||||
// This must be included after any boost headers, or anything that includes
|
||||
// boost headers. <mariadb.h> and boost are not friends.
|
||||
#include <mariadb.h>
|
||||
#undef set_bits // mariadb.h defines set_bits, which is incompatible with boost
|
||||
#include <my_sys.h>
|
||||
|
||||
#endif
|
@ -16,62 +16,24 @@
|
||||
#include "utils_utf8.h"
|
||||
#include "collation.h"
|
||||
|
||||
namespace utf8
|
||||
#include "mariadb_my_sys.h"
|
||||
#include <m_ctype.h>
|
||||
|
||||
|
||||
namespace datatypes
|
||||
{
|
||||
|
||||
/*
|
||||
* mcs_strcoll
|
||||
*/
|
||||
int mcs_strcoll(const char* str1, const char* str2, const uint32_t charsetNumber)
|
||||
static inline CHARSET_INFO & get_charset_or_bin(int32_t charsetNumber)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncoll(str1, strlen(str1), str2, strlen(str2));
|
||||
CHARSET_INFO *cs= get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs ? *cs : my_charset_bin;
|
||||
}
|
||||
|
||||
int mcs_strcoll(const char* str1, const uint32_t l1, const char* str2, const uint32_t l2, const uint32_t charsetNumber)
|
||||
|
||||
Charset::Charset(uint32_t charsetNumber)
|
||||
:mCharset(get_charset_or_bin(charsetNumber))
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncoll(str1, l1, str2, l2);
|
||||
}
|
||||
|
||||
int mcs_strcoll(const std::string* str1, const std::string* str2, const uint32_t charsetNumber)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncoll(str1->c_str(), str1->length(), str2->c_str(), str2->length());
|
||||
}
|
||||
|
||||
int mcs_strcoll(const std::string& str1, const std::string& str2, const uint32_t charsetNumber)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncoll(str1.c_str(), str1.length(), str2.c_str(), str2.length());
|
||||
}
|
||||
|
||||
/*
|
||||
* mcs_strcollsp
|
||||
*/
|
||||
int mcs_strcollsp(const char* str1, const char* str2, const uint32_t charsetNumber)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncollsp(str1, strlen(str1), str2, strlen(str2));
|
||||
}
|
||||
|
||||
int mcs_strcollsp(const char* str1, uint32_t l1, const char* str2, const uint32_t l2, const uint32_t charsetNumber)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncollsp(str1, l1, str2, l2);
|
||||
}
|
||||
|
||||
int mcs_strcollsp(const std::string* str1, const std::string* str2, const uint32_t charsetNumber)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncollsp(str1->c_str(), str1->length(), str2->c_str(), str2->length());
|
||||
}
|
||||
|
||||
int mcs_strcollsp(const std::string& str1, const std::string& str2, const uint32_t charsetNumber)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncollsp(str1.c_str(), str1.length(), str2.c_str(), str2.length());
|
||||
}
|
||||
|
||||
} //namespace utf8
|
||||
|
||||
|
@ -56,16 +56,14 @@ inline bool numericLE(result_t op1, result_t op2)
|
||||
return op1 <= op2;
|
||||
}
|
||||
|
||||
inline bool strGE(uint32_t charsetNumber, const string& op1, const string& op2)
|
||||
inline bool strGE(CHARSET_INFO &cs, const string& op1, const string& op2)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncoll(op1.c_str(), op1.length(), op2.c_str(), op2.length()) >= 0;
|
||||
return cs.strnncoll(op1.c_str(), op1.length(), op2.c_str(), op2.length()) >= 0;
|
||||
}
|
||||
|
||||
inline bool strLE(uint32_t charsetNumber, const string& op1, const string& op2)
|
||||
inline bool strLE(CHARSET_INFO &cs, const string& op1, const string& op2)
|
||||
{
|
||||
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME));
|
||||
return cs->strnncoll(op1.c_str(), op1.length(), op2.c_str(), op2.length()) <= 0;
|
||||
return cs.strnncoll(op1.c_str(), op1.length(), op2.c_str(), op2.length()) <= 0;
|
||||
}
|
||||
|
||||
inline bool getBool(rowgroup::Row& row,
|
||||
@ -258,19 +256,20 @@ inline bool getBool(rowgroup::Row& row,
|
||||
case execplan::CalpontSystemCatalog::TEXT:
|
||||
{
|
||||
const string& val = pm[0]->data()->getStrVal(row, isNull);
|
||||
CHARSET_INFO &cs = datatypes::Charset(ct.charsetNumber).getCharset();
|
||||
|
||||
if (notBetween)
|
||||
{
|
||||
if (!strGE(ct.charsetNumber, val, pm[1]->data()->getStrVal(row, isNull)) && !isNull)
|
||||
if (!strGE(cs, val, pm[1]->data()->getStrVal(row, isNull)) && !isNull)
|
||||
return true;
|
||||
|
||||
isNull = false;
|
||||
return (!strLE(ct.charsetNumber, val, pm[2]->data()->getStrVal(row, isNull)) && !isNull);
|
||||
return (!strLE(cs, val, pm[2]->data()->getStrVal(row, isNull)) && !isNull);
|
||||
}
|
||||
|
||||
return !isNull &&
|
||||
strGE(ct.charsetNumber, val, pm[1]->data()->getStrVal(row, isNull)) &&
|
||||
strLE(ct.charsetNumber, val, pm[2]->data()->getStrVal(row, isNull));
|
||||
strGE(cs, val, pm[1]->data()->getStrVal(row, isNull)) &&
|
||||
strLE(cs, val, pm[2]->data()->getStrVal(row, isNull));
|
||||
}
|
||||
|
||||
default:
|
||||
|
@ -39,6 +39,8 @@ using namespace rowgroup;
|
||||
using namespace logging;
|
||||
|
||||
#include "collation.h"
|
||||
#include "mariadb_my_sys.h"
|
||||
#include <myisampack.h> // min_intXstore()
|
||||
|
||||
#include "vlarray.h"
|
||||
|
||||
|
@ -37,6 +37,8 @@ using namespace rowgroup;
|
||||
using namespace joblist;
|
||||
|
||||
#include "collation.h"
|
||||
#include <mariadb.h> // INT_MAX32
|
||||
|
||||
|
||||
namespace funcexp
|
||||
{
|
||||
|
@ -22,11 +22,6 @@
|
||||
*
|
||||
****************************************************************************/
|
||||
|
||||
//#include <mariadb.h>
|
||||
//#undef set_bits // mariadb.h defines set_bits, which is incompatible with boost
|
||||
//#undef LONGLONG_MIN
|
||||
//#include <my_sys.h>
|
||||
|
||||
#include <cstdlib>
|
||||
#include <string>
|
||||
#include <sstream>
|
||||
|
@ -35,6 +35,7 @@ using namespace rowgroup;
|
||||
using namespace joblist;
|
||||
|
||||
#include "collation.h"
|
||||
#include <mariadb.h> // DBUG_ASSERT
|
||||
|
||||
namespace funcexp
|
||||
{
|
||||
|
@ -36,6 +36,7 @@ using namespace rowgroup;
|
||||
using namespace joblist;
|
||||
|
||||
#include "collation.h"
|
||||
#include <mariadb.h> // INT_MAX32
|
||||
|
||||
namespace funcexp
|
||||
{
|
||||
|
@ -41,9 +41,6 @@ using namespace funcexp;
|
||||
|
||||
#include "collation.h"
|
||||
|
||||
// Because including my_sys.h in a Columnstore header causes too many conflicts
|
||||
struct charset_info_st;
|
||||
typedef const struct charset_info_st CHARSET_INFO;
|
||||
|
||||
namespace funcexp
|
||||
{
|
||||
|
@ -97,7 +97,7 @@ std::string Func_substr::getStrVal(rowgroup::Row& row,
|
||||
if (start == 0 && strLen == length)
|
||||
return str;
|
||||
|
||||
length= MY_MIN(length, strLen - start);
|
||||
length= std::min(length, strLen - start);
|
||||
|
||||
std::string ret(strptr + start, length);
|
||||
return ret;
|
||||
|
@ -88,7 +88,7 @@ std::string Func_substring_index::getStrVal(rowgroup::Row& row,
|
||||
char* ptr = const_cast<char*>(src);
|
||||
char *i,*j;
|
||||
uint32_t l;
|
||||
int32 n = 0, c = count, pass;
|
||||
int32_t n = 0, c = count, pass;
|
||||
// For count > 0, this loop goes once.
|
||||
// For count < 0, it goes twice
|
||||
for (pass = (count > 0 ? 1 : 0); pass<2; ++pass)
|
||||
|
@ -53,9 +53,8 @@
|
||||
#include "mcsv1_udaf.h"
|
||||
#include "constantcolumn.h"
|
||||
|
||||
// Because including my_sys.h in a Columnstore header causes too many conflicts
|
||||
struct charset_info_st;
|
||||
typedef const struct charset_info_st CHARSET_INFO;
|
||||
#include "collation.h"
|
||||
|
||||
// To do: move code that depends on joblist to a proper subsystem.
|
||||
namespace joblist
|
||||
{
|
||||
|
@ -1240,7 +1240,7 @@ const CHARSET_INFO* Row::getCharset(uint32_t col) const
|
||||
{
|
||||
if (charsets[col] == NULL)
|
||||
{
|
||||
const_cast<CHARSET_INFO**>(charsets)[col] = get_charset(charsetNumbers[col], MYF(MY_WME));
|
||||
const_cast<CHARSET_INFO**>(charsets)[col] = & datatypes::Charset(charsetNumbers[col]).getCharset();
|
||||
}
|
||||
return charsets[col];
|
||||
}
|
||||
@ -1761,7 +1761,7 @@ const CHARSET_INFO* RowGroup::getCharset(uint32_t col)
|
||||
{
|
||||
if (charsets[col] == NULL)
|
||||
{
|
||||
charsets[col] = get_charset(charsetNumbers[col], MYF(MY_WME));
|
||||
charsets[col] = & datatypes::Charset(charsetNumbers[col]).getCharset();
|
||||
}
|
||||
return charsets[col];
|
||||
}
|
||||
|
@ -59,9 +59,7 @@
|
||||
|
||||
#include "../winport/winport.h"
|
||||
|
||||
// Because including my_sys.h in a Columnstore header causes too many conflicts
|
||||
struct charset_info_st;
|
||||
typedef const struct charset_info_st CHARSET_INFO;
|
||||
#include "collation.h"
|
||||
|
||||
|
||||
// Workaround for my_global.h #define of isnan(X) causing a std::std namespace
|
||||
|
Reference in New Issue
Block a user