From bbe0f861dd4e3ab99aa3d555d3fc5db5ee5ae39d Mon Sep 17 00:00:00 2001 From: stuconnolly Date: Mon, 24 May 2010 18:07:43 +0000 Subject: Merge export redesign branch back into trunk. Includes a completely redesign approach to all export data types based on the use of NSOperation subclasses. CSV, SQL, XML and dot export types are currently functional, while the source files for PDF and HTML export types exist they are to be implemented, but are currently hidden from the interface. Also includes the following: - Completely redesigned export interface. - The ability to customize CSV NULL values. - The ability to specify whether the UTF-8 BOM should be used in SQL dumps. - The ability to specify whether BLOB fields are output as hex or plain text during SQL dumps. Defaults to hex. - Exporting currently selected tables via the tables list context menu. Outstanding issues: - Not all progress indicators for all export types are functional (or functioning correctly). - A few issues related to the introduction of only exporting the content and create and drop syntax of specific tables during SQL dumps. Needs some serious testing and benchmarking to ensure it replicates the current export functionality. --- Source/SPDotExporterProtocol.h | 72 ++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 72 insertions(+) create mode 100644 Source/SPDotExporterProtocol.h (limited to 'Source/SPDotExporterProtocol.h') diff --git a/Source/SPDotExporterProtocol.h b/Source/SPDotExporterProtocol.h new file mode 100644 index 00000000..5d2c3db3 --- /dev/null +++ b/Source/SPDotExporterProtocol.h @@ -0,0 +1,72 @@ +// +// $Id$ +// +// SPDotExporterProtocol.h +// sequel-pro +// +// Created by Stuart Connolly (stuconnolly.com) on April 15, 2010 +// Copyright (c) 2010 Stuart Connolly. All rights reserved. +// +// 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 + +@class SPDotExporter; + +/** + * @protocol SPDotExporterProtocol SPDotExporterProtocol.h + * + * @author Stuart Connolly http://stuconnolly.com/ + * + * Dot schema exporter delegate protocol. + */ +@protocol SPDotExporterProtocol + +/** + * Called when the dot export process is about to begin. + * + * @param SPDotExpoter The expoter calling the method. + */ +- (void)dotExportProcessWillBegin:(SPDotExporter *)exporter; + +/** + * Called when the dot export process is complete. + * + * @param SPDotExpoter The expoter calling the method. + */ +- (void)dotExportProcessComplete:(SPDotExporter *)exporter; + +/** + * Called when the progress of the dot export process is updated. + * + * @param SPDotExpoter The expoter calling the method. + */ +- (void)dotExportProcessProgressUpdated:(SPDotExporter *)exporter; + +/** + * Called when the dot export process is about to begin fetching data from the database. + * + * @param SPDotExpoter The expoter calling the method. + */ +- (void)dotExportProcessWillBeginFetchingData:(SPDotExporter *)exporter; + +/** + * Called when the dot export process is about to begin writing data to disk. + * + * @param SPDotExpoter The expoter calling the method. + */ +- (void)dotExportProcessWillBeginFetchingRelationsData:(SPDotExporter *)exporter; + +@end -- cgit v1.2.3