You've already forked mariadb-columnstore-engine
mirror of
https://github.com/mariadb-corporation/mariadb-columnstore-engine.git
synced 2025-07-30 19:23:07 +03:00
MCOL-1559 remove the #define POSIX_REGEX and thus the use of regexec. Fix up the code changing #ifdef _MSC_VER to #ifdef POSIX_REGEX, where it applies to regexec.
This commit is contained in:
@ -205,11 +205,11 @@ ConstantColumn::ConstantColumn( const ConstantColumn& rhs):
|
||||
if (fRegex.get() != NULL)
|
||||
{
|
||||
fRegex.reset(new CNX_Regex());
|
||||
#ifdef _MSC_VER
|
||||
*fRegex = dataconvert::DataConvert::constructRegexp(fResult.strVal);
|
||||
#else
|
||||
#ifdef POSIX_REGEX
|
||||
string str = dataconvert::DataConvert::constructRegexp(fResult.strVal);
|
||||
regcomp(fRegex.get(), str.c_str(), REG_NOSUB | REG_EXTENDED);
|
||||
#else
|
||||
*fRegex = dataconvert::DataConvert::constructRegexp(fResult.strVal);
|
||||
#endif
|
||||
}
|
||||
}
|
||||
@ -256,7 +256,7 @@ ConstantColumn::ConstantColumn(const uint64_t val, TYPE type) :
|
||||
|
||||
ConstantColumn::~ConstantColumn()
|
||||
{
|
||||
#ifndef _MSC_VER
|
||||
#ifdef POSIX_REGEX
|
||||
|
||||
if (fRegex.get() != NULL)
|
||||
regfree(fRegex.get());
|
||||
@ -394,11 +394,11 @@ void ConstantColumn::constructRegex()
|
||||
{
|
||||
//fRegex = new regex_t();
|
||||
fRegex.reset(new CNX_Regex());
|
||||
#ifdef _MSC_VER
|
||||
*fRegex = dataconvert::DataConvert::constructRegexp(fResult.strVal);
|
||||
#else
|
||||
#ifdef POSIX_REGEX
|
||||
string str = dataconvert::DataConvert::constructRegexp(fResult.strVal);
|
||||
regcomp(fRegex.get(), str.c_str(), REG_NOSUB | REG_EXTENDED);
|
||||
#else
|
||||
*fRegex = dataconvert::DataConvert::constructRegexp(fResult.strVal);
|
||||
#endif
|
||||
}
|
||||
|
||||
|
@ -128,31 +128,31 @@ inline bool PredicateOperator::getBoolVal(rowgroup::Row& row, bool& isNull, Retu
|
||||
// considers these nulls significant, but they're not in the pattern, so we need to strip
|
||||
// them off...
|
||||
const std::string& v = lop->getStrVal(row, isNull);
|
||||
char* c = (char*)alloca(v.length() + 1);
|
||||
memcpy(c, v.c_str(), v.length());
|
||||
c[v.length()] = 0;
|
||||
std::string vv(c);
|
||||
// char* c = (char*)alloca(v.length() + 1);
|
||||
// memcpy(c, v.c_str(), v.length());
|
||||
// c[v.length()] = 0;
|
||||
// std::string vv(c);
|
||||
|
||||
if (regex)
|
||||
{
|
||||
#ifdef _MSC_VER
|
||||
bool ret = boost::regex_match(vv, *regex);
|
||||
#ifdef POSIX_REGEX
|
||||
bool ret = regexec(regex.get(), v.c_str(), 0, NULL, 0) == 0;
|
||||
#else
|
||||
bool ret = regexec(regex.get(), vv.c_str(), 0, NULL, 0) == 0;
|
||||
bool ret = boost::regex_match(v.c_str(), *regex);
|
||||
#endif
|
||||
return (((fOp == OP_LIKE) ? ret : !ret) && !isNull);
|
||||
}
|
||||
else
|
||||
{
|
||||
#ifdef _MSC_VER
|
||||
boost::regex regex(dataconvert::DataConvert::constructRegexp(rop->getStrVal(row, isNull)));
|
||||
bool ret = boost::regex_match(vv, regex);
|
||||
#else
|
||||
#ifdef POSIX_REGEX
|
||||
regex_t regex;
|
||||
std::string str = dataconvert::DataConvert::constructRegexp(rop->getStrVal(row, isNull));
|
||||
regcomp(®ex, str.c_str(), REG_NOSUB | REG_EXTENDED);
|
||||
bool ret = regexec(®ex, vv.c_str(), 0, NULL, 0) == 0;
|
||||
bool ret = regexec(®ex, v.c_str(), 0, NULL, 0) == 0;
|
||||
regfree(®ex);
|
||||
#else
|
||||
boost::regex regex(dataconvert::DataConvert::constructRegexp(rop->getStrVal(row, isNull)));
|
||||
bool ret = boost::regex_match(v.c_str(), regex);
|
||||
#endif
|
||||
return (((fOp == OP_LIKE) ? ret : !ret) && !isNull);
|
||||
}
|
||||
|
@ -167,10 +167,10 @@ typedef IDB_Decimal CNX_Decimal;
|
||||
* @brief IDB_Regex struct
|
||||
*
|
||||
*/
|
||||
#ifdef _MSC_VER
|
||||
typedef boost::regex IDB_Regex;
|
||||
#else
|
||||
#ifdef POSIX_REGEX
|
||||
typedef regex_t IDB_Regex;
|
||||
#else
|
||||
typedef boost::regex IDB_Regex;
|
||||
#endif
|
||||
|
||||
typedef IDB_Regex CNX_Regex;
|
||||
|
@ -1644,15 +1644,13 @@ const JobStepVector doSimpleFilter(SimpleFilter* sf, JobInfo& jobInfo)
|
||||
// type of pseudo column is set by connector
|
||||
if (!sc->schemaName().empty() && sc->isInfiniDB() && !pc)
|
||||
ct = jobInfo.csc->colType(sc->oid());
|
||||
//X
|
||||
|
||||
// Because, on a filter, we want to compare ignoring trailing spaces in many cases
|
||||
// MaraiDB Server compares without trim for LIKE against CHAR.
|
||||
if (ct.colDataType != execplan::CalpontSystemCatalog::CHAR ||
|
||||
sf->op()->op() != execplan::OP_LIKE)
|
||||
if (sf->op()->op() != execplan::OP_LIKE)
|
||||
{
|
||||
boost::algorithm::trim_right_if(constval, boost::is_any_of(" "));
|
||||
}
|
||||
//X
|
||||
//@bug 339 nulls are not stored in dictionary
|
||||
if ((dictOid = isDictCol(ct)) > 0 && ConstantColumn::NULLDATA != cc->type())
|
||||
{
|
||||
|
@ -33,9 +33,9 @@
|
||||
#include <unordered_set>
|
||||
#endif
|
||||
|
||||
#ifdef __linux__
|
||||
#define POSIX_REGEX
|
||||
#endif
|
||||
//#ifdef __linux__
|
||||
//#define POSIX_REGEX
|
||||
//#endif
|
||||
|
||||
#ifdef POSIX_REGEX
|
||||
#include <regex.h>
|
||||
|
@ -166,7 +166,6 @@ int idb_strtrimcoll(const std::string& str1, const std::string& str2)
|
||||
std::locale loc;
|
||||
const std::collate<char>& coll = std::use_facet<std::collate<char> >(loc);
|
||||
int rtn = coll.compare(s1, s1+found1+1, s2, s2+found2+1);
|
||||
// return coll.compare(s1, s1+found1, s2, s2+found2);
|
||||
return rtn;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user