blob: 71ab7611b8a6d4336be80233fd205a91f8686241 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
|
implementation module Version
import StdInt, StdClass
:: VersionInfo =
{ versionCurrent
:: Int
, versionOldestDefinition
:: Int
, versionOldestImplementation
:: Int
}
:: VersionsCompatability
= VersionsAreCompatible
| VersionObservedIsTooOld
| VersionObservedIsTooNew
versionCompare :: VersionInfo VersionInfo -> VersionsCompatability
versionCompare expected observed
| expected.versionCurrent < observed.versionCurrent
| expected.versionCurrent >= observed.versionOldestDefinition
= VersionsAreCompatible
// otherwise
= VersionObservedIsTooNew
| expected.versionCurrent == observed.versionCurrent
= VersionsAreCompatible
// expected.versionCurrent > observed.versionCurrent
| expected.versionOldestImplementation <= observed.versionCurrent
= VersionsAreCompatible
// otherwise
= VersionObservedIsTooOld
|