libobs/util: Make minor optimization to circlebuf pops
If size is 0 after popping data from the front or back, set the start/end points to 0 as well to ensure that any subsequent buffer pushes start from the beginning of the buffer rather than the middle of the buffer. Reduces potential unnecessary operations in that case. Additionally, this fixes a bug with circulebuf_pop_back where if start position was 0, and all the data was popped off the buffer (equal to the capacity), the end position would be equal to the original size. As an example to replicate the bug, push 5, pop 5, then push 10. The start/end points will be invalid. Closes jp9000/obs-studio#954
This commit is contained in:
parent
27bb2f836d
commit
8770453c09
@ -237,6 +237,11 @@ static inline void circlebuf_pop_front(struct circlebuf *cb, void *data,
|
|||||||
circlebuf_peek_front(cb, data, size);
|
circlebuf_peek_front(cb, data, size);
|
||||||
|
|
||||||
cb->size -= size;
|
cb->size -= size;
|
||||||
|
if (!cb->size) {
|
||||||
|
cb->start_pos = cb->end_pos = 0;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
cb->start_pos += size;
|
cb->start_pos += size;
|
||||||
if (cb->start_pos >= cb->capacity)
|
if (cb->start_pos >= cb->capacity)
|
||||||
cb->start_pos -= cb->capacity;
|
cb->start_pos -= cb->capacity;
|
||||||
@ -248,6 +253,11 @@ static inline void circlebuf_pop_back(struct circlebuf *cb, void *data,
|
|||||||
circlebuf_peek_front(cb, data, size);
|
circlebuf_peek_front(cb, data, size);
|
||||||
|
|
||||||
cb->size -= size;
|
cb->size -= size;
|
||||||
|
if (!cb->size) {
|
||||||
|
cb->start_pos = cb->end_pos = 0;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (cb->end_pos <= size)
|
if (cb->end_pos <= size)
|
||||||
cb->end_pos = cb->capacity - (size - cb->end_pos);
|
cb->end_pos = cb->capacity - (size - cb->end_pos);
|
||||||
else
|
else
|
||||||
|
Loading…
x
Reference in New Issue
Block a user