2015-07-07 02:54:22 +02:00
// Copyright 2015 The go-ethereum Authors
2015-07-22 18:48:40 +02:00
// This file is part of the go-ethereum library.
2015-07-07 02:54:22 +02:00
//
2015-07-23 18:35:11 +02:00
// The go-ethereum library is free software: you can redistribute it and/or modify
2015-07-07 02:54:22 +02:00
// it under the terms of the GNU Lesser General Public License as published by
// the Free Software Foundation, either version 3 of the License, or
// (at your option) any later version.
//
2015-07-22 18:48:40 +02:00
// The go-ethereum library is distributed in the hope that it will be useful,
2015-07-07 02:54:22 +02:00
// but WITHOUT ANY WARRANTY; without even the implied warranty of
2015-07-22 18:48:40 +02:00
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
2015-07-07 02:54:22 +02:00
// GNU Lesser General Public License for more details.
//
// You should have received a copy of the GNU Lesser General Public License
2015-07-22 18:48:40 +02:00
// along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>.
2015-07-07 02:54:22 +02:00
2015-04-15 16:39:44 +02:00
package common
import (
2023-03-23 10:18:36 +07:00
"crypto/rand"
2015-04-15 16:39:44 +02:00
"fmt"
2023-03-23 10:18:36 +07:00
"math/big"
2015-04-15 16:39:44 +02:00
"os"
"runtime"
"runtime/debug"
2016-03-01 23:32:43 +01:00
"strings"
2023-03-23 10:18:36 +07:00
"time"
2015-04-15 16:39:44 +02:00
)
2016-03-01 23:32:43 +01:00
// Report gives off a warning requesting the user to submit an issue to the github tracker.
2015-04-15 16:39:44 +02:00
func Report ( extra ... interface { } ) {
2021-05-26 13:35:39 +03:00
fmt . Fprintln ( os . Stderr , "You've encountered a sought after, hard to reproduce bug. Please report this to the developers <3 https://github.com/ledgerwatch/erigon/issues" )
2015-04-15 16:39:44 +02:00
fmt . Fprintln ( os . Stderr , extra ... )
_ , file , line , _ := runtime . Caller ( 1 )
fmt . Fprintf ( os . Stderr , "%v:%v\n" , file , line )
debug . PrintStack ( )
fmt . Fprintln ( os . Stderr , "#### BUG! PLEASE REPORT ####" )
}
2016-03-01 23:32:43 +01:00
// PrintDepricationWarning prinst the given string in a box using fmt.Println.
func PrintDepricationWarning ( str string ) {
line := strings . Repeat ( "#" , len ( str ) + 4 )
emptyLine := strings . Repeat ( " " , len ( str ) )
fmt . Printf ( `
% s
# % s #
# % s #
# % s #
% s
` , line , emptyLine , str , emptyLine , line )
}
2023-03-23 10:18:36 +07:00
// RandomizeDuration - periodic parallel actions may interfere and resonance.
// Use this func to add small randomness to period
func RandomizeDuration ( in time . Duration ) time . Duration {
randDuration , err := rand . Int ( rand . Reader , big . NewInt ( int64 ( time . Second ) ) )
if err != nil {
panic ( err )
}
return in + time . Duration ( randDuration . Uint64 ( ) )
}