summaryrefslogtreecommitdiff
path: root/sql/rpl_queue.h
diff options
context:
space:
mode:
authorsachin <sachin.setiya@mariadb.com>2021-03-11 21:59:13 +0000
committersachin <sachin.setiya@mariadb.com>2021-03-11 21:59:13 +0000
commit3ad829d31aeb56cd76331d3478a1d8e04ed7300a (patch)
treee855752cc9ed8b90b67b89b51336ac26ed977f7a /sql/rpl_queue.h
parent4b4a020d1ce15275689fc307b8d13c107e6a41be (diff)
downloadmariadb-git-queue-v1.tar.gz
commit 5queue-v1
Diffstat (limited to 'sql/rpl_queue.h')
-rw-r--r--sql/rpl_queue.h16
1 files changed, 14 insertions, 2 deletions
diff --git a/sql/rpl_queue.h b/sql/rpl_queue.h
index 288b74120b5..6e6887f6a0b 100644
--- a/sql/rpl_queue.h
+++ b/sql/rpl_queue.h
@@ -274,8 +274,11 @@ class circular_buffer_queue_events :public circular_buffer_queue<slave_queue_ele
//enqueue_1 will take care of it.
head+= size;
}
-
- void* dequeue_1(uint32 size)
+
+ //Dequeue by size ,
+ //So the the size of element which needs to be dequeued will be
+ //given in argument
+ void* dequeue_by_size(uint32 size)
{
if (used_buffer() > 0 )
{
@@ -300,6 +303,15 @@ class circular_buffer_queue_events :public circular_buffer_queue<slave_queue_ele
return NULL;
}
+ // This will simple update the tail ptr
+ void dequeue_by_tail_ptr(void *ptr)
+ {
+ DBUG_ASSERT(free_size() > 0);
+ lock_mutex();
+ tail= (uchar *)ptr;
+ unlock_mutex();
+ }
+
};
typedef circular_buffer_queue_events r_queue;