Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
M
MariaDB
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
nexedi
MariaDB
Commits
12ed008d
Commit
12ed008d
authored
Aug 20, 2007
by
marko
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
branches/zip: Use mem_heap_zalloc() when initializing
dict_table_t, dict_index_t, and dict_foreign_t.
parent
d723dbfa
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
9 additions
and
64 deletions
+9
-64
dict/dict0mem.c
dict/dict0mem.c
+3
-61
include/dict0mem.h
include/dict0mem.h
+6
-3
No files found.
dict/dict0mem.c
View file @
12ed008d
...
...
@@ -45,54 +45,22 @@ dict_mem_table_create(
heap
=
mem_heap_create
(
DICT_HEAP_SIZE
);
table
=
mem_heap_alloc
(
heap
,
sizeof
(
dict_table_t
));
table
=
mem_heap_
z
alloc
(
heap
,
sizeof
(
dict_table_t
));
table
->
heap
=
heap
;
table
->
flags
=
(
unsigned
int
)
flags
;
table
->
name
=
mem_heap_strdup
(
heap
,
name
);
table
->
dir_path_of_temp_table
=
NULL
;
table
->
version_number
=
0
;
table
->
space
=
(
unsigned
int
)
space
;
table
->
ibd_file_missing
=
FALSE
;
table
->
tablespace_discarded
=
FALSE
;
table
->
n_def
=
0
;
table
->
n_cols
=
(
unsigned
int
)
(
n_cols
+
DATA_N_SYS_COLS
);
table
->
n_mysql_handles_opened
=
0
;
table
->
n_foreign_key_checks_running
=
0
;
table
->
cached
=
FALSE
;
table
->
to_be_dropped
=
0
;
table
->
cols
=
mem_heap_alloc
(
heap
,
(
n_cols
+
DATA_N_SYS_COLS
)
*
sizeof
(
dict_col_t
));
table
->
col_names
=
NULL
;
UT_LIST_INIT
(
table
->
indexes
);
table
->
auto_inc_lock
=
mem_heap_alloc
(
heap
,
lock_get_size
());
table
->
query_cache_inv_trx_id
=
ut_dulint_zero
;
UT_LIST_INIT
(
table
->
locks
);
UT_LIST_INIT
(
table
->
foreign_list
);
UT_LIST_INIT
(
table
->
referenced_list
);
UT_LIST_INIT
(
table
->
prebuilts
);
#ifdef UNIV_DEBUG
table
->
does_not_fit_in_memory
=
FALSE
;
#endif
/* UNIV_DEBUG */
table
->
stat_initialized
=
FALSE
;
table
->
stat_modified_counter
=
0
;
table
->
big_rows
=
0
;
mutex_create
(
&
table
->
autoinc_mutex
,
SYNC_DICT_AUTOINC_MUTEX
);
table
->
autoinc_inited
=
FALSE
;
/* The actual increment value will be set by MySQL, we simply
default to 1 here.*/
table
->
autoinc_increment
=
1
;
...
...
@@ -241,29 +209,19 @@ dict_mem_index_create(
ut_ad
(
table_name
&&
index_name
);
heap
=
mem_heap_create
(
DICT_HEAP_SIZE
);
index
=
mem_heap_alloc
(
heap
,
sizeof
(
dict_index_t
));
index
=
mem_heap_
z
alloc
(
heap
,
sizeof
(
dict_index_t
));
index
->
id
=
ut_dulint_zero
;
index
->
heap
=
heap
;
index
->
type
=
type
;
index
->
space
=
(
unsigned
int
)
space
;
index
->
page
=
0
;
index
->
name
=
mem_heap_strdup
(
heap
,
index_name
);
index
->
table_name
=
table_name
;
index
->
table
=
NULL
;
index
->
n_def
=
index
->
n_nullable
=
0
;
index
->
n_fields
=
(
unsigned
int
)
n_fields
;
index
->
fields
=
mem_heap_alloc
(
heap
,
1
+
n_fields
*
sizeof
(
dict_field_t
));
/* The '1 +' above prevents allocation
of an empty mem block */
index
->
stat_n_diff_key_vals
=
NULL
;
index
->
cached
=
FALSE
;
index
->
to_be_dropped
=
FALSE
;
index
->
trx_id
=
ut_dulint_zero
;
memset
(
&
index
->
lock
,
0
,
sizeof
index
->
lock
);
#ifdef UNIV_DEBUG
index
->
magic_n
=
DICT_INDEX_MAGIC_N
;
#endif
/* UNIV_DEBUG */
...
...
@@ -283,26 +241,10 @@ dict_mem_foreign_create(void)
heap
=
mem_heap_create
(
100
);
foreign
=
mem_heap_alloc
(
heap
,
sizeof
(
dict_foreign_t
));
foreign
=
mem_heap_
z
alloc
(
heap
,
sizeof
(
dict_foreign_t
));
foreign
->
heap
=
heap
;
foreign
->
id
=
NULL
;
foreign
->
type
=
0
;
foreign
->
foreign_table_name
=
NULL
;
foreign
->
foreign_table
=
NULL
;
foreign
->
foreign_col_names
=
NULL
;
foreign
->
referenced_table_name
=
NULL
;
foreign
->
referenced_table
=
NULL
;
foreign
->
referenced_col_names
=
NULL
;
foreign
->
n_fields
=
0
;
foreign
->
foreign_index
=
NULL
;
foreign
->
referenced_index
=
NULL
;
return
(
foreign
);
}
...
...
include/dict0mem.h
View file @
12ed008d
...
...
@@ -189,7 +189,8 @@ struct dict_field_struct{
DICT_MAX_INDEX_COL_LEN */
};
/* Data structure for an index */
/* Data structure for an index. Most fields will be
initialized to 0, NULL or FALSE in dict_mem_index_create(). */
struct
dict_index_struct
{
dulint
id
;
/* id of the index */
mem_heap_t
*
heap
;
/* memory heap */
...
...
@@ -248,7 +249,8 @@ struct dict_index_struct{
};
/* Data structure for a foreign key constraint; an example:
FOREIGN KEY (A, B) REFERENCES TABLE2 (C, D) */
FOREIGN KEY (A, B) REFERENCES TABLE2 (C, D). Most fields will be
initialized to 0, NULL or FALSE in dict_mem_foreign_create(). */
struct
dict_foreign_struct
{
mem_heap_t
*
heap
;
/* this object is allocated from
...
...
@@ -296,7 +298,8 @@ a foreign key constraint is enforced, therefore RESTRICT just means no flag */
#define DICT_FOREIGN_ON_UPDATE_NO_ACTION 32
/* Data structure for a database table */
/* Data structure for a database table. Most fields will be
initialized to 0, NULL or FALSE in dict_mem_table_create(). */
struct
dict_table_struct
{
dulint
id
;
/* id of the table */
mem_heap_t
*
heap
;
/* memory heap */
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment