Hello all,

I am doing a program to input align image values for horizontal and vertical. 
Basically it uses NSTableview to enter integer at horizontal and vertical 
columns. It work fine until the close button is clicked, the window is suppose 
to end modal mode and close window. But somehow it crashed, from crashed log, 
it seems the window is still trying to update NSTableView even though the 
window is already closed. How do I prevent windows or NSTableView updating 
after window is close ?

Peter C

Here is the snippet of the codes,

- (IBAction)editButtonAction:(id)sender
{
  AlignWindowController *alignWindowController;

  alignWindowController = [[AlignWindowController alloc] 
initWithWindowNibName:@"AlignWin"];
  [alignWindowController window];
  [alignWindowController setArray:testArray];
  if ([NSApp runModalForWindow:[alignWindowController window]] == NSOKButton) {

  }
  [alignWindowController autorelease];
}

// =================================== part of AlignWindowController

- (IBAction)closeButtonAction:(id)sender
{
    [NSApp stopModalWithCode:NSOKButton];
    [[self window] close];
}       


- (NSInteger) numberOfRowsInTableView: (NSTableView *) theTableView
{ 
 return [colorObjArray count];
}


- (id) tableView:(NSTableView *) theTableView
      objectValueForTableColumn:(NSTableColumn *)theColumn 
row:(NSInteger)rowIndex
{
 NSString *colStr;
 PrintAlignObj *alignObj;
 
 alignObj = [colorObjArray objectAtIndex:rowIndex];
 colStr = [theColumn identifier];
 if ([colStr isEqualToString:@"horizontal"]) {
                return alignObj.horzNumber;
 } else if ([colStr isEqualToString:@"vertical"]) {
                return alignObj.vertNumber;
 }
 return nil;
}

- (void) tableView:(NSTableView *)theTableView setObjectValue:(id)obj
        forTableColumn:(NSTableColumn *)theColumn row:(NSInteger)rowIndex
{
 PrintAlignObj *alignObj;
 NSString *editStr;
 NSString *idenStr;
 int val;
 
 editStr = [obj description];
 idenStr = [theColumn identifier];
 alignObj = [colorObjArray objectAtIndex:rowIndex];
 if ([idenStr isEqualToString:@"horizontal"]) {
        val = [editStr intValue];
        if (val >= PIXEL_MIN && val <= PIXEL_MAX)
                alignObj.horzNumber = [NSNumber numberWithInt:val];
 } else if ([idenStr isEqualToString:@"vertical"]) {
                        val = [editStr intValue];
                        if (val >= PIXEL_MIN && val <= PIXEL_MAX)
                                alignObj.vertNumber = [NSNumber 
numberWithInt:val];
                }
}


// ===========================================

Date/Time:       2010-05-08 11:56:55.313 +0800
OS Version:      Mac OS X 10.6.3 (10D578)
Report Version:  6

Interval Since Last Report:          180589 sec
Crashes Since Last Report:           16
Per-App Interval Since Last Report:  17010 sec
Per-App Crashes Since Last Report:   6
Anonymous UUID:                      E296B5C0-F953-46AB-99F1-1AB33B68EA97

Exception Type:  EXC_BAD_ACCESS (SIGBUS)
Exception Codes: KERN_PROTECTION_FAILURE at 0x0000000000000099
Crashed Thread:  0  Dispatch queue: com.apple.main-thread

Application Specific Information:
objc_msgSend() selector name: tableView:objectValueForTableColumn:row:


Thread 0 Crashed:  Dispatch queue: com.apple.main-thread
0   libobjc.A.dylib                     0x98877ed7 objc_msgSend + 23
1   com.apple.AppKit                    0x97fc3cb2 -[NSTableView 
preparedCellAtColumn:row:] + 335
2   com.apple.AppKit                    0x97fde18c -[NSTableView 
_drawContentsAtRow:column:withCellFrame:] + 56
3   com.apple.AppKit                    0x97fdd1fa -[NSTableView 
drawRow:clipRect:] + 1131
4   com.apple.AppKit                    0x97fdcc32 -[NSTableView 
drawRowIndexes:clipRect:] + 360
5   com.apple.AppKit                    0x97fdb60b -[NSTableView drawRect:] + 
1144
6   com.apple.AppKit                    0x97fd11cc -[NSView _drawRect:clip:] + 
3721
7   com.apple.AppKit                    0x97fce898 -[NSView 
_recursiveDisplayRectIfNeededIgnoringOpacity:isVisibleRect:rectIsVisibleRectForView:topView:]
 + 2217
8   com.apple.AppKit                    0x97fcf22b -[NSView 
_recursiveDisplayRectIfNeededIgnoringOpacity:isVisibleRect:rectIsVisibleRectForView:topView:]
 + 4668
9   com.apple.AppKit                    0x97fcf22b -[NSView 
_recursiveDisplayRectIfNeededIgnoringOpacity:isVisibleRect:rectIsVisibleRectForView:topView:]
 + 4668
10  com.apple.AppKit                    0x97fcf22b -[NSView 
_recursiveDisplayRectIfNeededIgnoringOpacity:isVisibleRect:rectIsVisibleRectForView:topView:]
 + 4668
11  com.apple.AppKit                    0x97fcf22b -[NSView 
_recursiveDisplayRectIfNeededIgnoringOpacity:isVisibleRect:rectIsVisibleRectForView:topView:]
 + 4668
12  com.apple.AppKit                    0x97fcde2b -[NSThemeFrame 
_recursiveDisplayRectIfNeededIgnoringOpacity:isVisibleRect:rectIsVisibleRectForView:topView:]
 + 265
13  com.apple.AppKit                    0x97fca771 -[NSView 
_displayRectIgnoringOpacity:isVisibleRect:rectIsVisibleRectForView:] + 3309
14  com.apple.AppKit                    0x97f2b3ee -[NSView displayIfNeeded] + 
818
15  com.apple.AppKit                    0x97ef46ec -[NSWindow displayIfNeeded] 
+ 204
16  com.apple.AppKit                    0x97f25c26 _handleWindowNeedsDisplay + 
696
17  com.apple.CoreFoundation            0x9407e2e2 __CFRunLoopDoObservers + 1186
18  com.apple.CoreFoundation            0x9403aa1d __CFRunLoopRun + 557
19  com.apple.CoreFoundation            0x9403a0f4 CFRunLoopRunSpecific + 452
20  com.apple.CoreFoundation            0x94039f21 CFRunLoopRunInMode + 97
21  com.apple.HIToolbox                 0x927f00fc RunCurrentEventLoopInMode + 
392
22  com.apple.HIToolbox                 0x927efded ReceiveNextEventCommon + 158
23  com.apple.HIToolbox                 0x927efd36 
BlockUntilNextEventMatchingListInMode + 81
24  com.apple.AppKit                    0x97efc135 _DPSNextEvent + 847
25  com.apple.AppKit                    0x97efb976 -[NSApplication 
nextEventMatchingMask:untilDate:inMode:dequeue:] + 156
26  com.apple.AppKit                    0x97ebdbef -[NSApplication run] + 821
27  com.apple.AppKit                    0x97eb5c85 NSApplicationMain + 574
28  com.my.test                         0x0000277a main + 24 (main.m:14)
29  com.my.test                         0x00002736 start + 54


Thread 1:  Dispatch queue: com.apple.libdispatch-manager
0   libSystem.B.dylib                   0x93c2bb42 kevent + 10
1   libSystem.B.dylib                   0x93c2c25c _dispatch_mgr_invoke + 215
2   libSystem.B.dylib                   0x93c2b719 _dispatch_queue_invoke + 163
3   libSystem.B.dylib                   0x93c2b4be _dispatch_worker_thread2 + 
240
4   libSystem.B.dylib                   0x93c2af41 _pthread_wqthread + 390
5   libSystem.B.dylib                   0x93c2ad86 start_wqthread + 30

Thread 2:
0   libSystem.B.dylib                   0x93c33262 __semwait_signal + 10
1   libSystem.B.dylib                   0x93c5ee44 nanosleep$UNIX2003 + 188
2   libSystem.B.dylib                   0x93c5ed82 usleep$UNIX2003 + 61
3   com.apple.AppKit                    0x98065885 -[NSUIHeartBeat 
_heartBeatThread:] + 2039
4   com.apple.Foundation                0x90b708dc -[NSThread main] + 45
5   com.apple.Foundation                0x90b7088c __NSThread__main__ + 1499
6   libSystem.B.dylib                   0x93c32a19 _pthread_start + 345
7   libSystem.B.dylib                   0x93c3289e thread_start + 34

Thread 3:
0   libSystem.B.dylib                   0x93c2abd2 __workq_kernreturn + 10
1   libSystem.B.dylib                   0x93c2b168 _pthread_wqthread + 941
2   libSystem.B.dylib                   0x93c2ad86 start_wqthread + 30

Thread 4:  Dispatch queue: com.apple.root.default-priority
0   libSystem.B.dylib                   0x93c05342 semaphore_wait_signal_trap + 
10
1   libSystem.B.dylib                   0x93c0ae06 pthread_mutex_lock + 490
2   com.apple.Foundation                0x90b66463 -[NSLock lock] + 201
3   com.apple.AppKit                    0x980669d4 __-[NSUIHeartBeat 
updateHeartBeatState]_block_invoke_2 + 49
4   com.apple.Foundation                0x90ba04d7 -[NSBlockOperation main] + 
231
5   com.apple.Foundation                0x90b9833f -[__NSOperationInternal 
start] + 811
6   com.apple.Foundation                0x90b97f65 
____startOperations_block_invoke_2 + 94
7   libSystem.B.dylib                   0x93c391e4 
_dispatch_call_block_and_release + 16
8   libSystem.B.dylib                   0x93c2b4b2 _dispatch_worker_thread2 + 
228
9   libSystem.B.dylib                   0x93c2af41 _pthread_wqthread + 390
10  libSystem.B.dylib                   0x93c2ad86 start_wqthread + 30

Thread 0 crashed with X86 Thread State (32-bit):
  eax: 0x00242750  ebx: 0x98046cc0  ecx: 0x98698258  edx: 0x00000079
  edi: 0x0025fdb0  esi: 0x0025fdb0  ebp: 0xbfffd0c8  esp: 0xbfffd088
   ss: 0x0000001f  efl: 0x00010206  eip: 0x98877ed7   cs: 0x00000017
   ds: 0x0000001f   es: 0x0000001f   fs: 0x00000000   gs: 0x00000037
  cr2: 0x00000099


_______________________________________________

Cocoa-dev mailing list (Cocoa-dev@lists.apple.com)

Please do not post admin requests or moderator comments to the list.
Contact the moderators at cocoa-dev-admins(at)lists.apple.com

Help/Unsubscribe/Update your Subscription:
http://lists.apple.com/mailman/options/cocoa-dev/archive%40mail-archive.com

This email sent to arch...@mail-archive.com

Reply via email to