summaryrefslogtreecommitdiff
path: root/sql/unireg.cc
diff options
context:
space:
mode:
Diffstat (limited to 'sql/unireg.cc')
-rw-r--r--sql/unireg.cc70
1 files changed, 62 insertions, 8 deletions
diff --git a/sql/unireg.cc b/sql/unireg.cc
index 0e4b449c6a3..bab021aed59 100644
--- a/sql/unireg.cc
+++ b/sql/unireg.cc
@@ -46,11 +46,29 @@ static bool make_empty_rec(int file, enum db_type table_type,
List<create_field> &create_fields,
uint reclength,uint null_fields);
+/*
+ Create a frm (table definition) file
+
+ SYNOPSIS
+ mysql_create_frm()
+ thd Thread handler
+ file_name Name of file (including database and .frm)
+ create_info create info parameters
+ create_fields Fields to create
+ keys number of keys to create
+ key_info Keys to create
+ db_file Handler to use. May be zero, in which case we use
+ create_info->db_type
+ RETURN
+ 0 ok
+ 1 error
+*/
-int rea_create_table(THD *thd, my_string file_name,
- HA_CREATE_INFO *create_info,
- List<create_field> &create_fields,
- uint keys, KEY *key_info)
+bool mysql_create_frm(THD *thd, my_string file_name,
+ HA_CREATE_INFO *create_info,
+ List<create_field> &create_fields,
+ uint keys, KEY *key_info,
+ handler *db_file)
{
uint reclength,info_length,screens,key_info_length,maxlength,null_fields;
File file;
@@ -58,13 +76,13 @@ int rea_create_table(THD *thd, my_string file_name,
uchar fileinfo[64],forminfo[288],*keybuff;
TYPELIB formnames;
uchar *screen_buff;
- handler *db_file;
DBUG_ENTER("rea_create_table");
formnames.type_names=0;
if (!(screen_buff=pack_screens(create_fields,&info_length,&screens,0)))
DBUG_RETURN(1);
- db_file=get_new_handler((TABLE*) 0, create_info->db_type);
+ if (db_file == NULL)
+ db_file=get_new_handler((TABLE*) 0, create_info->db_type);
if (pack_header(forminfo, create_info->db_type,create_fields,info_length,
screens, create_info->table_options, db_file))
{
@@ -155,8 +173,7 @@ int rea_create_table(THD *thd, my_string file_name,
if (opt_sync_frm && !(create_info->options & HA_LEX_CREATE_TMP_TABLE) &&
my_sync(file, MYF(MY_WME)))
goto err2;
- if (my_close(file,MYF(MY_WME)) ||
- ha_create_table(file_name,create_info,0))
+ if (my_close(file,MYF(MY_WME)))
goto err3;
DBUG_RETURN(0);
@@ -168,6 +185,43 @@ err2:
err3:
my_delete(file_name,MYF(0));
DBUG_RETURN(1);
+} /* mysql_create_frm */
+
+
+/*
+ Create a frm (table definition) file and the tables
+
+ SYNOPSIS
+ mysql_create_frm()
+ thd Thread handler
+ file_name Name of file (including database and .frm)
+ create_info create info parameters
+ create_fields Fields to create
+ keys number of keys to create
+ key_info Keys to create
+ db_file Handler to use. May be zero, in which case we use
+ create_info->db_type
+ RETURN
+ 0 ok
+ 1 error
+*/
+
+int rea_create_table(THD *thd, my_string file_name,
+ HA_CREATE_INFO *create_info,
+ List<create_field> &create_fields,
+ uint keys, KEY *key_info)
+{
+ DBUG_ENTER("rea_create_table");
+
+ if (mysql_create_frm(thd, file_name, create_info,
+ create_fields, keys, key_info, NULL))
+ DBUG_RETURN(1);
+ if (ha_create_table(file_name,create_info,0))
+ {
+ my_delete(file_name,MYF(0));
+ DBUG_RETURN(1);
+ }
+ DBUG_RETURN(0);
} /* rea_create_table */