mirror of
https://github.com/gnustep/libs-gsweb.git
synced 2025-02-22 03:01:27 +00:00
o added methods for element/component caching
git-svn-id: svn+ssh://svn.gna.org/svn/gnustep/libs/gsweb/trunk@18748 72102866-910b-0410-8b05-ffd578937521
This commit is contained in:
parent
4993a3b043
commit
b43719c330
2 changed files with 308 additions and 16 deletions
|
@ -1,6 +1,6 @@
|
||||||
/** GSWMessage.h - <title>GSWeb: Class GSWMessage</title>
|
/** GSWMessage.h - <title>GSWeb: Class GSWMessage</title>
|
||||||
|
|
||||||
Copyright (C) 2003 Free Software Foundation, Inc.
|
Copyright (C) 2003-2004 Free Software Foundation, Inc.
|
||||||
|
|
||||||
Written by: Manuel Guesdon <mguesdon@orange-concept.com>
|
Written by: Manuel Guesdon <mguesdon@orange-concept.com>
|
||||||
Date: Aug 2003
|
Date: Aug 2003
|
||||||
|
@ -42,6 +42,9 @@
|
||||||
NSDictionary* _userInfo;
|
NSDictionary* _userInfo;
|
||||||
NSMutableString* _contentString;
|
NSMutableString* _contentString;
|
||||||
NSMutableData* _contentData;
|
NSMutableData* _contentData;
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
NSMutableArray* _cachesStack; // Cache Stacks
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
-(void)setHTTPVersion:(NSString*)version;
|
-(void)setHTTPVersion:(NSString*)version;
|
||||||
|
@ -130,6 +133,15 @@
|
||||||
+(NSStringEncoding)defaultEncoding;
|
+(NSStringEncoding)defaultEncoding;
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
//====================================================================
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
|
||||||
|
@interface GSWMessage (GSWMessageCache)
|
||||||
|
-(int)startCache;
|
||||||
|
-(id)stopCacheOfIndex:(int)cacheIndex;
|
||||||
|
@end
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#endif //_GSWMessage_h__
|
#endif //_GSWMessage_h__
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
/** GSWMessage.m - <title>GSWeb: Class GSWMessage</title>
|
/** GSWMessage.m - <title>GSWeb: Class GSWMessage</title>
|
||||||
|
|
||||||
Copyright (C) 1999-2003 Free Software Foundation, Inc.
|
Copyright (C) 1999-2004 Free Software Foundation, Inc.
|
||||||
|
|
||||||
Written by: Manuel Guesdon <mguesdon@orange-concept.com>
|
Written by: Manuel Guesdon <mguesdon@orange-concept.com>
|
||||||
Date: Jan 1999
|
Date: Jan 1999
|
||||||
|
@ -38,6 +38,18 @@ RCS_ID("$Id$")
|
||||||
static NSStringEncoding globalDefaultEncoding=NSISOLatin1StringEncoding;
|
static NSStringEncoding globalDefaultEncoding=NSISOLatin1StringEncoding;
|
||||||
static NSString* globalDefaultURLEncoding=nil;
|
static NSString* globalDefaultURLEncoding=nil;
|
||||||
|
|
||||||
|
//====================================================================
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
|
||||||
|
@interface GSWMessage (GSWMessageCachePrivate)
|
||||||
|
-(void)_cacheAppendString:(NSString*)string;
|
||||||
|
-(void)_cacheAppendData:(NSData*)data;
|
||||||
|
-(void)_cacheAppendBytes:(const void*)aBuffer
|
||||||
|
length:(unsigned int)bufferSize;
|
||||||
|
@end
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
//====================================================================
|
//====================================================================
|
||||||
@implementation GSWMessage
|
@implementation GSWMessage
|
||||||
|
|
||||||
|
@ -76,6 +88,9 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
//NSDebugFLog0(@"Release Message cookies");
|
//NSDebugFLog0(@"Release Message cookies");
|
||||||
DESTROY(_cookies);
|
DESTROY(_cookies);
|
||||||
// NSDebugFLog0(@"Release Message");
|
// NSDebugFLog0(@"Release Message");
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
DESTROY(_cachesStack);
|
||||||
|
#endif
|
||||||
[super dealloc];
|
[super dealloc];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -99,6 +114,11 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
|
|
||||||
DESTROY(clone->_contentData);
|
DESTROY(clone->_contentData);
|
||||||
clone->_contentData=[_contentData mutableCopyWithZone:zone];
|
clone->_contentData=[_contentData mutableCopyWithZone:zone];
|
||||||
|
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
DESTROY(clone->_cachesStack);
|
||||||
|
clone->_cachesStack=[_cachesStack mutableCopyWithZone:zone];
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
return clone;
|
return clone;
|
||||||
};
|
};
|
||||||
|
@ -326,9 +346,8 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------
|
//--------------------------------------------------------------------
|
||||||
// setContent:
|
/** Set content with contentData
|
||||||
|
**/
|
||||||
//Set content with contentData_
|
|
||||||
-(void)setContent:(NSData*)contentData
|
-(void)setContent:(NSData*)contentData
|
||||||
{
|
{
|
||||||
LOGObjectFnStart();
|
LOGObjectFnStart();
|
||||||
|
@ -337,7 +356,9 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
LOGObjectFnStop();
|
LOGObjectFnStop();
|
||||||
};
|
};
|
||||||
|
|
||||||
//Set content with contentString
|
//--------------------------------------------------------------------
|
||||||
|
/** Set content with contentString
|
||||||
|
**/
|
||||||
-(void)setContentString:(NSString*)contentString
|
-(void)setContentString:(NSString*)contentString
|
||||||
{
|
{
|
||||||
LOGObjectFnStart();
|
LOGObjectFnStart();
|
||||||
|
@ -405,6 +426,11 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
encoding:[self contentEncoding]]
|
encoding:[self contentEncoding]]
|
||||||
autorelease];
|
autorelease];
|
||||||
[_contentString appendString:tmpString];
|
[_contentString appendString:tmpString];
|
||||||
|
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
if (_cachesStack)
|
||||||
|
[self _cacheAppendString:tmpString];
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
else // No actual content or data one
|
else // No actual content or data one
|
||||||
{
|
{
|
||||||
|
@ -416,6 +442,11 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
{
|
{
|
||||||
_contentData = (NSMutableData*)[contentData mutableCopy];
|
_contentData = (NSMutableData*)[contentData mutableCopy];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
if (_cachesStack)
|
||||||
|
[self _cacheAppendData:contentData];
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
LOGObjectFnStop();
|
LOGObjectFnStop();
|
||||||
|
@ -432,10 +463,17 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
[[[NSString alloc]initWithData:_contentData
|
[[[NSString alloc]initWithData:_contentData
|
||||||
encoding:[self contentEncoding]]
|
encoding:[self contentEncoding]]
|
||||||
autorelease]);
|
autorelease]);
|
||||||
|
|
||||||
NSDebugMLLog(@"low",@"aString:%@",aString);
|
NSDebugMLLog(@"low",@"aString:%@",aString);
|
||||||
string=[NSString stringWithObject:aString];
|
string=[NSString stringWithObject:aString];
|
||||||
|
|
||||||
NSDebugMLLog(@"low",@"string:%@",string);
|
NSDebugMLLog(@"low",@"string:%@",string);
|
||||||
[_contentString appendString:string];
|
[_contentString appendString:string];
|
||||||
|
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
if (_cachesStack)
|
||||||
|
[self _cacheAppendString:string];
|
||||||
|
#endif
|
||||||
LOGObjectFnStop();
|
LOGObjectFnStop();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -444,6 +482,7 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
|
|
||||||
-(void)_appendContentCharacter:(char)aChar
|
-(void)_appendContentCharacter:(char)aChar
|
||||||
{
|
{
|
||||||
|
NSString* string=nil;
|
||||||
LOGObjectFnStart();
|
LOGObjectFnStart();
|
||||||
NSDebugMLLog(@"low",@"aChar:%c",aChar);
|
NSDebugMLLog(@"low",@"aChar:%c",aChar);
|
||||||
NSAssert2([_contentData length]==0,
|
NSAssert2([_contentData length]==0,
|
||||||
|
@ -451,11 +490,21 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
aChar,
|
aChar,
|
||||||
[[[NSString alloc]initWithData:_contentData
|
[[[NSString alloc]initWithData:_contentData
|
||||||
encoding:[self contentEncoding]]
|
encoding:[self contentEncoding]]
|
||||||
autorelease]);
|
autorelease]);
|
||||||
[_contentString appendFormat:@"%c",aChar];
|
|
||||||
|
string=[NSString stringWithFormat:@"%c",aChar];
|
||||||
|
|
||||||
|
[_contentString appendString:string];
|
||||||
|
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
if (_cachesStack)
|
||||||
|
[self _cacheAppendString:string];
|
||||||
|
#endif
|
||||||
|
|
||||||
LOGObjectFnStop();
|
LOGObjectFnStop();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
-(void)appendContentString:(NSString*)string
|
-(void)appendContentString:(NSString*)string
|
||||||
{
|
{
|
||||||
LOGObjectFnStart();
|
LOGObjectFnStart();
|
||||||
|
@ -467,9 +516,16 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
encoding:[self contentEncoding]]
|
encoding:[self contentEncoding]]
|
||||||
autorelease]);
|
autorelease]);
|
||||||
[_contentString appendString:string];
|
[_contentString appendString:string];
|
||||||
|
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
if (_cachesStack)
|
||||||
|
[self _cacheAppendString:string];
|
||||||
|
#endif
|
||||||
|
|
||||||
LOGObjectFnStop();
|
LOGObjectFnStop();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
-(int)_contentLength
|
-(int)_contentLength
|
||||||
{
|
{
|
||||||
int contentLength=[_contentString length];
|
int contentLength=[_contentString length];
|
||||||
|
@ -512,6 +568,12 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
{
|
{
|
||||||
[_contentData appendBytes:bytes
|
[_contentData appendBytes:bytes
|
||||||
length:length];
|
length:length];
|
||||||
|
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
if (_cachesStack)
|
||||||
|
[self _cacheAppendBytes:bytes
|
||||||
|
length:length];
|
||||||
|
#endif
|
||||||
};
|
};
|
||||||
LOGObjectFnStop();
|
LOGObjectFnStop();
|
||||||
};
|
};
|
||||||
|
@ -579,6 +641,7 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
LOGObjectFnStop();
|
LOGObjectFnStop();
|
||||||
};
|
};
|
||||||
*/
|
*/
|
||||||
|
|
||||||
//--------------------------------------------------------------------
|
//--------------------------------------------------------------------
|
||||||
// appendDebugCommentContentString:
|
// appendDebugCommentContentString:
|
||||||
|
|
||||||
|
@ -590,6 +653,7 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
-(void)replaceContentString:(NSString*)replaceString
|
-(void)replaceContentString:(NSString*)replaceString
|
||||||
byString:(NSString*)byString
|
byString:(NSString*)byString
|
||||||
{
|
{
|
||||||
|
@ -627,6 +691,7 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
LOGObjectFnStop();
|
LOGObjectFnStop();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
-(void)replaceContentData:(NSData*)replaceData
|
-(void)replaceContentData:(NSData*)replaceData
|
||||||
byData:(NSData*)byData
|
byData:(NSData*)byData
|
||||||
{
|
{
|
||||||
|
@ -832,6 +897,7 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
return (strings ? [NSArray arrayWithArray:strings] : nil);
|
return (strings ? [NSArray arrayWithArray:strings] : nil);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
-(void)_finalizeCookiesInContext:(GSWContext*)aContext
|
-(void)_finalizeCookiesInContext:(GSWContext*)aContext
|
||||||
{
|
{
|
||||||
NSArray* cookieHeader=nil;
|
NSArray* cookieHeader=nil;
|
||||||
|
@ -908,36 +974,250 @@ static NSString* globalDefaultURLEncoding=nil;
|
||||||
@end
|
@end
|
||||||
|
|
||||||
|
|
||||||
|
//====================================================================
|
||||||
|
#ifndef NO_GNUSTEP
|
||||||
|
|
||||||
|
@implementation GSWMessage (GSWMessageCache)
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
|
-(int)startCache
|
||||||
|
{
|
||||||
|
int index=0;
|
||||||
|
LOGObjectFnStart();
|
||||||
|
|
||||||
|
if (!_cachesStack)
|
||||||
|
{
|
||||||
|
_cachesStack=[NSMutableArray new];
|
||||||
|
};
|
||||||
|
if (_contentData)
|
||||||
|
[_cachesStack addObject:[NSMutableData data]];
|
||||||
|
else
|
||||||
|
[_cachesStack addObject:[NSMutableString string]];
|
||||||
|
|
||||||
|
index=[_cachesStack count]-1;
|
||||||
|
|
||||||
|
LOGObjectFnStop();
|
||||||
|
return index;
|
||||||
|
};
|
||||||
|
|
||||||
|
-(id)appendCacheData:(id)fromCacheData
|
||||||
|
toCacheData:(id)toCacheData
|
||||||
|
{
|
||||||
|
LOGObjectFnStart();
|
||||||
|
if ([fromCacheData length]>0)
|
||||||
|
{
|
||||||
|
if ([fromCacheData isKindOfClass:[NSString class]])
|
||||||
|
{
|
||||||
|
if ([toCacheData isKindOfClass:[NSString class]]) // String+String
|
||||||
|
{
|
||||||
|
[toCacheData appendString:(NSString*)fromCacheData];
|
||||||
|
}
|
||||||
|
else if ([toCacheData length]==0)
|
||||||
|
{ // Empty Data+String
|
||||||
|
toCacheData=[NSMutableString stringWithString:fromCacheData];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Empty String
|
||||||
|
NSAssert(NO,
|
||||||
|
@"Try to append cache string to cache");
|
||||||
|
};
|
||||||
|
}
|
||||||
|
else // ??+Data
|
||||||
|
{
|
||||||
|
if ([toCacheData isKindOfClass:[NSData class]]) // Data+Data
|
||||||
|
{
|
||||||
|
[toCacheData appendData:fromCacheData];
|
||||||
|
}
|
||||||
|
else // String+Data
|
||||||
|
{
|
||||||
|
// Convert fromCacheData data to append into toCacheData string
|
||||||
|
NSString* fromCacheDataString=nil;
|
||||||
|
NSDebugMLog(@"Converting appending Data To String");
|
||||||
|
fromCacheDataString=[[[NSString alloc]initWithData:(NSData*)fromCacheData
|
||||||
|
encoding:[self contentEncoding]]
|
||||||
|
autorelease];
|
||||||
|
[toCacheData appendString:fromCacheDataString];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
LOGObjectFnStop();
|
||||||
|
return toCacheData;
|
||||||
|
}
|
||||||
|
//--------------------------------------------------------------------
|
||||||
|
-(id)stopCacheOfIndex:(int)cacheIndex
|
||||||
|
{
|
||||||
|
id cachedData=nil;
|
||||||
|
int cacheStackCount=0;
|
||||||
|
|
||||||
|
LOGObjectFnStart();
|
||||||
|
|
||||||
|
NSDebugMLLog(@"GSWCacheElement",@"cacheIndex=%d",cacheIndex);
|
||||||
|
|
||||||
|
cacheStackCount=[_cachesStack count];
|
||||||
|
|
||||||
|
NSDebugMLLog(@"GSWCacheElement",@"cacheStackCount=%d",cacheStackCount);
|
||||||
|
|
||||||
|
if (cacheIndex<cacheStackCount)
|
||||||
|
{
|
||||||
|
cachedData=[_cachesStack objectAtIndex:cacheIndex];
|
||||||
|
AUTORELEASE(RETAIN(cachedData));
|
||||||
|
|
||||||
|
NSDebugMLLog(@"GSWCacheElement",@"cachedData=%@",cachedData);
|
||||||
|
|
||||||
|
// Last one ? (normal case)
|
||||||
|
if (cacheIndex==(cacheStackCount-1))
|
||||||
|
{
|
||||||
|
[_cachesStack removeObjectAtIndex:cacheIndex];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// Strange case: may be an exception which avoided component to retrieve their cache ?
|
||||||
|
cacheIndex++;
|
||||||
|
while(cacheIndex<cacheStackCount)
|
||||||
|
{
|
||||||
|
id tmp=[_cachesStack objectAtIndex:cacheIndex];
|
||||||
|
NSDebugMLLog(@"GSWCacheElement",@"tmp=%@",tmp);
|
||||||
|
cachedData=[self appendCacheData:tmp
|
||||||
|
toCacheData:cachedData];
|
||||||
|
[_cachesStack removeObjectAtIndex:cacheIndex];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
cacheStackCount=[_cachesStack count];
|
||||||
|
|
||||||
|
//Add cachedData to previous cache item data
|
||||||
|
if (cacheStackCount>0 && [cachedData length]>0)
|
||||||
|
{
|
||||||
|
id previous=[_cachesStack objectAtIndex:cacheStackCount-1];
|
||||||
|
id newPrevious=[self appendCacheData:cachedData
|
||||||
|
toCacheData:previous];
|
||||||
|
if (newPrevious!=previous)
|
||||||
|
[_cachesStack replaceObjectAtIndex:cacheStackCount-1
|
||||||
|
withObject:newPrevious];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
NSDebugMLLog(@"GSWCacheElement",@"cachedData=%@",cachedData);
|
||||||
|
|
||||||
|
LOGObjectFnStop();
|
||||||
|
|
||||||
|
return cachedData;
|
||||||
|
}
|
||||||
|
|
||||||
|
@end
|
||||||
|
|
||||||
|
@implementation GSWMessage (GSWMessageCachePrivate)
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
|
-(void)_cacheAppendString:(NSString*)string
|
||||||
|
{
|
||||||
|
LOGObjectFnStart();
|
||||||
|
|
||||||
|
if ([string length]>0)
|
||||||
|
{
|
||||||
|
int index=0;
|
||||||
|
index=[_cachesStack count]-1;
|
||||||
|
if (index>=0)
|
||||||
|
{
|
||||||
|
id cachedData=[_cachesStack objectAtIndex:index];
|
||||||
|
if ([cachedData isKindOfClass:[NSData class]])
|
||||||
|
{
|
||||||
|
if ([cachedData length]>0)
|
||||||
|
{
|
||||||
|
NSAssert2(NO,
|
||||||
|
@"Try to append string to cache but content is data. \nString: '%@'\nData: '%@'",
|
||||||
|
string,
|
||||||
|
[[[NSString alloc]initWithData:_contentData
|
||||||
|
encoding:[self contentEncoding]]
|
||||||
|
autorelease]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
[_cachesStack replaceObjectAtIndex:index
|
||||||
|
withObject:[NSMutableString stringWithString:string]];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
[cachedData appendString:string];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
LOGObjectFnStop();
|
||||||
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
|
-(void)_cacheAppendData:(NSData*)data
|
||||||
|
{
|
||||||
|
LOGObjectFnStart();
|
||||||
|
|
||||||
|
if ([data length]>0)
|
||||||
|
{
|
||||||
|
int index=0;
|
||||||
|
index=[_cachesStack count]-1;
|
||||||
|
if (index>=0)
|
||||||
|
{
|
||||||
|
id cachedData=[_cachesStack objectAtIndex:index];
|
||||||
|
if ([cachedData isKindOfClass:[NSString class]])
|
||||||
|
{
|
||||||
|
if ([cachedData length]>0)
|
||||||
|
{
|
||||||
|
// Convert contentData to append into string and append it to _contentString
|
||||||
|
NSString* tmpString=nil;
|
||||||
|
NSDebugMLog(@"Converting appending Data To String");
|
||||||
|
tmpString=[[[NSString alloc]initWithData:data
|
||||||
|
encoding:[self contentEncoding]]
|
||||||
|
autorelease];
|
||||||
|
[cachedData appendString:tmpString];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
[_cachesStack replaceObjectAtIndex:index
|
||||||
|
withObject:[NSMutableData dataWithData:data]];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
[cachedData appendData:data];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
LOGObjectFnStop();
|
||||||
|
}
|
||||||
|
|
||||||
|
//--------------------------------------------------------------------
|
||||||
|
-(void)_cacheAppendBytes:(const void*)aBuffer
|
||||||
|
length: (unsigned int)bufferSize
|
||||||
|
{
|
||||||
|
LOGObjectFnStart();
|
||||||
|
if (bufferSize>0)
|
||||||
|
{
|
||||||
|
int index=0;
|
||||||
|
index=[_cachesStack count]-1;
|
||||||
|
if (index>=0)
|
||||||
|
{
|
||||||
|
id cachedData=[_cachesStack objectAtIndex:index];
|
||||||
|
if ([cachedData isKindOfClass:[NSString class]])
|
||||||
|
{
|
||||||
|
if ([cachedData length]>0)
|
||||||
|
{
|
||||||
|
// Convert contentData to append into string and append it to _contentString
|
||||||
|
NSString* tmpString=nil;
|
||||||
|
NSData* tmpData=nil;
|
||||||
|
NSDebugMLog(@"Converting appending Data To String");
|
||||||
|
tmpData=[NSData dataWithBytes:aBuffer
|
||||||
|
length:bufferSize];
|
||||||
|
tmpString=[[[NSString alloc]initWithData:tmpData
|
||||||
|
encoding:[self contentEncoding]]
|
||||||
|
autorelease];
|
||||||
|
[cachedData appendString:tmpString];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
[_cachesStack replaceObjectAtIndex:index
|
||||||
|
withObject:[NSMutableData dataWithBytes:aBuffer
|
||||||
|
length:bufferSize]];
|
||||||
|
}
|
||||||
|
else
|
||||||
|
[cachedData appendBytes:aBuffer
|
||||||
|
length:bufferSize];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
LOGObjectFnStop();
|
||||||
|
};
|
||||||
|
@end
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue