Documentation ¶
Index ¶
- Variables
- func GetApricotPhase0Time(networkID uint32) time.Time
- func GetApricotPhase1Time(networkID uint32) time.Time
- func GetApricotPhase2Time(networkID uint32) time.Time
- func GetApricotPhase3Time(networkID uint32) time.Time
- type Application
- type ApplicationParser
- type Compatibility
- type Parser
- type Version
Constants ¶
This section is empty.
Variables ¶
View Source
var ( String string // Printed when CLI arg --version is used GitCommit string // Set in the build script (i.e. at compile time) Current = NewDefaultVersion(0, 0, 1) CurrentApp = NewDefaultApplication(constants.PlatformName, Current.Major(), Current.Minor(), Current.Patch()) MinimumCompatibleVersion = NewDefaultApplication(constants.PlatformName, 0, 0, 1) PrevMinimumCompatibleVersion = NewDefaultApplication(constants.PlatformName, 0, 0, 0) MinimumUnmaskedVersion = NewDefaultApplication(constants.PlatformName, 0, 0, 1) PrevMinimumUnmaskedVersion = NewDefaultApplication(constants.PlatformName, 0, 0, 0) VersionParser = NewDefaultApplicationParser() CurrentDatabase = DatabaseVersion1_4_5 PrevDatabase = DatabaseVersion1_0_0 DatabaseVersion1_4_5 = NewDefaultVersion(1, 4, 5) DatabaseVersion1_0_0 = NewDefaultVersion(1, 0, 0) ApricotPhase0Times = map[uint32]time.Time{} ApricotPhase0DefaultTime = time.Date(2021, time.January, 0, 0, 0, 0, 0, time.UTC) ApricotPhase1Times = map[uint32]time.Time{} ApricotPhase1DefaultTime = time.Date(2021, time.January, 0, 0, 0, 0, 0, time.UTC) ApricotPhase2Times = map[uint32]time.Time{} ApricotPhase2DefaultTime = time.Date(2021, time.January, 0, 0, 0, 0, 0, time.UTC) ApricotPhase3Times = map[uint32]time.Time{} ApricotPhase3DefaultTime = time.Date(2021, time.January, 0, 0, 0, 0, 0, time.UTC) )
View Source
var (
DefaultVersion1_0_0 = NewDefaultVersion(1, 0, 0)
)
Functions ¶
func GetApricotPhase0Time ¶
func GetApricotPhase1Time ¶
func GetApricotPhase2Time ¶
func GetApricotPhase3Time ¶
Types ¶
type Application ¶
type Application interface { Version App() string Compatible(Application) error Before(Application) bool }
Application defines what is needed to describe a versioned Application.
func NewApplication ¶
func NewApplication( app string, appSeparator string, versionSeparator string, major int, minor int, patch int, ) Application
NewApplication returns a new version
func NewDefaultApplication ¶
func NewDefaultApplication( app string, major int, minor int, patch int, ) Application
NewDefaultApplication returns a new version with default separators
type ApplicationParser ¶
type ApplicationParser interface {
Parse(string) (Application, error)
}
ApplicationParser defines the interface of an ApplicationVersion parser
func NewApplicationParser ¶
func NewApplicationParser(appSeparator string, versionSeparator string) ApplicationParser
NewApplicationParser returns a new parser
func NewDefaultApplicationParser ¶
func NewDefaultApplicationParser() ApplicationParser
NewDefaultApplicationParser returns a new parser with the default separators
type Compatibility ¶
type Compatibility interface { // Returns the local version Version() Application // Returns nil if the provided version is compatible with the local version. // This means that the version is connectable and that consensus messages // can be made to them. Compatible(Application) error // Returns nil if the provided version shouldn't be masked. This means that // the version is connectable but not compatible. The version is so old that // it should just be masked. Unmaskable(Application) error // Returns nil if the provided version will not be masked by this version. WontMask(Application) error // Returns when additional masking will occur. MaskTime() time.Time }
Compatibility a utility for checking the compatibility of peer versions
func GetCompatibility ¶
func GetCompatibility(networkID uint32) Compatibility
func NewCompatibility ¶
func NewCompatibility( version Application, minCompatable Application, minCompatableTime time.Time, prevMinCompatable Application, minUnmaskable Application, minUnmaskableTime time.Time, prevMinUnmaskable Application, ) Compatibility
NewCompatibility returns a compatibility checker with the provided options
type Parser ¶
Parser defines the interface of a Version parser
func NewDefaultParser ¶
func NewDefaultParser() Parser
Click to show internal directories.
Click to hide internal directories.