aboutsummaryrefslogtreecommitdiffstats
path: root/Source
diff options
context:
space:
mode:
authorBibiko <bibiko@eva.mpg.de>2009-06-19 14:35:03 +0000
committerBibiko <bibiko@eva.mpg.de>2009-06-19 14:35:03 +0000
commit42848b23d2f5f49ff753baa9816da32b5ddd9e6e (patch)
tree7dd1215155de2cc1e4344f9673bb0d6d99b6c7fd /Source
parentc8582f347c0536126d1066b5c5c6e69c0c91f522 (diff)
downloadsequelpro-42848b23d2f5f49ff753baa9816da32b5ddd9e6e.tar.gz
sequelpro-42848b23d2f5f49ff753baa9816da32b5ddd9e6e.tar.bz2
sequelpro-42848b23d2f5f49ff753baa9816da32b5ddd9e6e.zip
• added to TableContent.m:
- (NSArray * )currentDataResult -- like currentResult but returns "BLOB" for blob data and a base64 encoded string for images à la <IMG SRC="data:image/auto;base64,"> - (NSString * ) base64EncodingOfData:(NSData * )data withLineLength:(unsigned int)lineLength -- it returns a base64 encoded string of data • changed: currentDataResult is now called for printing from the Table Content Browser
Diffstat (limited to 'Source')
-rw-r--r--Source/TableContent.h3
-rw-r--r--Source/TableContent.m117
-rw-r--r--Source/TableDocument.m2
3 files changed, 121 insertions, 1 deletions
diff --git a/Source/TableContent.h b/Source/TableContent.h
index 1c294144..80305fca 100644
--- a/Source/TableContent.h
+++ b/Source/TableContent.h
@@ -108,6 +108,9 @@
//getter methods
- (NSArray *)currentResult;
+- (NSArray *)currentDataResult;
+
+- (NSString *) base64EncodingOfData:(NSData*)data withLineLength:(unsigned int)lineLength;
//additional methods
- (void)setConnection:(CMMCPConnection *)theConnection;
diff --git a/Source/TableContent.m b/Source/TableContent.m
index 46fde6b3..319b46ae 100644
--- a/Source/TableContent.m
+++ b/Source/TableContent.m
@@ -40,6 +40,15 @@
#import "SPTextViewAdditions.h"
#import "QLPreviewPanel.h"
+
+static char encodingTable[64] = {
+'A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P',
+'Q','R','S','T','U','V','W','X','Y','Z','a','b','c','d','e','f',
+'g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v',
+'w','x','y','z','0','1','2','3','4','5','6','7','8','9','+','/' };
+
+
+
@implementation TableContent
/**
@@ -1251,6 +1260,114 @@
}
//getter methods
+- (NSArray *)currentDataResult
+/*
+ returns the current result (as shown in table content view) as array, the first object containing the field names as array, the following objects containing the rows as array
+ */
+{
+ NSArray *tableColumns;
+ NSEnumerator *enumerator;
+ id tableColumn;
+ NSMutableArray *currentResult = [NSMutableArray array];
+ NSMutableArray *tempRow = [NSMutableArray array];
+ int i;
+
+ //load table if not already done
+ if ( ![tablesListInstance contentLoaded] ) {
+ [self loadTable:[tablesListInstance tableName]];
+ }
+
+ tableColumns = [tableContentView tableColumns];
+ enumerator = [tableColumns objectEnumerator];
+
+ //set field names as first line
+ while ( (tableColumn = [enumerator nextObject]) ) {
+ [tempRow addObject:[[tableColumn headerCell] stringValue]];
+ }
+ [currentResult addObject:[NSArray arrayWithArray:tempRow]];
+
+ //add rows
+ for ( i = 0 ; i < [self numberOfRowsInTableView:nil] ; i++) {
+ [tempRow removeAllObjects];
+ enumerator = [tableColumns objectEnumerator];
+ while ( (tableColumn = [enumerator nextObject]) ) {
+ id o = [[fullResult objectAtIndex:i] objectForKey:[[tableColumn headerCell] stringValue]];
+ if([o isKindOfClass:[NSNull class]])
+ [tempRow addObject:@"NULL"];
+ else if([o isKindOfClass:[NSString class]])
+ [tempRow addObject:[o description]];
+ else {
+ NSImage *image = [[NSImage alloc] initWithData:o];
+ if(image) {
+ [tempRow addObject:[NSString stringWithFormat:@"<IMG WIDTH='100' SRC=\"data:image/auto;base64,%@\">", [self base64EncodingOfData: o withLineLength:0]]];
+ } else {
+ [tempRow addObject:@"&lt;BLOB&gt;"];
+ }
+ if(image) [image release];
+ }
+ }
+ [currentResult addObject:[NSArray arrayWithArray:tempRow]];
+ }
+ return currentResult;
+}
+
+- (NSString *) base64EncodingOfData:(NSData*)data withLineLength:(unsigned int)lineLength {
+ const unsigned char *bytes = [data bytes];
+ NSMutableString *result = [NSMutableString stringWithCapacity:[data length]];
+ unsigned long ixtext = 0;
+ unsigned long lentext = [data length];
+ long ctremaining = 0;
+ unsigned char inbuf[3], outbuf[4];
+ short i = 0;
+ short charsonline = 0, ctcopy = 0;
+ unsigned long ix = 0;
+
+ while( YES ) {
+ ctremaining = lentext - ixtext;
+ if( ctremaining <= 0 ) break;
+
+ for( i = 0; i < 3; i++ ) {
+ ix = ixtext + i;
+ if( ix < lentext ) inbuf[i] = bytes[ix];
+ else inbuf [i] = 0;
+ }
+
+ outbuf [0] = (inbuf [0] & 0xFC) >> 2;
+ outbuf [1] = ((inbuf [0] & 0x03) << 4) | ((inbuf [1] & 0xF0) >> 4);
+ outbuf [2] = ((inbuf [1] & 0x0F) << 2) | ((inbuf [2] & 0xC0) >> 6);
+ outbuf [3] = inbuf [2] & 0x3F;
+ ctcopy = 4;
+
+ switch( ctremaining ) {
+ case 1:
+ ctcopy = 2;
+ break;
+ case 2:
+ ctcopy = 3;
+ break;
+ }
+
+ for( i = 0; i < ctcopy; i++ )
+ [result appendFormat:@"%c", encodingTable[outbuf[i]]];
+
+ for( i = ctcopy; i < 4; i++ )
+ [result appendFormat:@"%c",'='];
+
+ ixtext += 3;
+ charsonline += 4;
+
+ if( lineLength > 0 ) {
+ if (charsonline >= lineLength) {
+ charsonline = 0;
+ [result appendString:@"\n"];
+ }
+ }
+ }
+
+ return result;
+}
+
+//getter methods
- (NSArray *)currentResult
/*
returns the current result (as shown in table content view) as array, the first object containing the field names as array, the following objects containing the rows as array
diff --git a/Source/TableDocument.m b/Source/TableDocument.m
index f98a2c1c..52dbc229 100644
--- a/Source/TableDocument.m
+++ b/Source/TableDocument.m
@@ -225,7 +225,7 @@ NSString *TableDocumentFavoritesControllerSelectionIndexDidChange = @"TableDocum
else if ( [tableTabView indexOfTabViewItem:[tableTabView selectedTabViewItem]] == 1 ){
if([[tableContentInstance currentResult] count] > 1)
rows = [[NSArray alloc] initWithArray:
- [[tableContentInstance currentResult] objectsAtIndexes:
+ [[tableContentInstance currentDataResult] objectsAtIndexes:
[NSIndexSet indexSetWithIndexesInRange:NSMakeRange(1, [[tableContentInstance currentResult] count]-1)]
]
];