mirror of
https://github.com/MariaDB/server.git
synced 2025-07-29 05:21:33 +03:00
Added sql_alloc.h
- Moved declaration of Sql_alloc from Sql_list.h as they are independent structures.
This commit is contained in:
committed by
Sergei Golubchik
parent
828602356c
commit
1ed605e490
@ -17,7 +17,7 @@
|
|||||||
#ifndef _EVENT_PARSE_DATA_H_
|
#ifndef _EVENT_PARSE_DATA_H_
|
||||||
#define _EVENT_PARSE_DATA_H_
|
#define _EVENT_PARSE_DATA_H_
|
||||||
|
|
||||||
#include "sql_list.h" /* Sql_alloc */
|
#include "sql_alloc.h"
|
||||||
|
|
||||||
class Item;
|
class Item;
|
||||||
class THD;
|
class THD;
|
||||||
|
@ -17,7 +17,7 @@
|
|||||||
#define FILESORT_INCLUDED
|
#define FILESORT_INCLUDED
|
||||||
|
|
||||||
#include "my_base.h" /* ha_rows */
|
#include "my_base.h" /* ha_rows */
|
||||||
#include "sql_list.h" /* Sql_alloc */
|
#include "sql_alloc.h"
|
||||||
#include "filesort_utils.h"
|
#include "filesort_utils.h"
|
||||||
|
|
||||||
class SQL_SELECT;
|
class SQL_SELECT;
|
||||||
|
@ -18,7 +18,7 @@
|
|||||||
#define _PARSE_FILE_H_
|
#define _PARSE_FILE_H_
|
||||||
|
|
||||||
#include "sql_string.h" // LEX_STRING
|
#include "sql_string.h" // LEX_STRING
|
||||||
#include "sql_list.h" // Sql_alloc
|
#include "sql_alloc.h" // Sql_alloc
|
||||||
|
|
||||||
class THD;
|
class THD;
|
||||||
|
|
||||||
|
54
sql/sql_alloc.h
Normal file
54
sql/sql_alloc.h
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
#ifndef SQL_ALLOC_INCLUDED
|
||||||
|
#define SQL_ALLOC_INCLUDED
|
||||||
|
/* Copyright (c) 2000, 2012, Oracle and/or its affiliates.
|
||||||
|
Copyright (c) 2017, MariaDB AB
|
||||||
|
|
||||||
|
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 St, Fifth Floor, Boston, MA 02110-1301 USA */
|
||||||
|
|
||||||
|
#include <my_sys.h> /* alloc_root, MEM_ROOT, TRASH */
|
||||||
|
|
||||||
|
THD *thd_get_current_thd();
|
||||||
|
|
||||||
|
/* mysql standard class memory allocator */
|
||||||
|
|
||||||
|
class Sql_alloc
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
static void *operator new(size_t size) throw ()
|
||||||
|
{
|
||||||
|
return thd_alloc(thd_get_current_thd(), size);
|
||||||
|
}
|
||||||
|
static void *operator new[](size_t size) throw ()
|
||||||
|
{
|
||||||
|
return thd_alloc(thd_get_current_thd(), size);
|
||||||
|
}
|
||||||
|
static void *operator new[](size_t size, MEM_ROOT *mem_root) throw ()
|
||||||
|
{ return alloc_root(mem_root, size); }
|
||||||
|
static void *operator new(size_t size, MEM_ROOT *mem_root) throw ()
|
||||||
|
{ return alloc_root(mem_root, size); }
|
||||||
|
static void operator delete(void *ptr, size_t size) { TRASH(ptr, size); }
|
||||||
|
static void operator delete(void *ptr, MEM_ROOT *mem_root)
|
||||||
|
{ /* never called */ }
|
||||||
|
static void operator delete[](void *ptr, MEM_ROOT *mem_root)
|
||||||
|
{ /* never called */ }
|
||||||
|
static void operator delete[](void *ptr, size_t size) { TRASH(ptr, size); }
|
||||||
|
#ifdef HAVE_valgrind
|
||||||
|
bool dummy_for_valgrind;
|
||||||
|
inline Sql_alloc() :dummy_for_valgrind(0) {}
|
||||||
|
#else
|
||||||
|
inline Sql_alloc() {}
|
||||||
|
#endif
|
||||||
|
inline ~Sql_alloc() {}
|
||||||
|
};
|
||||||
|
#endif /* SQL_ALLOC_INCLUDED */
|
@ -21,7 +21,7 @@
|
|||||||
#pragma interface /* gcc class implementation */
|
#pragma interface /* gcc class implementation */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include "sql_list.h" /* Sql_alloc */
|
#include "sql_alloc.h" /* Sql_alloc */
|
||||||
#include "my_rnd.h" /* rand_struct */
|
#include "my_rnd.h" /* rand_struct */
|
||||||
|
|
||||||
class SQL_CRYPT :public Sql_alloc
|
class SQL_CRYPT :public Sql_alloc
|
||||||
|
@ -17,12 +17,12 @@
|
|||||||
#ifndef SQL_ERROR_H
|
#ifndef SQL_ERROR_H
|
||||||
#define SQL_ERROR_H
|
#define SQL_ERROR_H
|
||||||
|
|
||||||
#include "sql_list.h" /* Sql_alloc, MEM_ROOT */
|
#include "sql_list.h" /* Sql_alloc, MEM_ROOT, list */
|
||||||
#include "m_string.h" /* LEX_STRING */
|
#include "m_string.h" /* LEX_STRING */
|
||||||
#include "sql_string.h" /* String */
|
#include "sql_string.h" /* String */
|
||||||
#include "sql_plist.h" /* I_P_List */
|
#include "sql_plist.h" /* I_P_List */
|
||||||
#include "mysql_com.h" /* MYSQL_ERRMSG_SIZE */
|
#include "mysql_com.h" /* MYSQL_ERRMSG_SIZE */
|
||||||
#include "my_time.h" /* MYSQL_TIME */
|
#include "my_time.h" /* MYSQL_TIME */
|
||||||
#include "decimal.h"
|
#include "decimal.h"
|
||||||
|
|
||||||
class THD;
|
class THD;
|
||||||
|
@ -19,46 +19,7 @@
|
|||||||
#pragma interface /* gcc class implementation */
|
#pragma interface /* gcc class implementation */
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <my_sys.h> /* alloc_root, TRASH, MY_WME,
|
#include "sql_alloc.h"
|
||||||
MY_FAE, MY_ALLOW_ZERO_PTR */
|
|
||||||
#include "m_string.h" /* bfill */
|
|
||||||
|
|
||||||
THD *thd_get_current_thd();
|
|
||||||
|
|
||||||
/* mysql standard class memory allocator */
|
|
||||||
|
|
||||||
class Sql_alloc
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
static void *operator new(size_t size) throw ()
|
|
||||||
{
|
|
||||||
return thd_alloc(thd_get_current_thd(), size);
|
|
||||||
}
|
|
||||||
static void *operator new[](size_t size) throw ()
|
|
||||||
{
|
|
||||||
return thd_alloc(thd_get_current_thd(), size);
|
|
||||||
}
|
|
||||||
static void *operator new[](size_t size, MEM_ROOT *mem_root) throw ()
|
|
||||||
{ return alloc_root(mem_root, size); }
|
|
||||||
static void *operator new(size_t size, MEM_ROOT *mem_root) throw ()
|
|
||||||
{ return alloc_root(mem_root, size); }
|
|
||||||
static void operator delete(void *ptr, size_t size) { TRASH(ptr, size); }
|
|
||||||
static void operator delete(void *ptr, MEM_ROOT *mem_root)
|
|
||||||
{ /* never called */ }
|
|
||||||
static void operator delete[](void *ptr, MEM_ROOT *mem_root)
|
|
||||||
{ /* never called */ }
|
|
||||||
static void operator delete[](void *ptr, size_t size) { TRASH(ptr, size); }
|
|
||||||
#ifdef HAVE_valgrind
|
|
||||||
bool dummy_for_valgrind;
|
|
||||||
inline Sql_alloc() :dummy_for_valgrind(0) {}
|
|
||||||
inline ~Sql_alloc() {}
|
|
||||||
#else
|
|
||||||
inline Sql_alloc() {}
|
|
||||||
inline ~Sql_alloc() {}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
Simple intrusive linked list.
|
Simple intrusive linked list.
|
||||||
@ -67,6 +28,7 @@ public:
|
|||||||
a pointer to the first element in the list and a indirect
|
a pointer to the first element in the list and a indirect
|
||||||
reference to the last element.
|
reference to the last element.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
class SQL_I_List :public Sql_alloc
|
class SQL_I_List :public Sql_alloc
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user