/* Copyright (C) 2006 MySQL AB & MySQL Finland AB & TCX DataKonsult AB This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; version 2 of the License. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #include "ma_fulltext.h" #include "trnman_public.h" /** @brief drops (deletes) a table @param name table's name @return Operation status @retval 0 ok @retval 1 error */ int maria_delete_table(const char *name) { MARIA_HA *info; myf sync_dir; DBUG_ENTER("maria_delete_table"); #ifdef EXTRA_DEBUG _ma_check_table_is_closed(name,"delete"); #endif /** @todo LOCK take X-lock on table */ /* We need to know if this table is transactional. Unfortunately it is necessary to open the table just to check this. We use 'open_for_repair' to be able to open even a crashed table. */ if (!(info= maria_open(name, O_RDONLY, HA_OPEN_FOR_REPAIR))) { sync_dir= 0; } else { sync_dir= (info->s->now_transactional && !info->s->temporary && !maria_in_recovery) ? MY_SYNC_DIR : 0; /* Remove history for table */ _ma_reset_state(info); maria_close(info); } if (sync_dir) { /* For this log record to be of any use for Recovery, we need the upper MySQL layer to be crash-safe in DDLs. For now this record can serve when we apply logs to a backup, so we sync it. */ LSN lsn; LEX_CUSTRING log_array[TRANSLOG_INTERNAL_PARTS + 1]; log_array[TRANSLOG_INTERNAL_PARTS + 0].str= (uchar*)name; log_array[TRANSLOG_INTERNAL_PARTS + 0].length= strlen(name) + 1; if (unlikely(translog_write_record(&lsn, LOGREC_REDO_DROP_TABLE, &dummy_transaction_object, NULL, (translog_size_t) log_array[TRANSLOG_INTERNAL_PARTS + 0].length, sizeof(log_array)/sizeof(log_array[0]), log_array, NULL, NULL) || translog_flush(lsn))) DBUG_RETURN(1); } DBUG_RETURN(maria_delete_table_files(name, sync_dir)); } int maria_delete_table_files(const char *name, myf sync_dir) { char from[FN_REFLEN]; DBUG_ENTER("maria_delete_table_files"); fn_format(from,name,"",MARIA_NAME_IEXT,MY_UNPACK_FILENAME|MY_APPEND_EXT); if (mysql_file_delete_with_symlink(key_file_kfile, from, MYF(MY_WME | sync_dir))) DBUG_RETURN(my_errno); fn_format(from,name,"",MARIA_NAME_DEXT,MY_UNPACK_FILENAME|MY_APPEND_EXT); if (mysql_file_delete_with_symlink(key_file_dfile, from, MYF(MY_WME | sync_dir))) DBUG_RETURN(my_errno); // optional files from maria_pack: fn_format(from,name,"",".TMD",MY_UNPACK_FILENAME|MY_APPEND_EXT); mysql_file_delete_with_symlink(key_file_dfile, from, MYF(0)); fn_format(from,name,"",".OLD",MY_UNPACK_FILENAME|MY_APPEND_EXT); mysql_file_delete_with_symlink(key_file_dfile, from, MYF(0)); DBUG_RETURN(0); }