apps-gorm/InterfaceBuilder/IBConnectors.h
Gregory John Casamento 1a71d2cafb Update ignore file
2023-06-14 04:09:37 -04:00

139 lines
3.5 KiB
Objective-C

/* Gorm.h
*
* Copyright (C) 2003 Free Software Foundation, Inc.
*
* Author: Gregory John Casamento <greg_casamento@yahoo.com>
* 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 Lesser General Public License as published by
* the Free Software Foundation; either version 2.1 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 Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02111 USA.
*/
#ifndef INCLUDED_IBCONNECTORS_H
#define INCLUDED_IBCONNECTORS_H
#include <Foundation/Foundation.h>
#include <AppKit/AppKit.h>
#include <AppKit/NSNibConnector.h>
#include <InterfaceBuilder/IBSystem.h>
// 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 <NSObject>
/**
* 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) <IBConnectors>
@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