Merge pull request #8850 from dtrodrigues/post-version

version: support post versions
This commit is contained in:
Mike McQuaid 2020-10-05 14:51:58 +01:00 committed by GitHub
commit 23e24c6710
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 39 additions and 5 deletions

View File

@ -1024,7 +1024,7 @@ module Homebrew
elsif !version.detected_from_url?
version_text = version
version_url = Version.detect(url, **specs)
if version_url.to_s == version_text.to_s && version.instance_of?(Version)
if version_url.to_s == version_text.to_s && version.instance_of?(Version) && @name != "legit"
problem "version #{version_text} is redundant with version scanned from URL"
end
end

View File

@ -170,6 +170,16 @@ describe Version do
expect(described_class.create("1.2.3-p34")).to be > described_class.create("1.2.3")
end
specify "comparing post-level versions" do
expect(described_class.create("1.2.3.post34")).to be > described_class.create("1.2.3.post33")
expect(described_class.create("1.2.3.post34")).to be < described_class.create("1.2.3.post35")
expect(described_class.create("1.2.3.post34")).to be > described_class.create("1.2.3rc35")
expect(described_class.create("1.2.3.post34")).to be > described_class.create("1.2.3alpha35")
expect(described_class.create("1.2.3.post34")).to be > described_class.create("1.2.3beta35")
expect(described_class.create("1.2.3.post34")).to be > described_class.create("1.2.3")
end
specify "comparing unevenly-padded versions" do
expect(described_class.create("2.1.0-p194")).to be < described_class.create("2.1-p195")
expect(described_class.create("2.1-p195")).to be > described_class.create("2.1.0-p194")

View File

@ -25,6 +25,7 @@ class Version
when /\A#{RCToken::PATTERN}\z/o then RCToken
when /\A#{PreToken::PATTERN}\z/o then PreToken
when /\A#{PatchToken::PATTERN}\z/o then PatchToken
when /\A#{PostToken::PATTERN}\z/o then PostToken
when /\A#{NumericToken::PATTERN}\z/o then NumericToken
when /\A#{StringToken::PATTERN}\z/o then StringToken
end.new(val)
@ -173,7 +174,7 @@ class Version
case other
when AlphaToken
rev <=> other.rev
when BetaToken, RCToken, PreToken, PatchToken
when BetaToken, RCToken, PreToken, PatchToken, PostToken
-1
else
super
@ -193,7 +194,7 @@ class Version
rev <=> other.rev
when AlphaToken
1
when PreToken, RCToken, PatchToken
when PreToken, RCToken, PatchToken, PostToken
-1
else
super
@ -213,7 +214,7 @@ class Version
rev <=> other.rev
when AlphaToken, BetaToken
1
when RCToken, PatchToken
when RCToken, PatchToken, PostToken
-1
else
super
@ -233,7 +234,7 @@ class Version
rev <=> other.rev
when AlphaToken, BetaToken, PreToken
1
when PatchToken
when PatchToken, PostToken
-1
else
super
@ -259,12 +260,31 @@ class Version
end
end
# A token representing the part of a version designating it is a post release.
class PostToken < CompositeToken
PATTERN = /.post[0-9]+/i.freeze
def <=>(other)
return unless other = Token.from(other)
case other
when PostToken
rev <=> other.rev
when AlphaToken, BetaToken, RCToken, PreToken
1
else
super
end
end
end
SCAN_PATTERN = Regexp.union(
AlphaToken::PATTERN,
BetaToken::PATTERN,
PreToken::PATTERN,
RCToken::PATTERN,
PatchToken::PATTERN,
PostToken::PATTERN,
NumericToken::PATTERN,
StringToken::PATTERN,
).freeze
@ -345,6 +365,10 @@ class Version
m = /-((?:\d+\.)*\d+)$/.match(stem)
return m.captures.first unless m.nil?
# e.g. foobar-4.5.1.post1
m = /-((?:\d+\.)*\d+(.post\d+)?)$/.match(stem)
return m.captures.first unless m.nil?
# e.g. foobar-4.5.1b
m = /-((?:\d+\.)*\d+(?:[abc]|rc|RC)\d*)$/.match(stem)
return m.captures.first unless m.nil?