From d6f4dff6337d29c52eafc13e06c4541c0c8ab249 Mon Sep 17 00:00:00 2001 From: Graydon Hoare Date: Fri, 1 Dec 2023 20:55:25 -0800 Subject: [PATCH] Bug #1178 - use Timepoint on get_ledger_timestamp --- soroban-env-common/env.json | 2 +- soroban-env-common/src/env.rs | 5 +++-- soroban-env-common/src/vmcaller_env.rs | 4 ++-- soroban-env-guest/src/guest.rs | 6 +++--- soroban-env-host/src/host.rs | 11 +++++++---- soroban-env-host/src/vm/dispatch.rs | 3 ++- 6 files changed, 18 insertions(+), 13 deletions(-) diff --git a/soroban-env-common/env.json b/soroban-env-common/env.json index df7d5c4f2..7d59e376c 100644 --- a/soroban-env-common/env.json +++ b/soroban-env-common/env.json @@ -78,7 +78,7 @@ "export": "4", "name": "get_ledger_timestamp", "args": [], - "return": "U64Val", + "return": "TimepointVal", "docs": "Return the timestamp number of the current ledger as a u64." }, { diff --git a/soroban-env-common/src/env.rs b/soroban-env-common/src/env.rs index e9fdac42d..fc5571c25 100644 --- a/soroban-env-common/src/env.rs +++ b/soroban-env-common/src/env.rs @@ -5,8 +5,8 @@ use crate::Object; use super::Symbol; use super::{ AddressObject, Bool, BytesObject, DurationObject, Error, I128Object, I256Object, I256Val, - I64Object, MapObject, StorageType, StringObject, SymbolObject, TimepointObject, U128Object, - U256Object, U256Val, U32Val, U64Object, U64Val, Val, VecObject, Void, + I64Object, MapObject, StorageType, StringObject, SymbolObject, TimepointObject, TimepointVal, + U128Object, U256Object, U256Val, U32Val, U64Object, U64Val, Val, VecObject, Void, }; use crate::xdr::{ScErrorCode, ScErrorType}; @@ -235,6 +235,7 @@ impl_checkedenvarg_for_val_or_wrapper!(BytesObject); impl_checkedenvarg_for_val_or_wrapper!(DurationObject); impl_checkedenvarg_for_val_or_wrapper!(TimepointObject); +impl_checkedenvarg_for_val_or_wrapper!(TimepointVal); impl_checkedenvarg_for_val_or_wrapper!(SymbolObject); impl_checkedenvarg_for_val_or_wrapper!(StringObject); diff --git a/soroban-env-common/src/vmcaller_env.rs b/soroban-env-common/src/vmcaller_env.rs index 767865d64..7b92f0ed2 100644 --- a/soroban-env-common/src/vmcaller_env.rs +++ b/soroban-env-common/src/vmcaller_env.rs @@ -3,8 +3,8 @@ use crate::xdr::{ScErrorCode, ScErrorType}; use super::{ AddressObject, Bool, BytesObject, DurationObject, Error, I128Object, I256Object, I256Val, - I64Object, MapObject, StorageType, StringObject, SymbolObject, TimepointObject, U128Object, - U256Object, U256Val, U32Val, U64Object, U64Val, Val, VecObject, Void, + I64Object, MapObject, StorageType, StringObject, SymbolObject, TimepointObject, TimepointVal, + U128Object, U256Object, U256Val, U32Val, U64Object, Val, VecObject, Void, }; use crate::call_macro_with_all_host_functions; use crate::{CheckedEnvArg, EnvBase, Symbol}; diff --git a/soroban-env-guest/src/guest.rs b/soroban-env-guest/src/guest.rs index 79a578837..eea1f44a7 100644 --- a/soroban-env-guest/src/guest.rs +++ b/soroban-env-guest/src/guest.rs @@ -4,8 +4,8 @@ use soroban_env_common::call_macro_with_all_host_functions; use super::{ AddressObject, Bool, BytesObject, DurationObject, Error, I128Object, I256Object, I256Val, - I64Object, MapObject, StorageType, StringObject, SymbolObject, TimepointObject, U128Object, - U256Object, U256Val, U32Val, U64Object, U64Val, Val, VecObject, Void, + I64Object, MapObject, StorageType, StringObject, SymbolObject, TimepointObject, TimepointVal, + U128Object, U256Object, U256Val, U32Val, U64Object, Val, VecObject, Void, }; use super::{Env, EnvBase, Symbol}; use static_assertions as sa; @@ -329,7 +329,7 @@ macro_rules! generate_extern_modules { #[allow(unused_imports)] use crate::{Val,Object,Symbol,Error,MapObject,VecObject,BytesObject}; #[allow(unused_imports)] - use crate::{I128Object, I256Object, I256Val, I64Object, I64Val, U128Object, U256Object, U256Val, U32Val, U64Object, U64Val, StorageType, TimepointObject, DurationObject}; + use crate::{I128Object, I256Object, I256Val, I64Object, I64Val, U128Object, U256Object, U256Val, U32Val, U64Object, U64Val, StorageType, TimepointObject, TimepointVal, DurationObject}; #[allow(unused_imports)] use crate::{Void,AddressObject,SymbolObject,StringObject,Bool}; #[link(wasm_import_module = $mod_str)] diff --git a/soroban-env-host/src/host.rs b/soroban-env-host/src/host.rs index 9d014321d..3002ce807 100644 --- a/soroban-env-host/src/host.rs +++ b/soroban-env-host/src/host.rs @@ -18,8 +18,8 @@ use crate::{ }, AddressObject, Bool, BytesObject, Compare, ConversionError, EnvBase, Error, I128Object, I256Object, MapObject, Object, StorageType, StringObject, Symbol, SymbolObject, SymbolSmall, - TryFromVal, U128Object, U256Object, U32Val, U64Val, Val, VecObject, Vm, VmCaller, VmCallerEnv, - Void, I256, U256, + TimepointVal, TryFromVal, U128Object, U256Object, U32Val, Val, VecObject, Vm, VmCaller, + VmCallerEnv, Void, I256, U256, }; mod comparison; @@ -1052,8 +1052,11 @@ impl VmCallerEnv for Host { self.with_ledger_info(|li| Ok(li.sequence_number.into())) } - fn get_ledger_timestamp(&self, _vmcaller: &mut VmCaller) -> Result { - self.with_ledger_info(|li| Ok(U64Val::try_from_val(self, &li.timestamp)?)) + fn get_ledger_timestamp( + &self, + _vmcaller: &mut VmCaller, + ) -> Result { + self.with_ledger_info(|li| Ok(TimepointVal::try_from_val(self, &li.timestamp)?)) } fn fail_with_error( diff --git a/soroban-env-host/src/vm/dispatch.rs b/soroban-env-host/src/vm/dispatch.rs index ea4f943fc..2d6f48d1c 100644 --- a/soroban-env-host/src/vm/dispatch.rs +++ b/soroban-env-host/src/vm/dispatch.rs @@ -6,7 +6,7 @@ use crate::{ use crate::{ AddressObject, Bool, BytesObject, DurationObject, Error, I128Object, I256Object, I256Val, I64Object, MapObject, StorageType, StringObject, Symbol, SymbolObject, TimepointObject, - U128Object, U256Object, U256Val, U32Val, U64Object, U64Val, Val, VecObject, Void, + TimepointVal, U128Object, U256Object, U256Val, U32Val, U64Object, U64Val, Val, VecObject, Void, }; use soroban_env_common::{call_macro_with_all_host_functions, WasmiMarshal}; use wasmi::{ @@ -61,6 +61,7 @@ impl_relative_object_conversion!(BytesObject); impl_relative_object_conversion!(DurationObject); impl_relative_object_conversion!(TimepointObject); +impl_relative_object_conversion!(TimepointVal); impl_relative_object_conversion!(SymbolObject); impl_relative_object_conversion!(StringObject);