-
Notifications
You must be signed in to change notification settings - Fork 12
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Ability to lift a ScalaVersion from a String #82
Conversation
def apply(version: String): ScalaVersion = { | ||
val regex = raw"""(\d+)\.(\d+)\.(\d+).*""".r | ||
version match { | ||
case regex(major, minor, patch) => ScalaVersion(major.toLong, minor.toLong, patch.toLong) | ||
case _ => throw new IllegalArgumentException(s"Scala version $version not recognized") | ||
} | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you for the PR!
I would probably go with more explicit fromString
name rather than overloading apply
.
Another couple of concerns (which I am personally not sure about):
- should we validate the version numbers per se (i.e. make sure that we cannot create out of a nonexistent scala version like "100.200.300"?
- should we return
Option
or evenEither
instead of throwing an exception? In that case there could be anotherunsafeFromString
that would throw on an error.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the comment.
Sounds like @armanbilge is agreeing?
So would that mean we could not upgrade to a newer Scala version until this dependency is supporting it? Might me ok to me. It's kind of the same with semanticdb. WDYT?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry, let me clarify: I am 👍 to fromString
and Option
(or Either
) but I think validation against a list of known versions is not worth the maintenance effort i.e. it's not buying us much and its making a lot of busywork to re-publish for every Scala release.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, it was on the question side. Feel free to disregard the validation please. Perhaps, I overthought it.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I pushed an new version. Have a look.
e239c58
to
2916a6d
Compare
@@ -44,6 +44,18 @@ object ScalaVersion { | |||
val V3_3_0 = ScalaVersion(3, 3, 0) | |||
val V3_3_1 = ScalaVersion(3, 3, 1) | |||
|
|||
def fromString(version: String): Either[IllegalArgumentException, ScalaVersion] = { | |||
val regex = raw"""(\d+)\.(\d+)\.(\d+).*""".r |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I wonder, what is the last part .*
in the regex is supposed for?
To me it looks like it's going to accept any arbitrary string after the last digit, like "1.2.3abc" – is that correct?
Another thought – perhaps it makes sense to keep the pre-compiled regex value in a private value outside of the method. To avoid getting it compiled every time upon the method call. Wdyt?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The .*
after the digit was to catch stuff like -SNAPSHOT
, but you are right here it's a bug and would blow on the patch.toLong
. So I removed it.
I pushed a version with the regex pulled out.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
but you are right here it's a bug and would blow on the
patch.toLong
Wait, why is that? The three parenthetical groups in the regex are the major, minor, and patch, the other stuff would be omitted, no?
I hate to say it but I think the answer here is we need to write some tests for this stuff :) I don't see why we shouldn't support prerelease scala versions.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I added some tests and support for -RC
or -M..
versions. Let me know what you think @armanbilge
c0cf265
to
254928d
Compare
Are we good with this? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry for the late response. Looks good to me, thank you!
Do we need someone to merge the PR? |
@satorg @armanbilge @BalmungSan How can we move forward on this? |
@@ -44,6 +44,17 @@ object ScalaVersion { | |||
val V3_3_0 = ScalaVersion(3, 3, 0) | |||
val V3_3_1 = ScalaVersion(3, 3, 1) | |||
|
|||
private val versionRegex = raw"""(\d+)\.(\d+)\.(\d+)""".r |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[Yak Shaving Alert] Can I suggest something like this? I think we will do another PR before either Scala 4 will come out or any minor/hotfix of any existing scala version will pass number 99.
private val versionRegex = raw"""(\d+)\.(\d+)\.(\d+)""".r | |
private val versionRegex = raw"""(2|3)\.(\d\d?)\.(\d\d?)""".r |
Have you seen #82 (comment)? |
Scala version numbers aren't just Might the existing methods in sbt's If you decide to go forward with adding your own version number parsing here, I'd suggest at minimum supporting both |
This could be a good idea indeed. |
254928d
to
e814321
Compare
@joan38 have you tried the Seth's suggestion of leveraging sbt's |
} | ||
} | ||
|
||
property("fromString parse an RC version") { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we also add tests for versions like:
3.4.0-RC1-bin-20231106-f61026d-NIGHTLY
2.13.12-bin-80514f7
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Added
Sorry I totally not see the comments. |
e814321
to
a580823
Compare
a580823
to
10d3bb2
Compare
It makes sense indeed |
Thanks guys for all the great suggestions! Excited to use this. |
Hi,
I'm helping @DavidGregory084 to maintain the mill-tpolecat and I just found out about this project and the split with sbt-tpolecat. Great idea! and thank you for doing this!
Now I feel like we could deprecate mill-tpolecat and only use this dependency in mill. Here is an example:
You can see this is very compact already and mill-tpolecat would not really add much value.
However the thing that bothers me is that now we have to edit the Scala version at multiple places.
With this PR it would look like this:
Thanks