Documentation ¶
Overview ¶
Package common contains various helper functions.
Index ¶
- Constants
- Variables
- func AbsolutePath(datadir string, filename string) string
- func Bytes2Hex(d []byte) string
- func CopyBytes(b []byte) (copiedBytes []byte)
- func FileExist(filePath string) bool
- func FromHex(s string) []byte
- func Hex2Bytes(str string) []byte
- func Hex2BytesFixed(str string, flen int) []byte
- func IsHexAddress(s string) bool
- func IsHexPubKey(s string) bool
- func IsValidAccountName(s string) bool
- func IsValidAssetName(s string) bool
- func IsValidCreator(name string, subName string) bool
- func LeftPadBytes(slice []byte, l int) []byte
- func MakeName(name, version string) string
- func ReadVarInt(r io.Reader) (uint64, error)
- func RightPadBytes(slice []byte, l int) []byte
- func SetAccountNameCheckRule(nameLevel, nameLen, subNameLen uint64)
- func SetAssetNameCheckRule(nameLevel, nameLen, subNameLen uint64)
- func SplitString(s string) []string
- func ToHex(b []byte) stringdeprecated
- type AbsTime
- type AccountAuthor
- type Address
- func (a Address) Big() *big.Int
- func (a Address) Bytes() []byte
- func (a Address) Compare(x Address) int
- func (a Address) Format(s fmt.State, c rune)
- func (a Address) Hash() Hash
- func (a Address) Hex() string
- func (a Address) MarshalText() ([]byte, error)
- func (a *Address) SetBytes(b []byte)
- func (a Address) String() string
- func (a *Address) UnmarshalJSON(input []byte) error
- func (a *Address) UnmarshalText(input []byte) error
- type Author
- type AuthorType
- type GasPool
- type Hash
- func (h Hash) Big() *big.Int
- func (h Hash) Bytes() []byte
- func (h Hash) Format(s fmt.State, c rune)
- func (h Hash) Generate(rand *rand.Rand, size int) reflect.Value
- func (h Hash) Hex() string
- func (h Hash) MarshalText() ([]byte, error)
- func (h *Hash) SetBytes(b []byte)
- func (h Hash) String() string
- func (h Hash) TerminalString() string
- func (h *Hash) UnmarshalJSON(input []byte) error
- func (h *Hash) UnmarshalText(input []byte) error
- type MixedcaseAddress
- func (ma *MixedcaseAddress) Address() Address
- func (ma *MixedcaseAddress) MarshalJSON() ([]byte, error)
- func (ma *MixedcaseAddress) Original() string
- func (ma *MixedcaseAddress) String() string
- func (ma *MixedcaseAddress) UnmarshalJSON(input []byte) error
- func (ma *MixedcaseAddress) ValidChecksum() bool
- type Name
- func (n Name) AccountNameLevel() int
- func (n Name) Big() *big.Int
- func (n *Name) DecodeRLP(s *rlp.Stream) error
- func (n Name) EncodeRLP(w io.Writer) error
- func (n Name) IsValidCreator(name string) bool
- func (n *Name) SetString(s string) bool
- func (n Name) String() string
- func (n *Name) UnmarshalJSON(data []byte) error
- func (n *Name) UnmarshalText(input []byte) error
- type Owner
- type PrettyDuration
- type PubKey
- func (p PubKey) Big() *big.Int
- func (p PubKey) Bytes() []byte
- func (p PubKey) Compare(x PubKey) int
- func (p PubKey) Hex() string
- func (p PubKey) MarshalText() ([]byte, error)
- func (p *PubKey) SetBytes(key []byte)
- func (p PubKey) String() string
- func (p *PubKey) UnmarshalJSON(input []byte) error
- func (p *PubKey) UnmarshalText(input []byte) error
- type StorageAuthor
- type StorageSize
- type UnprefixedAddress
- type UnprefixedHash
Constants ¶
const AddressLength = 20
AddressLength of addresses in bytes
const HashLength = 32
HashLength of hashes in bytes.
const PubKeyLength = 65
PubKeyLength of PubKey in bytes
Variables ¶
var ( Big1 = big.NewInt(1) Big2 = big.NewInt(2) Big3 = big.NewInt(3) Big0 = big.NewInt(0) Big32 = big.NewInt(32) Big256 = big.NewInt(256) Big257 = big.NewInt(257) )
Common big integers often used
var ( AccountNameLevel uint64 = 1 AccountNameLen uint64 = 16 SubAccountNameLen uint64 = 8 AssetNameLevel uint64 = 1 AssetNameLen uint64 = 16 SubAssetNameLen uint64 = 8 )
var ErrGasLimitReached = errors.New("gas limit reached")
ErrGasLimitReached is returned by the gas pool if the amount of gas required by a transaction is higher than what's left in the block.
Functions ¶
func AbsolutePath ¶
AbsolutePath returns datadir + filename, or filename if it is absolute.
func FromHex ¶
FromHex returns the bytes represented by the hexadecimal string s. s may be prefixed with "0x".
func Hex2BytesFixed ¶
Hex2BytesFixed returns bytes of a specified fixed length flen.
func IsHexAddress ¶
IsHexAddress verifies whether a string can represent a valid hex-encoded
address or not.
func IsHexPubKey ¶
IsHexPubKey verifies whether a string can represent a valid hex-encoded
PubKey or not.
func IsValidAccountName ¶ added in v0.0.7
IsValidAccountName verifies whether a string can represent a valid name or not.
func IsValidAssetName ¶ added in v0.0.7
func IsValidCreator ¶ added in v0.0.7
func LeftPadBytes ¶
LeftPadBytes zero-pads slice to the left up to length l.
func MakeName ¶
MakeName creates a node name that follows the Fractal convention for such names. It adds the operation system name and Go runtime version the name.
func RightPadBytes ¶
RightPadBytes zero-pads slice to the right up to length l.
func SetAccountNameCheckRule ¶ added in v0.0.7
func SetAccountNameCheckRule(nameLevel, nameLen, subNameLen uint64)
func SetAssetNameCheckRule ¶ added in v0.0.7
func SetAssetNameCheckRule(nameLevel, nameLen, subNameLen uint64)
func SplitString ¶ added in v0.0.7
Types ¶
type AccountAuthor ¶ added in v0.0.7
type AccountAuthor struct {
Account Name
}
type Address ¶
type Address [AddressLength]byte
Address represents the 20 byte address of an account.
func BigToAddress ¶
BigToAddress returns Address with byte values of b. If b is larger than len(h), b will be cropped from the left.
func BytesToAddress ¶
BytesToAddress returns Address with value b. If b is larger than len(h), b will be cropped from the left.
func HexToAddress ¶
HexToAddress returns Address with byte values of s. If s is larger than len(h), s will be cropped from the left.
func (Address) Format ¶
Format implements fmt.Formatter, forcing the byte slice to be formatted as is, without going through the stringer interface used for logging.
func (Address) MarshalText ¶
MarshalText returns the hex representation of a.
func (*Address) SetBytes ¶
SetBytes sets the address to the value of b. If b is larger than len(a) it will panic.
func (*Address) UnmarshalJSON ¶
UnmarshalJSON parses a hash in hex syntax.
func (*Address) UnmarshalText ¶
UnmarshalText parses a hash in hex syntax.
type AuthorType ¶ added in v0.0.7
type AuthorType uint8
const ( AccountNameType AuthorType = iota PubKeyType AddressType )
type GasPool ¶
type GasPool uint64
GasPool tracks the amount of gas available during execution of the transactions in a block. The zero value is a pool with zero gas available.
type Hash ¶
type Hash [HashLength]byte
Hash represents the 32 byte Keccak256 hash of arbitrary data.
func BigToHash ¶
BigToHash sets byte representation of b to hash. If b is larger than len(h), b will be cropped from the left.
func BytesToHash ¶
BytesToHash sets b to hash. If b is larger than len(h), b will be cropped from the left.
func HexToHash ¶
HexToHash sets byte representation of s to hash. If b is larger than len(h), b will be cropped from the left.
func (Hash) Format ¶
Format implements fmt.Formatter, forcing the byte slice to be formatted as is, without going through the stringer interface used for logging.
func (Hash) MarshalText ¶
MarshalText returns the hex representation of h.
func (*Hash) SetBytes ¶
SetBytes sets the hash to the value of b. If b is larger than len(h), b will be cropped from the left.
func (Hash) String ¶
String implements the stringer interface and is used also by the logger when doing full logging into a file.
func (Hash) TerminalString ¶
TerminalString implements log.TerminalStringer, formatting a string for console output during logging.
func (*Hash) UnmarshalJSON ¶
UnmarshalJSON parses a hash in hex syntax.
func (*Hash) UnmarshalText ¶
UnmarshalText parses a hash in hex syntax.
type MixedcaseAddress ¶
type MixedcaseAddress struct {
// contains filtered or unexported fields
}
MixedcaseAddress retains the original string, which may or may not be correctly checksummed
func NewMixedcaseAddress ¶
func NewMixedcaseAddress(addr Address) MixedcaseAddress
NewMixedcaseAddress constructor (mainly for testing)
func NewMixedcaseAddressFromString ¶
func NewMixedcaseAddressFromString(hexaddr string) (*MixedcaseAddress, error)
NewMixedcaseAddressFromString is mainly meant for unit-testing
func (*MixedcaseAddress) Address ¶
func (ma *MixedcaseAddress) Address() Address
Address returns the address
func (*MixedcaseAddress) MarshalJSON ¶
func (ma *MixedcaseAddress) MarshalJSON() ([]byte, error)
MarshalJSON marshals the original value
func (*MixedcaseAddress) Original ¶
func (ma *MixedcaseAddress) Original() string
Original returns the mixed-case input string
func (*MixedcaseAddress) String ¶
func (ma *MixedcaseAddress) String() string
String implements fmt.Stringer
func (*MixedcaseAddress) UnmarshalJSON ¶
func (ma *MixedcaseAddress) UnmarshalJSON(input []byte) error
UnmarshalJSON parses MixedcaseAddress
func (*MixedcaseAddress) ValidChecksum ¶
func (ma *MixedcaseAddress) ValidChecksum() bool
ValidChecksum returns true if the address has valid checksum
type Name ¶
type Name string
Name represents the account name
func StringToName ¶ added in v0.0.7
StrToName returns Name with string of s.
func (Name) AccountNameLevel ¶ added in v0.0.7
func (Name) IsValidCreator ¶ added in v0.0.7
func (*Name) UnmarshalJSON ¶
UnmarshalJSON parses a hash in hex syntax.
func (*Name) UnmarshalText ¶
UnmarshalText parses a hash in hex syntax.
type PrettyDuration ¶
PrettyDuration is a pretty printed version of a time.Duration value that cuts the unnecessary precision off from the formatted textual representation.
func (PrettyDuration) String ¶
func (d PrettyDuration) String() string
String implements the Stringer interface, allowing pretty printing of duration values rounded to three decimals.
type PubKey ¶
type PubKey [PubKeyLength]byte
PubKey represents the 64 byte public key
func HexToPubKey ¶
HexToPubKey returns PubKey with byte values of s.
func (PubKey) Compare ¶
Compare returns an integer comparing two byte slices lexicographically. The result will be 0 if a==b, -1 if a < b, and +1 if a > b. A nil argument is equivalent to an empty slice.
func (PubKey) MarshalText ¶
MarshalText returns the hex representation of a.
func (*PubKey) UnmarshalJSON ¶
UnmarshalJSON parses a hash in hex syntax.
func (*PubKey) UnmarshalText ¶
UnmarshalText parses a hash in hex syntax.
type StorageAuthor ¶ added in v0.0.7
type StorageAuthor struct { Type AuthorType DataRaw rlp.RawValue Weight uint64 }
type StorageSize ¶
type StorageSize float64
StorageSize is a wrapper around a float value that supports user friendly formatting.
func (StorageSize) String ¶
func (s StorageSize) String() string
String implements the stringer interface.
func (StorageSize) TerminalString ¶
func (s StorageSize) TerminalString() string
TerminalString implements log.TerminalStringer, formatting a string for console output during logging.
type UnprefixedAddress ¶
type UnprefixedAddress Address
UnprefixedAddress allows marshaling an Address without 0x prefix.
func (UnprefixedAddress) MarshalText ¶
func (a UnprefixedAddress) MarshalText() ([]byte, error)
MarshalText encodes the address as hex.
func (*UnprefixedAddress) UnmarshalText ¶
func (a *UnprefixedAddress) UnmarshalText(input []byte) error
UnmarshalText decodes the address from hex. The 0x prefix is optional.
type UnprefixedHash ¶
type UnprefixedHash Hash
UnprefixedHash allows marshaling a Hash without 0x prefix.
func (UnprefixedHash) MarshalText ¶
func (h UnprefixedHash) MarshalText() ([]byte, error)
MarshalText encodes the hash as hex.
func (*UnprefixedHash) UnmarshalText ¶
func (h *UnprefixedHash) UnmarshalText(input []byte) error
UnmarshalText decodes the hash from hex. The 0x prefix is optional.