2002-11-15 22:57:05 +00:00
|
|
|
/**
|
|
|
|
EOCheapArray.m <title>EOCheapCopyArray Classes</title>
|
|
|
|
|
2005-08-17 08:07:57 +00:00
|
|
|
Copyright (C) 2000-2002,2003,2004,2005 Free Software Foundation, Inc.
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
Author: Manuel Guesdon <mguesdon@orange-concept.com>
|
|
|
|
Date: Sep 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
|
2007-07-12 06:39:22 +00:00
|
|
|
version 3 of the License, or (at your option) any later version.
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
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,
|
2005-08-17 08:07:57 +00:00
|
|
|
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
2002-11-15 22:57:05 +00:00
|
|
|
</license>
|
|
|
|
**/
|
|
|
|
|
2002-12-31 16:25:21 +00:00
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
RCS_ID("$Id$")
|
2002-11-15 22:57:05 +00:00
|
|
|
|
2004-03-19 16:41:21 +00:00
|
|
|
#ifdef GNUSTEP
|
2003-03-31 00:24:15 +00:00
|
|
|
#include <Foundation/NSArray.h>
|
|
|
|
#include <Foundation/NSString.h>
|
|
|
|
#include <Foundation/NSZone.h>
|
|
|
|
#include <Foundation/NSException.h>
|
2004-02-25 16:32:36 +00:00
|
|
|
#include <Foundation/NSThread.h>
|
2003-03-31 00:24:15 +00:00
|
|
|
#include <Foundation/NSDebug.h>
|
|
|
|
#else
|
|
|
|
#include <Foundation/Foundation.h>
|
|
|
|
#endif
|
2002-11-15 22:57:05 +00:00
|
|
|
|
2003-07-11 19:04:05 +00:00
|
|
|
#ifndef GNUSTEP
|
2003-08-25 20:01:59 +00:00
|
|
|
#include <GNUstepBase/GNUstep.h>
|
2010-09-12 17:54:00 +00:00
|
|
|
#include <GNUstepBase/NSDebug+GNUstepBase.h>
|
|
|
|
#include <GNUstepBase/NSThread+GNUstepBase.h>
|
2003-07-11 19:04:05 +00:00
|
|
|
#endif
|
|
|
|
|
2003-03-31 00:24:15 +00:00
|
|
|
#include <EOControl/EOCheapArray.h>
|
|
|
|
#include <EOControl/EODebug.h>
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
|
|
|
|
@implementation EOCheapCopyArray : NSArray
|
|
|
|
|
2003-03-21 20:41:07 +00:00
|
|
|
- (id) init
|
|
|
|
{
|
|
|
|
#ifdef DEBUG
|
|
|
|
NSDebugFLog(@"Init EOCheapCopyArray %p",
|
|
|
|
self);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
return [super init];
|
|
|
|
};
|
2005-02-14 12:17:26 +00:00
|
|
|
- (id)initWithArray: (NSArray *)array
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
2003-03-21 20:41:07 +00:00
|
|
|
#ifdef DEBUG
|
|
|
|
NSDebugFLog(@"initWithArray EOCheapCopyArray %p",
|
|
|
|
self);
|
|
|
|
#endif
|
|
|
|
|
2002-11-15 22:57:05 +00:00
|
|
|
if ((self = [super initWithArray: array]))
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
return self;
|
|
|
|
}
|
|
|
|
|
2013-03-02 18:20:35 +00:00
|
|
|
- (id) initWithObjects: (const id[])objects
|
2010-04-14 21:06:05 +00:00
|
|
|
count: (NSUInteger)count
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
2003-03-21 20:41:07 +00:00
|
|
|
#ifdef DEBUG
|
|
|
|
NSDebugFLog(@"initWithObjects EOCheapCopyArray %p",
|
|
|
|
self);
|
|
|
|
#endif
|
|
|
|
|
2002-11-15 22:57:05 +00:00
|
|
|
if (count > 0)
|
|
|
|
{
|
2010-04-19 17:43:01 +00:00
|
|
|
NSUInteger i;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
_contents_array = NSZoneMalloc([self zone], sizeof(id) * count);
|
|
|
|
|
|
|
|
if (_contents_array == 0)
|
|
|
|
{
|
|
|
|
RELEASE(self);
|
|
|
|
return nil;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < count; i++)
|
|
|
|
{
|
|
|
|
if ((_contents_array[i] = RETAIN(objects[i])) == nil)
|
|
|
|
{
|
|
|
|
_count = i;
|
|
|
|
RELEASE(self);
|
|
|
|
[NSException raise: NSInvalidArgumentException
|
|
|
|
format: @"Tried to add nil"];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
_count = count;
|
|
|
|
}
|
|
|
|
|
|
|
|
return self;
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void) dealloc
|
|
|
|
{
|
|
|
|
|
|
|
|
if (_contents_array)
|
|
|
|
{
|
|
|
|
#if !GS_WITH_GC
|
2010-04-19 17:43:01 +00:00
|
|
|
NSUInteger i;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
for (i = 0; i < _count; i++)
|
|
|
|
{
|
|
|
|
[_contents_array[i] release];
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
NSZoneFree([self zone], _contents_array);
|
|
|
|
}
|
|
|
|
|
|
|
|
NSDeallocateObject(self);
|
* EOAccess/EOSQLExpression.h (deleteStatementWithQualifier:entity:)
* EOAccess/EOSQLExpressionPriv.h (_aliasForRelationshipPath:)
(_flattenRelPath:entity:, _aliasForRelatedAttribute:relationshipPath:)
* EOAccess/EOSQLExpression.m (insertStatementForRow:entity:)
(updateStatementForRow:qualifier:entity:)
(deleteStatementWithQualifier:entity:)
(selectStatementForAttributes:lock:fetchSpecification:entity:)
(_aliasForRelationshipPath:)
* EOAccess/EORelationship.h (intermediateEntity)
(_foreignKeyForSourceRow:)
* EOAccess/EORelationship.m (_foreignKeyForSourceRow:, _leftSideKeyMap)
* EOAccess/EODatabaseContext.h (databaseOperationForObject:)
(databaseOperationForGlobalID:, recordDatabaseOperation:)
(_openChannelWithLoginPanel:)
* EOAccess/EODatabaseContextPriv.h (primaryKeyForObject:)
(_currentCommittedSnapshotForObject:)
* EOAccess/EOEntityPriv.h (_keyMapForRelationshipPath:)
(_keyMapForIdenticalKeyRelationshipPath:, _mapAttribute:)
(_relationshipPathIsToMany: valueForSQLExpression:)
(_parsePropertyName:, classPropertyAttributeNames)
(classPropertyToManyRelationshipNames)
(classPropertyToOneRelationshipNames, dbSnapshotKeys)
* EOAccess/EOUtilities.m (rawRowsForEntityNamed:qualifierFormat:)
(rawRowsMatchingValue:forKey:entityNamed:)
(rawRowsMatchingValues:entityNamed:, rawRowsWithSQL:modelNamed:)
(rawRowsWithStoredProcedureNamed:arguments:)
(executeStoredProcedureNamed:arguments:, databaseContextForModelNamed:)
(primaryKeyForObject:)
(destinationKeyForSourceObject:relationshipNamed:)
* EOAccess/EOEntity.m
(_mapAttribute:toDestinationAttributeInLastComponentOfRelationshipPath:)
* EOAccess/EOAdaptor.h (adaptorWithModel:,adaptorWithName:)
* EOAccess/EOModel.h (_classDescriptionNeeded:,_entityForClass:)
(_addEntityWithPropertyList:)
* EOAdaptors/Postgres95/Postgres95Channel.h
(_evaluateExpression:withAttributes:)
* EOControl/EOMutableKnownKeyDictionary.h/m (arrayMappingForKeys:)
(subsetMappingForSourceDictionaryInitializer:sourceKeys:destinationKeys:)
(subsetMappingForSourceDictionaryInitializer:)
(setObject:forKey:, removeObjectForKey:, indexForKey:, objectForKey:)
* EOControl/EOEditingContext.m (handleErrors:,setSharedEditingContext:)
(faultForRawRow:entityNamed:)
* GDL2Palette/KeyWrapper.h (setKey:, _key):
* EOModeler/EOModelerEditor.h (selectionWithinViewedObject)
* EOModeler/EOModelerEditor.m (initWithDocument:)
(initWithParentEditor:)
Correct method signatures. Add necessary forward @class declations.
* EOInterface/EOMasterDetailAssociation.m (establishConnection):
* DBModeler/ModelerTableEmbedibleEditor.m
(addDefaultTableColumnsForTableView:displayGroup:)
* DBModeler/DefaultColumnProvider.m (setupTitleForColumn:named:)
Cast types to avoid compiler warnings.
* EOControl/EOCheapArray.m (dealloc): Supress compiler warning.
* EOAdaptors/Postgres95/LoginPanel/Postgres95LoginPanel.m (dealloc)
* EOModeler/EOModelerEditor.m (dealloc):
* DBModeler/ModelerAttributeEditor.m (dealloc): Add missing call
to super.
* DBModeler/Preferences.m (sharedPreferences): Fix implementation for
new compiler semantics.
* EOControl/EOMultiReaderLock.m (init): Correct NSConditionLock
initialization.
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gdl2/trunk@23472 72102866-910b-0410-8b05-ffd578937521
2006-09-12 19:36:24 +00:00
|
|
|
/* Suppress compiler warning. */
|
|
|
|
if (0) [super dealloc];
|
2003-03-21 20:41:07 +00:00
|
|
|
|
|
|
|
#ifdef DEBUG
|
2004-02-25 14:21:47 +00:00
|
|
|
NSDebugFLog(@"Stop Dealloc EOCheapCopyArray %p. %@",
|
|
|
|
(void*)self, GSCurrentThread());
|
2003-03-21 20:41:07 +00:00
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
- (id) autorelease
|
|
|
|
{
|
|
|
|
#ifdef DEBUG
|
2004-02-26 14:18:04 +00:00
|
|
|
NSDebugFLog(@"autorelease EOCheapCopyArray %p. %@ [super retainCount]=%d",
|
|
|
|
(void*)self,GSCurrentThread(),[super retainCount]);
|
2003-03-21 20:41:07 +00:00
|
|
|
#endif
|
|
|
|
return [super autorelease];
|
2002-11-15 22:57:05 +00:00
|
|
|
}
|
|
|
|
|
2013-03-02 18:20:35 +00:00
|
|
|
- (oneway void) release
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
2003-03-21 20:41:07 +00:00
|
|
|
#ifdef DEBUG
|
2004-02-26 14:18:04 +00:00
|
|
|
NSDebugFLog(@"Release EOCheapCopyArray %p. %@ [super retainCount]=%d",
|
|
|
|
(void*)self,GSCurrentThread(),[super retainCount]);
|
2003-03-21 20:41:07 +00:00
|
|
|
#endif
|
|
|
|
[super release];
|
2002-11-15 22:57:05 +00:00
|
|
|
}
|
|
|
|
|
2010-04-26 22:05:17 +00:00
|
|
|
- (NSUInteger) retainCount
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
2003-03-21 20:41:07 +00:00
|
|
|
#ifdef DEBUG
|
2004-02-26 14:18:04 +00:00
|
|
|
NSDebugFLog(@"retainCount EOCheapCopyArray %p. %@",
|
|
|
|
(void*)self,GSCurrentThread());
|
2003-03-21 20:41:07 +00:00
|
|
|
#endif
|
|
|
|
return [super retainCount];
|
|
|
|
|
2002-11-15 22:57:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
- (id) retain
|
|
|
|
{
|
2003-03-21 20:41:07 +00:00
|
|
|
#ifdef DEBUG
|
2004-02-26 14:18:04 +00:00
|
|
|
NSDebugFLog(@"retain EOCheapCopyArray %p. %@, [super retainCount]=%d",
|
|
|
|
(void*)self,GSCurrentThread(),[super retainCount]);
|
2003-03-21 20:41:07 +00:00
|
|
|
#endif
|
|
|
|
return [super retain];
|
2002-11-15 22:57:05 +00:00
|
|
|
}
|
|
|
|
|
2010-04-19 17:43:01 +00:00
|
|
|
- (id) objectAtIndex: (NSUInteger)index
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
if (index >= _count)
|
|
|
|
{
|
|
|
|
[NSException raise: NSRangeException
|
|
|
|
format: @"Index out of bounds"];
|
|
|
|
}
|
|
|
|
|
|
|
|
return _contents_array[index];
|
|
|
|
}
|
|
|
|
|
|
|
|
//- (id) copyWithZone: (NSZone*)zone;
|
2010-04-19 17:43:01 +00:00
|
|
|
- (NSUInteger) count
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
return _count;
|
|
|
|
}
|
|
|
|
|
|
|
|
//- (BOOL) containsObject: (id)obejct;
|
|
|
|
@end
|
|
|
|
|
|
|
|
@implementation EOCheapCopyMutableArray
|
|
|
|
|
2010-04-14 21:06:05 +00:00
|
|
|
- (id) initWithCapacity: (NSUInteger)capacity
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
if (capacity == 0)
|
|
|
|
{
|
|
|
|
capacity = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
_contents_array = NSZoneMalloc([self zone], sizeof(id) * capacity);
|
|
|
|
_capacity = capacity;
|
|
|
|
_grow_factor = capacity > 1 ? capacity/2 : 1;
|
|
|
|
|
|
|
|
return self;
|
|
|
|
}
|
|
|
|
|
2013-03-02 18:20:35 +00:00
|
|
|
- (id) initWithObjects: (const id[])objects
|
2010-04-14 21:06:05 +00:00
|
|
|
count: (NSUInteger)count
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
self = [self initWithCapacity: count];
|
|
|
|
|
|
|
|
if (self != nil && count > 0)
|
|
|
|
{
|
|
|
|
unsigned i;
|
|
|
|
|
|
|
|
for (i = 0; i < count; i++)
|
|
|
|
{
|
|
|
|
if ((_contents_array[i] = RETAIN(objects[i])) == nil)
|
|
|
|
{
|
|
|
|
_count = i;
|
|
|
|
RELEASE(self);
|
|
|
|
[NSException raise: NSInvalidArgumentException
|
|
|
|
format: @"Tried to add nil"];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
_count = count;
|
|
|
|
}
|
|
|
|
|
|
|
|
return self;
|
|
|
|
}
|
|
|
|
|
2005-02-14 12:17:26 +00:00
|
|
|
- (id)initWithArray: (NSArray *)array
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
if ((self = [super initWithArray: array]))
|
|
|
|
{
|
2005-02-14 12:17:26 +00:00
|
|
|
_grow_factor = 5;
|
2002-11-15 22:57:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return self;
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void) dealloc
|
|
|
|
{
|
2003-03-21 20:41:07 +00:00
|
|
|
#ifdef DEBUG
|
|
|
|
NSDebugFLog(@"Deallocate EOCheapCopyMutableArray %p zone=%p _contents_array=%p _count=%d _capacity=%d",
|
|
|
|
self, [self zone], _contents_array, _count, _capacity);
|
|
|
|
#endif
|
2002-11-15 22:57:05 +00:00
|
|
|
if (_contents_array)
|
|
|
|
{
|
|
|
|
#if !GS_WITH_GC
|
2010-04-19 17:43:01 +00:00
|
|
|
NSUInteger i;
|
2002-11-15 22:57:05 +00:00
|
|
|
for (i = 0; i < _count; i++)
|
|
|
|
{
|
|
|
|
[_contents_array[i] release];
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
NSZoneFree([self zone], _contents_array);
|
|
|
|
}
|
|
|
|
|
|
|
|
DESTROY(_immutableCopy);
|
|
|
|
NSDeallocateObject(self);
|
* EOAccess/EOSQLExpression.h (deleteStatementWithQualifier:entity:)
* EOAccess/EOSQLExpressionPriv.h (_aliasForRelationshipPath:)
(_flattenRelPath:entity:, _aliasForRelatedAttribute:relationshipPath:)
* EOAccess/EOSQLExpression.m (insertStatementForRow:entity:)
(updateStatementForRow:qualifier:entity:)
(deleteStatementWithQualifier:entity:)
(selectStatementForAttributes:lock:fetchSpecification:entity:)
(_aliasForRelationshipPath:)
* EOAccess/EORelationship.h (intermediateEntity)
(_foreignKeyForSourceRow:)
* EOAccess/EORelationship.m (_foreignKeyForSourceRow:, _leftSideKeyMap)
* EOAccess/EODatabaseContext.h (databaseOperationForObject:)
(databaseOperationForGlobalID:, recordDatabaseOperation:)
(_openChannelWithLoginPanel:)
* EOAccess/EODatabaseContextPriv.h (primaryKeyForObject:)
(_currentCommittedSnapshotForObject:)
* EOAccess/EOEntityPriv.h (_keyMapForRelationshipPath:)
(_keyMapForIdenticalKeyRelationshipPath:, _mapAttribute:)
(_relationshipPathIsToMany: valueForSQLExpression:)
(_parsePropertyName:, classPropertyAttributeNames)
(classPropertyToManyRelationshipNames)
(classPropertyToOneRelationshipNames, dbSnapshotKeys)
* EOAccess/EOUtilities.m (rawRowsForEntityNamed:qualifierFormat:)
(rawRowsMatchingValue:forKey:entityNamed:)
(rawRowsMatchingValues:entityNamed:, rawRowsWithSQL:modelNamed:)
(rawRowsWithStoredProcedureNamed:arguments:)
(executeStoredProcedureNamed:arguments:, databaseContextForModelNamed:)
(primaryKeyForObject:)
(destinationKeyForSourceObject:relationshipNamed:)
* EOAccess/EOEntity.m
(_mapAttribute:toDestinationAttributeInLastComponentOfRelationshipPath:)
* EOAccess/EOAdaptor.h (adaptorWithModel:,adaptorWithName:)
* EOAccess/EOModel.h (_classDescriptionNeeded:,_entityForClass:)
(_addEntityWithPropertyList:)
* EOAdaptors/Postgres95/Postgres95Channel.h
(_evaluateExpression:withAttributes:)
* EOControl/EOMutableKnownKeyDictionary.h/m (arrayMappingForKeys:)
(subsetMappingForSourceDictionaryInitializer:sourceKeys:destinationKeys:)
(subsetMappingForSourceDictionaryInitializer:)
(setObject:forKey:, removeObjectForKey:, indexForKey:, objectForKey:)
* EOControl/EOEditingContext.m (handleErrors:,setSharedEditingContext:)
(faultForRawRow:entityNamed:)
* GDL2Palette/KeyWrapper.h (setKey:, _key):
* EOModeler/EOModelerEditor.h (selectionWithinViewedObject)
* EOModeler/EOModelerEditor.m (initWithDocument:)
(initWithParentEditor:)
Correct method signatures. Add necessary forward @class declations.
* EOInterface/EOMasterDetailAssociation.m (establishConnection):
* DBModeler/ModelerTableEmbedibleEditor.m
(addDefaultTableColumnsForTableView:displayGroup:)
* DBModeler/DefaultColumnProvider.m (setupTitleForColumn:named:)
Cast types to avoid compiler warnings.
* EOControl/EOCheapArray.m (dealloc): Supress compiler warning.
* EOAdaptors/Postgres95/LoginPanel/Postgres95LoginPanel.m (dealloc)
* EOModeler/EOModelerEditor.m (dealloc):
* DBModeler/ModelerAttributeEditor.m (dealloc): Add missing call
to super.
* DBModeler/Preferences.m (sharedPreferences): Fix implementation for
new compiler semantics.
* EOControl/EOMultiReaderLock.m (init): Correct NSConditionLock
initialization.
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gdl2/trunk@23472 72102866-910b-0410-8b05-ffd578937521
2006-09-12 19:36:24 +00:00
|
|
|
/* Suppress compiler warning. */
|
|
|
|
if (0) [super dealloc];
|
2003-03-21 20:41:07 +00:00
|
|
|
|
|
|
|
#ifdef DEBUG
|
2004-02-26 14:18:04 +00:00
|
|
|
NSDebugFLog(@"Stop Dealloc EOCheapCopyMutableArray %p. %@",
|
|
|
|
(void*)self,GSCurrentThread());
|
2003-03-21 20:41:07 +00:00
|
|
|
#endif
|
2002-11-15 22:57:05 +00:00
|
|
|
}
|
|
|
|
|
2005-02-14 12:24:07 +00:00
|
|
|
- (NSArray *)shallowCopy
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
2003-03-21 20:41:07 +00:00
|
|
|
#ifdef DEBUG
|
2004-02-26 14:18:04 +00:00
|
|
|
NSDebugFLog(@"Start shallowCopy EOCheapCopyMutableArray %p. %@ immutableCopy=%p",
|
|
|
|
(void*)self,GSCurrentThread(),_immutableCopy);
|
2003-03-21 20:41:07 +00:00
|
|
|
#endif
|
2002-11-15 22:57:05 +00:00
|
|
|
//OK
|
|
|
|
if (!_immutableCopy)
|
|
|
|
{
|
2003-03-21 20:41:07 +00:00
|
|
|
// OK. It's retained for us.
|
2002-11-15 22:57:05 +00:00
|
|
|
_immutableCopy= [[EOCheapCopyArray alloc]
|
|
|
|
initWithObjects: _contents_array
|
|
|
|
count: _count];
|
2003-03-21 20:41:07 +00:00
|
|
|
//Next will retain for caller
|
2002-11-15 22:57:05 +00:00
|
|
|
}
|
2003-03-21 20:41:07 +00:00
|
|
|
RETAIN(_immutableCopy); // Because copy return a not autoreleased object. Retain for request caller
|
2002-11-15 22:57:05 +00:00
|
|
|
|
2003-03-21 20:41:07 +00:00
|
|
|
#ifdef DEBUG
|
2004-02-26 14:18:04 +00:00
|
|
|
NSDebugFLog(@"Stop shallowCopy EOCheapCopyMutableArray %p. %@ immutableCopy=%p",
|
|
|
|
(void*)self,GSCurrentThread(),_immutableCopy);
|
2003-03-21 20:41:07 +00:00
|
|
|
#endif
|
2002-11-15 22:57:05 +00:00
|
|
|
return _immutableCopy;
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void) _setCopy: (id)param0
|
|
|
|
{
|
|
|
|
//TODO
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void) _mutate
|
|
|
|
{
|
|
|
|
DESTROY(_immutableCopy);
|
|
|
|
}
|
|
|
|
|
2010-04-19 17:43:01 +00:00
|
|
|
- (NSUInteger) count
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
return _count;
|
|
|
|
}
|
|
|
|
|
2010-04-19 17:43:01 +00:00
|
|
|
- (id) objectAtIndex: (NSUInteger)index
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
if (index >= _count)
|
|
|
|
{
|
|
|
|
[NSException raise: NSRangeException
|
|
|
|
format: @"Index out of bounds"];
|
|
|
|
}
|
|
|
|
|
|
|
|
return _contents_array[index];
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void)addObject: (id)object
|
|
|
|
{
|
2010-05-30 19:25:53 +00:00
|
|
|
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
if (!object)
|
|
|
|
{
|
|
|
|
[NSException raise: NSInvalidArgumentException
|
|
|
|
format: @"Tried to add nil"];
|
|
|
|
}
|
|
|
|
|
|
|
|
[self _mutate];
|
|
|
|
|
|
|
|
if (_count >= _capacity)
|
|
|
|
{
|
|
|
|
unsigned int grow = (_grow_factor>5 ? _grow_factor : 5);
|
|
|
|
size_t size = (_capacity + grow) * sizeof(id);
|
|
|
|
id *ptr;
|
|
|
|
|
|
|
|
ptr = NSZoneRealloc([self zone], _contents_array, size);
|
|
|
|
|
|
|
|
if (ptr == 0)
|
|
|
|
{
|
|
|
|
[NSException raise: NSMallocException
|
|
|
|
format: @"Unable to grow"];
|
|
|
|
}
|
|
|
|
|
|
|
|
_contents_array = ptr;
|
|
|
|
_capacity += _grow_factor;
|
|
|
|
_grow_factor = _capacity / 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
_contents_array[_count] = RETAIN(object);
|
|
|
|
_count++; // Do this AFTER we have retained the object.
|
|
|
|
|
2010-05-30 19:25:53 +00:00
|
|
|
|
2002-11-15 22:57:05 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
- (void) insertObject: (id)object
|
2010-04-19 17:43:01 +00:00
|
|
|
atIndex: (NSUInteger)index
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
2010-04-19 17:43:01 +00:00
|
|
|
NSUInteger i;
|
2002-11-15 22:57:05 +00:00
|
|
|
|
|
|
|
if (!object)
|
|
|
|
{
|
|
|
|
[NSException raise: NSInvalidArgumentException
|
|
|
|
format: @"Tried to insert nil"];
|
|
|
|
}
|
|
|
|
|
|
|
|
if (index > _count)
|
|
|
|
{
|
|
|
|
[NSException raise: NSRangeException
|
|
|
|
format:
|
|
|
|
@"in insertObject:atIndex:, index %d is out of range",
|
|
|
|
index];
|
|
|
|
}
|
|
|
|
|
|
|
|
[self _mutate];
|
|
|
|
|
|
|
|
if (_count == _capacity)
|
|
|
|
{
|
|
|
|
id *ptr;
|
|
|
|
size_t size = (_capacity + _grow_factor) * sizeof(id);
|
|
|
|
|
|
|
|
ptr = NSZoneRealloc([self zone], _contents_array, size);
|
|
|
|
|
|
|
|
if (ptr == 0)
|
|
|
|
{
|
|
|
|
[NSException raise: NSMallocException
|
|
|
|
format: @"Unable to grow"];
|
|
|
|
}
|
|
|
|
|
|
|
|
_contents_array = ptr;
|
|
|
|
_capacity += _grow_factor;
|
|
|
|
_grow_factor = _capacity / 2;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = _count; i > index; i--)
|
|
|
|
{
|
|
|
|
_contents_array[i] = _contents_array[i - 1];
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Make sure the array is 'sane' so that it can be deallocated
|
|
|
|
* safely by an autorelease pool if the '[anObject retain]' causes
|
|
|
|
* an exception.
|
|
|
|
*/
|
|
|
|
_contents_array[index] = nil;
|
|
|
|
_count++;
|
|
|
|
_contents_array[index] = RETAIN(object);
|
|
|
|
}
|
|
|
|
|
|
|
|
- (void) removeLastObject
|
|
|
|
{
|
|
|
|
if (_count == 0)
|
|
|
|
{
|
|
|
|
[NSException raise: NSRangeException
|
|
|
|
format: @"Trying to remove from an empty array."];
|
|
|
|
}
|
|
|
|
|
|
|
|
[self _mutate];
|
|
|
|
_count--;
|
|
|
|
|
|
|
|
RELEASE(_contents_array[_count]);
|
|
|
|
}
|
|
|
|
|
2010-04-19 17:43:01 +00:00
|
|
|
- (void) removeObjectAtIndex: (NSUInteger)index
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
id obj;
|
|
|
|
|
|
|
|
if (index >= _count)
|
|
|
|
{
|
|
|
|
[NSException raise: NSRangeException
|
|
|
|
format: @"in removeObjectAtIndex:, index %d is out of range",
|
|
|
|
index];
|
|
|
|
}
|
|
|
|
obj = _contents_array[index];
|
|
|
|
[self _mutate];
|
|
|
|
_count--;
|
|
|
|
|
|
|
|
while (index < _count)
|
|
|
|
{
|
|
|
|
_contents_array[index] = _contents_array[index+1];
|
|
|
|
index++;
|
|
|
|
}
|
|
|
|
|
|
|
|
RELEASE(obj); /* Adjust array BEFORE releasing object. */
|
|
|
|
}
|
|
|
|
|
2010-04-19 17:43:01 +00:00
|
|
|
- (void) replaceObjectAtIndex: (NSUInteger)index
|
2002-11-15 22:57:05 +00:00
|
|
|
withObject: (id)object;
|
|
|
|
{
|
|
|
|
id obj;
|
|
|
|
|
|
|
|
if (index >= _count)
|
|
|
|
{
|
|
|
|
[NSException raise: NSRangeException format:
|
|
|
|
@"in replaceObjectAtIndex:withObject:, index %d is out of range",
|
|
|
|
index];
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Swap objects in order so that there is always a valid object in the
|
|
|
|
* array in case a retain or release causes an exception.
|
|
|
|
*/
|
|
|
|
obj = _contents_array[index];
|
|
|
|
[self _mutate];
|
|
|
|
|
|
|
|
IF_NO_GC(RETAIN(object));
|
|
|
|
_contents_array[index] = object;
|
|
|
|
|
|
|
|
RELEASE(obj);
|
|
|
|
}
|
|
|
|
|
|
|
|
//TODO implement it for speed ?? - (BOOL) containsObject:(id)object
|
|
|
|
//TODO implement it for speed ?? - (unsigned int) indexOfObjectIdenticalTo:(id)object
|
|
|
|
//TODO implement it for speed ?? - (void) removeAllObjects;
|
2010-04-19 17:43:01 +00:00
|
|
|
- (void) exchangeObjectAtIndex: (NSUInteger)index1
|
|
|
|
withObjectAtIndex: (NSUInteger)index2
|
2002-11-15 22:57:05 +00:00
|
|
|
{
|
|
|
|
id obj = nil;
|
|
|
|
|
|
|
|
if (index1 >= _count || index2>=_count)
|
|
|
|
{
|
|
|
|
[NSException raise: NSRangeException format:
|
|
|
|
@"in exchangeObjectAtIndex:withObjectAtIndex:, index %d is out of range",
|
|
|
|
(index1 >= _count ? index1 : index2)];
|
|
|
|
}
|
|
|
|
|
|
|
|
obj = _contents_array[index1];
|
|
|
|
|
|
|
|
[self _mutate];
|
|
|
|
|
|
|
|
_contents_array[index1] = _contents_array[index2];
|
|
|
|
_contents_array[index2] = obj;
|
|
|
|
}
|
|
|
|
|
|
|
|
@end
|