mirror of
https://github.com/MariaDB/server.git
synced 2025-01-18 04:53:01 +01:00
6b63c5b247
modified: storage/connect/ha_connect.cc - Suppress the use of connect.in by adding the connect_xtrace system variable. modified: storage/connect/ha_connect.cc - Make column length, varchar, and temporal column types recognized in discovery when using SRCDEF,or PIVOT. modified: storage/connect/ha_connect.cc storage/connect/myconn.cpp storage/connect/myutil.cpp storage/connect/plgdbsem.h - Avoid (rare) crash when using DECIMAL type. (buf was too small) modified: storage/connect/tabfmt.cpp storage/connect/tabmysql.cpp storage/connect/tabodbc.cpp storage/connect/tabpivot.cpp storage/connect/valblk.cpp storage/connect/value.cpp - General cleaning of unused code, standardize tracing, and update version number modified: storage/connect/block.h storage/connect/colblk.cpp storage/connect/connect.cc storage/connect/csort.h storage/connect/filamap.cpp storage/connect/filamdbf.cpp storage/connect/filamfix.cpp storage/connect/filamzip.cpp storage/connect/ha_connect.cc storage/connect/mycat.cc storage/connect/myconn.cpp storage/connect/mysql-test/connect/r/alter.result storage/connect/mysql-test/connect/r/xml.result storage/connect/myutil.cpp storage/connect/osutil.c storage/connect/plgdbsem.h storage/connect/plgdbutl.cpp storage/connect/plugutil.c storage/connect/reldef.cpp storage/connect/tabcol.cpp storage/connect/tabfmt.cpp storage/connect/tabmysql.cpp storage/connect/tabodbc.cpp storage/connect/tabpivot.cpp storage/connect/tabvct.cpp storage/connect/user_connect.cc storage/connect/valblk.cpp storage/connect/value.cpp storage/connect/xindex.cpp
104 lines
4.7 KiB
C++
104 lines
4.7 KiB
C++
/*************** Csort H Declares Source Code File (.H) ****************/
|
|
/* Name: CSORT.H Version 1.2 */
|
|
/* */
|
|
/* (C) Copyright to the author Olivier BERTRAND 2000-2012 */
|
|
/* */
|
|
/* This file contains the CSORT class declares (not 64-bits ready) */
|
|
/* */
|
|
/* Note on use of this class: This class is meant to be used as a */
|
|
/* base class by the calling class. This is because the comparison */
|
|
/* routine must belong to both CSORT and the calling class. */
|
|
/* This avoids to pass explicitly to it the calling "this" pointer. */
|
|
/***********************************************************************/
|
|
#if !defined(CSORT_DEFINED)
|
|
#define CSORT_DEFINED
|
|
|
|
#include <math.h> /* Required for log function */
|
|
#undef DOMAIN // Was defined in math.h
|
|
|
|
/***********************************************************************/
|
|
/* Constant and external definitions. */
|
|
/***********************************************************************/
|
|
#define THRESH 4 /* Threshold for insertion (was 4) */
|
|
#define MTHRESH 6 /* Threshold for median */
|
|
|
|
//extern FILE *debug; /* Debug file */
|
|
|
|
typedef int* const CPINT;
|
|
|
|
/***********************************************************************/
|
|
/* This is the CSORT base class declaration. */
|
|
/***********************************************************************/
|
|
class DllExport CSORT {
|
|
public:
|
|
// Constructor
|
|
CSORT(bool cns, int th = THRESH, int mth = MTHRESH);
|
|
virtual ~CSORT() {}
|
|
protected:
|
|
// Implementation
|
|
/*********************************************************************/
|
|
/* qsortx/qstx are NOT conservative but use less storage space. */
|
|
/* qsortc/qstc ARE conservative but use more storage space. */
|
|
/*********************************************************************/
|
|
int Qsortx(void); /* Index quick/insert sort */
|
|
void Qstx(int *base, int *max); /* Preliminary quick sort */
|
|
int Qsortc(void); /* Conservative q/ins sort */
|
|
void Qstc(int *base, int *max); /* Preliminary quick sort */
|
|
void Istc(int *base, int *hi, int *max); /* Insertion sort routine */
|
|
|
|
public:
|
|
// Methods
|
|
int Qsort(PGLOBAL g, int n); /* Sort calling routine */
|
|
//virtual void Print(PGLOBAL g, FILE *f, uint n);
|
|
//virtual void Print(PGLOBAL g, char *ps, uint z);
|
|
#ifdef DEBTRACE
|
|
int GetNcmp(void) {return num_comp;}
|
|
#endif
|
|
|
|
protected:
|
|
// Overridable
|
|
virtual int Qcompare(int *, int *) = 0; /* Item compare routine */
|
|
#ifdef DEBTRACE
|
|
virtual void DebugSort(int ph, int n, int *base, int *mid, int *tmp);
|
|
#endif
|
|
|
|
public:
|
|
// Utility
|
|
static void SetCmpNum(void)
|
|
{for (int i = 1; i < 1000; i++) Cpn[i] = Cmpnum(i); Limit = 1000;}
|
|
protected:
|
|
static size_t Cmpnum(int n)
|
|
#if defined(AIX)
|
|
{return (n < Limit) ? Cpn[n]
|
|
: (size_t)round(1.0 + (double)n * (log2((double)n) - 1.0));}
|
|
#else // !AIX
|
|
{return (n < Limit) ? Cpn[n]
|
|
: (size_t)(1.5 + (double)n * (log((double)n)/Lg2 - 1.0));}
|
|
#endif // !AIX
|
|
|
|
|
|
// Members
|
|
static int Limit; /* Size of precalculated array */
|
|
static size_t Cpn[1000]; /* Precalculated cmpnum values */
|
|
static double Lg2; /* Precalculated log(2) value */
|
|
PGLOBAL G;
|
|
PDBUSER Dup; /* Used for progress info */
|
|
bool Cons; /* true for conservative sort */
|
|
int Thresh; /* Threshold for using qsort */
|
|
int Mthresh; /* Threshold for median find */
|
|
int Nitem; /* Number of items to sort */
|
|
MBLOCK Index; /* Index allocation block */
|
|
MBLOCK Offset; /* Offset allocation block */
|
|
CPINT &Pex; /* Reference to sort index */
|
|
CPINT &Pof; /* Reference to offset array */
|
|
int *Swix; /* Pointer on EQ/GT work area */
|
|
int Savmax; /* Saved ProgMax value */
|
|
int Savcur; /* Saved ProgCur value */
|
|
LPCSTR Savstep; /* Saved progress step */
|
|
#ifdef DEBTRACE
|
|
int num_comp; /* Number of quick sort calls */
|
|
#endif
|
|
}; // end of class CSORT
|
|
|
|
#endif // CSORT_DEFINED
|
|
|