forked from jverkoey/nimbus
-
Notifications
You must be signed in to change notification settings - Fork 1
/
_n_i_overview_logger_8m_source.html
256 lines (238 loc) · 18.2 KB
/
_n_i_overview_logger_8m_source.html
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/>
<title>Nimbus: /Users/featherless/workbench/ios/nimbus/src/overview/src/NIOverviewLogger.m Source File</title>
<link href="tabs.css" rel="stylesheet" type="text/css"/>
<link href="navtree.css" rel="stylesheet" type="text/css"/>
<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="resize.js"></script>
<script type="text/javascript" src="navtree.js"></script>
<script type="text/javascript">
$(document).ready(initResizable);
</script>
<link href="stylesheet.css" rel="stylesheet" type="text/css" />
<script type="text/javascript">
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-24278774-1']);
_gaq.push(['_trackPageview']);
(function() {
var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
})();
</script>
</head>
<body>
<div id="page">
<div style="position:relative">
<div id="top"><!-- do not remove this div! -->
<div id="titlearea">
<a style="float: right;margin-right:20px;margin-top:20px" href='http://www.pledgie.com/campaigns/15519'><img alt='Click here to support Nimbus development and make a donation at www.pledgie.com !' src='http://www.pledgie.com/campaigns/15519.png?skin_name=chrome' border='0' /></a>
<table cellspacing="0" cellpadding="0">
<tbody>
<tr style="height: 56px;">
<td style="padding-left: 0.5em;">
<div id="projectname">Nimbus
 <span id="projectnumber">0.6.0 - <a href="http://github.com/jverkoey/nimbus">Nimbus is proudly hosted on Github</a></span>
</div>
<div id="projectbrief">An iOS framework whose growth is bounded by O(documentation).</div>
</td>
</tr>
</tbody>
</table>
</div>
<!-- Generated by Doxygen 1.7.4-20110629 -->
</div>
<div id="side-nav" class="ui-resizable side-nav-resizable">
<div id="nav-tree">
<div id="nav-tree-contents">
</div>
</div>
<div id="splitbar" style="-moz-user-select:none;"
class="ui-resizable-handle">
</div>
</div>
<script type="text/javascript">
initNavTree('_n_i_overview_logger_8m.html','');
</script>
<div id="doc-content">
<div class="header">
<div class="headertitle">
<div class="title">/Users/featherless/workbench/ios/nimbus/src/overview/src/NIOverviewLogger.m</div> </div>
</div>
<div class="contents">
<div class="fragment"><pre class="fragment"><a name="l00001"></a>00001 <span class="comment">//</span>
<a name="l00002"></a>00002 <span class="comment">// Copyright 2011 Jeff Verkoeyen</span>
<a name="l00003"></a>00003 <span class="comment">//</span>
<a name="l00004"></a>00004 <span class="comment">// Licensed under the Apache License, Version 2.0 (the "License");</span>
<a name="l00005"></a>00005 <span class="comment">// you may not use this file except in compliance with the License.</span>
<a name="l00006"></a>00006 <span class="comment">// You may obtain a copy of the License at</span>
<a name="l00007"></a>00007 <span class="comment">//</span>
<a name="l00008"></a>00008 <span class="comment">// http://www.apache.org/licenses/LICENSE-2.0</span>
<a name="l00009"></a>00009 <span class="comment">//</span>
<a name="l00010"></a>00010 <span class="comment">// Unless required by applicable law or agreed to in writing, software</span>
<a name="l00011"></a>00011 <span class="comment">// distributed under the License is distributed on an "AS IS" BASIS,</span>
<a name="l00012"></a>00012 <span class="comment">// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.</span>
<a name="l00013"></a>00013 <span class="comment">// See the License for the specific language governing permissions and</span>
<a name="l00014"></a>00014 <span class="comment">// limitations under the License.</span>
<a name="l00015"></a>00015 <span class="comment">//</span>
<a name="l00016"></a>00016
<a name="l00017"></a>00017 <span class="preprocessor">#import "NIOverviewLogger.h"</span>
<a name="l00018"></a>00018
<a name="l00019"></a>00019 <a class="code" href="class_n_s_string.html" title="For manipulating NSStrings.">NSString</a>* <span class="keyword">const</span> NIOverviewLoggerDidAddConsoleLog = <span class="stringliteral">@"NIOverviewLoggerDidAddConsoleLog"</span>;
<a name="l00020"></a>00020
<a name="l00021"></a>00021
<a name="l00025"></a>00025 <span class="keyword">@implementation </span><a class="code" href="interface_n_i_overview_logger.html" title="The Overview logger.">NIOverviewLogger</a>
<a name="l00026"></a>00026
<a name="l00027"></a>00027 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_logger.html#a06381e17f301ef75d27168f3e055b319" title="The oldest age of a memory or disk log entry.">oldestLogAge</a> = _oldestLogAge;
<a name="l00028"></a>00028 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_logger.html#a0eea6bdec68e5c08672752cf7a6f91ad" title="The linked list of device logs.">deviceLogs</a> = _deviceLogs;
<a name="l00029"></a>00029 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_logger.html#aae148521e230db7cfa551cc5330c71da" title="The linked list of console logs.">consoleLogs</a> = _consoleLogs;
<a name="l00030"></a>00030 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_logger.html#a49e1b8a96fb9e13c3a5652e06c48d2a9" title="The linked list of events.">eventLogs</a> = _eventLogs;
<a name="l00031"></a>00031
<a name="l00032"></a>00032
<a name="l00034"></a>00034 - (void)dealloc {
<a name="l00035"></a>00035 <a class="code" href="group___preprocessor-_macros.html#ga5d2e99251aeb3ddb687e27f72336e5db" title="Release and assign nil to an object.">NI_RELEASE_SAFELY</a>(_deviceLogs);
<a name="l00036"></a>00036 <a class="code" href="group___preprocessor-_macros.html#ga5d2e99251aeb3ddb687e27f72336e5db" title="Release and assign nil to an object.">NI_RELEASE_SAFELY</a>(_consoleLogs);
<a name="l00037"></a>00037 <a class="code" href="group___preprocessor-_macros.html#ga5d2e99251aeb3ddb687e27f72336e5db" title="Release and assign nil to an object.">NI_RELEASE_SAFELY</a>(_eventLogs);
<a name="l00038"></a>00038
<a name="l00039"></a>00039 [<span class="keyword">super</span> dealloc];
<a name="l00040"></a>00040 }
<a name="l00041"></a>00041
<a name="l00042"></a>00042
<a name="l00044"></a>00044 - (id)init {
<a name="l00045"></a>00045 <span class="keywordflow">if</span> ((<span class="keyword">self</span> = [super init])) {
<a name="l00046"></a>00046 _deviceLogs = [[<a class="code" href="interface_n_i_linked_list.html" title="A singly linked list implementation.">NILinkedList</a> alloc] init];
<a name="l00047"></a>00047 _consoleLogs = [[<a class="code" href="interface_n_i_linked_list.html" title="A singly linked list implementation.">NILinkedList</a> alloc] init];
<a name="l00048"></a>00048 _eventLogs = [[<a class="code" href="interface_n_i_linked_list.html" title="A singly linked list implementation.">NILinkedList</a> alloc] init];
<a name="l00049"></a>00049
<a name="l00050"></a>00050 _oldestLogAge = 60;
<a name="l00051"></a>00051 }
<a name="l00052"></a>00052 <span class="keywordflow">return</span> <span class="keyword">self</span>;
<a name="l00053"></a>00053 }
<a name="l00054"></a>00054
<a name="l00055"></a>00055
<a name="l00057"></a>00057 - (void)pruneEntriesFromLinkedList:(<a class="code" href="interface_n_i_linked_list.html" title="A singly linked list implementation.">NILinkedList</a> *)ll {
<a name="l00058"></a>00058 NSDate* cutoffDate = [NSDate dateWithTimeIntervalSinceNow:-_oldestLogAge];
<a name="l00059"></a>00059 <span class="keywordflow">while</span> ([[((<a class="code" href="interface_n_i_overview_log_entry.html" title="The basic requirements for a log entry.">NIOverviewLogEntry</a> *)[ll firstObject])
<a name="l00060"></a>00060 timestamp] compare:cutoffDate] == NSOrderedAscending) {
<a name="l00061"></a>00061 [ll <a class="code" href="interface_n_i_linked_list.html#acf58608c591cd3350d92a51520ec5c56" title="Remove the first object from the linked list.">removeFirstObject</a>];
<a name="l00062"></a>00062 }
<a name="l00063"></a>00063 }
<a name="l00064"></a>00064
<a name="l00065"></a>00065
<a name="l00067"></a><a class="code" href="interface_n_i_overview_logger.html#ab63e68f85ea1105bb7636329d492d8ae">00067</a> - (void)addDeviceLog:(<a class="code" href="interface_n_i_overview_device_log_entry.html" title="A device log entry.">NIOverviewDeviceLogEntry</a> *)logEntry {
<a name="l00068"></a>00068 [<span class="keyword">self</span> pruneEntriesFromLinkedList:_deviceLogs];
<a name="l00069"></a>00069
<a name="l00070"></a>00070 [<a class="code" href="interface_n_i_linked_list.html" title="A singly linked list implementation.">_deviceLogs</a> <a class="code" href="interface_n_i_linked_list.html#a424313c1e697b5ba6a136be7a7d8dd3e" title="Append an object to the linked list.">addObject</a>:logEntry];
<a name="l00071"></a>00071 }
<a name="l00072"></a>00072
<a name="l00073"></a>00073
<a name="l00075"></a><a class="code" href="interface_n_i_overview_logger.html#a2f7a0f3cbabb4e81987f7dd95bc54678">00075</a> - (void)addConsoleLog:(<a class="code" href="interface_n_i_overview_console_log_entry.html" title="A console log entry.">NIOverviewConsoleLogEntry</a> *)logEntry {
<a name="l00076"></a>00076 [<a class="code" href="interface_n_i_linked_list.html" title="A singly linked list implementation.">_consoleLogs</a> <a class="code" href="interface_n_i_linked_list.html#a424313c1e697b5ba6a136be7a7d8dd3e" title="Append an object to the linked list.">addObject</a>:logEntry];
<a name="l00077"></a>00077
<a name="l00078"></a>00078 [[NSNotificationCenter defaultCenter] postNotificationName: NIOverviewLoggerDidAddConsoleLog
<a name="l00079"></a>00079 object: nil
<a name="l00080"></a>00080 userInfo:
<a name="l00081"></a>00081 [NSDictionary dictionaryWithObject:logEntry forKey:@"entry"]];
<a name="l00082"></a>00082 }
<a name="l00083"></a>00083
<a name="l00084"></a>00084
<a name="l00086"></a><a class="code" href="interface_n_i_overview_logger.html#a93579c6a70c4533de12e66226435bdf9">00086</a> - (void)addEventLog:(<a class="code" href="interface_n_i_overview_event_log_entry.html" title="An event log entry.">NIOverviewEventLogEntry</a> *)logEntry {
<a name="l00087"></a>00087 [<span class="keyword">self</span> pruneEntriesFromLinkedList:_eventLogs];
<a name="l00088"></a>00088
<a name="l00089"></a>00089 [<a class="code" href="interface_n_i_linked_list.html" title="A singly linked list implementation.">_eventLogs</a> <a class="code" href="interface_n_i_linked_list.html#a424313c1e697b5ba6a136be7a7d8dd3e" title="Append an object to the linked list.">addObject</a>:logEntry];
<a name="l00090"></a>00090 }
<a name="l00091"></a>00091
<a name="l00092"></a>00092
<a name="l00093"></a>00093 <span class="keyword">@end</span>
<a name="l00094"></a>00094
<a name="l00095"></a>00095
<a name="l00099"></a>00099 <span class="keyword">@implementation </span><a class="code" href="interface_n_i_overview_log_entry.html" title="The basic requirements for a log entry.">NIOverviewLogEntry</a>
<a name="l00100"></a>00100
<a name="l00101"></a>00101 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_log_entry.html#a62dce908251cfeaa50c1205fb3608d0e" title="The timestamp for this log entry.">timestamp</a> = _timestamp;
<a name="l00102"></a>00102
<a name="l00103"></a>00103
<a name="l00105"></a>00105 - (void)dealloc {
<a name="l00106"></a>00106 <a class="code" href="group___preprocessor-_macros.html#ga5d2e99251aeb3ddb687e27f72336e5db" title="Release and assign nil to an object.">NI_RELEASE_SAFELY</a>(_timestamp);
<a name="l00107"></a>00107
<a name="l00108"></a>00108 [<span class="keyword">super</span> dealloc];
<a name="l00109"></a>00109 }
<a name="l00110"></a>00110
<a name="l00111"></a>00111
<a name="l00113"></a><a class="code" href="interface_n_i_overview_log_entry.html#af2f7896e2887d56cde6c6073c3af0f52">00113</a> - (id)initWithTimestamp:(NSDate *)timestamp {
<a name="l00114"></a>00114 <span class="keywordflow">if</span> ((<span class="keyword">self</span> = [super init])) {
<a name="l00115"></a>00115 _timestamp = [<a class="code" href="interface_n_i_overview_log_entry.html#a62dce908251cfeaa50c1205fb3608d0e" title="The timestamp for this log entry.">timestamp</a> retain];
<a name="l00116"></a>00116 }
<a name="l00117"></a>00117 <span class="keywordflow">return</span> <span class="keyword">self</span>;
<a name="l00118"></a>00118 }
<a name="l00119"></a>00119
<a name="l00120"></a>00120
<a name="l00121"></a>00121 <span class="keyword">@end</span>
<a name="l00122"></a>00122
<a name="l00123"></a>00123
<a name="l00127"></a>00127 <span class="keyword">@implementation </span><a class="code" href="interface_n_i_overview_device_log_entry.html" title="A device log entry.">NIOverviewDeviceLogEntry</a>
<a name="l00128"></a>00128
<a name="l00129"></a>00129 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_device_log_entry.html#ab078aa890e76a4406c239bf6679748df" title="The number of bytes of free memory.">bytesOfFreeMemory</a> = _bytesOfFreeMemory;
<a name="l00130"></a>00130 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_device_log_entry.html#a61f89c2f98949aa4bd63be2e64e4e4c4" title="The number of bytes of total memory.">bytesOfTotalMemory</a> = _bytesOfTotalMemory;
<a name="l00131"></a>00131 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_device_log_entry.html#adb2fcb24e4470fa9d6eb952332088343" title="The number of bytes of total disk space.">bytesOfTotalDiskSpace</a> = _bytesOfTotalDiskSpace;
<a name="l00132"></a>00132 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_device_log_entry.html#a32d0aefadafa709641df9ff4c47a3aee" title="The number of bytes of free disk space.">bytesOfFreeDiskSpace</a> = _bytesOfFreeDiskSpace;
<a name="l00133"></a>00133 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_device_log_entry.html#a74bf0e48dd2ba94e5ca624e021f47f22" title="The battery level.">batteryLevel</a> = _batteryLevel;
<a name="l00134"></a>00134 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_device_log_entry.html#a009e4bd4b3eb9aebe661d1db7edbe6d5" title="The state of the battery.">batteryState</a> = _batteryState;
<a name="l00135"></a>00135
<a name="l00136"></a>00136 <span class="keyword">@end</span>
<a name="l00137"></a>00137
<a name="l00138"></a>00138
<a name="l00142"></a>00142 <span class="keyword">@implementation </span><a class="code" href="interface_n_i_overview_console_log_entry.html" title="A console log entry.">NIOverviewConsoleLogEntry</a>
<a name="l00143"></a>00143
<a name="l00144"></a>00144 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_console_log_entry.html#a7a411d8e7e587361c3efc0ccda36c7ad" title="The text that was written to the console log.">log</a> = _log;
<a name="l00145"></a>00145
<a name="l00146"></a>00146
<a name="l00148"></a>00148 - (void)dealloc {
<a name="l00149"></a>00149 <a class="code" href="group___preprocessor-_macros.html#ga5d2e99251aeb3ddb687e27f72336e5db" title="Release and assign nil to an object.">NI_RELEASE_SAFELY</a>(_log);
<a name="l00150"></a>00150
<a name="l00151"></a>00151 [<span class="keyword">super</span> dealloc];
<a name="l00152"></a>00152 }
<a name="l00153"></a>00153
<a name="l00154"></a>00154
<a name="l00156"></a><a class="code" href="interface_n_i_overview_console_log_entry.html#a3f442d14ff713dee83275d73fac22dc0">00156</a> - (id)initWithLog:(<a class="code" href="class_n_s_string.html" title="For manipulating NSStrings.">NSString</a> *)logText {
<a name="l00157"></a>00157 <span class="keywordflow">if</span> ((<span class="keyword">self</span> = [super initWithTimestamp:[NSDate date]])) {
<a name="l00158"></a>00158 _log = [logText copy];
<a name="l00159"></a>00159 }
<a name="l00160"></a>00160
<a name="l00161"></a>00161 <span class="keywordflow">return</span> <span class="keyword">self</span>;
<a name="l00162"></a>00162 }
<a name="l00163"></a>00163
<a name="l00164"></a>00164
<a name="l00165"></a>00165 <span class="keyword">@end</span>
<a name="l00166"></a>00166
<a name="l00167"></a>00167
<a name="l00171"></a>00171 <span class="keyword">@implementation </span><a class="code" href="interface_n_i_overview_event_log_entry.html" title="An event log entry.">NIOverviewEventLogEntry</a>
<a name="l00172"></a>00172
<a name="l00173"></a>00173 <span class="keyword">@synthesize</span> <a class="code" href="interface_n_i_overview_event_log_entry.html#ae1d4d7b73806280eb959ed15d80a0db9" title="The type of event.">type</a> = _eventType;
<a name="l00174"></a>00174
<a name="l00175"></a>00175
<a name="l00177"></a><a class="code" href="interface_n_i_overview_event_log_entry.html#aa8750ee90afd66e414f8cfad0342606f">00177</a> - (id)initWithType:(NSInteger)type {
<a name="l00178"></a>00178 <span class="keywordflow">if</span> ((<span class="keyword">self</span> = [super initWithTimestamp:[NSDate date]])) {
<a name="l00179"></a>00179 _eventType = <a class="code" href="interface_n_i_overview_event_log_entry.html#ae1d4d7b73806280eb959ed15d80a0db9" title="The type of event.">type</a>;
<a name="l00180"></a>00180 }
<a name="l00181"></a>00181
<a name="l00182"></a>00182 <span class="keywordflow">return</span> <span class="keyword">self</span>;
<a name="l00183"></a>00183 }
<a name="l00184"></a>00184
<a name="l00185"></a>00185
<a name="l00186"></a>00186 <span class="keyword">@end</span>
</pre></div></div>
</div>
<div id="nav-path" class="navpath">
<ul>
<li class="navelem"><b>NIOverviewLogger.m</b> </li>
</div><!-- .fixedwidth -->
<span class="footer">Generated for Nimbus by
<a href="http://www.doxygen.org/index.html">
<img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.7.4-20110629 </span>
</ul>
</div>
</div> <!-- page -->
</body>
</html>