//
// $Id: $
//
// SPDatabaseCopy.h
// sequel-pro
//
// Created by David Rekowski on Apr 13, 2010
//
// 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; either version 2 of the License, or
// (at your option) any later version.
//
// 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
//
// More info at
#import
#import
#import "SPDatabaseInfo.h"
/**
* The SPDatabaseCopy class povides functionality to create a copy of a database.
*/
@interface SPDatabaseCopy : NSObject {
MCPConnection *connection;
SPDatabaseInfo *dbInfo;
NSObject *parent;
}
/**
* @property MCPConnection references the MCPKit connection to MySQL; it has to be set.
*/
@property (retain) MCPConnection *connection;
/**
* @property SPDatabaseInfo an instance of the database info class
*/
@property (retain) SPDatabaseInfo *dbInfo;
/**
* @property the parent object that issues the action, needs to provide stuff like tableWindow for messages
*/
@property (retain) NSObject *parent;
/**
* This method retrieves the dbInfo object if it exists; otherwise it is generated and the
* connection is passed to it.
*
* @result SPDatabaseInfo dbInfo object
*/
- (SPDatabaseInfo *)getDBInfoObject;
/**
* This method clones an existing database.
*
* @param NSString sourceDatabaseName the name of the source database
* @param NSString targetDatabaseName the name of the target database
* @result BOOL success
*/
- (BOOL)copyDatabaseFrom: (NSString *)sourceDatabaseName to: (NSString *)targetDatabaseName withContent: (BOOL)copyWithContent;
/**
* This method creates a new database.
*
* @param NSString newDatabaseName name of the new database to be created
* @return BOOL YES on success, otherwise NO
*/
- (BOOL) createDatabase: (NSString *)newDatabaseName;
@end