libs-gdl2/EOAccess/EOAdaptorChannel.m
David Ayers f3e520ee9a 2003-03-30 David Ayers <d.ayers@inode.at>
* *.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
2003-03-31 00:24:15 +00:00

626 lines
17 KiB
Objective-C

/**
EOAdaptorChannel.m <title>EOAdaptorChannel</title>
Copyright (C) 2000 Free Software Foundation, Inc.
Author: Mirko Viviani <mirko.viviani@rccr.cremona.it>
Date: February 2000
$Revision$
$Date$
<abstract></abstract>
This file is part of the GNUstep Database Library.
<license>
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.
</license>
**/
#include "config.h"
RCS_ID("$Id$")
#ifndef NeXT_Foundation_LIBRARY
#include <Foundation/NSString.h>
#include <Foundation/NSArray.h>
#include <Foundation/NSDictionary.h>
#include <Foundation/NSEnumerator.h>
#include <Foundation/NSException.h>
#include <Foundation/NSZone.h>
#include <Foundation/NSObjCRuntime.h>
#include <Foundation/NSDebug.h>
#else
#include <Foundation/Foundation.h>
#endif
#include <EOControl/EOMutableKnownKeyDictionary.h>
#include <EOControl/EOFetchSpecification.h>
#include <EOControl/EONSAddOns.h>
#include <EOControl/EODebug.h>
#include <EOAccess/EOEntity.h>
#include <EOAccess/EOAttribute.h>
#include <EOAccess/EOAdaptor.h>
#include <EOAccess/EOAdaptorContext.h>
#include <EOAccess/EOAdaptorChannel.h>
#include <EOAccess/EOSQLExpression.h>
#include <EOAccess/EODatabaseOperation.h>
NSString *EOAdaptorOperationsKey = @"EOAdaptorOperationsKey";
NSString *EOFailedAdaptorOperationKey = @"EOFailedAdaptorOperationKey";
NSString *EOAdaptorFailureKey = @"EOAdaptorFailureKey";
NSString *EOAdaptorOptimisticLockingFailure = @"EOAdaptorOptimisticLockingFailure";
@implementation EOAdaptorChannel
+ (EOAdaptorChannel *)adaptorChannelWithAdaptorContext: (EOAdaptorContext *)adaptorContext
{
return [[[self alloc] initWithAdaptorContext: adaptorContext] autorelease];
}
- (id) initWithAdaptorContext: (EOAdaptorContext *)adaptorContext
{
if ((self = [super init]))
{
ASSIGN(_context, adaptorContext);
[_context _channelDidInit: self]; //TODO it's _registerAdaptorChannel:
}
return self;
}
- (void)dealloc
{
[_context _channelWillDealloc: self];
DESTROY(_context);
[super dealloc];
}
- (void)openChannel
{
[self subclassResponsibility: _cmd];
}
- (void)closeChannel
{
[self subclassResponsibility: _cmd];
}
- (void)insertRow: (NSDictionary *)row
forEntity: (EOEntity *)entity
{
[self subclassResponsibility: _cmd];
}
- (void)updateValues: (NSDictionary *)row
inRowDescribedByQualifier: (EOQualifier *)qualifier
entity: (EOEntity *)entity
{
int rows;
rows = [self updateValues: row
inRowsDescribedByQualifier: qualifier
entity: entity];
if(rows != 1)
[NSException raise: NSInvalidArgumentException
format: @"%@ -- %@ 0x%x: updated %d rows",
NSStringFromSelector(_cmd),
NSStringFromClass([self class]),
self,
rows];
}
- (unsigned)updateValues: (NSDictionary *)values
inRowsDescribedByQualifier: (EOQualifier *)qualifier
entity: (EOEntity *)entity
{
[self subclassResponsibility: _cmd];
return 0;
}
- (void)deleteRowDescribedByQualifier: (EOQualifier *)qualifier
entity: (EOEntity *)entity
{
int rows = 0;
rows = [self deleteRowsDescribedByQualifier: qualifier
entity: entity];
if (rows != 1)
[NSException raise: NSInvalidArgumentException
format: @"%@ -- %@ 0x%x: deleted %d rows",
NSStringFromSelector(_cmd),
NSStringFromClass([self class]),
self,
rows];
}
- (unsigned)deleteRowsDescribedByQualifier: (EOQualifier *)qualifier
entity: (EOEntity *)entity
{
[self subclassResponsibility: _cmd];
return 0;
}
- (void)selectAttributes: (NSArray *)attributes
fetchSpecification: (EOFetchSpecification *)fetchSpecification
lock: (BOOL)flag
entity: (EOEntity *)entity
{
[self subclassResponsibility: _cmd];
}
- (void)lockRowComparingAttributes: (NSArray *)attrs
entity: (EOEntity *)entity
qualifier: (EOQualifier *)qualifier
snapshot: (NSDictionary *)snapshot
{
EOFetchSpecification *fetch = nil;
NSDictionary *row = nil;
NSEnumerator *attrsEnum = nil;
EOAttribute *attr = nil;
NSMutableArray *attributes = nil;
BOOL isEqual = YES;
EOFLOGObjectFnStart();
EOFLOGObjectLevelArgs(@"gsdb", @"attrs=%@", attrs);
EOFLOGObjectLevelArgs(@"gsdb", @"entity=%@", entity);
EOFLOGObjectLevelArgs(@"gsdb", @"qualifier=%@" ,qualifier);
EOFLOGObjectLevelArgs(@"gsdb", @"snapshot=%@", snapshot);
if (attrs)
attributes = [[attrs mutableCopy] autorelease];
if(attributes == nil)
attributes = [NSMutableArray array];
[attributes removeObjectsInArray: [entity primaryKeyAttributes]];
[attributes addObjectsFromArray: [entity primaryKeyAttributes]];
fetch = [EOFetchSpecification fetchSpecificationWithEntityName: [entity name]
qualifier: qualifier
sortOrderings: nil];
[self selectAttributes: attributes
fetchSpecification: fetch
lock: YES
entity: entity];
row = [self fetchRowWithZone: NULL];
EOFLOGObjectLevelArgs(@"gsdb", @"row=%@", row);
if(row == nil || [self fetchRowWithZone: NULL] != nil)
{
[NSException raise: EOGeneralAdaptorException
format: @"%@ -- %@ 0x%x: cannot lock row for entity '%@' with qualifier: %@",
NSStringFromSelector(_cmd),
NSStringFromClass([self class]),
self,
[entity name],
qualifier];
}
attrsEnum = [attributes objectEnumerator];
while((attr = [attrsEnum nextObject]))
{
NSString *name;
name = [attr name];
if([[row objectForKey: name]
isEqual: [snapshot objectForKey:name]] == NO)
{
isEqual = NO;
break;
}
}
if(isEqual == NO)
{
[NSException raise: EOGeneralAdaptorException
format: @"%@ -- %@ 0x%x: cannot lock row for entity '%@' with qualifier: %@",
NSStringFromSelector(_cmd),
NSStringFromClass([self class]),
self,
[entity name],
qualifier];
}
EOFLOGObjectFnStop();
}
- (void)evaluateExpression: (EOSQLExpression *)expression
{
[self subclassResponsibility: _cmd];
}
- (BOOL)isFetchInProgress
{
[self subclassResponsibility: _cmd];
return NO;
}
- (NSArray *)describeResults
{
[self subclassResponsibility: _cmd];
return nil;
}
- (NSMutableDictionary *)fetchRowWithZone: (NSZone *)zone
{
[self subclassResponsibility: _cmd];
return nil;
}
- (void)setAttributesToFetch: (NSArray *)attributes
{
[self subclassResponsibility: _cmd];
}
- (NSArray *)attributesToFetch
{
[self subclassResponsibility: _cmd];
return nil;
}
- (void)cancelFetch
{
[self subclassResponsibility: _cmd];
}
- (NSDictionary *)primaryKeyForNewRowWithEntity: (EOEntity *)entity
{
EOFLOGObjectFnStart();
EOFLOGObjectFnStop();
return nil;//no or subclass respo ?
}
- (NSArray *)describeTableNames
{
return nil;
}
- (NSArray *)describeStoredProcedureNames
{
[self subclassResponsibility: _cmd];
return nil;
}
- (EOModel *)describeModelWithTableNames: (NSArray *)tableNames
{
return nil;
}
- (void)addStoredProceduresNamed: (NSArray *)storedProcedureNames
toModel: (EOModel *)model
{
[self subclassResponsibility: _cmd];
}
- (void)setDebugEnabled: (BOOL)flag
{
_debug = flag;
}
- (BOOL)isDebugEnabled
{
return _debug;
}
- delegate
{
return _delegate;
}
- (void)setDelegate:delegate
{
_delegate = delegate;
_delegateRespondsTo.willPerformOperations =
[_delegate respondsToSelector:
@selector(adaptorChannel:willPerformOperations:)];
_delegateRespondsTo.didPerformOperations =
[_delegate respondsToSelector:
@selector(adaptorChannel:didPerformOperations:exception:)];
_delegateRespondsTo.shouldSelectAttributes =
[_delegate respondsToSelector:
@selector(adaptorChannel:shouldSelectAttributes:fetchSpecification:lock:)];
_delegateRespondsTo.didSelectAttributes =
[_delegate respondsToSelector:
@selector(adaptorChannel:didSelectAttributes:fetchSpecification:lock:)];
_delegateRespondsTo.willFetchRow =
[_delegate respondsToSelector:
@selector(adaptorChannelWillFetchRow:)];
_delegateRespondsTo.didFetchRow =
[_delegate respondsToSelector:
@selector(adaptorChannel:didFetchRow:)];
_delegateRespondsTo.didChangeResultSet =
[_delegate respondsToSelector:
@selector(adaptorChannelDidChangeResultSet:)];
_delegateRespondsTo.didFinishFetching =
[_delegate respondsToSelector:
@selector(adaptorChannelDidFinishFetching:)];
_delegateRespondsTo.shouldEvaluateExpression =
[_delegate respondsToSelector:
@selector(adaptorChannel:shouldEvaluateExpression:)];
_delegateRespondsTo.didEvaluateExpression =
[_delegate respondsToSelector:
@selector(adaptorChannel:didEvaluateExpression:)];
_delegateRespondsTo.shouldExecuteStoredProcedure =
[_delegate respondsToSelector:
@selector(adaptorChannel:shouldExecuteStoredProcedure:withValues:)];
_delegateRespondsTo.didExecuteStoredProcedure =
[_delegate respondsToSelector:
@selector(adaptorChannelDidExecuteStoredProcedure:withValues:)];
_delegateRespondsTo.shouldConstructStoredProcedureReturnValues =
[_delegate respondsToSelector:
@selector(adaptorChannelShouldConstructStoredProcedureReturnValues:)];
_delegateRespondsTo.shouldReturnValuesForStoredProcedure =
[_delegate respondsToSelector:
@selector(adaptorChannel:shouldReturnValuesForStoredProcedure:)];
}
- (NSMutableDictionary *)dictionaryWithObjects: (id *)objects
forAttributes: (NSArray *)attributes
zone: (NSZone *)zone
{
//OK (can be improved by calling EOMutableKnownKeyDictionary iini with objects but the order may be different
EOMutableKnownKeyDictionary *dict=nil;
EOAttribute *anAttribute=[attributes firstObject];
NSAssert(anAttribute, @"No attribute");
if (anAttribute)
{
EOEntity *entity = [anAttribute entity];
EOMKKDInitializer *initializer;
int i = 0;
int count = [attributes count];
// We may not have entity for direct SQL calls
// We may not have entity for direct SQL calls
if (entity)
{
//NSArray *attributesToFetch = [entity _attributesToFetch];
initializer = [entity _adaptorDictionaryInitializer];
}
else
{
initializer = [EOMKKDInitializer initializerFromKeyArray:
[attributes resultsOfPerformingSelector:
@selector(name)]];
};
EOFLOGObjectLevelArgs(@"gsdb",
@"\ndictionaryWithObjects:forAttributes:zone: attributes=%@ objects=%p\n",
attributes,objects);
NSAssert(initializer,@"No initializer");
EOFLOGObjectLevelArgs(@"gsdb", @"initializer=%@", initializer);
dict = [[[EOMutableKnownKeyDictionary allocWithZone: zone]
initWithInitializer:initializer] autorelease];
EOFLOGObjectLevelArgs(@"gsdb", @"dict=%@", dict);
for(i = 0; i < count; i++)
{
EOAttribute *attribute = (EOAttribute *)[attributes objectAtIndex: i];
EOFLOGObjectLevelArgs(@"gsdb", @"Attribute=%@ value=%@", attribute, objects[i]);
[dict setObject: objects[i]
forKey: [attribute name]];
}
}
return dict;
}
- (EOAdaptorContext *)adaptorContext
{
return _context;
}
- (BOOL)isOpen
{
[self subclassResponsibility: _cmd];
return NO;
}
@end /* EOAdaptorChannel */
@implementation EOAdaptorChannel (EOStoredProcedures)
- (void)executeStoredProcedure: (EOStoredProcedure *)storedProcedure
withValues: (NSDictionary *)values
{
[self subclassResponsibility: _cmd];
}
- (NSDictionary *)returnValuesForLastStoredProcedureInvocation
{
[self subclassResponsibility: _cmd];
return nil;
}
@end
@implementation EOAdaptorChannel (EOBatchProcessing)
- (void)performAdaptorOperation: (EOAdaptorOperation *)adaptorOperation
{
EOAdaptorContext *adaptorContext = nil;
EOEntity *entity = nil;
EOAdaptorOperator operator;
NSDictionary *changedValues=nil;
EOFLOGObjectFnStart();
adaptorContext = [self adaptorContext];
//adaptorcontext transactionNestingLevel
//2fois
//...
EOFLOGObjectLevelArgs(@"gsdb", @"adaptorOperation=%@", adaptorOperation);
entity = [adaptorOperation entity];
operator = [adaptorOperation adaptorOperator];
changedValues = [adaptorOperation changedValues];
EOFLOGObjectLevelArgs(@"gsdb", @"ad op: %d %@", operator, [entity name]);
EOFLOGObjectLevelArgs(@"gsdb", @"ad op: %@ %@", [adaptorOperation changedValues], [adaptorOperation qualifier]);
NS_DURING
switch(operator)
{
case EOAdaptorLockOperator:
EOFLOGObjectLevel(@"gsdb", @"EOAdaptorLockOperator");
[self lockRowComparingAttributes: [adaptorOperation attributes]
entity: entity
qualifier: [adaptorOperation qualifier]
snapshot: changedValues];
break;
case EOAdaptorInsertOperator:
EOFLOGObjectLevel(@"gsdb", @"EOAdaptorInsertOperator");
/*
//self adaptorContext
//adaptorcontext transactionNestingLevel
NSArray* attributes=[entity attributes];
forech: externaltype
name
PostgreSQLExpression initWithEntity:
//called from ??: expr setUseAliases:NO
prepareInsertExpressionWithRow:changedValues
[expr staement];
*/
[self insertRow: [adaptorOperation changedValues]
forEntity: entity];
break;
case EOAdaptorUpdateOperator:
EOFLOGObjectLevel(@"gsdb", @"EOAdaptorUpdateOperator");
//OK
[self updateValues: [adaptorOperation changedValues]
inRowDescribedByQualifier: [adaptorOperation qualifier]
entity: entity];
break;
case EOAdaptorDeleteOperator:
EOFLOGObjectLevel(@"gsdb", @"EOAdaptorDeleteOperator");
[self deleteRowDescribedByQualifier: [adaptorOperation qualifier]
entity: entity];
break;
case EOAdaptorStoredProcedureOperator:
EOFLOGObjectLevel(@"gsdb", @"EOAdaptorStoredProcedureOperator");
[self executeStoredProcedure: [adaptorOperation storedProcedure]
withValues: [adaptorOperation changedValues]];
break;
case EOAdaptorUndefinedOperator:
EOFLOGObjectLevel(@"gsdb", @"EOAdaptorUndefinedOperator");
default:
[NSException raise: NSInvalidArgumentException
format: @"%@ -- %@ 0x%x: Operator %d is not defined",
NSStringFromSelector(_cmd),
NSStringFromClass([self class]),
self,
(int)operator];
break;
}
NS_HANDLER
{
NSDebugMLog(@"EXCEPTION %@", localException);
[adaptorOperation setException: localException];
[localException raise];
}
NS_ENDHANDLER;
//end
EOFLOGObjectFnStop();
}
- (void)performAdaptorOperations: (NSArray *)adaptorOperations
{
int i = 0;
int count = 0;
EOFLOGObjectFnStart();
count=[adaptorOperations count];
for(i = 0; i < count; i++)
{
EOAdaptorOperation *operation = [adaptorOperations objectAtIndex:i];
NS_DURING
[self performAdaptorOperation: operation];
NS_HANDLER
{
NSException *exp = nil;
NSMutableDictionary *userInfo = nil;
EOAdaptorOperator operator = 0;
NSDebugMLog(@"EXCEPTION %@", localException);
operator = [operation adaptorOperator];
userInfo = [NSMutableDictionary dictionaryWithCapacity: 3];
[userInfo setObject: adaptorOperations
forKey: EOAdaptorOperationsKey];
[userInfo setObject: operation
forKey: EOFailedAdaptorOperationKey];
if(operator == EOAdaptorLockOperator
|| operator == EOAdaptorUpdateOperator)
[userInfo setObject: EOAdaptorOptimisticLockingFailure
forKey: EOAdaptorFailureKey];
exp = [NSException exceptionWithName: EOGeneralAdaptorException
reason: [NSString stringWithFormat:@"%@ -- %@ 0x%x: failed with exception name:%@ reason:\"%@\"",
NSStringFromSelector(_cmd),
NSStringFromClass([self class]),
self,
[localException name],
[localException reason]]
userInfo: userInfo];
[exp raise];
}
NS_ENDHANDLER;
}
EOFLOGObjectFnStop();
}
@end