~drizzle-trunk/drizzle/development

« back to all changes in this revision

Viewing changes to drizzled/thr_malloc.cc

Merged from Toru - removal of my_time_t.

Show diffs side-by-side

added added

removed removed

Lines of Context:
11
11
 
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 */
15
15
 
16
16
 
17
17
/* Mallocs for used in threads */
18
18
 
19
 
#include <config.h>
20
 
 
21
 
#include <string.h>
22
 
 
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>
28
 
 
29
 
#include <drizzled/internal/my_sys.h>
30
 
 
31
 
namespace drizzled
32
 
{
33
 
 
34
 
static void sql_alloc_error_handler(void)
35
 
{
36
 
  errmsg_printf(error::ERROR, "%s",ER(ER_OUT_OF_RESOURCES));
37
 
}
38
 
 
39
 
void memory::init_sql_alloc(memory::Root *mem_root, size_t block_size, size_t)
40
 
{
41
 
  mem_root->init_alloc_root(block_size);
42
 
  mem_root->error_handler= sql_alloc_error_handler;
43
 
}
44
 
 
45
 
 
46
 
void *memory::sql_alloc(size_t Size)
47
 
{
48
 
  memory::Root *root= current_mem_root();
49
 
  return root->alloc_root(Size);
50
 
}
51
 
 
52
 
 
53
 
void *memory::sql_calloc(size_t size)
 
22
 
 
23
 
 
24
extern "C" {
 
25
  void sql_alloc_error_handler(void)
 
26
  {
 
27
    sql_print_error("%s",ER(ER_OUT_OF_RESOURCES));
 
28
  }
 
29
}
 
30
 
 
31
void init_sql_alloc(MEM_ROOT *mem_root, size_t block_size, size_t pre_alloc)
 
32
{
 
33
  init_alloc_root(mem_root, block_size, pre_alloc);
 
34
  mem_root->error_handler=sql_alloc_error_handler;
 
35
}
 
36
 
 
37
 
 
38
void *sql_alloc(size_t Size)
 
39
{
 
40
  MEM_ROOT *root= current_mem_root();
 
41
  return alloc_root(root,Size);
 
42
}
 
43
 
 
44
 
 
45
void *sql_calloc(size_t size)
54
46
{
55
47
  void *ptr;
56
 
 
57
 
  if ((ptr=memory::sql_alloc(size)))
 
48
  if ((ptr=sql_alloc(size)))
58
49
    memset(ptr, 0, size);
59
 
 
60
50
  return ptr;
61
51
}
62
52
 
63
53
 
64
 
char *memory::sql_strdup(const char *str)
 
54
char *sql_strdup(const char *str)
65
55
{
66
56
  size_t len= strlen(str)+1;
67
57
  char *pos;
68
 
  if ((pos= (char*) memory::sql_alloc(len)))
 
58
  if ((pos= (char*) sql_alloc(len)))
69
59
    memcpy(pos,str,len);
70
60
  return pos;
71
61
}
72
62
 
73
63
 
74
 
char *memory::sql_strmake(const char *str, size_t len)
 
64
char *sql_strmake(const char *str, size_t len)
75
65
{
76
66
  char *pos;
77
 
  if ((pos= (char*) memory::sql_alloc(len+1)))
 
67
  if ((pos= (char*) sql_alloc(len+1)))
78
68
  {
79
69
    memcpy(pos,str,len);
80
70
    pos[len]=0;
83
73
}
84
74
 
85
75
 
86
 
void* memory::sql_memdup(const void *ptr, size_t len)
 
76
void* sql_memdup(const void *ptr, size_t len)
87
77
{
88
78
  void *pos;
89
 
  if ((pos= memory::sql_alloc(len)))
 
79
  if ((pos= sql_alloc(len)))
90
80
    memcpy(pos,ptr,len);
91
81
  return pos;
92
82
}
93
83
 
94
 
void *memory::SqlAlloc::operator new(size_t size)
95
 
{
96
 
  return memory::sql_alloc(size);
97
 
}
98
 
 
99
 
void *memory::SqlAlloc::operator new[](size_t size)
100
 
{
101
 
  return memory::sql_alloc(size);
102
 
}
103
 
 
104
 
void *memory::SqlAlloc::operator new[](size_t size, memory::Root *mem_root)
105
 
{
106
 
  return mem_root->alloc_root(size);
107
 
}
108
 
 
109
 
void *memory::SqlAlloc::operator new(size_t size, memory::Root *mem_root)
110
 
{
111
 
  return mem_root->alloc_root(size);
112
 
}
113
 
 
114
 
} /* namespace drizzled */
 
84
void sql_element_free(void *)
 
85
{} /* purecov: deadcode */
 
86
 
 
87
 
 
88
 
 
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)
 
94
{
 
95
  char *pos;
 
96
  size_t new_length= to_cs->mbmaxlen*arg_length;
 
97
  max_res_length--;                             // Reserve place for end null
 
98
 
 
99
  set_if_smaller(new_length, max_res_length);
 
100
  if (!(pos= (char*) sql_alloc(new_length+1)))
 
101
    return pos;                                 // Error
 
102
 
 
103
  if ((from_cs == &my_charset_bin) || (to_cs == &my_charset_bin))
 
104
  {
 
105
    // Safety if to_cs->mbmaxlen > 0
 
106
    new_length= cmin(arg_length, max_res_length);
 
107
    memcpy(pos, str, new_length);
 
108
  }
 
109
  else
 
110
  {
 
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);
 
114
  }
 
115
  pos[new_length]= 0;
 
116
  *result_length= new_length;
 
117
  return pos;
 
118
}
 
119