-
Notifications
You must be signed in to change notification settings - Fork 4k
/
Copy pathrwlock_scoped_lock.cc
75 lines (62 loc) · 2.54 KB
/
rwlock_scoped_lock.cc
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
/* Copyright (c) 2016, 2024, Oracle and/or its affiliates.
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License, version 2.0,
as published by the Free Software Foundation.
This program is designed to work with certain software (including
but not limited to OpenSSL) that is licensed under separate terms,
as designated in a particular file or component or in included license
documentation. The authors of MySQL hereby grant you an additional
permission to link the program and your derivative works with the
separately licensed software that they have either included with
the program or referenced in the documentation.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License, version 2.0, for more details.
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */
#include "rwlock_scoped_lock.h"
#include <stddef.h>
#include "my_compiler.h"
#include "mysql/psi/mysql_rwlock.h"
struct mysql_rwlock_t;
/**
Acquires lock on specified lock object.
The lock may be NULL, in which case this is a no-op.
@param lock Lock object to lock.
@param lock_for_write Specifies if to lock for write or read.
@param file File in which lock acquisition is to be presented.
@param line Line of file in which lock acquisition is to be presented.
*/
rwlock_scoped_lock::rwlock_scoped_lock(mysql_rwlock_t *lock,
bool lock_for_write,
const char *file [[maybe_unused]],
int line [[maybe_unused]]) {
if (lock_for_write) {
if (!mysql_rwlock_wrlock_with_src(lock, file, line)) {
m_lock = lock;
} else
m_lock = nullptr;
} else {
if (!mysql_rwlock_rdlock_with_src(lock, file, line)) {
m_lock = lock;
} else
m_lock = nullptr;
}
}
/**
Moves lock from another object.
@param lock Scoped lock object to move from.
*/
rwlock_scoped_lock::rwlock_scoped_lock(rwlock_scoped_lock &&lock)
: m_lock(lock.m_lock) {
lock.m_lock = nullptr;
}
rwlock_scoped_lock::~rwlock_scoped_lock() {
/* If lock is NULL, then lock was set to remain locked when going out of
scope or was moved to other object. */
if (m_lock != nullptr) {
mysql_rwlock_unlock(m_lock);
}
}