Skip to content

Commit

Permalink
Merge PR cosmos#5160: Simply Dec and Int sign check
Browse files Browse the repository at this point in the history
* Simply Dec and Int sign check

* address comment
  • Loading branch information
Xuefeng-Zhu authored and alexanderbez committed Oct 14, 2019
1 parent 21f2896 commit 3428291
Show file tree
Hide file tree
Showing 12 changed files with 23 additions and 23 deletions.
2 changes: 1 addition & 1 deletion types/coin.go
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@ func validate(denom string, amount Int) error {
return err
}

if amount.LT(ZeroInt()) {
if amount.IsNegative() {
return fmt.Errorf("negative coin amount: %v", amount)
}

Expand Down
6 changes: 3 additions & 3 deletions types/dec_coin.go
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ type DecCoin struct {
func NewDecCoin(denom string, amount Int) DecCoin {
mustValidateDenom(denom)

if amount.LT(ZeroInt()) {
if amount.IsNegative() {
panic(fmt.Sprintf("negative coin amount: %v\n", amount))
}

Expand All @@ -33,7 +33,7 @@ func NewDecCoin(denom string, amount Int) DecCoin {
func NewDecCoinFromDec(denom string, amount Dec) DecCoin {
mustValidateDenom(denom)

if amount.LT(ZeroDec()) {
if amount.IsNegative() {
panic(fmt.Sprintf("negative decimal coin amount: %v\n", amount))
}

Expand All @@ -44,7 +44,7 @@ func NewDecCoinFromDec(denom string, amount Dec) DecCoin {
}

func NewDecCoinFromCoin(coin Coin) DecCoin {
if coin.Amount.LT(ZeroInt()) {
if coin.Amount.IsNegative() {
panic(fmt.Sprintf("negative decimal coin amount: %v\n", coin.Amount))
}
if strings.ToLower(coin.Denom) != coin.Denom {
Expand Down
2 changes: 1 addition & 1 deletion x/distribution/keeper/delegation.go
Original file line number Diff line number Diff line change
Expand Up @@ -36,7 +36,7 @@ func (k Keeper) calculateDelegationRewardsBetween(ctx sdk.Context, val exported.
}

// sanity check
if stake.LT(sdk.ZeroDec()) {
if stake.IsNegative() {
panic("stake should not be negative")
}

Expand Down
4 changes: 2 additions & 2 deletions x/distribution/keeper/invariants.go
Original file line number Diff line number Diff line change
Expand Up @@ -90,14 +90,14 @@ func CanWithdrawInvariant(k Keeper) sdk.Invariant {
}

remaining = k.GetValidatorOutstandingRewards(ctx, val.GetOperator())
if len(remaining) > 0 && remaining[0].Amount.LT(sdk.ZeroDec()) {
if len(remaining) > 0 && remaining[0].Amount.IsNegative() {
return true
}

return false
})

broken := len(remaining) > 0 && remaining[0].Amount.LT(sdk.ZeroDec())
broken := len(remaining) > 0 && remaining[0].Amount.IsNegative()
return sdk.FormatInvariant(types.ModuleName, "can withdraw",
fmt.Sprintf("remaining coins: %v\n", remaining)), broken
}
Expand Down
2 changes: 1 addition & 1 deletion x/distribution/keeper/validator.go
Original file line number Diff line number Diff line change
Expand Up @@ -88,7 +88,7 @@ func (k Keeper) decrementReferenceCount(ctx sdk.Context, valAddr sdk.ValAddress,
}

func (k Keeper) updateValidatorSlashFraction(ctx sdk.Context, valAddr sdk.ValAddress, fraction sdk.Dec) {
if fraction.GT(sdk.OneDec()) || fraction.LT(sdk.ZeroDec()) {
if fraction.GT(sdk.OneDec()) || fraction.IsNegative() {
panic(fmt.Sprintf("fraction must be >=0 and <=1, current fraction: %v", fraction))
}

Expand Down
2 changes: 1 addition & 1 deletion x/mint/internal/types/minter.go
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ func DefaultInitialMinter() Minter {

// validate minter
func ValidateMinter(minter Minter) error {
if minter.Inflation.LT(sdk.ZeroDec()) {
if minter.Inflation.IsNegative() {
return fmt.Errorf("mint parameter Inflation should be positive, is %s",
minter.Inflation.String())
}
Expand Down
2 changes: 1 addition & 1 deletion x/mint/internal/types/params.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,7 +59,7 @@ func DefaultParams() Params {

// validate params
func ValidateParams(params Params) error {
if params.GoalBonded.LT(sdk.ZeroDec()) {
if params.GoalBonded.IsNegative() {
return fmt.Errorf("mint parameter GoalBonded should be positive, is %s ", params.GoalBonded.String())
}
if params.GoalBonded.GT(sdk.OneDec()) {
Expand Down
4 changes: 2 additions & 2 deletions x/staking/keeper/slash.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ import (
func (k Keeper) Slash(ctx sdk.Context, consAddr sdk.ConsAddress, infractionHeight int64, power int64, slashFactor sdk.Dec) {
logger := k.Logger(ctx)

if slashFactor.LT(sdk.ZeroDec()) {
if slashFactor.IsNegative() {
panic(fmt.Errorf("attempted to slash with a negative slash factor: %v", slashFactor))
}

Expand Down Expand Up @@ -105,7 +105,7 @@ func (k Keeper) Slash(ctx sdk.Context, consAddr sdk.ConsAddress, infractionHeigh
tokensToBurn = sdk.MaxInt(tokensToBurn, sdk.ZeroInt()) // defensive.

// we need to calculate the *effective* slash fraction for distribution
if validator.Tokens.GT(sdk.ZeroInt()) {
if validator.Tokens.IsPositive() {
effectiveFraction := tokensToBurn.ToDec().QuoRoundUp(validator.Tokens.ToDec())
// possible if power has changed
if effectiveFraction.GT(sdk.OneDec()) {
Expand Down
2 changes: 1 addition & 1 deletion x/staking/keeper/validator.go
Original file line number Diff line number Diff line change
Expand Up @@ -187,7 +187,7 @@ func (k Keeper) RemoveValidator(ctx sdk.Context, address sdk.ValAddress) {
if validator.Tokens.IsPositive() {
panic("attempting to remove a validator which still contains tokens")
}
if validator.Tokens.GT(sdk.ZeroInt()) {
if validator.Tokens.IsPositive() {
panic("validator being removed should never have positive tokens")
}

Expand Down
6 changes: 3 additions & 3 deletions x/staking/simulation/operations/msgs.go
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ func SimulateMsgCreateValidator(m auth.AccountKeeper, k staking.Keeper) simulati
acc := simulation.RandomAcc(r, accs)
address := sdk.ValAddress(acc.Address)
amount := m.GetAccount(ctx, acc.Address).GetCoins().AmountOf(denom)
if amount.GT(sdk.ZeroInt()) {
if amount.IsPositive() {
amount = simulation.RandomAmount(r, amount)
}

Expand Down Expand Up @@ -116,7 +116,7 @@ func SimulateMsgDelegate(m auth.AccountKeeper, k staking.Keeper) simulation.Oper
delegatorAcc := simulation.RandomAcc(r, accs)
delegatorAddress := delegatorAcc.Address
amount := m.GetAccount(ctx, delegatorAddress).GetCoins().AmountOf(denom)
if amount.GT(sdk.ZeroInt()) {
if amount.IsPositive() {
amount = simulation.RandomAmount(r, amount)
}
if amount.Equal(sdk.ZeroInt()) {
Expand Down Expand Up @@ -201,7 +201,7 @@ func SimulateMsgBeginRedelegate(m auth.AccountKeeper, k staking.Keeper) simulati
delegatorAddress := delegatorAcc.Address
// TODO
amount := m.GetAccount(ctx, delegatorAddress).GetCoins().AmountOf(denom)
if amount.GT(sdk.ZeroInt()) {
if amount.IsPositive() {
amount = simulation.RandomAmount(r, amount)
}
if amount.Equal(sdk.ZeroInt()) {
Expand Down
8 changes: 4 additions & 4 deletions x/staking/types/commission.go
Original file line number Diff line number Diff line change
Expand Up @@ -69,23 +69,23 @@ func (c Commission) String() string {
// parameters. If validation fails, an SDK error is returned.
func (c CommissionRates) Validate() sdk.Error {
switch {
case c.MaxRate.LT(sdk.ZeroDec()):
case c.MaxRate.IsNegative():
// max rate cannot be negative
return ErrCommissionNegative(DefaultCodespace)

case c.MaxRate.GT(sdk.OneDec()):
// max rate cannot be greater than 1
return ErrCommissionHuge(DefaultCodespace)

case c.Rate.LT(sdk.ZeroDec()):
case c.Rate.IsNegative():
// rate cannot be negative
return ErrCommissionNegative(DefaultCodespace)

case c.Rate.GT(c.MaxRate):
// rate cannot be greater than the max rate
return ErrCommissionGTMaxRate(DefaultCodespace)

case c.MaxChangeRate.LT(sdk.ZeroDec()):
case c.MaxChangeRate.IsNegative():
// change rate cannot be negative
return ErrCommissionChangeRateNegative(DefaultCodespace)

Expand All @@ -105,7 +105,7 @@ func (c Commission) ValidateNewRate(newRate sdk.Dec, blockTime time.Time) sdk.Er
// new rate cannot be changed more than once within 24 hours
return ErrCommissionUpdateTime(DefaultCodespace)

case newRate.LT(sdk.ZeroDec()):
case newRate.IsNegative():
// new rate cannot be negative
return ErrCommissionNegative(DefaultCodespace)

Expand Down
6 changes: 3 additions & 3 deletions x/staking/types/msg.go
Original file line number Diff line number Diff line change
Expand Up @@ -170,7 +170,7 @@ func (msg MsgCreateValidator) ValidateBasic() sdk.Error {
if err := msg.Commission.Validate(); err != nil {
return err
}
if !msg.MinSelfDelegation.GT(sdk.ZeroInt()) {
if !msg.MinSelfDelegation.IsPositive() {
return ErrMinSelfDelegationInvalid(DefaultCodespace)
}
if msg.Value.Amount.LT(msg.MinSelfDelegation) {
Expand Down Expand Up @@ -226,12 +226,12 @@ func (msg MsgEditValidator) ValidateBasic() sdk.Error {
return sdk.NewError(DefaultCodespace, CodeInvalidInput, "transaction must include some information to modify")
}

if msg.MinSelfDelegation != nil && !msg.MinSelfDelegation.GT(sdk.ZeroInt()) {
if msg.MinSelfDelegation != nil && !msg.MinSelfDelegation.IsPositive() {
return ErrMinSelfDelegationInvalid(DefaultCodespace)
}

if msg.CommissionRate != nil {
if msg.CommissionRate.GT(sdk.OneDec()) || msg.CommissionRate.LT(sdk.ZeroDec()) {
if msg.CommissionRate.GT(sdk.OneDec()) || msg.CommissionRate.IsNegative() {
return sdk.NewError(DefaultCodespace, CodeInvalidInput, "commission rate must be between 0 and 1, inclusive")
}
}
Expand Down

0 comments on commit 3428291

Please sign in to comment.