Here is a summary of the main points that have been raised so far. I suggest taking them into account before submitting an actual SIP.
Motivation
Do you (@romanowski) plan to update the motivation part to include that point?
Alternative Solution: Comments
data:image/s3,"s3://crabby-images/bcdee/bcdee1fa659ad790110ed11dc6f393ad22fe4081" alt=""
The fact that it looks similar to Scala expressions at all is misleading. Can I import stuff? What’s the evaluation order? Can I define
val
s/def
s/class
es and so on? I assume not, and that this stuff would get statically inspected as metadata, rather than evaluated as code. This means the syntax is actively misleading people into thinking it’s Scala expressions, when it’s not
Could you please expand on why you think “using directives” is the best solution vs comments?
Alternative Solution: Annotations
data:image/s3,"s3://crabby-images/bcdee/bcdee1fa659ad790110ed11dc6f393ad22fe4081" alt=""
TBH, if we want a way to associate metadata with Scala files, that sounds a lot like the existing way to associate metadata with pieces of Scala code: an annotation. I think some annotation-like syntax using
@
would be a lot better than theusing
syntax proposed above. We’d need to finesse the syntax in order to make it unambiguous and ergonomic, but I think it can be done and result in a much more familiar user experience. This applies to people coming from any language, as most languages have some sort of annotation-like syntax for associating metadata with code, and that’s exactly what we want to do here.
Probably, a discussion on a solution based on annotations should be included. An argument against annotation has been made here already:
data:image/s3,"s3://crabby-images/0d5d6/0d5d6f0b5c5e2c42f56277cdc167199e80c1dce7" alt=""
I think annotations suffer from the problem that they require processing (typing). By the time you’ve typechecked, you already needed the metadata, which may include compile time or run time directives.
Alternative Solution: Language Imports
data:image/s3,"s3://crabby-images/95b9f/95b9ff80403ac48eb062d6bed3d997c58e83b470" alt=""
Conversely, we could use
import
for general settings:import scala "3.1.2"
It would address the objection that
using
already has its (different) purpose.
data:image/s3,"s3://crabby-images/74892/7489235f2e6755073cdce27e89cadc5edc8c85a7" alt=""
Or without breaking scala syntax:
import language.version.`3.1.2`
Maybe consider including language imports in the alternative solutions. There is already an argument against reusing imports:
data:image/s3,"s3://crabby-images/3a1ca/3a1ca6ac19031d603936ba77846da079c8fabd9a" alt=""
It would from what I understand not supercede language imports, as those can be locally scoped, while these can not.
Re-purposing the using
keyword vs introducing a new keyword
data:image/s3,"s3://crabby-images/bcdee/bcdee1fa659ad790110ed11dc6f393ad22fe4081" alt=""
It’s re-purposing an existing keyword in a weird way.
using
is kinda-sorta tangentially related to one particular use case of what we’re trying to do here, just likeimport $
is kinda-sorta tangentially related to one particular use case of what Ammonite does. But it’s different enough that it seems like it would cause confusion, not unlike how we used to use underscore_
for a bunch of scenarios that were kinda-sorta related
Would you mind elaborating on why you think re-purposing using
is the best solution? Should we introduce another keyword instead? E.g. “pragma”?
data:image/s3,"s3://crabby-images/a5562/a5562aacb4808a1fbccb1b82e48f443a184e206b" alt=""
I think
pragma
would fit perfectly as a keyword for this. It is well known for this kind of feature in other programming languages.
Syntax does not look like usual Scala
data:image/s3,"s3://crabby-images/bcdee/bcdee1fa659ad790110ed11dc6f393ad22fe4081" alt=""
It doesn’t look like Scala.
scala "3.1.2"
does not look like valid Scala syntax at all.someSettings { setting1 value 1; setting2; }
is technically valid Scala syntax, but is in the style of odd DSLs. It looks like Kotlin or Groovy with their convention of builder DSLs, but those aren’t ubiquitous in the Scala ecosystem.