David M. Lloyd created MRESOLVER-336:
----------------------------------------

             Summary: Unexpected handling of qualifiers in GenericVersionScheme
                 Key: MRESOLVER-336
                 URL: https://issues.apache.org/jira/browse/MRESOLVER-336
             Project: Maven Resolver
          Issue Type: Bug
    Affects Versions: 1.9.5
            Reporter: David M. Lloyd


Given the following:

{code}
$ jbang --main=org.eclipse.aether.util.version.GenericVersionScheme 
org.apache.maven.resolver:maven-resolver-util:1.9.5 0.0.0.ga.ga.foo foo
Display parameters as parsed by Maven Resolver (in canonical form and as a list 
of tokens) and comparison result:
1. 0.0.0.ga.ga.foo -> 0.0.0.ga.ga.foo; tokens: [0, 0, 0, foo]
   0.0.0.ga.ga.foo == foo
2. foo -> foo; tokens: [foo]
{code}

This is expected iff zero-prefixed qualifiers are considered equal to the bare 
qualifier, which does seem to be the case *mostly*. However, we also have this:

{code}
$ jbang --main=org.eclipse.aether.util.version.GenericVersionScheme 
org.apache.maven.resolver:maven-resolver-util:1.9.5 ga.ga.foo foo
Display parameters as parsed by Maven Resolver (in canonical form and as a list 
of tokens) and comparison result:
1. ga.ga.foo -> ga.ga.foo; tokens: [0, 0, foo]
   ga.ga.foo < foo
2. foo -> foo; tokens: [foo]
{code}

In this case we have "zero"-valued qualifiers but no leading numerical segment, 
which unexpectedly changes the parsing rules. I would expect {{ga.ga.foo == 
foo}} as above. Is this a bug? Is there an explanation for this behavior? The 
spec doesn't seem to directly address this.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to