aboutsummaryrefslogtreecommitdiffstats
path: root/Frameworks/MCPKit/MCPFoundationKit/MCPStreamingResult.m
diff options
context:
space:
mode:
Diffstat (limited to 'Frameworks/MCPKit/MCPFoundationKit/MCPStreamingResult.m')
-rw-r--r--Frameworks/MCPKit/MCPFoundationKit/MCPStreamingResult.m46
1 files changed, 13 insertions, 33 deletions
diff --git a/Frameworks/MCPKit/MCPFoundationKit/MCPStreamingResult.m b/Frameworks/MCPKit/MCPFoundationKit/MCPStreamingResult.m
index 3b39738b..f6371b03 100644
--- a/Frameworks/MCPKit/MCPFoundationKit/MCPStreamingResult.m
+++ b/Frameworks/MCPKit/MCPFoundationKit/MCPStreamingResult.m
@@ -85,9 +85,7 @@
[mNames release];
mNames = nil;
}
-
-
-
+
mResult = mysql_use_result(mySQLPtr);
if (mResult) {
@@ -100,7 +98,7 @@
// Obtain SEL references and pointer
isConnectedSEL = @selector(isConnected);
isConnectedPtr = [parentConnection methodForSelector:isConnectedSEL];
-
+
// If the result is opened in download-data-fast safe mode, set up the additional variables
// and threads required.
if (!fullyStreaming) {
@@ -133,14 +131,9 @@
*/
- (void) dealloc
{
- [self cancelResultLoad]; //this should close the connection if it is still open
-
- if (!connectionUnlocked) {
- //this should NEVER happen
- NSLog(@"MCPStreamingResult: The connection has not been unlocked.");
- [parentConnection unlockConnection];
- }
-
+ [self cancelResultLoad];
+ if (!connectionUnlocked) [parentConnection unlockConnection];
+
if (!fullyStreaming) {
pthread_mutex_destroy(&dataFreeLock);
pthread_mutex_destroy(&dataCreationLock);
@@ -169,14 +162,8 @@
if (fullyStreaming) {
theRow = mysql_fetch_row(mResult);
- // If no data was returned, we're at the end of the result set - unlock the connection and return nil
- if (theRow == NULL) {
- if (!connectionUnlocked) {
- [parentConnection unlockConnection];
- connectionUnlocked = YES;
- }
- return nil;
- }
+ // If no data was returned, we're at the end of the result set - return nil.
+ if (theRow == NULL) return nil;
// Retrieve the lengths of the returned data
fieldLengths = mysql_fetch_lengths(mResult);
@@ -346,7 +333,6 @@
/*
* Ensure the result set is fully processed and freed without any processing
- * This method ensures that the connection is unlocked.
*/
- (void) cancelResultLoad
{
@@ -359,13 +345,7 @@
theRow = mysql_fetch_row(mResult);
// If no data was returned, we're at the end of the result set - return.
- if (theRow == NULL) {
- if (!connectionUnlocked) {
- [parentConnection unlockConnection];
- connectionUnlocked = YES;
- }
- return;
- }
+ if (theRow == NULL) return;
}
// If in cached-streaming/fast download mode, loop until all data is fetched and freed
@@ -381,8 +361,8 @@
// once all memory has been freed
if (processedRowCount == downloadedRowCount) {
while (!dataFreed) usleep(1000);
- // we don't need to unlock the connection because
- // the data loading thread already did that
+ [parentConnection unlockConnection];
+ connectionUnlocked = YES;
return;
}
processedRowCount++;
@@ -479,8 +459,8 @@
}
// Unlock the parent connection now data has been retrieved
- [parentConnection unlockConnection];
- connectionUnlocked = YES;
+ connectionUnlocked = YES;
+ [parentConnection unlockConnection];
dataDownloaded = YES;
[downloadPool drain];
@@ -528,4 +508,4 @@
[dataFreeingPool drain];
}
-@end
+@end \ No newline at end of file