summaryrefslogtreecommitdiffstats
path: root/openpgp-ffi/src/tsk.rs
diff options
context:
space:
mode:
authorJustus Winter <justus@sequoia-pgp.org>2019-01-29 12:07:48 +0100
committerJustus Winter <justus@sequoia-pgp.org>2019-01-29 17:41:26 +0100
commit88ec4ab63f280db148da83f78afca62d5eeabf76 (patch)
tree2d92f893402c90c93bd60a4ce8bc575b2a7863a6 /openpgp-ffi/src/tsk.rs
parentad0e87312c5e18945a15f5988433ee288c89cdd7 (diff)
openpgp-ffi: Fix TPK handling.
Diffstat (limited to 'openpgp-ffi/src/tsk.rs')
-rw-r--r--openpgp-ffi/src/tsk.rs15
1 files changed, 7 insertions, 8 deletions
diff --git a/openpgp-ffi/src/tsk.rs b/openpgp-ffi/src/tsk.rs
index 49a6e4a4..688a4760 100644
--- a/openpgp-ffi/src/tsk.rs
+++ b/openpgp-ffi/src/tsk.rs
@@ -10,13 +10,14 @@ use libc::c_char;
extern crate sequoia_openpgp;
use self::sequoia_openpgp::{
- TPK,
TSK,
packet::Signature,
serialize::Serialize,
};
+use super::tpk::TPK;
use ::error::Status;
+use MoveIntoRaw;
/// Generates a new RSA 3072 bit key with UID `primary_uid`.
#[::ffi_catch_abort] #[no_mangle]
@@ -47,19 +48,17 @@ pub extern "system" fn pgp_tsk_free(tsk: Option<&mut TSK>) {
}
/// Returns a reference to the corresponding TPK.
-#[::ffi_catch_abort] #[no_mangle]
-pub extern "system" fn pgp_tsk_tpk(tsk: *const TSK)
- -> *const TPK {
- let tsk = ffi_param_ref!(tsk);
- tsk.tpk()
+#[::ffi_catch_abort] #[no_mangle] pub extern "system"
+fn pgp_tsk_tpk(tsk: *const TSK)
+ -> *const TPK {
+ ffi_param_ref!(tsk).tpk().move_into_raw()
}
/// Converts the TSK into a TPK.
#[::ffi_catch_abort] #[no_mangle]
pub extern "system" fn pgp_tsk_into_tpk(tsk: *mut TSK)
-> *mut TPK {
- let tsk = ffi_param_move!(tsk);
- box_raw!(tsk.into_tpk())
+ ffi_param_move!(tsk).into_tpk().move_into_raw()
}