1
0
mirror of https://github.com/mariadb-corporation/mariadb-columnstore-engine.git synced 2025-07-30 19:23:07 +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:
Roman Nozdrin
2020-11-30 15:01:17 +03:00
committed by GitHub
26 changed files with 175 additions and 99 deletions

View File

@ -6138,7 +6138,7 @@ CalpontSystemCatalog::ColType& CalpontSystemCatalog::ColType::operator=(const Co
CHARSET_INFO* CalpontSystemCatalog::ColType::getCharset() CHARSET_INFO* CalpontSystemCatalog::ColType::getCharset()
{ {
if (!cs) if (!cs)
cs= get_charset(charsetNumber, MYF(MY_WME)); cs= & datatypes::Charset(charsetNumber).getCharset();
return cs; return cs;
} }

View File

@ -50,7 +50,7 @@
#undef max #undef max
#include "mcs_datatype.h" #include "mcs_datatype.h"
#include "collation.h"
class ExecPlanTest; class ExecPlanTest;

View File

@ -92,7 +92,7 @@ void PredicateOperator::unserialize(messageqcpp::ByteStream& b)
ObjectReader::checkType(b, ObjectReader::PREDICATEOPERATOR); ObjectReader::checkType(b, ObjectReader::PREDICATEOPERATOR);
//b >> fData; //b >> fData;
Operator::unserialize(b); Operator::unserialize(b);
cs = get_charset(fOperationType.charsetNumber, MYF(MY_WME)); cs = & datatypes::Charset(fOperationType.charsetNumber).getCharset();
} }
bool PredicateOperator::operator==(const PredicateOperator& t) const bool PredicateOperator::operator==(const PredicateOperator& t) const
@ -342,7 +342,7 @@ void PredicateOperator::setOpType(Type& l, Type& r)
fOperationType.colWidth = 8; fOperationType.colWidth = 8;
} }
cs = get_charset(fOperationType.charsetNumber, MYF(MY_WME)); cs = & datatypes::Charset(fOperationType.charsetNumber).getCharset();
} }
inline bool PredicateOperator::strTrimCompare(const std::string& op1, const std::string& op2) inline bool PredicateOperator::strTrimCompare(const std::string& op1, const std::string& op2)

View File

@ -44,8 +44,7 @@
#include "returnedcolumn.h" #include "returnedcolumn.h"
#include "dataconvert.h" #include "dataconvert.h"
struct charset_info_st; #include "collation.h"
typedef const struct charset_info_st CHARSET_INFO;
namespace messageqcpp namespace messageqcpp
{ {

View File

@ -826,7 +826,7 @@ create_columnstore_select_handler(THD* thd, SELECT_LEX* select_lex)
sel->first_cond_optimization= false; sel->first_cond_optimization= false;
conds= simplify_joins_mcs(join, select_lex->join_list, conds= simplify_joins_mcs(join, select_lex->join_list,
join->conds, TRUE, FALSE); join->conds, true, false);
build_bitmap_for_nested_joins_mcs(select_lex->join_list, 0); build_bitmap_for_nested_joins_mcs(select_lex->join_list, 0);
sel->where= conds; sel->where= conds;

View File

@ -63,7 +63,7 @@ using namespace execplan;
#include "crashtrace.h" #include "crashtrace.h"
#include "installdir.h" #include "installdir.h"
#include "collation.h" #include "mariadb_my_sys.h"
#include "service.h" #include "service.h"

View File

@ -83,7 +83,7 @@ using namespace joblist;
#include "crashtrace.h" #include "crashtrace.h"
#include "installdir.h" #include "installdir.h"
#include "collation.h" #include "mariadb_my_sys.h"
#include "service.h" #include "service.h"

View File

@ -77,7 +77,7 @@
#include "dbrm.h" #include "dbrm.h"
#include "collation.h" #include "mariadb_my_sys.h"
class Opt class Opt

View File

@ -145,7 +145,7 @@ void PrimitiveProcessor::p_TokenByScan(const TokenByScanRequestHeader* h,
offsets = reinterpret_cast<const uint16_t*>(&niceBlock[10]); offsets = reinterpret_cast<const uint16_t*>(&niceBlock[10]);
niceInput = reinterpret_cast<const uint8_t*>(h); niceInput = reinterpret_cast<const uint8_t*>(h);
const CHARSET_INFO* cs = get_charset(h->charsetNumber, MYF(MY_WME)); const CHARSET_INFO* cs = & datatypes::Charset(h->charsetNumber).getCharset();
// if LIKE is an operator, compile regexp's in advance. // if LIKE is an operator, compile regexp's in advance.
if ((h->NVALS > 0 && h->COP1 & COMPARE_LIKE) || if ((h->NVALS > 0 && h->COP1 & COMPARE_LIKE) ||
@ -662,7 +662,7 @@ void PrimitiveProcessor::p_Dictionary(const DictInput* in,
uint16_t aggCount; uint16_t aggCount;
bool cmpResult; bool cmpResult;
DictOutput header; DictOutput header;
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME)); const CHARSET_INFO* cs = & datatypes::Charset(charsetNumber).getCharset();
// default size of the ouput to something sufficiently large to prevent // default size of the ouput to something sufficiently large to prevent
// excessive reallocation and copy when resizing // excessive reallocation and copy when resizing

View File

@ -74,7 +74,7 @@ using namespace idbdatafile;
#include "crashtrace.h" #include "crashtrace.h"
#include "installdir.h" #include "installdir.h"
#include "collation.h" #include "mariadb_my_sys.h"
#include "service.h" #include "service.h"

View File

@ -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 This program is free software; you can redistribute it and/or
// boost headers. <mariadb.h> and boost are not friends. modify it under the terms of the GNU General Public License
#include <mariadb.h> as published by the Free Software Foundation; version 2 of
#undef set_bits // mariadb.h defines set_bits, which is incompatible with boost the License.
#include <my_sys.h>
#include <m_ctype.h> This program is distributed in the hope that it will be useful,
#include <myisampack.h> 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

View 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

View File

@ -16,62 +16,24 @@
#include "utils_utf8.h" #include "utils_utf8.h"
#include "collation.h" #include "collation.h"
namespace utf8 #include "mariadb_my_sys.h"
#include <m_ctype.h>
namespace datatypes
{ {
/* static inline CHARSET_INFO & get_charset_or_bin(int32_t charsetNumber)
* mcs_strcoll
*/
int mcs_strcoll(const char* str1, const char* str2, const uint32_t charsetNumber)
{ {
const CHARSET_INFO* cs = get_charset(charsetNumber, MYF(MY_WME)); CHARSET_INFO *cs= get_charset(charsetNumber, MYF(MY_WME));
return cs->strnncoll(str1, strlen(str1), str2, strlen(str2)); 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

View File

@ -56,16 +56,14 @@ inline bool numericLE(result_t op1, result_t op2)
return op1 <= 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, inline bool getBool(rowgroup::Row& row,
@ -258,19 +256,20 @@ inline bool getBool(rowgroup::Row& row,
case execplan::CalpontSystemCatalog::TEXT: case execplan::CalpontSystemCatalog::TEXT:
{ {
const string& val = pm[0]->data()->getStrVal(row, isNull); const string& val = pm[0]->data()->getStrVal(row, isNull);
CHARSET_INFO &cs = datatypes::Charset(ct.charsetNumber).getCharset();
if (notBetween) 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; return true;
isNull = false; 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 && return !isNull &&
strGE(ct.charsetNumber, val, pm[1]->data()->getStrVal(row, isNull)) && strGE(cs, val, pm[1]->data()->getStrVal(row, isNull)) &&
strLE(ct.charsetNumber, val, pm[2]->data()->getStrVal(row, isNull)); strLE(cs, val, pm[2]->data()->getStrVal(row, isNull));
} }
default: default:

View File

@ -39,6 +39,8 @@ using namespace rowgroup;
using namespace logging; using namespace logging;
#include "collation.h" #include "collation.h"
#include "mariadb_my_sys.h"
#include <myisampack.h> // min_intXstore()
#include "vlarray.h" #include "vlarray.h"

View File

@ -37,6 +37,8 @@ using namespace rowgroup;
using namespace joblist; using namespace joblist;
#include "collation.h" #include "collation.h"
#include <mariadb.h> // INT_MAX32
namespace funcexp namespace funcexp
{ {

View File

@ -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 <cstdlib>
#include <string> #include <string>
#include <sstream> #include <sstream>

View File

@ -35,6 +35,7 @@ using namespace rowgroup;
using namespace joblist; using namespace joblist;
#include "collation.h" #include "collation.h"
#include <mariadb.h> // DBUG_ASSERT
namespace funcexp namespace funcexp
{ {

View File

@ -36,6 +36,7 @@ using namespace rowgroup;
using namespace joblist; using namespace joblist;
#include "collation.h" #include "collation.h"
#include <mariadb.h> // INT_MAX32
namespace funcexp namespace funcexp
{ {

View File

@ -41,9 +41,6 @@ using namespace funcexp;
#include "collation.h" #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 namespace funcexp
{ {

View File

@ -97,7 +97,7 @@ std::string Func_substr::getStrVal(rowgroup::Row& row,
if (start == 0 && strLen == length) if (start == 0 && strLen == length)
return str; return str;
length= MY_MIN(length, strLen - start); length= std::min(length, strLen - start);
std::string ret(strptr + start, length); std::string ret(strptr + start, length);
return ret; return ret;

View File

@ -88,7 +88,7 @@ std::string Func_substring_index::getStrVal(rowgroup::Row& row,
char* ptr = const_cast<char*>(src); char* ptr = const_cast<char*>(src);
char *i,*j; char *i,*j;
uint32_t l; 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, this loop goes once.
// For count < 0, it goes twice // For count < 0, it goes twice
for (pass = (count > 0 ? 1 : 0); pass<2; ++pass) for (pass = (count > 0 ? 1 : 0); pass<2; ++pass)

View File

@ -53,9 +53,8 @@
#include "mcsv1_udaf.h" #include "mcsv1_udaf.h"
#include "constantcolumn.h" #include "constantcolumn.h"
// Because including my_sys.h in a Columnstore header causes too many conflicts #include "collation.h"
struct charset_info_st;
typedef const struct charset_info_st CHARSET_INFO;
// To do: move code that depends on joblist to a proper subsystem. // To do: move code that depends on joblist to a proper subsystem.
namespace joblist namespace joblist
{ {

View File

@ -1240,7 +1240,7 @@ const CHARSET_INFO* Row::getCharset(uint32_t col) const
{ {
if (charsets[col] == NULL) 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]; return charsets[col];
} }
@ -1761,7 +1761,7 @@ const CHARSET_INFO* RowGroup::getCharset(uint32_t col)
{ {
if (charsets[col] == NULL) if (charsets[col] == NULL)
{ {
charsets[col] = get_charset(charsetNumbers[col], MYF(MY_WME)); charsets[col] = & datatypes::Charset(charsetNumbers[col]).getCharset();
} }
return charsets[col]; return charsets[col];
} }

View File

@ -59,9 +59,7 @@
#include "../winport/winport.h" #include "../winport/winport.h"
// Because including my_sys.h in a Columnstore header causes too many conflicts #include "collation.h"
struct charset_info_st;
typedef const struct charset_info_st CHARSET_INFO;
// Workaround for my_global.h #define of isnan(X) causing a std::std namespace // Workaround for my_global.h #define of isnan(X) causing a std::std namespace

View File

@ -52,7 +52,7 @@ using namespace oam;
#include "crashtrace.h" #include "crashtrace.h"
#include "collation.h" #include "mariadb_my_sys.h"
#include "service.h" #include "service.h"