diff options
author | Justus Winter <justus@sequoia-pgp.org> | 2019-01-29 12:07:48 +0100 |
---|---|---|
committer | Justus Winter <justus@sequoia-pgp.org> | 2019-01-29 17:41:26 +0100 |
commit | 88ec4ab63f280db148da83f78afca62d5eeabf76 (patch) | |
tree | 2d92f893402c90c93bd60a4ce8bc575b2a7863a6 /openpgp-ffi/src/tsk.rs | |
parent | ad0e87312c5e18945a15f5988433ee288c89cdd7 (diff) |
openpgp-ffi: Fix TPK handling.
Diffstat (limited to 'openpgp-ffi/src/tsk.rs')
-rw-r--r-- | openpgp-ffi/src/tsk.rs | 15 |
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() } |