From 5902821605d8ad7e8af3eb076c0c345f2cba8d57 Mon Sep 17 00:00:00 2001 From: "mergify[bot]" <37929162+mergify[bot]@users.noreply.github.com> Date: Tue, 2 Jul 2024 16:18:26 -0600 Subject: [PATCH] v2.0: Remove deprecated symbols from solana-sdk (backport of #1953) (#1962) Remove deprecated symbols from solana-sdk (#1953) * Remove deprecated Account methods * Remove deprecated info macro * Remove deprecated Signature method * Remove deprecated native_loader method * Remove deprecated transaction method (deprecated in v1.9) * Remove deprecated entrypoint definitions * Remove deprecated program_stubs macro (cherry picked from commit e2643f3dc765a6f27a452bd37e76665a19ed7246) Co-authored-by: Tyera --- sdk/src/account.rs | 20 ---------------- sdk/src/entrypoint.rs | 27 ---------------------- sdk/src/entrypoint_deprecated.rs | 20 ---------------- sdk/src/lib.rs | 10 -------- sdk/src/log.rs | 11 --------- sdk/src/native_loader.rs | 15 ++---------- sdk/src/signature.rs | 8 ------- sdk/src/transaction/mod.rs | 39 -------------------------------- 8 files changed, 2 insertions(+), 148 deletions(-) diff --git a/sdk/src/account.rs b/sdk/src/account.rs index c0f3d783c14038..0541e1f8d9ce44 100644 --- a/sdk/src/account.rs +++ b/sdk/src/account.rs @@ -675,15 +675,6 @@ impl AccountSharedData { pub type InheritableAccountFields = (u64, Epoch); pub const DUMMY_INHERITABLE_ACCOUNT_FIELDS: InheritableAccountFields = (1, INITIAL_RENT_EPOCH); -/// Create an `Account` from a `Sysvar`. -#[deprecated( - since = "1.5.17", - note = "Please use `create_account_for_test` instead" -)] -pub fn create_account(sysvar: &S, lamports: u64) -> Account { - create_account_with_fields(sysvar, (lamports, INITIAL_RENT_EPOCH)) -} - pub fn create_account_with_fields( sysvar: &S, (lamports, rent_epoch): InheritableAccountFields, @@ -700,17 +691,6 @@ pub fn create_account_for_test(sysvar: &S) -> Account { } /// Create an `Account` from a `Sysvar`. -#[deprecated( - since = "1.5.17", - note = "Please use `create_account_shared_data_for_test` instead" -)] -pub fn create_account_shared_data(sysvar: &S, lamports: u64) -> AccountSharedData { - AccountSharedData::from(create_account_with_fields( - sysvar, - (lamports, INITIAL_RENT_EPOCH), - )) -} - pub fn create_account_shared_data_with_fields( sysvar: &S, fields: InheritableAccountFields, diff --git a/sdk/src/entrypoint.rs b/sdk/src/entrypoint.rs index e83bdf0575b1f0..38c85e00af958a 100644 --- a/sdk/src/entrypoint.rs +++ b/sdk/src/entrypoint.rs @@ -5,30 +5,3 @@ //! [`bpf_loader`]: crate::bpf_loader pub use solana_program::entrypoint::*; - -#[macro_export] -#[deprecated( - since = "1.4.3", - note = "use solana_program::entrypoint::entrypoint instead" -)] -macro_rules! entrypoint { - ($process_instruction:ident) => { - #[cfg(all(not(feature = "custom-heap"), not(test)))] - #[global_allocator] - static A: $crate::entrypoint::BumpAllocator = $crate::entrypoint::BumpAllocator { - start: $crate::entrypoint::HEAP_START_ADDRESS, - len: $crate::entrypoint::HEAP_LENGTH, - }; - - /// # Safety - #[no_mangle] - pub unsafe extern "C" fn entrypoint(input: *mut u8) -> u64 { - let (program_id, accounts, instruction_data) = - unsafe { $crate::entrypoint::deserialize(input) }; - match $process_instruction(&program_id, &accounts, &instruction_data) { - Ok(()) => $crate::entrypoint::SUCCESS, - Err(error) => error.into(), - } - } - }; -} diff --git a/sdk/src/entrypoint_deprecated.rs b/sdk/src/entrypoint_deprecated.rs index c75b9c47a57a49..443a9bc0893f12 100644 --- a/sdk/src/entrypoint_deprecated.rs +++ b/sdk/src/entrypoint_deprecated.rs @@ -8,23 +8,3 @@ //! [`bpf_loader_deprecated`]: crate::bpf_loader_deprecated pub use solana_program::entrypoint_deprecated::*; - -#[macro_export] -#[deprecated( - since = "1.4.3", - note = "use solana_program::entrypoint::entrypoint instead" -)] -macro_rules! entrypoint_deprecated { - ($process_instruction:ident) => { - /// # Safety - #[no_mangle] - pub unsafe extern "C" fn entrypoint(input: *mut u8) -> u64 { - let (program_id, accounts, instruction_data) = - unsafe { $crate::entrypoint_deprecated::deserialize(input) }; - match $process_instruction(&program_id, &accounts, &instruction_data) { - Ok(()) => $crate::entrypoint_deprecated::SUCCESS, - Err(error) => error.into(), - } - } - }; -} diff --git a/sdk/src/lib.rs b/sdk/src/lib.rs index 728f63e316b887..fa3eb64ef92289 100644 --- a/sdk/src/lib.rs +++ b/sdk/src/lib.rs @@ -157,16 +157,6 @@ pub use solana_sdk_macro::pubkeys; #[rustversion::since(1.46.0)] pub use solana_sdk_macro::respan; -// Unused `solana_sdk::program_stubs!()` macro retained for source backwards compatibility with older programs -#[macro_export] -#[deprecated( - since = "1.4.3", - note = "program_stubs macro is obsolete and can be safely removed" -)] -macro_rules! program_stubs { - () => {}; -} - /// Convenience macro for `AddAssign` with saturating arithmetic. /// Replace by `std::num::Saturating` once stable #[macro_export] diff --git a/sdk/src/log.rs b/sdk/src/log.rs index 78a45afaf4a1e8..748b241c02b77f 100644 --- a/sdk/src/log.rs +++ b/sdk/src/log.rs @@ -1,14 +1,3 @@ #![cfg(feature = "program")] pub use solana_program::log::*; - -#[macro_export] -#[deprecated( - since = "1.4.3", - note = "Please use `solana_program::log::info` instead" -)] -macro_rules! info { - ($msg:expr) => { - $crate::log::sol_log($msg) - }; -} diff --git a/sdk/src/native_loader.rs b/sdk/src/native_loader.rs index 3f10fc527ad8a6..53a7ded4b61f54 100644 --- a/sdk/src/native_loader.rs +++ b/sdk/src/native_loader.rs @@ -1,23 +1,12 @@ //! The native loader native program. -use crate::{ - account::{ - Account, AccountSharedData, InheritableAccountFields, DUMMY_INHERITABLE_ACCOUNT_FIELDS, - }, - clock::INITIAL_RENT_EPOCH, +use crate::account::{ + Account, AccountSharedData, InheritableAccountFields, DUMMY_INHERITABLE_ACCOUNT_FIELDS, }; crate::declare_id!("NativeLoader1111111111111111111111111111111"); /// Create an executable account with the given shared object name. -#[deprecated( - since = "1.5.17", - note = "Please use `create_loadable_account_for_test` instead" -)] -pub fn create_loadable_account(name: &str, lamports: u64) -> AccountSharedData { - create_loadable_account_with_fields(name, (lamports, INITIAL_RENT_EPOCH)) -} - pub fn create_loadable_account_with_fields( name: &str, (lamports, rent_epoch): InheritableAccountFields, diff --git a/sdk/src/signature.rs b/sdk/src/signature.rs index 158fa5ceeaf136..3509e96522a657 100644 --- a/sdk/src/signature.rs +++ b/sdk/src/signature.rs @@ -28,14 +28,6 @@ pub struct Signature(GenericArray); impl crate::sanitize::Sanitize for Signature {} impl Signature { - #[deprecated( - since = "1.16.4", - note = "Please use 'Signature::from' or 'Signature::try_from' instead" - )] - pub fn new(signature_slice: &[u8]) -> Self { - Self(GenericArray::clone_from_slice(signature_slice)) - } - pub fn new_unique() -> Self { Self::from(std::array::from_fn(|_| rand::random())) } diff --git a/sdk/src/transaction/mod.rs b/sdk/src/transaction/mod.rs index 47e4ae95cbfdb5..d0eb01a3af96e0 100644 --- a/sdk/src/transaction/mod.rs +++ b/sdk/src/transaction/mod.rs @@ -1125,17 +1125,6 @@ pub fn uses_durable_nonce(tx: &Transaction) -> Option<&CompiledInstruction> { }) } -#[deprecated] -pub fn get_nonce_pubkey_from_instruction<'a>( - ix: &CompiledInstruction, - tx: &'a Transaction, -) -> Option<&'a Pubkey> { - ix.accounts.first().and_then(|idx| { - let idx = *idx as usize; - tx.message().account_keys.get(idx) - }) -} - #[cfg(test)] mod tests { #![allow(deprecated)] @@ -1630,34 +1619,6 @@ mod tests { assert!(uses_durable_nonce(&tx).is_none()); } - #[test] - fn get_nonce_pub_from_ix_ok() { - let (_, nonce_pubkey, tx) = nonced_transfer_tx(); - let nonce_ix = uses_durable_nonce(&tx).unwrap(); - assert_eq!( - get_nonce_pubkey_from_instruction(nonce_ix, &tx), - Some(&nonce_pubkey), - ); - } - - #[test] - fn get_nonce_pub_from_ix_no_accounts_fail() { - let (_, _, tx) = nonced_transfer_tx(); - let nonce_ix = uses_durable_nonce(&tx).unwrap(); - let mut nonce_ix = nonce_ix.clone(); - nonce_ix.accounts.clear(); - assert_eq!(get_nonce_pubkey_from_instruction(&nonce_ix, &tx), None,); - } - - #[test] - fn get_nonce_pub_from_ix_bad_acc_idx_fail() { - let (_, _, tx) = nonced_transfer_tx(); - let nonce_ix = uses_durable_nonce(&tx).unwrap(); - let mut nonce_ix = nonce_ix.clone(); - nonce_ix.accounts[0] = 255u8; - assert_eq!(get_nonce_pubkey_from_instruction(&nonce_ix, &tx), None,); - } - #[test] fn tx_keypair_pubkey_mismatch() { let from_keypair = Keypair::new();