Create a LoggingController that shows all the commands sent and received.
[macgdbp.git] / Source / LoggingController.m
1 /*
2 * MacGDBp
3 * Copyright (c) 2010, Blue Static <http://www.bluestatic.org>
4 *
5 * This program is free software; you can redistribute it and/or modify it under the terms of the GNU
6 * General Public License as published by the Free Software Foundation; either version 2 of the
7 * License, or (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without
10 * even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
11 * General Public License for more details.
12 *
13 * You should have received a copy of the GNU General Public License along with this program; if not,
14 * write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
15 */
16
17 #import "LoggingController.h"
18
19
20 @implementation LoggingController
21
22 @synthesize logEntries = logEntries_;
23
24 - (id)init
25 {
26 if (self = [self initWithWindowNibName:@"Log"])
27 {
28 logEntries_ = [NSMutableArray new];
29 }
30 return self;
31 }
32
33 - (void)dealloc
34 {
35 [logEntries_ release];
36 [super dealloc];
37 }
38
39 - (LogEntry*)recordSend:(NSString*)command
40 {
41 LogEntry* entry = [LogEntry new];
42 entry.direction = kLogEntrySending;
43 entry.contents = command;
44 [logEntries_ addObject:entry];
45 [logEntriesController_ rearrangeObjects];
46 return [entry autorelease];
47 }
48
49 - (LogEntry*)recordReceive:(NSString*)response
50 {
51 LogEntry* entry = [LogEntry new];
52 entry.direction = kLogEntryReceiving;
53 entry.contents = response;
54 [logEntries_ addObject:entry];
55 [logEntriesController_ rearrangeObjects];
56 return [entry autorelease];
57 }
58
59 @end
60
61 ////////////////////////////////////////////////////////////////////////////////
62
63 @implementation LogEntry
64
65 @synthesize direction = direction_;
66 @synthesize contents = contents_;
67 @synthesize error = error_;
68 @synthesize lastWrittenTransactionID = lastWrittenTransactionID_;
69 @synthesize lastReadTransactionID = lastReadTransactionID_;
70
71 - (void)dealloc
72 {
73 self.contents = nil;
74 self.error = nil;
75 self.lastWrittenTransactionID = 0;
76 self.lastReadTransactionID = 0;
77 }
78
79 - (NSString*)directionName
80 {
81 return (direction_ == kLogEntryReceiving ? @"Recv" : @"Send");
82 }
83
84 @end
85