aboutsummaryrefslogtreecommitdiffstats
path: root/src/core/model/GpgKey.cpp
diff options
context:
space:
mode:
authorSaturneric <[email protected]>2022-12-04 07:44:29 +0000
committerSaturneric <[email protected]>2022-12-04 07:44:29 +0000
commitbf39cd6fb8a1716652b266c31778cfe865a5ba81 (patch)
treebd0c0aa64e8d6973c48d0da74d6a1f4017e31c55 /src/core/model/GpgKey.cpp
parentfix: solve a crash issue (diff)
downloadGpgFrontend-bf39cd6fb8a1716652b266c31778cfe865a5ba81.tar.gz
GpgFrontend-bf39cd6fb8a1716652b266c31778cfe865a5ba81.zip
fix: solve a refresh crash
Diffstat (limited to 'src/core/model/GpgKey.cpp')
-rw-r--r--src/core/model/GpgKey.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/core/model/GpgKey.cpp b/src/core/model/GpgKey.cpp
index ad88a649..4716d9cc 100644
--- a/src/core/model/GpgKey.cpp
+++ b/src/core/model/GpgKey.cpp
@@ -28,6 +28,8 @@
#include "core/model/GpgKey.h"
+#include <mutex>
+
GpgFrontend::GpgKey::GpgKey(gpgme_key_t &&key) : key_ref_(std::move(key)) {}
GpgFrontend::GpgKey::GpgKey(GpgKey &&k) noexcept { swap(key_ref_, k.key_ref_); }
@@ -225,7 +227,10 @@ bool GpgFrontend::GpgKey::IsHasActualEncryptionCapability() const {
}
GpgFrontend::GpgKey GpgFrontend::GpgKey::Copy() const {
- gpgme_key_ref(key_ref_.get());
+ {
+ const std::lock_guard<std::mutex> guard(gpgme_key_opera_mutex);
+ gpgme_key_ref(key_ref_.get());
+ }
auto *_new_key_ref = key_ref_.get();
return GpgKey(std::move(_new_key_ref));
}