12
12
You should have received a copy of the GNU General Public License
13
13
along with this program; if not, write to the Free Software
14
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
14
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
17
17
/* Mallocs for used in threads */
23
#include <drizzled/errmsg_print.h>
24
#include <drizzled/memory/sql_alloc.h>
19
#include <drizzled/server_includes.h>
25
20
#include <drizzled/current_session.h>
26
21
#include <drizzled/error.h>
27
#include <drizzled/definitions.h>
29
#include <drizzled/internal/my_sys.h>
34
static void sql_alloc_error_handler(void)
36
errmsg_printf(error::ERROR, "%s",ER(ER_OUT_OF_RESOURCES));
39
void memory::init_sql_alloc(memory::Root *mem_root, size_t block_size, size_t)
41
mem_root->init_alloc_root(block_size);
42
mem_root->error_handler= sql_alloc_error_handler;
46
void *memory::sql_alloc(size_t Size)
48
memory::Root *root= current_mem_root();
49
return root->alloc_root(Size);
53
void *memory::sql_calloc(size_t size)
25
void sql_alloc_error_handler(void)
27
sql_print_error("%s",ER(ER_OUT_OF_RESOURCES));
31
void init_sql_alloc(MEM_ROOT *mem_root, size_t block_size, size_t pre_alloc)
33
init_alloc_root(mem_root, block_size, pre_alloc);
34
mem_root->error_handler=sql_alloc_error_handler;
38
void *sql_alloc(size_t Size)
40
MEM_ROOT *root= current_mem_root();
41
return alloc_root(root,Size);
45
void *sql_calloc(size_t size)
57
if ((ptr=memory::sql_alloc(size)))
48
if ((ptr=sql_alloc(size)))
58
49
memset(ptr, 0, size);
64
char *memory::sql_strdup(const char *str)
54
char *sql_strdup(const char *str)
66
56
size_t len= strlen(str)+1;
68
if ((pos= (char*) memory::sql_alloc(len)))
58
if ((pos= (char*) sql_alloc(len)))
69
59
memcpy(pos,str,len);
74
char *memory::sql_strmake(const char *str, size_t len)
64
char *sql_strmake(const char *str, size_t len)
77
if ((pos= (char*) memory::sql_alloc(len+1)))
67
if ((pos= (char*) sql_alloc(len+1)))
79
69
memcpy(pos,str,len);
86
void* memory::sql_memdup(const void *ptr, size_t len)
76
void* sql_memdup(const void *ptr, size_t len)
89
if ((pos= memory::sql_alloc(len)))
79
if ((pos= sql_alloc(len)))
90
80
memcpy(pos,ptr,len);
94
void *memory::SqlAlloc::operator new(size_t size)
96
return memory::sql_alloc(size);
99
void *memory::SqlAlloc::operator new[](size_t size)
101
return memory::sql_alloc(size);
104
void *memory::SqlAlloc::operator new[](size_t size, memory::Root *mem_root)
106
return mem_root->alloc_root(size);
109
void *memory::SqlAlloc::operator new(size_t size, memory::Root *mem_root)
111
return mem_root->alloc_root(size);
114
} /* namespace drizzled */
84
void sql_element_free(void *)
85
{} /* purecov: deadcode */
89
char *sql_strmake_with_convert(const char *str, size_t arg_length,
90
const CHARSET_INFO * const from_cs,
91
size_t max_res_length,
92
const CHARSET_INFO * const to_cs,
93
size_t *result_length)
96
size_t new_length= to_cs->mbmaxlen*arg_length;
97
max_res_length--; // Reserve place for end null
99
set_if_smaller(new_length, max_res_length);
100
if (!(pos= (char*) sql_alloc(new_length+1)))
103
if ((from_cs == &my_charset_bin) || (to_cs == &my_charset_bin))
105
// Safety if to_cs->mbmaxlen > 0
106
new_length= cmin(arg_length, max_res_length);
107
memcpy(pos, str, new_length);
111
uint32_t dummy_errors;
112
new_length= copy_and_convert((char*) pos, new_length, to_cs, str,
113
arg_length, from_cs, &dummy_errors);
116
*result_length= new_length;