Commit f05204f9 authored by marko's avatar marko

branches/zip: Clean up fast index creation.

row_merge_dict_table_get_index(): Add function comment.
Use inlined versions of mem_alloc() and mem_free().
parent a05c36c2
...@@ -116,20 +116,23 @@ struct merge_block_struct { ...@@ -116,20 +116,23 @@ struct merge_block_struct {
typedef struct merge_block_struct merge_block_t; typedef struct merge_block_struct merge_block_t;
/**************************************************************************
Search an index object by name and column names. If several indexes match,
return the index with the max id. */
static static
dict_index_t* dict_index_t*
row_merge_dict_table_get_index( row_merge_dict_table_get_index(
/*===========================*/ /*===========================*/
dict_table_t* table, /* out: matching index,
const merge_index_def_t* NULL if not found */
index_def) dict_table_t* table, /* in: table */
const merge_index_def_t*index_def) /* in: index definition */
{ {
ulint i; ulint i;
dict_index_t* index; dict_index_t* index;
const char** column_names; const char** column_names;
column_names = (const char**) mem_alloc_noninline( column_names = mem_alloc(index_def->n_fields * sizeof *column_names);
index_def->n_fields * sizeof(char*));
for (i = 0; i < index_def->n_fields; ++i) { for (i = 0; i < index_def->n_fields; ++i) {
column_names[i] = index_def->fields[i].field_name; column_names[i] = index_def->fields[i].field_name;
...@@ -138,7 +141,7 @@ row_merge_dict_table_get_index( ...@@ -138,7 +141,7 @@ row_merge_dict_table_get_index(
index = dict_table_get_index_by_max_id( index = dict_table_get_index_by_max_id(
table, index_def->name, column_names, index_def->n_fields); table, index_def->name, column_names, index_def->n_fields);
mem_free_noninline(column_names); mem_free(column_names);
return(index); return(index);
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment