mirror of
https://github.com/gnustep/libs-gdl2.git
synced 2025-02-22 02:41:05 +00:00
* *.h/m, *.h/m): Used #include instead of depricated #import. Avoid including entire library headers. Use export macro where applicable. * EOControl/GNUmakefile: Removed EOKeyValueCodingBase.m/h and EOUndoMananger.h. Added EOArrayDataSource.m/h, EODefines.h and EODepricated.h. * EOControl/EODefines.h: Updated for GDL2 & gnustep-make. * EOControl/EODebug.h: Updated. * EOControl/EODepricated.h: Updated for current state of GDL2. ([NSObject +flushClassKeyBindings]): Added declaration. ([EOClassDescription +setDelegate:]): Added declaration. ([EOClassDescription +delegate]): Added declaration. (EOUndoManager): Moved declaration of interface here. * EOControl/EOKeyValueCoding.m ([EOClassDescription +flushClassKeyBindings]): Added empty implementation. ([NSObject takeStoredValuesFromDictionary:]): Cache EONull instance and use it instead of isKindOfClass:. * EOControl/EOEditingContext.m ([EOEditingContext +initialize]): Tidied. ([EOEditingContest -deleteObject]): Use NSUndoManager instead of EOUndoManager. * EOControl/EOQualifier.m ([NSArray -filteredArrayUsingQualifier:]): Added minor optimization tweak. * EOControl/EOClassDescription.m: Removed inactive commented code. Added private declerations of EOAccess methods to avoid compiler warnings. ([EOClassDescription +initialize]): Tidied. ([EOClassDescription -classDescriptionForClass:]): Use GSObjCName() instead of objc runtime routines. * EOControl/EOFault.m: Exchanged direct usages of ObjC runtime routines with NS/GSObjCRuntime abstraction API. ([EOFault +superclass]): Ditto. ([EOFault +targetClassForFault:]): Ditto. ([EOFault -respondsToSelector:]): Ditto. ([EOFault +initialize]): Cache static class variable. ([EOFault +isKindOfClass]): Use static class variable. ([EOFault +handlerForFault:]): Ditto. ([EOFault +targetClassForFault:]): Ditto. ([EOFault -dealloc]): Ditto. * EOControl/EOGenericRecord.m: ([EOGenericRecord +initialize]): Tidied. * EOControl/EOKeyComparisonQualifier.m: Tidied documentation. * EOControl/EOKeyValueQualifier.m: Ditto. * EOControl/EONSAddOns.h/m: Added declarations to surpress compiler warnings. ([NSObject -eoCompareOnName:]): Adjusted casts to surpress compiler warnings. (GSUseStrictWO451Compatibility): Added function. (GDL2GlobalLock, GDL2GlobalRecursive): Ditto. * EOControl/EONull: Remove implementations for foundation libraries without key value coding and fully rely on NSNull. Added assertions in all intance methods as instances should never be created. ([EONull +allocWithZone:]) Corrected method name so it will actually be used. * EOControl/EOSortOrdering.m ([NSArray sortedArrayUsingKeyOrderArray:]): Tidied. ([NSMutableArray sortUsingKeyOrderArray:]): Ditto. ([EONull compareAscending:]): Sync with referencs implementation. ([EONull compareDescending:]): Ditto. ([EONull compareCaseInsensitiveAscending:]): Ditto. ([EONull compareCaseInsensitiveDescending:]): Ditto. * EOAccess/EOAdaptor.h: Added comment about API compatibility. * EOAccess/EOAdaptor.m ([EOAdaptor -contexts]): Return array of adaptor contexts rather tham GC-wrapper objects containing adaptor contexts. ([EOAdaptor -databaseEncoding]): Use GSEncodingName() instead of GetEncodingName(). * EOAccess/EODatabaseContext.m ([EODatabaseContext -_turnFault:gid:editingContext:isComplete:]): Use GSObjCClass() instead of trying to access isa by dereferencing from id with incorrect member. * EOAccess/EOModel.m ([EOModel -entityNames]): Sort returned array to insure comparable output. * EOAccess/EOSQLExpression.m ([EOSQLExpression sqlStringForArrayOfQualifiers:operation:]): Added cast to surpress compiler warning. * EOAccess/EOUtilities.m ([EOObjectStoreCoordinator setModelGroup:]): Ditto. * EOAccess/EORelationship.h ([EORelationship -docComment]): Added declaration. * EOAccess/GNUmakefile: Added EODefines.h and EODepricated.h. * Tools/*.m: Use RCS_ID macro. * Tools/EOAttribute+GSDoc.h: ([EOAttribute gsdocContentWithTagName:idPtr:]): Corrected Typo. * Tools/EOModel+GSDoc.h/m: ([EOModel gsdocContentSplittedByEntities:idPtr:]): Ditto. * Tools/EORelationship+GSDoc.m: ([EORelationship gsdocContentWithTagName:idPtr:]): Change variable type to supress compiler warnings. * Tools/eoutil.m (dump): Initialize variables to supress compiler warnings. * Tools/gsdoc-model.m: Include GSCategories.h to supress compiler warnings. (main): Added cast to supress compiler warning. Fixed typo in method invocation. 2003-03-25 Stephane Corthesy <stephane@sente.ch> * EOControl/EODefines.h: Added new file for export/win32 support. * EOControl/EODepricated.h: Added new file for depricated features. * EOControl/EOControl.h: Added EOArrayDataSource.h and EODefines.h. * EOControl/EOArrayDataSource.h/m: Added new files. Some methods (<NSCoding> and qualifier bindings) are empty stubs. * EOControl/EODebug.h: Use export macro instead of explicit extern for function and symbol declarations. * EOControl/EOGlobalID.h: Ditto. * EOControl/EONull.h: Ditto. * EOControl/EOObjectStore.h: Ditto. * EOControl/EOOrQualifier.m: Replaced autorelease by AUTORELEASE and fixed typo. * EOControl/EOQualifier.m ([NSArray -filteredArrayUsingQualifier:]): Implemented. * EOControl/EONSAddOns.m: Use volatile in some exception handlers (man longjmp for more info). * EOControl/EOSortOrdering.h/m ([EOSortOrdering -copyWithZone:]): Implemented <NSCopying>. ([EOSortOrdering -encodeWithKeyValueArchiver:]): Implemented. * EOAccess/EODefines.h: Added new file for export/win32 support. * EOAccess/EODepricated.h: Added new file for depricated features. * EOAccess/EOAccess.h: Added EODefines.h. * EOAccess/EOSQLExpression.h/m: Fixed typo for EOPrimaryKeyConstraintKey. * EOAccess/EOExpressionArray.h/m: Use volatile for variables usein in exception handlers. (man longjmp for more info) * EOAccess/EODatabase.h: Use export macro instead of explicit extern for function and symbol declarations. * EOAccess/EOEntity.h: Ditto. * EOAccess/EOModel.h: Ditto. * EOAccess/EOSchemaGeneration.h: Ditto. * EOAccess/EOSQLExpression.h: Ditto. * EOAccess/EOUtilities.h: Ditto. * Tools/eoutil.m (dump): Implemented use of -postinstall option. Corrected bug when getting adaptor's expression class. Renamed symbol EOPrimaryKeyContraintsKey into EOPrimaryKeyConstraintsKey. git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gdl2/trunk@16298 72102866-910b-0410-8b05-ffd578937521
193 lines
6 KiB
Objective-C
193 lines
6 KiB
Objective-C
/*
|
|
EODatabaseOperation.h
|
|
|
|
Copyright (C) 2000 Free Software Foundation, Inc.
|
|
|
|
Author: Mirko Viviani <mirko.viviani@rccr.cremona.it>
|
|
Date: February 2000
|
|
|
|
This file is part of the GNUstep Database Library.
|
|
|
|
This library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2 of the License, or (at your option) any later version.
|
|
|
|
This library 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
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
License along with this library; see the file COPYING.LIB.
|
|
If not, write to the Free Software Foundation,
|
|
59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*/
|
|
|
|
#ifndef __EODatabaseOperation_h__
|
|
#define __EODatabaseOperation_h__
|
|
|
|
#ifndef NeXT_Foundation_LIBRARY
|
|
#include <Foundation/NSObject.h>
|
|
#else
|
|
#include <Foundation/Foundation.h>
|
|
#endif
|
|
|
|
|
|
@class NSArray;
|
|
@class NSMutableArray;
|
|
@class NSDictionary;
|
|
@class NSMutableDictionary;
|
|
@class NSException;
|
|
@class NSString;
|
|
|
|
@class EOStoredProcedure;
|
|
@class EOEntity;
|
|
@class EOQualifier;
|
|
@class EOGlobalID;
|
|
|
|
|
|
typedef enum {
|
|
EOAdaptorUndefinedOperator = 0,
|
|
EOAdaptorLockOperator,
|
|
EOAdaptorInsertOperator,
|
|
EOAdaptorUpdateOperator,
|
|
EOAdaptorDeleteOperator,
|
|
EOAdaptorStoredProcedureOperator
|
|
} EOAdaptorOperator;
|
|
|
|
/**
|
|
EOAdaptorOperation represent an adaptor 'elementaty' operation.
|
|
Instance objects are created by EODatabaseOperation
|
|
**/
|
|
@interface EOAdaptorOperation : NSObject
|
|
{
|
|
EOAdaptorOperator _adaptorOperator; /** Database Adaptor **/
|
|
EOEntity *_entity; /** Main concerned entity **/
|
|
EOQualifier *_qualifier; /** qualifier **/
|
|
NSDictionary *_changedValues; /** dictionary of changed fields/values **/
|
|
NSArray *_attributes;
|
|
EOStoredProcedure *_storedProcedure; /** Stored Procedure **/
|
|
NSException *_exception;
|
|
}
|
|
|
|
+ (EOAdaptorOperation *)adaptorOperationWithEntity: (EOEntity *)entity;
|
|
|
|
/** Init the instance with the main concerned entity **/
|
|
- (id) initWithEntity: (EOEntity *)entity;
|
|
|
|
/** returns adaptor operator **/
|
|
- (EOAdaptorOperator)adaptorOperator;
|
|
|
|
/** set adaptor operator **/
|
|
- (void)setAdaptorOperator: (EOAdaptorOperator)adaptorOperator;
|
|
|
|
/** returns entity **/
|
|
- (EOEntity *)entity;
|
|
|
|
/** returns qualifier **/
|
|
- (EOQualifier *)qualifier;
|
|
|
|
/** set Qualifier **/
|
|
- (void)setQualifier: (EOQualifier *)qualifier;
|
|
|
|
/** returns dictionary of changed values **/
|
|
- (NSDictionary *)changedValues;
|
|
|
|
/** set dictionary of changed values **/
|
|
- (void)setChangedValues: (NSDictionary *)changedValues;
|
|
|
|
|
|
- (NSArray *)attributes;
|
|
- (void)setAttributes: (NSArray *)attributes;
|
|
|
|
- (EOStoredProcedure *)storedProcedure;
|
|
- (void)setStoredProcedure: (EOStoredProcedure *)storedProcedure;
|
|
|
|
- (NSException *)exception;
|
|
- (void)setException: (NSException *)exception;
|
|
|
|
/** compare 2 adaptor operations **/
|
|
- (NSComparisonResult)compareAdaptorOperation: (EOAdaptorOperation *)adaptorOp;
|
|
|
|
@end
|
|
|
|
typedef enum {
|
|
EODatabaseNothingOperator = 0,
|
|
EODatabaseInsertOperator,
|
|
EODatabaseUpdateOperator,
|
|
EODatabaseDeleteOperator
|
|
} EODatabaseOperator;
|
|
|
|
/**
|
|
EODatabaseOperation represent a database high level operation on an object (record)
|
|
It creates EOAdaptorOperations.
|
|
You generally don't need to create such objects by yourself. They are created by EOEditingContext
|
|
**/
|
|
@interface EODatabaseOperation : NSObject
|
|
{
|
|
EODatabaseOperator _databaseOperator; //** Database Operator **/
|
|
NSMutableDictionary *_newRow; //** New Row (new state of the object) **/
|
|
EOGlobalID *_globalID; /** global ID of the object **/
|
|
EOEntity *_entity; /** entity **/
|
|
NSMutableArray *_adaptorOps; /** EOAdaptorOperations generated to perfor this DatabaseOperation **/
|
|
id _object; /** object (record) **/
|
|
NSDictionary *_dbSnapshot; /** The last known database values for the object (i.e. values from last fetch or last commited operation) **/
|
|
NSMutableDictionary *_toManySnapshots; /** **/
|
|
}
|
|
|
|
+ (EODatabaseOperation*)databaseOperationWithGlobalID: (EOGlobalID *)globalID
|
|
object: (id)object
|
|
entity: (EOEntity *)entity;
|
|
|
|
- (id)initWithGlobalID: (EOGlobalID *)globalID
|
|
object: (id)object
|
|
entity: (EOEntity *)entity;
|
|
|
|
/** Returns the database snapshot for the object.
|
|
The snapshot contains the last known database values for the object.
|
|
If the object has just been inserted (i.e. not yet in database), the returned dictionary is empty
|
|
**/
|
|
- (NSDictionary *)dbSnapshot;
|
|
|
|
/** sets the snapshot for the object (should be empty if the object has just been inserted into an EOEditingContext **/
|
|
- (void)setDBSnapshot: (NSDictionary *)dbSnapshot;
|
|
|
|
/** Returns a dictionary with (new) values (properties+primary keys...) of the object.
|
|
The newRow dictionary is created when creating the database operation (in EODatabaseChannel -databaseOperationForObject: for exemple). Values come from object state in database and overrides by changes made on the object
|
|
**/
|
|
- (NSMutableDictionary *)newRow;
|
|
- (void)setNewRow:(NSMutableDictionary *)newRow;
|
|
|
|
- (EOGlobalID *)globalID;
|
|
|
|
- (id)object;
|
|
|
|
- (EOEntity *)entity;
|
|
|
|
- (EODatabaseOperator)databaseOperator;
|
|
- (void)setDatabaseOperator: (EODatabaseOperator)dbOp;
|
|
|
|
- (NSDictionary *)rowDiffs;
|
|
|
|
- (NSDictionary *)rowDiffsForAttributes: (NSArray *)attributes;
|
|
|
|
- (NSDictionary *)primaryKeyDiffs;
|
|
|
|
/** returns array of EOAdaptorOperations to perform **/
|
|
- (NSArray *)adaptorOperations;
|
|
|
|
/** adds an Adaptor Operation
|
|
Raises an exception if adaptorOperation is nil
|
|
**/
|
|
- (void)addAdaptorOperation: (EOAdaptorOperation *)adaptorOperation;
|
|
|
|
/** removes an Adaptor Operation **/
|
|
- (void)removeAdaptorOperation: (EOAdaptorOperation *)adaptorOperation;
|
|
|
|
- (void)recordToManySnapshot: (NSArray *)gids relationshipName:(NSString *)name;
|
|
- (NSDictionary *)toManySnapshots;
|
|
|
|
@end
|
|
|
|
#endif /* __EODatabaseOperation_h__ */
|