/* Copyright (C) 2000-2001, 2004, 2006 MySQL AB, 2008-2009 Sun Microsystems, Inc 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 */ /* deletes a table */ #include "fulltext.h" int mi_delete_table(const char *name) { char from[FN_REFLEN]; #ifdef USE_RAID uint raid_type=0,raid_chunks=0; #endif DBUG_ENTER("mi_delete_table"); #ifdef EXTRA_DEBUG check_table_is_closed(name,"delete"); #endif #ifdef USE_RAID { MI_INFO *info; /* When built with RAID support, we need to determine if this table makes use of the raid feature. If yes, we need to remove all raid chunks. This is done with my_raid_delete(). 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 even this open fails, we assume no raid configuration for this table and try to remove the normal data file only. This may however leave the raid chunks behind. */ if (!(info= mi_open(name, O_RDONLY, HA_OPEN_FOR_REPAIR))) raid_type= 0; else { raid_type= info->s->base.raid_type; raid_chunks= info->s->base.raid_chunks; mi_close(info); } } #ifdef EXTRA_DEBUG check_table_is_closed(name,"delete"); #endif #endif /* USE_RAID */ fn_format(from,name,"",MI_NAME_IEXT,MY_UNPACK_FILENAME|MY_APPEND_EXT); if (mysql_file_delete_with_symlink(mi_key_file_kfile, from, MYF(MY_WME))) DBUG_RETURN(my_errno); fn_format(from,name,"",MI_NAME_DEXT,MY_UNPACK_FILENAME|MY_APPEND_EXT); #ifdef USE_RAID if (raid_type) DBUG_RETURN(my_raid_delete(from, raid_chunks, MYF(MY_WME)) ? my_errno : 0); #endif DBUG_RETURN(mysql_file_delete_with_symlink(mi_key_file_dfile, from, MYF(MY_WME)) ? my_errno : 0); }