Skip to content
This repository has been archived by the owner on Nov 15, 2023. It is now read-only.

Deprecate Currency; introduce holds and freezing into fungible traits #12951

Merged
merged 174 commits into from
Mar 18, 2023
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
174 commits
Select commit Hold shift + click to select a range
ccd2ebb
First reworking of fungibles API
gavofyork Dec 14, 2022
de93255
New API and docs
gavofyork Dec 16, 2022
31ba6f2
More fungible::* API improvements
gavofyork Dec 16, 2022
0c8a27c
New ref-counting logic for old API
gavofyork Dec 19, 2022
97f7460
Missing files
gavofyork Dec 19, 2022
5027cb1
Fixes
gavofyork Dec 19, 2022
b42a687
Use the new transfer logic
gavofyork Dec 20, 2022
77d4c8e
Use fungibles for the dispatchables
gavofyork Dec 20, 2022
4485cd6
Use shelve/restore names
gavofyork Dec 20, 2022
67d8a7d
Locking works with total balance.
gavofyork Dec 22, 2022
77152ab
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Dec 23, 2022
04a4c75
repotting and removal
gavofyork Dec 27, 2022
e84fbb5
Separate Holds from Reserves
gavofyork Jan 6, 2023
11306ed
Introduce freezes
gavofyork Jan 16, 2023
872bbcc
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Jan 17, 2023
3f33588
Missing files
gavofyork Jan 17, 2023
900fef3
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Jan 18, 2023
359d858
Tests for freezing
gavofyork Jan 18, 2023
428a41c
Fix hold+freeze combo
gavofyork Jan 19, 2023
f009268
More tests
gavofyork Jan 19, 2023
1d5a2d8
Fee-free dispatchable for upgrading accounts
gavofyork Jan 19, 2023
3807bb4
Benchmarks and a few fixes
gavofyork Jan 19, 2023
db5d596
Another test
gavofyork Jan 20, 2023
c609d74
Docs and refactor to avoid blanket impls
gavofyork Jan 20, 2023
3af6d09
Repot
gavofyork Jan 20, 2023
cd9343a
Fit out ItemOf fully
gavofyork Jan 20, 2023
5f5e6d1
Add events to Balanced traits
gavofyork Jan 20, 2023
176f92d
Introduced events into Hold traits
gavofyork Jan 20, 2023
1e0219a
Fix Assets pallet tests
gavofyork Jan 20, 2023
7cfd446
Assets benchmarks pass
gavofyork Jan 20, 2023
0f92a6b
Missing files and fixes
gavofyork Jan 21, 2023
4745cb8
Fixes
gavofyork Jan 21, 2023
4ee2a44
Fixes
gavofyork Jan 23, 2023
aa0eccf
Benchmarks fixes
gavofyork Jan 23, 2023
14beb70
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Jan 23, 2023
84049b1
Fix balance benchmarks
gavofyork Jan 23, 2023
857efce
Formatting
gavofyork Jan 23, 2023
bf24b91
Expose fungible sub modules
gavofyork Jan 23, 2023
0ab291c
Merge branch 'gav-hold-freeze' into gav-nis-hold
gavofyork Jan 23, 2023
72fce5f
Move NIS to fungible API
gavofyork Jan 23, 2023
b2cae2a
Fix broken impl and add test
gavofyork Jan 23, 2023
020d11a
Merge branch 'gav-hold-freeze' into gav-nis-hold
gavofyork Jan 23, 2023
4b28afb
Fix tests
gavofyork Jan 23, 2023
d4da1a1
API for `transfer_and_hold`
gavofyork Jan 23, 2023
49fd3fc
Merge branch 'gav-hold-freeze' into gav-nis-hold
gavofyork Jan 23, 2023
bee7038
Use composite APIs
gavofyork Jan 23, 2023
f438f86
Merge branch 'gav-nis-hold' into gav-hold-freeze
gavofyork Jan 23, 2023
947d2b3
Formatting
gavofyork Jan 23, 2023
b469b45
Upgraded event
gavofyork Jan 23, 2023
ecb1765
Fixes
gavofyork Jan 23, 2023
79cf354
Fixes
gavofyork Jan 23, 2023
4c28b9d
Fixes
gavofyork Jan 23, 2023
01caead
Fixes
gavofyork Jan 23, 2023
83f47cb
Repot tests and some fixed
gavofyork Jan 24, 2023
16bdba7
Fix some bits
gavofyork Jan 24, 2023
cad82e8
Fix dust tests
gavofyork Jan 24, 2023
7b0b55c
Rename `set_balance`
gavofyork Jan 26, 2023
30de46d
becomes
gavofyork Jan 26, 2023
81dedbd
Move dust handling to fungibles API
gavofyork Jan 27, 2023
e0c1dc5
Formatting
gavofyork Jan 27, 2023
63e1698
Merge branch 'master' into gav-hold-freeze
gavofyork Jan 27, 2023
b210e19
Fixes and more refactoring
gavofyork Jan 27, 2023
6289a64
Fixes
gavofyork Jan 27, 2023
732e102
Fixes
gavofyork Jan 27, 2023
607b36a
Fixes
gavofyork Jan 27, 2023
37b999a
Fixes
gavofyork Jan 27, 2023
be3b91a
Fixes
gavofyork Jan 27, 2023
cdbd9b1
Merge branch 'master' into gav-hold-freeze
gavofyork Jan 27, 2023
dec5e42
Fixes
gavofyork Jan 28, 2023
242a8a1
Merge branch 'gav-hold-freeze' of github.com:paritytech/substrate int…
gavofyork Jan 28, 2023
f8439c1
Fixes
gavofyork Jan 28, 2023
1beffe4
Fixes
gavofyork Jan 28, 2023
75d5924
Fixes
gavofyork Jan 28, 2023
804f776
Use reducible_balance for better correctness on fees
gavofyork Feb 7, 2023
a5b6971
Reducing hold to zero should remove entry.
gavofyork Feb 7, 2023
c982d1b
Add test
gavofyork Feb 7, 2023
696b859
Docs
gavofyork Feb 7, 2023
32ee5dc
Update frame/support/src/traits/tokens/fungibles/hold.rs
gavofyork Feb 7, 2023
576f8a1
Update frame/support/src/traits/tokens/fungibles/regular.rs
gavofyork Feb 7, 2023
4a124cb
Update frame/support/src/traits/tokens/fungible/hold.rs
gavofyork Feb 7, 2023
574cdec
Update frame/support/src/traits/tokens/fungible/regular.rs
gavofyork Feb 7, 2023
c0c320d
Docs
gavofyork Feb 7, 2023
07d8132
Merge branch 'gav-hold-freeze' of github.com:paritytech/substrate int…
gavofyork Feb 7, 2023
b632c9f
Docs
gavofyork Feb 7, 2023
436fea7
Docs
gavofyork Feb 7, 2023
49caee7
Merge branch 'master' into gav-hold-freeze
gavofyork Feb 7, 2023
91b7343
Fix NIS benchmarks
gavofyork Feb 9, 2023
53fbf7d
Doc comment
gavofyork Feb 9, 2023
c7459ae
Remove post_mutation
gavofyork Feb 9, 2023
864f46a
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Feb 23, 2023
7360c20
Fix some tests
gavofyork Feb 23, 2023
6dbdca4
Fix some grumbles
gavofyork Feb 23, 2023
543713b
Enumify bool args to fungible(s) functions
gavofyork Feb 23, 2023
78a6b18
Fix up assets and balances
gavofyork Feb 23, 2023
35760c0
Formatting
gavofyork Feb 23, 2023
0d1a458
Fix contracts
gavofyork Feb 23, 2023
1f292ae
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Feb 24, 2023
1415e77
Fix tests & benchmarks build
gavofyork Feb 24, 2023
dd6e45f
Typify minted boolean arg
gavofyork Feb 24, 2023
4d69fb8
Typify on_hold boolean arg; renames
gavofyork Feb 24, 2023
3e513e1
Fix numerous tests
gavofyork Feb 24, 2023
e14456e
Fix dependency issue
gavofyork Feb 24, 2023
0f1cd51
Privatize dangerous API mutate_account
gavofyork Feb 24, 2023
dd200cd
Fix contracts (@alext - please check this commit)
gavofyork Feb 24, 2023
5c1ea9d
Remove println
gavofyork Feb 24, 2023
354aa13
Fix tests for contracts
athei Feb 24, 2023
82ace53
Fix broken rename
gavofyork Feb 24, 2023
36ae88e
Merge branch 'gav-hold-freeze' of github.com:paritytech/substrate int…
gavofyork Feb 24, 2023
fcb69a8
Fix broken rename
gavofyork Feb 24, 2023
a3579af
Fix broken rename
gavofyork Feb 24, 2023
a40f3a8
Docs
gavofyork Feb 24, 2023
ba9ff68
Update frame/support/src/traits/tokens/fungible/hold.rs
gavofyork Mar 3, 2023
9d5e61f
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Mar 3, 2023
22595ef
remove from_ref_time
gavofyork Mar 3, 2023
f9ca2ae
Update frame/executive/src/lib.rs
gavofyork Mar 6, 2023
ef22af2
Update frame/executive/src/lib.rs
gavofyork Mar 6, 2023
d6f71e3
Reenable test
gavofyork Mar 6, 2023
7ab3d21
Merge branch 'gav-hold-freeze' of github.com:paritytech/substrate int…
gavofyork Mar 6, 2023
114d623
Update frame/support/src/traits/tokens/fungibles/hold.rs
gavofyork Mar 6, 2023
b1a20d8
Update frame/support/src/traits/tokens/fungible/hold.rs
gavofyork Mar 6, 2023
5c712bd
Update frame/support/src/traits/tokens/fungible/hold.rs
gavofyork Mar 6, 2023
1607004
Update frame/support/src/traits/tokens/fungible/hold.rs
gavofyork Mar 6, 2023
a50dde8
Update frame/support/src/traits/tokens/currency.rs
gavofyork Mar 6, 2023
c3cdb70
Update frame/lottery/src/tests.rs
gavofyork Mar 6, 2023
57a4140
Update frame/support/src/traits/tokens/fungible/mod.rs
gavofyork Mar 6, 2023
176b6a1
Update frame/support/src/traits/tokens/fungible/regular.rs
gavofyork Mar 6, 2023
bbcace9
Update frame/support/src/traits/tokens/fungibles/freeze.rs
gavofyork Mar 6, 2023
a84e900
Update frame/support/src/traits/tokens/fungible/regular.rs
gavofyork Mar 6, 2023
96644e5
Update frame/support/src/traits/tokens/fungibles/hold.rs
gavofyork Mar 6, 2023
58f0a32
Update frame/support/src/traits/tokens/fungibles/hold.rs
gavofyork Mar 6, 2023
73b49d3
Update frame/support/src/traits/tokens/fungibles/hold.rs
gavofyork Mar 6, 2023
4fd8bc2
Rename UnwantedRemoval to UnwantedAccountRemoval
gavofyork Mar 6, 2023
200e274
Merge branch 'gav-hold-freeze' of github.com:paritytech/substrate int…
gavofyork Mar 6, 2023
f88ed63
Docs
gavofyork Mar 6, 2023
aa681b2
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Mar 6, 2023
a1117e8
Formatting
gavofyork Mar 6, 2023
b5884b2
Update frame/balances/src/lib.rs
gavofyork Mar 13, 2023
d78b14a
Update primitives/runtime/src/lib.rs
gavofyork Mar 13, 2023
68f1acb
handle_raw_dust oes nothing
gavofyork Mar 13, 2023
d288318
Formatting
gavofyork Mar 14, 2023
fc5ff3d
Fixes
gavofyork Mar 14, 2023
cc1bd4f
Grumble
gavofyork Mar 14, 2023
516cc00
Fixes
gavofyork Mar 14, 2023
69fedb7
Add test
gavofyork Mar 14, 2023
4a8e549
Add test
gavofyork Mar 14, 2023
ebdc4b9
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Mar 14, 2023
c6fdad5
Tests for reducible_balance
gavofyork Mar 14, 2023
535c918
Fixes
gavofyork Mar 14, 2023
deae58f
Fix Salary
gavofyork Mar 14, 2023
0e2f5d9
Fixes
gavofyork Mar 14, 2023
d9c3c22
Disable broken test
gavofyork Mar 14, 2023
e8ff2b2
Disable nicely
gavofyork Mar 14, 2023
a2cdc2f
Fixes
gavofyork Mar 15, 2023
39fa2fc
Fixes
gavofyork Mar 15, 2023
07d9e48
Fixes
gavofyork Mar 15, 2023
9e56f0d
Rename some events
gavofyork Mar 15, 2023
b8a13c0
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Mar 15, 2023
68dbc16
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Mar 16, 2023
2e30a2a
Fix nomination pools breakage
gavofyork Mar 16, 2023
f546870
Add compatibility stub for transfer tx
gavofyork Mar 16, 2023
5686ca4
Reinstate a safely compatible version of Balances set_balance
gavofyork Mar 16, 2023
590b780
Fixes
gavofyork Mar 16, 2023
181bcd5
Grumble
gavofyork Mar 16, 2023
880fac6
Update frame/nis/src/lib.rs
gavofyork Mar 16, 2023
58dca36
Merge branch 'master' of https://github.com/paritytech/substrate into…
Mar 17, 2023
1d47200
".git/.scripts/commands/bench/bench.sh" pallet dev pallet_balances
Mar 17, 2023
d025e95
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Mar 17, 2023
be47675
disable flakey tests
gavofyork Mar 17, 2023
3f1a752
Update frame/balances/src/lib.rs
gavofyork Mar 17, 2023
66e7acc
Grumbles
gavofyork Mar 17, 2023
a730846
Merge branch 'gav-hold-freeze' of github.com:paritytech/substrate int…
gavofyork Mar 17, 2023
938db17
Grumble
gavofyork Mar 17, 2023
a76f91c
Merge branch 'master' into gav-hold-freeze
gavofyork Mar 17, 2023
d59d300
Merge remote-tracking branch 'origin/master' into gav-hold-freeze
gavofyork Mar 18, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
Enumify bool args to fungible(s) functions
  • Loading branch information
gavofyork committed Feb 23, 2023
commit 543713bc448705a26dfc7802f91ed7f12c4e7938
8 changes: 4 additions & 4 deletions frame/assets/src/impl_fungibles.rs
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ impl<T: Config<I>, I: 'static> fungibles::Inspect<<T as SystemConfig>::AccountId
asset: Self::AssetId,
who: &<T as SystemConfig>::AccountId,
keep_alive: KeepAlive,
_force: bool,
_force: Privilege,
) -> Self::Balance {
Pallet::<T, I>::reducible_balance(asset, who, keep_alive.into()).unwrap_or(Zero::zero())
}
Expand Down Expand Up @@ -102,9 +102,9 @@ impl<T: Config<I>, I: 'static> fungibles::Unbalanced<T::AccountId> for Pallet<T,
asset: T::AssetId,
who: &T::AccountId,
amount: Self::Balance,
best_effort: bool,
best_effort: Precision,
keep_alive: KeepAlive,
_force: bool,
_force: Privilege,
) -> Result<Self::Balance, DispatchError> {
let keep_alive = match keep_alive {
KeepAlive::CanKill => false,
Expand All @@ -117,7 +117,7 @@ impl<T: Config<I>, I: 'static> fungibles::Unbalanced<T::AccountId> for Pallet<T,
asset: T::AssetId,
who: &T::AccountId,
amount: Self::Balance,
_best_effort: bool,
_best_effort: Precision,
) -> Result<Self::Balance, DispatchError> {
Self::increase_balance(asset, who, amount, |_| Ok(()))?;
Ok(amount)
Expand Down
4 changes: 2 additions & 2 deletions frame/balances/src/impl_fungible.rs
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ impl<T: Config<I>, I: 'static> fungible::Inspect<T::AccountId> for Pallet<T, I>
fn balance(who: &T::AccountId) -> Self::Balance {
Self::account(who).free
}
fn reducible_balance(who: &T::AccountId, keep_alive: KeepAlive, force: bool) -> Self::Balance {
fn reducible_balance(who: &T::AccountId, keep_alive: KeepAlive, force: Privilege) -> Self::Balance {
let a = Self::account(who);
let mut untouchable = Zero::zero();
if !force {
Expand Down Expand Up @@ -200,7 +200,7 @@ impl<T: Config<I>, I: 'static> fungible::InspectHold<T::AccountId> for Pallet<T,
fn total_balance_on_hold(who: &T::AccountId) -> T::Balance {
Self::account(who).reserved
}
fn reducible_total_balance_on_hold(who: &T::AccountId, force: bool) -> Self::Balance {
fn reducible_total_balance_on_hold(who: &T::AccountId, force: Privilege) -> Self::Balance {
// The total balance must never drop below the freeze requirements if we're not forcing:
let a = Self::account(who);
let unavailable = if force {
Expand Down
2 changes: 1 addition & 1 deletion frame/support/src/traits/tokens.rs
Original file line number Diff line number Diff line change
Expand Up @@ -29,5 +29,5 @@ pub mod nonfungibles_v2;
pub use imbalance::Imbalance;
pub use misc::{
AssetId, AttributeNamespace, Balance, BalanceConversion, BalanceStatus, DepositConsequence,
ExistenceRequirement, KeepAlive, Locker, WithdrawConsequence, WithdrawReasons,
ExistenceRequirement, KeepAlive, Locker, WithdrawConsequence, WithdrawReasons, Privilege, Precision,
};
80 changes: 40 additions & 40 deletions frame/support/src/traits/tokens/fungible/hold.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@

use crate::{
ensure,
traits::tokens::{DepositConsequence::Success, KeepAlive},
traits::tokens::{DepositConsequence::Success, KeepAlive, Privilege::{self, Force}, Precision::{self, Exact, BestEffort}},
};
use scale_info::TypeInfo;
use sp_arithmetic::{
Expand All @@ -46,7 +46,7 @@ pub trait Inspect<AccountId>: super::Inspect<AccountId> {
/// an inconsistent state with regards any required existential deposit.
///
/// Always less than `total_balance_on_hold()`.
fn reducible_total_balance_on_hold(who: &AccountId, force: bool) -> Self::Balance;
fn reducible_total_balance_on_hold(who: &AccountId, force: Privilege) -> Self::Balance;

/// Amount of funds on hold (for the given reason) of `who`.
fn balance_on_hold(reason: &Self::Reason, who: &AccountId) -> Self::Balance;
Expand Down Expand Up @@ -83,7 +83,7 @@ pub trait Inspect<AccountId>: super::Inspect<AccountId> {
) -> DispatchResult {
ensure!(Self::hold_available(reason, who), TokenError::CannotCreateHold);
ensure!(
amount <= Self::reducible_balance(who, KeepAlive::NoKill, true),
amount <= Self::reducible_balance(who, KeepAlive::NoKill, Force),
TokenError::FundsUnavailable
);
Ok(())
Expand Down Expand Up @@ -137,19 +137,19 @@ pub trait Unbalanced<AccountId>: Inspect<AccountId> {

/// Reduce the balance on hold of `who` by `amount`.
///
/// If `best_effort` is `false` and it cannot be reduced by that amount for
/// some reason, return `Err` and don't reduce it at all. If `best_effort` is `true`, then
/// If `precision` is `Exact` and it cannot be reduced by that amount for
/// some reason, return `Err` and don't reduce it at all. If `precision` is `BestEffort`, then
/// reduce the balance of `who` by the most that is possible, up to `amount`.
///
/// In either case, if `Ok` is returned then the inner is the amount by which is was reduced.
fn decrease_balance_on_hold(
reason: &Self::Reason,
who: &AccountId,
mut amount: Self::Balance,
best_effort: bool,
precision: Precision,
) -> Result<Self::Balance, DispatchError> {
let old_balance = Self::balance_on_hold(reason, who);
if best_effort {
if let BestEffort = precision {
amount = amount.min(old_balance);
}
let new_balance = old_balance.checked_sub(&amount).ok_or(TokenError::FundsUnavailable)?;
Expand All @@ -165,10 +165,10 @@ pub trait Unbalanced<AccountId>: Inspect<AccountId> {
reason: &Self::Reason,
who: &AccountId,
amount: Self::Balance,
best_effort: bool,
precision: Precision,
) -> Result<Self::Balance, DispatchError> {
let old_balance = Self::balance_on_hold(reason, who);
let new_balance = if best_effort {
let new_balance = if let BestEffort = precision {
old_balance.saturating_add(amount)
} else {
old_balance.checked_add(&amount).ok_or(ArithmeticError::Overflow)?
Expand All @@ -193,8 +193,8 @@ pub trait Mutate<AccountId>:

Self::ensure_can_hold(reason, who, amount)?;
// Should be infallible now, but we proceed softly anyway.
Self::decrease_balance(who, amount, false, KeepAlive::NoKill, true)?;
Self::increase_balance_on_hold(reason, who, amount, true)?;
Self::decrease_balance(who, amount, Exact, KeepAlive::NoKill, Force)?;
Self::increase_balance_on_hold(reason, who, amount, BestEffort)?;
Self::done_hold(reason, who, amount);
Ok(())
}
Expand All @@ -203,7 +203,7 @@ pub trait Mutate<AccountId>:
///
/// The actual amount released is returned with `Ok`.
///
/// If `best_effort` is `true`, then the amount actually unreserved and returned as the inner
/// If `precision` is `BestEffort`, then the amount actually unreserved and returned as the inner
/// value of `Ok` may be smaller than the `amount` passed.
///
/// NOTE! The inner of the `Ok` result variant returns the *actual* amount released. This is the
Expand All @@ -213,7 +213,7 @@ pub trait Mutate<AccountId>:
reason: &Self::Reason,
who: &AccountId,
amount: Self::Balance,
best_effort: bool,
precision: Precision,
) -> Result<Self::Balance, DispatchError> {
// NOTE: This doesn't change the total balance of the account so there's no need to
// check liquidity.
Expand All @@ -223,38 +223,38 @@ pub trait Mutate<AccountId>:
ensure!(Self::can_deposit(who, amount, false) == Success, TokenError::CannotCreate);
// Get the amount we can actually take from the hold. This might be less than what we want
// if we're only doing a best-effort.
let amount = Self::decrease_balance_on_hold(reason, who, amount, best_effort)?;
let amount = Self::decrease_balance_on_hold(reason, who, amount, precision)?;
// Increase the main balance by what we took. We always do a best-effort here because we
// already checked that we can deposit before.
let actual = Self::increase_balance(who, amount, true)?;
let actual = Self::increase_balance(who, amount, BestEffort)?;
Self::done_release(reason, who, actual);
Ok(actual)
}

/// Attempt to decrease the balance of `who` which is held for the given `reason` by `amount`.
///
/// If `best_effort` is true, then as much as possible is reduced, up to `amount`, and the
/// If `precision` is `BestEffort`, then as much as possible is reduced, up to `amount`, and the
/// amount of tokens reduced is returned. Otherwise, if the total amount can be reduced, then it
/// is and the amount returned, and if not, then nothing changes and `Err` is returned.
///
/// If `force` is true, then locks/freezes will be ignored. This should only be used when
/// If `force` is `Force`, then locks/freezes will be ignored. This should only be used when
/// conducting slashing or other activity which materially disadvantages the account holder
/// since it could provide a means of circumventing freezes.
fn burn_held(
reason: &Self::Reason,
who: &AccountId,
mut amount: Self::Balance,
best_effort: bool,
force: bool,
precision: Precision,
force: Privilege,
) -> Result<Self::Balance, DispatchError> {
// We must check total-balance requirements if `!force`.
let liquid = Self::reducible_total_balance_on_hold(who, force);
if best_effort {
if let BestEffort = precision {
amount = amount.min(liquid);
} else {
ensure!(amount <= liquid, TokenError::Frozen);
}
let amount = Self::decrease_balance_on_hold(reason, who, amount, best_effort)?;
let amount = Self::decrease_balance_on_hold(reason, who, amount, precision)?;
Self::set_total_issuance(Self::total_issuance().saturating_sub(amount));
Self::done_burn_held(reason, who, amount);
Ok(amount)
Expand All @@ -266,12 +266,12 @@ pub trait Mutate<AccountId>:
/// transferred will still be on hold in the destination account. If not, then the destination
/// account need not already exist, but must be creatable.
///
/// If `best_effort` is `true`, then an amount less than `amount` may be transferred without
/// If `precision` is `BestEffort`, then an amount less than `amount` may be transferred without
/// error.
///
/// If `force` is `true`, then other fund-locking mechanisms may be disregarded. It should be
/// left as `false` in most circumstances, but when you want the same power as a `slash`, it
/// may be `true`.
/// If `force` is `Force`, then other fund-locking mechanisms may be disregarded. It should be
/// left as `Regular` in most circumstances, but when you want the same power as a `slash`, it
/// may be `Force`.
gavofyork marked this conversation as resolved.
Show resolved Hide resolved
///
/// The actual amount transferred is returned, or `Err` in the case of error and nothing is
/// changed.
Expand All @@ -280,14 +280,14 @@ pub trait Mutate<AccountId>:
source: &AccountId,
dest: &AccountId,
mut amount: Self::Balance,
best_effort: bool,
precision: Precision,
on_hold: bool,
force: bool,
force: Privilege,
) -> Result<Self::Balance, DispatchError> {
// We must check total-balance requirements if `!force`.
gavofyork marked this conversation as resolved.
Show resolved Hide resolved
let have = Self::balance_on_hold(reason, source);
let liquid = Self::reducible_total_balance_on_hold(source, force);
if best_effort {
if let BestEffort = precision {
amount = amount.min(liquid).min(have);
} else {
ensure!(amount <= liquid, TokenError::Frozen);
Expand All @@ -299,11 +299,11 @@ pub trait Mutate<AccountId>:
ensure!(Self::can_deposit(dest, amount, false) == Success, TokenError::CannotCreate);
ensure!(!on_hold || Self::hold_available(reason, dest), TokenError::CannotCreateHold);

let amount = Self::decrease_balance_on_hold(reason, source, amount, best_effort)?;
let amount = Self::decrease_balance_on_hold(reason, source, amount, precision)?;
let actual = if on_hold {
Self::increase_balance_on_hold(reason, dest, amount, best_effort)?
Self::increase_balance_on_hold(reason, dest, amount, precision)?
} else {
Self::increase_balance(dest, amount, best_effort)?
Self::increase_balance(dest, amount, precision)?
};
Self::done_transfer_on_hold(reason, source, dest, actual);
Ok(actual)
Expand All @@ -312,14 +312,14 @@ pub trait Mutate<AccountId>:
/// Transfer some `amount` of free balance from `source` to become owned by `dest` but on hold
/// for `reason`.
///
/// If `best_effort` is `true`, then an amount less than `amount` may be transferred without
/// If `precision` is `BestEffort`, then an amount less than `amount` may be transferred without
/// error.
///
/// `source` must obey the requirements of `keep_alive`.
///
/// If `force` is `true`, then other fund-locking mechanisms may be disregarded. It should be
/// left as `false` in most circumstances, but when you want the same power as a `slash`, it
/// may be `true`.
/// If `force` is `Force`, then other fund-locking mechanisms may be disregarded. It should be
/// left as `Regular` in most circumstances, but when you want the same power as a `slash`, it
gavofyork marked this conversation as resolved.
Show resolved Hide resolved
/// may be `Force`.
///
/// The amount placed on hold is returned or `Err` in the case of error and nothing is changed.
///
Expand All @@ -330,14 +330,14 @@ pub trait Mutate<AccountId>:
source: &AccountId,
dest: &AccountId,
amount: Self::Balance,
best_effort: bool,
precision: Precision,
keep_alive: KeepAlive,
force: bool,
force: Privilege,
) -> Result<Self::Balance, DispatchError> {
ensure!(Self::hold_available(reason, dest), TokenError::CannotCreateHold);
ensure!(Self::can_deposit(dest, amount, false) == Success, TokenError::CannotCreate);
let actual = Self::decrease_balance(source, amount, best_effort, keep_alive, force)?;
Self::increase_balance_on_hold(reason, dest, actual, best_effort)?;
let actual = Self::decrease_balance(source, amount, precision, keep_alive, force)?;
Self::increase_balance_on_hold(reason, dest, actual, precision)?;
Self::done_transfer_on_hold(reason, source, dest, actual);
Ok(actual)
}
Expand Down Expand Up @@ -375,7 +375,7 @@ pub trait Balanced<AccountId>: super::Balanced<AccountId> + Unbalanced<AccountId
amount: Self::Balance,
) -> (Credit<AccountId, Self>, Self::Balance) {
let decrease =
Self::decrease_balance_on_hold(reason, who, amount, true).unwrap_or(Default::default());
Self::decrease_balance_on_hold(reason, who, amount, BestEffort).unwrap_or(Default::default());
let credit =
Imbalance::<Self::Balance, Self::OnDropCredit, Self::OnDropDebt>::new(decrease);
Self::done_slash(reason, who, decrease);
Expand Down
Loading