diff options
author | David Robillard <d@drobilla.net> | 2011-09-15 04:53:18 +0000 |
---|---|---|
committer | David Robillard <d@drobilla.net> | 2011-09-15 04:53:18 +0000 |
commit | d4cf461177a0e0309cefc3d02910c51477a3c105 (patch) | |
tree | ec3a680629342d161d8425c58650d0c71c2e31c3 /src | |
parent | 728f510e8c542db2907dcd439a9ab99d07282220 (diff) | |
download | ingen-d4cf461177a0e0309cefc3d02910c51477a3c105.tar.gz ingen-d4cf461177a0e0309cefc3d02910c51477a3c105.tar.bz2 ingen-d4cf461177a0e0309cefc3d02910c51477a3c105.zip |
Fix crash on client event post-processing (e.g. when rapidly manipulating controls).
git-svn-id: http://svn.drobilla.net/lad/trunk/ingen@3462 a436a847-0d15-0410-975c-d299462d15a1
Diffstat (limited to 'src')
-rw-r--r-- | src/server/EventSource.cpp | 6 | ||||
-rw-r--r-- | src/server/PostProcessor.cpp | 32 |
2 files changed, 20 insertions, 18 deletions
diff --git a/src/server/EventSource.cpp b/src/server/EventSource.cpp index cdecfd4a..ef982664 100644 --- a/src/server/EventSource.cpp +++ b/src/server/EventSource.cpp @@ -98,9 +98,11 @@ EventSource::process(PostProcessor& dest, ProcessContext& context, bool limit) } if (num_events_processed > 0) { + QueuedEvent* next = (QueuedEvent*)last->next(); + last->next(NULL); dest.append(_head.get(), last); - _head = (QueuedEvent*)last->next(); - if (!last->next()) + _head = next; + if (!next) _tail = NULL; } } diff --git a/src/server/PostProcessor.cpp b/src/server/PostProcessor.cpp index 7c756812..2dd9666b 100644 --- a/src/server/PostProcessor.cpp +++ b/src/server/PostProcessor.cpp @@ -47,14 +47,14 @@ PostProcessor::append(QueuedEvent* first, QueuedEvent* last) { assert(first); assert(last); - QueuedEvent* const head = _head.get(); - QueuedEvent* const tail = _tail.get(); - if (!head) { - _head = first; + assert(!last->next()); + if (_head.get()) { + _tail.get()->next(first); + _tail = last; } else { - tail->next(first); + _tail = last; + _head = first; } - _tail = last; } void @@ -88,19 +88,19 @@ PostProcessor::process() /* Process normal events */ QueuedEvent* ev = _head.get(); - while (ev) { - if (ev->time() > end_time) - break; - + if (!ev) { + return; + } + + QueuedEvent* const tail = _tail.get(); + _head = (QueuedEvent*)tail->next(); + while (ev && ev->time() <= end_time) { QueuedEvent* const next = (QueuedEvent*)ev->next(); ev->post_process(); - if (next) { - _head = next; - } else { - _head = NULL; - _tail = NULL; - } delete ev; + if (ev == tail) { + break; + } ev = next; } } |