/* Gorm.h * * Copyright (C) 2003 Free Software Foundation, Inc. * * Author: Gregory John Casamento * Date: 2003 * * This file is part of GNUstep. * * 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., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef INCLUDED_IBCONNECTORS_H #define INCLUDED_IBCONNECTORS_H #include #include #include #include // forward declarations @class NSString; IB_EXTERN NSString *IBWillAddConnectorNotification; IB_EXTERN NSString *IBDidAddConnectorNotification; IB_EXTERN NSString *IBWillRemoveConnectorNotification; IB_EXTERN NSString *IBDidRemoveConnectorNotification; /* * Connector objects are used to record connections between nib objects. */ @protocol IBConnectors /** * Destination for the receiver. */ - (id) destination; /** * Establish the connection. */ - (void) establishConnection; /** * The method to which the receiver will be connected. */ - (NSString*) label; /** * Replace anObject with anotherObject. This method looks at * the receiver's source and destination and replaces whichever * one matches anObject with anotherObject. */ - (void) replaceObject: (id)anObject withObject: (id)anotherObject; /** * The source of the receiver. */ - (id) source; /** * Set the receiver's destination to anObject. */ - (void) setDestination: (id)anObject; /** * Set the receiver's label. */ - (void) setLabel: (NSString*)label; /** * Set the receiver's source to anObject. */ - (void) setSource: (id)anObject; /** * Called after the document is loaded on connections. */ - (id) nibInstantiate; @end @interface NSNibConnector (IBConnectorsProtocol) @end @interface NSObject (IBNibInstantiation) /** * Invoked after loading. */ - (id) nibInstantiate; @end @interface NSApplication (IBConnections) /** * [NSApp -connectSource] returns the source object as set by the most recent * [NSApp -displayConnectionBetween:and:] */ - (id) connectSource; /** * [NSApp -connectDestination] returns the target object as set by the most * recent [NSApp -displayConnectionBetween:and:] */ - (id) connectDestination; /** * [NSApp -isConnecting] simply lets you know if a connection is in progress. */ - (BOOL) isConnecting; /** * [NSApp -stopConnecting] terminates the current connection process and * removes the connection marks from the display. */ - (void) stopConnecting; /** * [NSApp -displayConnectionBetween:and:] is used to set the source and target * objects and mark the display appropriately. Setting either source or * target to 'nil' will remove markup from any previous source or target. * NB. This method expects to be able to call the active document to ask it * for the window and rectangle in which to perform markup. */ - (void) displayConnectionBetween: (id)source and: (id)destination; @end #endif