Gui progress

Version 214 (Adrian Georgescu, 07/25/2009 05:50 pm)

1 1 Adrian Georgescu
[[TOC(gui_progress, depth=3)]]
2 1 Adrian Georgescu
3 74 Adrian Georgescu
= Audio sessions =
4 1 Adrian Georgescu
5 195 Adrian Georgescu
 1. '''Outbound ringtone''' does not play
6 195 Adrian Georgescu
 1. After a few calls the '''primary ringing''' is confused for secondary ringing  
7 195 Adrian Georgescu
 1. '''Mute''' microphone when pressing mute button
8 195 Adrian Georgescu
 1. Call '''set_audio_devices()''' when changing the audio device or tail_length in global Preferences
9 195 Adrian Georgescu
 1. Set SIP User Agent name to '''blink-<version>'''
10 193 Adrian Georgescu
 1. ~~Play '''ringtones'''~~ 
11 176 Adrian Georgescu
 1. '''Cancel''' is not handled for incoming sessions, the pop-up remains active 
12 1 Adrian Georgescu
  1. With every new incoming session the window shrinks in size
13 1 Adrian Georgescu
  1. After the second call is canceled the window does not auto close anymore and one previous canceled call remains on top
14 179 Adrian Georgescu
 1. ~~ Incoming sessions do not display '''session information''' and the control buttons are missing~~
15 179 Adrian Georgescu
 1. ~~ When '''rejecting a session''' it creates an entry in the drawer~~
16 178 Adrian Georgescu
 1. ~~'''Maximize drawer''' when it opens the first time, it seem to open only 80% now ~~
17 146 Adrian Georgescu
 1. ~~Playback DTMF tones~~
18 115 Adrian Georgescu
 1. ~~ A terminated session must '''disappear from the drawer''' automatically after 5 seconds ~~
19 115 Adrian Georgescu
 1. ~~ Remaining sessions must '''shuffle to the top''' when a session ends~~
20 115 Adrian Georgescu
 1. ~~ Toggle hold does not change hold '''button color''' ~~
21 115 Adrian Georgescu
 1. ~~ Update session audio information with '''Hold by remote''' when held by remote party ~~
22 115 Adrian Georgescu
 1. ~~ Only one audio session can be '''active at a time''', all other existing audio sessions must be put on hold~~
23 1 Adrian Georgescu
 1. ~~ Highlight the '''active session''' with a bold border, click on a session to select it as the active session~~
24 140 Adrian Georgescu
 1. ~~ When the active session is selected, what is typed on the keyboard must be transmitted as '''DTMF tones'''~~
25 115 Adrian Georgescu
 1. ~~ When a call is connected move keyboard focus to it ~~
26 115 Adrian Georgescu
 1. ~~ When a session has ended, display it for '''5 more seconds''' then hide it and shuffle the deck  ~~
27 115 Adrian Georgescu
 1. ~~ Add an item '''Show audio sessions''' to the '''Session menu''' to show the drawer, if it was closed  (activated the View -> Toggle Sessions Drawer) ~~
28 147 Adrian Georgescu
 1. ~~ '''Scroll bar''' appears as result of multiple sessions, but it does not disappear when the number of session decreases~~
29 147 Adrian Georgescu
 1. ~~ '''Hangup All''' is not implemented~~
30 156 Adrian Georgescu
 1. ~~Display icon with lock when sRTP is active~~
31 161 Adrian Georgescu
 1. ~~ Disable Hangup All button if no session is active~~
32 150 Adrian Georgescu
 1. ~~ Disable Conference button if less than two sessions active~~
33 160 Adrian Georgescu
 1. ~~Allow the session end button for incoming sessions, which have not yet been established  (waiting for the ACK message) ~~
34 1 Adrian Georgescu
35 1 Adrian Georgescu
= Chat sessions =
36 1 Adrian Georgescu
37 210 Adrian Georgescu
 1. Use the same look and feel for the toolbar buttons as the main interface (greyish buttons) 
38 212 Adrian Georgescu
 1. Rename Call button text with Audio
39 212 Adrian Georgescu
 1. Rename '''Close chat''' button to Close
40 206 Adrian Georgescu
 1. Chat session logging:
41 206 Adrian Georgescu
  1. ~~Display session information inline with a different border color~~
42 206 Adrian Georgescu
  1. When using a relay during stream initialization: '''MSRP session reserved at relay host:port''' and timestamp on the right
43 206 Adrian Georgescu
  1. Use the following message when connected: '''MSRP chat session established to MSRP_URI''' and timestamp on the right
44 1 Adrian Georgescu
  1. Use the following message when disconnected: '''MSRP chat session terminated (reason)''' and timestamp on the right
45 211 Adrian Georgescu
 1. Delay closing the window after closing the chat session with 3 seconds
46 211 Adrian Georgescu
 1. Read '''history directory''' from global.chat.history_directory
47 212 Adrian Georgescu
 1. Auto-accept chat only sessions when caller is in the contacts list
48 1 Adrian Georgescu
 1. Copy all chat stream notification to the Python console
49 210 Adrian Georgescu
 1. Remove confirmation window with: "There is an active chat session, would you like to terminate and close it?"
50 209 Adrian Georgescu
 1. If an audio session exists to or from the chat recipient, replace call button with '''mute|hold|terminate buttons''', update audio drawer when pushing the buttons 
51 1 Adrian Georgescu
 1. When click on the Call button, create a '''separate audio session''' from scratch (as opposed to add_stream)
52 210 Adrian Georgescu
 1. Use same + button from the main interface for add contact
53 195 Adrian Georgescu
 1. Do not play an '''audible tone when terminating''' a chat session, the stop tone is for audio session only
54 180 Adrian Georgescu
 1. Display the number of '''un-read messages''' in non-visible tabs in a red circle over the tab name
55 156 Adrian Georgescu
 1. ~~Add a '''+''' button (to add contact) in the toolbar~~
56 156 Adrian Georgescu
 1. ~~Display the full From and To headers~~
57 164 Adrian Georgescu
 1. ~~Use secondary ring tone on output_device  when incoming session with chat media only~~
58 164 Adrian Georgescu
 1. ~~When close the window or click on close button call session.end() if the session has no other stream or session.remove_stream() otherwise~~
59 174 Adrian Georgescu
 1. ~~When click on close, close the tab or the whole window if no tab left~~
60 135 Adrian Georgescu
 1. ~~'''Throttle playback''' of audible notifications to maximum one every 3 seconds ~~
61 164 Adrian Georgescu
 1. ~~ Display timestamp in HH:MM:ss format to the right side of the window, same lin as From/To header ~~ 
62 164 Adrian Georgescu
 1. ~~Bug: Cannot get rid of existing tabs, they keep growing~~
63 164 Adrian Georgescu
 1. ~~Bug: opening and closing chat windows bring up different number of former chat tabs back~~
64 1 Adrian Georgescu
 1. ~~Append chat messages to '''chat.history_directory/sip_account/YYYYMMDD-recipient.txt'''~~
65 1 Adrian Georgescu
 1. ~~Play an audible message when a message is received, based on '''silent''' and '''general.message_received_sound''' settings~~
66 180 Adrian Georgescu
 1. ~~Play an audible message when a message is sent, based on silent and '''general.message_sent_sound''' settings~~
67 180 Adrian Georgescu
 1. ~~Add '''File transfer''' button on toolbar~~
68 180 Adrian Georgescu
 1. ~~Add '''History''' button on toolbar~~
69 131 Adrian Georgescu
 1. When dragging a recipient tab outside of the window '''spawn a new chat window''' and move the session into it
70 157 Adrian Georgescu
 1. When start typing send a message with '''is-composing''' payload. This requires implementing the is-composing payload parser, see http://sipsimpleclient.com/ticket/40. If user has deleted the typed text before sending it update is-composing. 
71 174 Adrian Georgescu
 
72 131 Adrian Georgescu
73 1 Adrian Georgescu
= Main interface =
74 167 Adrian Georgescu
75 195 Adrian Georgescu
 1. Instead of maximizing the window, use the '''green + title button''' to collapse/expand the buddy list, hide + sign when the interface is collapsed
76 195 Adrian Georgescu
 1. '''Bonjour account''' does not appear when deactivate/activate
77 167 Adrian Georgescu
 1. ~~At least one account must be active, use the bonjour acocunt if no accounts are defined ~~
78 167 Adrian Georgescu
 1. ~~ The list of account is built based the active attribute of each account alone, registration status has no role~~
79 167 Adrian Georgescu
 1. ~~When selecting a different account, mark it as '''default''' using the settings api~~
80 167 Adrian Georgescu
 1. ~~Bonjour account does not show up in account list~~
81 1 Adrian Georgescu
 1. ~~'''Remove account''' from list when is disabled in preferences  ~~
82 167 Adrian Georgescu
 1. ~~On startup, '''select the default account''' in the account list~~
83 1 Adrian Georgescu
 1. ~~If red Close button is pressed, the main window disappears and is no option to bring it back~~
84 1 Adrian Georgescu
 1. ~~No dock icon available~~
85 180 Adrian Georgescu
86 132 Adrian Georgescu
= Contacts =
87 1 Adrian Georgescu
88 195 Adrian Georgescu
 1. When add a contact without domain part, always append the '''curent domain'''
89 195 Adrian Georgescu
 1. Type a '''new group''' in add contact: (NameError: global name 'ContactsGroup' is not defined)
90 132 Adrian Georgescu
 1. '''Delete the contact''' when pressing delete
91 195 Adrian Georgescu
 1. Rename '''Add as a contact''' to Add Contact
92 195 Adrian Georgescu
 1. Hide '''Add contact''' if contact exists
93 195 Adrian Georgescu
 1. After dialing a found contact, '''display back''' the buddy list
94 195 Adrian Georgescu
 1. '''Cannot press''' start session buttons for input in search bar if no match found
95 195 Adrian Georgescu
 1. Show search results from system '''address book'''
96 1 Adrian Georgescu
97 199 Adrian Georgescu
98 199 Adrian Georgescu
= Preferences =
99 199 Adrian Georgescu
100 199 Adrian Georgescu
 1. Properly '''align''' horizontally the Advanced settings
101 202 Adrian Georgescu
 1. Audio device must also list 'Default system input ' and 'Default system output'
102 200 Adrian Georgescu
 1. ~~Make all text input fields equal in size~~
103 200 Adrian Georgescu
 1. Do not allow resize of pref window
104 200 Adrian Georgescu
 1. '''bonjour account''' has only Display name as main property
105 200 Adrian Georgescu
 1. Hide the minus button for Bonjour, it cannot be deleted
106 199 Adrian Georgescu
 1. When password field is changed, re-Register the account 
107 201 Adrian Georgescu
 1. Codec lists must be an ordered list with at least one active codec
108 199 Adrian Georgescu
 1. '''Stun server''' addresses cannot be set, they seem to inherit the results found in DNS  
109 199 Adrian Georgescu
 1. '''general.rtp.local_ip''': Can't set option local_ip illegal local IP address value: auto
110 199 Adrian Georgescu
 1. '''general.rtp.port_range''': (AttributeError: 'PortRangeOption' object has no attribute 'save')
111 199 Adrian Georgescu
 1. '''general.sip.transports''' cannot be saved
112 199 Adrian Georgescu
 1. '''general.audio.codec_list''' cannot be saved and displays duplicate codecs
113 199 Adrian Georgescu
 1. '''account.audio.codec_list''' cannot be saved and displays duplicate codecs
114 199 Adrian Georgescu
 1. '''account.msrp.relay''' cannot be set: global name 'MSRPRelayAddres' is not defined
115 199 Adrian Georgescu
 1. Display text to the '''left of the checkbox''' instead of the right
116 199 Adrian Georgescu
 1. ~~'''Delete account Enabled checkbox''', leave only the checkbox in the account list~~
117 199 Adrian Georgescu
 1. When '''enable an account''', select it in the main interface account list
118 199 Adrian Georgescu
 1. ~~ Display the '''bonjour account''' always at the end of the list ~~
119 199 Adrian Georgescu
 1. For '''account.ringtone''' advanced setting, the default setting must be inherited from '''general.ringtone.inbound'''
120 199 Adrian Georgescu
 1. '''general.message_received_sound''' does not fit in window
121 199 Adrian Georgescu
 1. Allow ordering of accounts in the account list
122 199 Adrian Georgescu
 1. While clicking on account I got this (cannot reproduce): (TypeError: 'NSAutoreleasePool' object is not iterable)
123 199 Adrian Georgescu
 1. Check if the wav file is in the right format before saving the settings related to ringtones
124 199 Adrian Georgescu
 1. Check if the TLS options set by the user are valid before saving them (by loading them outside the engine using gnutls library)
125 199 Adrian Georgescu
126 199 Adrian Georgescu
Display SIP registration state in '''account.advanced.registration''' section.
127 199 Adrian Georgescu
128 199 Adrian Georgescu
129 48 Adrian Georgescu
= Conferencing =
130 1 Adrian Georgescu
131 1 Adrian Georgescu
Only one conference is possible to make the interface easy to use.
132 194 Adrian Georgescu
133 194 Adrian Georgescu
To start a conference:
134 194 Adrian Georgescu
135 1 Adrian Georgescu
 1. Send a re-INVITE to a) take each call off hold and b) set the is-focus attribute of the Contact header
136 121 Adrian Georgescu
 1. Set the conference bridge to mix audio between all parties
137 194 Adrian Georgescu
 1. Disable the hold buttons, they do not operate while in conference
138 185 Adrian Georgescu
 1. Draw the selection rectangle around the sessions part of the conference
139 180 Adrian Georgescu
140 180 Adrian Georgescu
To stop a conference
141 168 Adrian Georgescu
142 151 Adrian Georgescu
 1. Send a re-INVITE to a) take each call an leave only one off hold and b) disable is-focus attribute of the Contact header
143 42 Adrian Georgescu
 1. Set the conference bridge to stop mixing audio
144 42 Adrian Georgescu
 1. Enable the hold buttons
145 42 Adrian Georgescu
 1. Draw the selection rectangle around the selected session
146 42 Adrian Georgescu
147 41 Adrian Georgescu
New sessions while in a conference
148 1 Adrian Georgescu
149 41 Adrian Georgescu
 1. New sessions are added bellow the conference
150 168 Adrian Georgescu
 1. A session can be dragged in and out of the conference
151 149 Adrian Georgescu
 1. When switching from a conference to another single session, do not use hold
152 1 Adrian Georgescu
153 151 Adrian Georgescu
= Audio history =
154 154 Adrian Georgescu
155 41 Adrian Georgescu
 1. Use the same session drawer to display previous sessions
156 41 Adrian Georgescu
 1. Keep same layout as active sessions with the following changes:
157 96 Adrian Georgescu
   1. Missed calls (incoming un-answered sessions must display the SIP address in red) 
158 118 Adrian Georgescu
   1. Duration line must display also the Start time: HH:MM:SS (YYYY-MM-DD HH:MM )
159 118 Adrian Georgescu
   1. Instead of audio session information display: Incoming|Outgoing
160 29 Adrian Georgescu
   1. Replace the current session buttons with a callback button
161 29 Adrian Georgescu
 1. Add a Session menu item to toggle the drawer content between active session and history sessions
162 41 Adrian Georgescu
 1. Show most recent sessions on top
163 1 Adrian Georgescu
164 116 Adrian Georgescu
= Engine =
165 122 Adrian Georgescu
166 41 Adrian Georgescu
 1. If '''engine is dead''', the message  '''no sip account is active''' is displayed but is unclear what the real reason is. An engine stop must be logged to general debug window. Not clear how to restart the engine, maybe we should restart the application until a good solution is found
167 29 Adrian Georgescu
 1. If the engine has stopped (because of some crash) the preferences do not show anymore:
168 29 Adrian Georgescu
169 29 Adrian Georgescu
{{{
170 29 Adrian Georgescu
Blink[26992:10b] <type 'exceptions.AttributeError'>: 'Engine' object has no attribute 'output_devices'
171 29 Adrian Georgescu
}}}
172 29 Adrian Georgescu
173 29 Adrian Georgescu
By setting the wrong TLS certificate files, the middleware does not start anymore:
174 29 Adrian Georgescu
175 29 Adrian Georgescu
{{{
176 29 Adrian Georgescu
[Session started at 2009-07-19 10:37:39 +0200.]
177 29 Adrian Georgescu
Traceback (most recent call last):
178 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/BlinkAppDelegate.py", line 40,
179 29 Adrian Georgescu
   in applicationDidFinishLaunching_
180 29 Adrian Georgescu
    self.backend.init(options)
181 29 Adrian Georgescu
  File "/Users/adigeo/work/blink/build/Debug/Blink.app/Contents/Resources/SIPManager.py", line 108, in init
182 29 Adrian Georgescu
    self._app.start(config_backend=config_be)
183 29 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/api.py", line 85, in start
184 29 Adrian Georgescu
    trace_sip=settings.logging.trace_sip,
185 41 Adrian Georgescu
  File "/Library/Python/2.5/site-packages/sipsimple/engine.py", line 75, in start
186 29 Adrian Georgescu
    self._ua = PJSIPUA(self._handle_event, 1.1.init_options)
187 29 Adrian Georgescu
  File "core.ua.pxi", line 66, in sipsimple.core.PJSIPUA.__init__ (sipsimple/core.c:23189)
188 29 Adrian Georgescu
  File "core.lib.pxi", line 106, in sipsimple.core.PJSIPEndpoint.__cinit__ (sipsimple/core.c:6231)
189 29 Adrian Georgescu
  File "core.lib.pxi", line 167, in sipsimple.core.PJSIPEndpoint._start_tls_transport (sipsimple/core.c:6884)
190 29 Adrian Georgescu
PJSIPError: Could not create TLS transport: Error loading/verifying SSL CA list file (PJSIP_TLS_ECACERT)
191 1 Adrian Georgescu
None
192 34 Adrian Georgescu
}}}
193 1 Adrian Georgescu
194 155 Adrian Georgescu
= Menu structure =
195 155 Adrian Georgescu
196 155 Adrian Georgescu
 1. File
197 155 Adrian Georgescu
 1. Edit
198 155 Adrian Georgescu
 1. View
199 198 Adrian Georgescu
  1. Audio sessions drawer 
200 198 Adrian Georgescu
  1. Previous audio sessions
201 198 Adrian Georgescu
  1. Previous chat sessions
202 155 Adrian Georgescu
 1. Audio
203 213 Adrian Georgescu
  1. Output device selection
204 213 Adrian Georgescu
  1. Input device selection
205 213 Adrian Georgescu
  1. Alert device selection
206 213 Adrian Georgescu
  1. Mute (mute mic input)
207 213 Adrian Georgescu
  1. Silent (mute output)
208 155 Adrian Georgescu
 1. Presence
209 155 Adrian Georgescu
  1. Activity
210 155 Adrian Georgescu
   1. Available
211 155 Adrian Georgescu
   1. Phone call
212 1 Adrian Georgescu
   1. Meeting
213 155 Adrian Georgescu
   1. Lunch
214 155 Adrian Georgescu
   1. Dinner
215 198 Adrian Georgescu
   1. Do not disturb (when enabled reject automatically all audio calls)
216 155 Adrian Georgescu
   1. Travel
217 155 Adrian Georgescu
   1. Offline
218 155 Adrian Georgescu
   1. Holiday
219 155 Adrian Georgescu
 1. Contacts
220 155 Adrian Georgescu
  1. Add contact
221 155 Adrian Georgescu
  1. Delete contact
222 155 Adrian Georgescu
  1. Edit contact
223 155 Adrian Georgescu
  1. Add group
224 155 Adrian Georgescu
  1. Delete group
225 155 Adrian Georgescu
  1. Edit group
226 155 Adrian Georgescu
 1. Sessions
227 173 Adrian Georgescu
  1. New audio session ...
228 166 Adrian Georgescu
  1. New chat session ...
229 166 Adrian Georgescu
  1. New multi party chat session ...
230 166 Adrian Georgescu
  1. Close all audio sessions
231 166 Adrian Georgescu
  1. Conference audio sessions
232 155 Adrian Georgescu
233 1 Adrian Georgescu
= Presence bar =
234 1 Adrian Georgescu
235 1 Adrian Georgescu
Make it as high as the contacts (two rows high).
236 142 Adrian Georgescu
237 142 Adrian Georgescu
 1. ~~ Show '''own photo''' to the left ~~
238 1 Adrian Georgescu
 1. Acquire photo from webcam and cache it
239 1 Adrian Georgescu
 1. Show '''Display name''' next to the photo on top row
240 142 Adrian Georgescu
 1. Show '''Presence activity note''' on second row, editable text
241 1 Adrian Georgescu
 1. Show '''Presence activity''' next to name on top row. Activities:
242 1 Adrian Georgescu
   1. Available
243 142 Adrian Georgescu
   1. Phone call
244 142 Adrian Georgescu
   1. Meeting
245 142 Adrian Georgescu
   1. Lunch
246 142 Adrian Georgescu
   1. Dinner
247 142 Adrian Georgescu
   1. Do not disturb
248 142 Adrian Georgescu
   1. Travel
249 142 Adrian Georgescu
   1. Offline
250 142 Adrian Georgescu
   1. Holiday
251 148 Adrian Georgescu
252 148 Adrian Georgescu
Add a Presence menu item before Session.
253 7 Adrian Georgescu
254 1 Adrian Georgescu
= Debug window =
255 7 Adrian Georgescu
256 41 Adrian Georgescu
 1. Display all traces in a '''debug window''' with tabs for each debug type
257 41 Adrian Georgescu
 1. Add a '''General messages''' window to the Debug menu, first item
258 1 Adrian Georgescu
259 1 Adrian Georgescu
= GUI settings =
260 1 Adrian Georgescu
261 1 Adrian Georgescu
Remember the following settings between restarts:
262 79 Adrian Georgescu
263 41 Adrian Georgescu
 1. '''Debug window''' and the selected tab
264 41 Adrian Georgescu
 1. Status of '''contact groups''' - colapsed/expanded and their order
265 100 Adrian Georgescu
266 14 Adrian Georgescu
= Middleware =
267 47 Adrian Georgescu
268 102 Adrian Georgescu
 1. On startup, check if the audio device from the preferences '''is available''' in the detected devices list. If not, set the device to the system default device and display a warning to the user to set the devices in the preferences
269 214 Adrian Georgescu
 1. Enable logging of notifications to file
270 102 Adrian Georgescu
 1. Check the validity of the '''TLS''' settings/files before starting the engine
271 102 Adrian Georgescu
 1. It seems that the '''stun servers''' are learned from the DNS and cannot be overwritten in settings, they show up automatically
272 102 Adrian Georgescu
 1. If I set the relay to abcd.com standard '''port 2855''' must be used, now is set to zero: relay = abcd.com:0;transport=tls
273 41 Adrian Georgescu
 1. We need a solution to accept a session without a 180- ringing. For instance we can have automatic answer based on various preferences.
274 41 Adrian Georgescu
 1. Move '''general.audio.codec_list''' to '''general.rtp.audio_codecs'''
275 1 Adrian Georgescu
 1. Move '''account.audio.codec_list''' to '''account.rtp.audio_codecs'''
276 1 Adrian Georgescu
 1. Move '''account.audio.srtp_encryption''' to '''account.rtp.srtp_encryption'''
277 1 Adrian Georgescu
 1. Delete '''general.audio.playback_dtmf''' setting
278 1 Adrian Georgescu
 1. Add '''general.audio.mute''' setting
279 1 Adrian Georgescu
 1. Delete '''account.audio''' section
280 66 Adrian Georgescu
 1. Add '''account.sip''' section
281 66 Adrian Georgescu
 1. Move '''account.outbound_proxy''' to '''account.sip.outbound_proxy'''
282 66 Adrian Georgescu
 1. Move '''account.presence.publish_interval''' to '''account.sip.publish_interval'''
283 66 Adrian Georgescu
 1. Move '''account.presence.subscribe_interval''' to '''account.sip.subscribe_interval'''
284 66 Adrian Georgescu
 1. Move '''account.registration.interval''' to '''account.sip.register_interval'''
285 66 Adrian Georgescu
 1. Delete '''account.ice.use_stun''', it is always true
286 68 Adrian Georgescu
 1. Rename '''account.ice''' to '''account.nat_traversal'''
287 109 Adrian Georgescu
 1. Rename '''account.ice.enabled''' to '''account.nat_traversal.enable_ice'''
288 109 Adrian Georgescu
 1. Delete global.chat.accept_types
289 1 Adrian Georgescu
 1. Delete global.chat.accept_wrapped_types
290 172 Adrian Georgescu
 1.  Add a new setting '''account.chat.server''' default = chatserver.domain
291 159 Adrian Georgescu
292 159 Adrian Georgescu
= General =
293 159 Adrian Georgescu
294 189 Adrian Georgescu
 1. ~~Enable logging based on log settings~~
295 189 Adrian Georgescu
 1. ~~'''Set global.user_data_directory''' to ~/Library/Application\ Support/Blink/~~
296 171 Adrian Georgescu
 1. Scratchy noises when playing tone generator tones, they do not appear using the CLI
297 170 Adrian Georgescu
 1. Crash when more than 32 tones in the tone generator queue
298 171 Adrian Georgescu
299 170 Adrian Georgescu
 1. Random crashes during functioning always end up in debugger at:
300 159 Adrian Georgescu
301 159 Adrian Georgescu
{{{
302 159 Adrian Georgescu
[Switching to process 59222 thread 0x9b73]
303 159 Adrian Georgescu
(gdb) bt
304 159 Adrian Georgescu
#0  0x937691c6 in mach_msg_trap ()
305 159 Adrian Georgescu
#1  0x937709bc in mach_msg ()
306 159 Adrian Georgescu
#2  0x9351104e in CFRunLoopRunSpecific ()
307 159 Adrian Georgescu
#3  0x93511c78 in CFRunLoopRunInMode ()
308 159 Adrian Georgescu
#4  0x9411128c in RunCurrentEventLoopInMode ()
309 159 Adrian Georgescu
#5  0x941110a5 in ReceiveNextEventCommon ()
310 159 Adrian Georgescu
#6  0x94110f19 in BlockUntilNextEventMatchingListInMode ()
311 159 Adrian Georgescu
#7  0x96863d0d in _DPSNextEvent ()
312 159 Adrian Georgescu
#8  0x968635c0 in -[NSApplication nextEventMatchingMask:untilDate:inMode:dequeue:] ()
313 159 Adrian Georgescu
#9  0x9685c5fb in -[NSApplication run] ()
314 159 Adrian Georgescu
#10 0x00233855 in ffi_call_SYSV ()
315 159 Adrian Georgescu
#11 0x00233d6c in ffi_call ()
316 159 Adrian Georgescu
#12 0x0024a825 in PyObjCFFI_Caller ()
317 159 Adrian Georgescu
#13 0x00261b63 in PyObjCSelector_GetMetadata ()
318 159 Adrian Georgescu
#14 0x00121505 in PyObject_Call ()
319 159 Adrian Georgescu
#15 0x0018f832 in PyEval_EvalFrameEx ()
320 159 Adrian Georgescu
#16 0x00191173 in PyEval_EvalCodeEx ()
321 159 Adrian Georgescu
#17 0x0018f79d in PyEval_EvalFrameEx ()
322 159 Adrian Georgescu
#18 0x00191173 in PyEval_EvalCodeEx ()
323 159 Adrian Georgescu
#19 0x00191260 in PyEval_EvalCode ()
324 159 Adrian Georgescu
#20 0x001a883c in PyErr_Display ()
325 159 Adrian Georgescu
#21 0x001a8e66 in PyRun_FileExFlags ()
326 159 Adrian Georgescu
#22 0x001aa7d2 in PyRun_SimpleFileExFlags ()
327 159 Adrian Georgescu
#23 0x00001d4e in main (argc=1, argv=0xbfffeef4) at /Users/adigeo/work/blink/main.m:33
328 159 Adrian Georgescu
kill
329 159 Adrian Georgescu
}}}