Skip to content
This repository was archived by the owner on Apr 18, 2019. It is now read-only.

Conversation

@ashawley
Copy link
Member

@ashawley ashawley commented Dec 19, 2016

After adding the library dependency for scala-xml 1.0.6 to an SBT project, there's evidence the new version is not being used.

In scala/scala-xml#125, a user reported the new version of scala-xml didn't include an improvement it was supposed to have.

This isn't a pull request. It provides code for a test driver, ExponentialTransformer, that can confirm if scala.xml.transform.RuleTransformer makes just one call or is the old version that makes 32 calls.

$ sbt ++2.11.8 "runMain ExponentialTransformer" 
[info] Running ExponentialTransformer 
scala.xml.transform.RuleTransformer called 32 time(s)
[success] Total time: 1 s, completed
$ sbt ++2.12.0 "runMain ExponentialTransformer" 
[info] Running ExponentialTransformer 
scala.xml.transform.RuleTransformer called 32 time(s)
[success] Total time: 14 s, completed
$ sbt ++2.12.1 "runMain ExponentialTransformer"
[info] Running ExponentialTransformer 
scala.xml.transform.RuleTransformer called 1 time(s)
[success] Total time: 14 s, completed

Unsurprisingly, the correct version of scala-xml 1.0.6 is called when run by Java directly with what you think the classpath should be:

$ java -cp target/scala-2.11/classes:$HOME/.ivy2/cache/org.scala-lang/scala-compiler/jars/scala-compiler-2.11.8.jar:$HOME/.ivy2/cache/org.scala-lang/scala-library/jars/scala-library-2.11.8.jar:$HOME/.ivy2/cache/org.scala-lang.modules/scala-xml_2.11/bundles/scala-xml_2.11-1.0.6.jar ExponentialTransformer
scala.xml.transform.RuleTransformer called 1 time(s)

$ java -cp target/scala-2.12/classes:$HOME/.ivy2/cache/org.scala-lang/scala-compiler/jars/scala-compiler-2.12.0.jar:$HOME/.ivy2/cache/org.scala-lang/scala-library/jars/scala-library-2.12.0.jar:$HOME/.ivy2/cache/org.scala-lang.modules/scala-xml_2.12/bundles/scala-xml_2.12-1.0.6.jar ExponentialTransformer
scala.xml.transform.RuleTransformer called 1 time(s)

This is what SBT reports the classpath to be:

   > show fullClasspath
[info] * Attributed(scala-module-dependency-sample/sbt-sample/target/scala-2.11/classes)
[info] * Attributed(~/.ivy2/cache/org.scala-lang/scala-library/jars/scala-library-2.11.8.jar)
[info] * Attributed(~/.ivy2/cache/org.scala-lang.modules/scala-xml_2.11/bundles/scala-xml_2.11-1.0.6.jar)
[...]

@note
Copy link

note commented Dec 19, 2016

I guess the problem with old version of scala-xml getting used is just in sbt process. That's because when I run sample code you commited with myProject/run I see scala.xml.transform.RuleTransformer called 32 time(s). When I run the same code with myProject/re-start (using sbt-revolver) I see scala.xml.transform.RuleTransformer called 1 time(s). AFAIK sbt-revolver forks a new process in which application is run while standard run runs app in sbt process. It's also consistent with fork in Test := true in build.sbt of scala-xml (see at scala/scala-xml#20)

@ashawley
Copy link
Member Author

ashawley commented Dec 19, 2016

@SethTisue It seems downstream users of SBT need to run their projects in a forked JVM to use scala-xml releases. I thought it was only an issue for the build.sbt file in the scala-xml project.

Instructions for the JVM forking workaround could be documented, or the source of the problem in SBT could be fixed.

Seems there is previous reports in Jira

https://issues.scala-lang.org/browse/SI-8358
https://issues.scala-lang.org/browse/SI-8472
https://issues.scala-lang.org/browse/SI-9560

ashawley added a commit to ashawley/scala that referenced this pull request Dec 20, 2016
Nothing should transitively depend on the scala-xml module except for
scaladoc and library-all.

Compiler needs scala-xml as a build dependency, but not at runtime.
The user is supposed to provide scala-xml as a dependency at runtime.
This fixes an issue where the classpath in SBT shadows the scala-xml
module, see scala/scala-module-dependency-sample#14.  The only
consequence of dropping the dependency at runtime is that scala-xml
always needs to be binary compatible.  That's the point of MiMa and
dbuild, no?
@ashawley
Copy link
Member Author

I've modified Travis to verify the issue. I'm not sure why I didn't think of that earlier.

@ashawley
Copy link
Member Author

I don't know Ivy very well but it seems that the scala-compiler library could be providing scala-xml at runtime vis a vis SBT. This is why it is ignoring the scala-xml the user specifies when running an unforked JVM in SBT.

I am wondering if removing scala-xml could be removed as a dependency for scala-compiler.

Here is the dependency for scala-xml in scala-compiler's ivy-2.12.0.xml

<dependency
    org="org.scala-lang.modules"
    name="scala-xml_2.12"
    rev="1.0.5"
    force="true"
    conf="compile->compile(*),master(compile);runtime->runtime(*)"/>

Here is the dependency for scala-xml in scala-compiler in ivy-2.12.1.xml where it was incremented to 1.0.6

<dependency
    org="org.scala-lang.modules"
    name="scala-xml_2.12"
    rev="1.0.6"
    force="true"
    conf="compile->compile(*),master(compile);runtime->runtime(*)"/>

SBT started building the Scala compiler in 2.12, but the dependency is roughly the same as it was with the last Ant build, 2.11.8. Here is ivy-2.11.8.xml

<dependency
    org="org.scala-lang.modules"
    name="scala-xml_2.11"
    rev="1.0.4"
    force="true"
    conf="compile->compile(*),master(*);runtime->runtime(*)"/>

Seems the dependency for scala-xml to scala-compiler could be changed to a provided configuration in Ivy. I've tried looking in to this at scala/scala#5609. Here is the ivy-2.11.9-SNAPSHOT.xml it produces:

<dependency
    org="org.scala-lang.modules"
    name="scala-xml_2.11"
    rev="1.0.5"
    force="true"
    conf="provided->default(compile)"/>

When I publish this version of scala-compiler locally with the provided configuration, I can use the 1.0.6 version of scala-xml in SBT without forking.

Getting this fixed upstream becomes complicated quickly, and is beyond my experience to resolve.

Currently, changing the dependency for scala-xml in scala-compiler to provided seems to break Scaladoc in the Scala build system. Could scaladoc possibly be using scala-xml from scala-compiler as well? According to ivy.xml for scala-compiler-doc it needs scala-xml:

<dependency
    org="org.scala-lang.modules"
    name="scala-xml_2.11"
    rev="1.0.4"
    conf="compile->default(compile)">
  <exclude org="org.scala-lang"
	   module="*"
	   name="*"
	   type="*"
	   ext="*"
	   conf=""
	   matcher="exact"/>
</dependency>

Why isn't SBT getting scala-xml for scaladoc? Has it not been and instead just using the one in scala-compiler this whole time? I'm not sure how to resolve this.

@ashawley
Copy link
Member Author

ashawley commented Jan 6, 2017

According to scala/scala#5609, Adriaan hopes that the scaladoc dependency on scala-xml could be cut in 2.13. From my research, this will require considering the following solutions:

  • Require the scaladoc dependency on scala-xml be provided
  • Remove scaladoc from scala-compiler
  • Change how SBT runs scaladoc
  • Change the way SBT defines the classpath when running scaladoc (or the compiler)

For now, we'll just have to live with the defect in 2.11 and 2.12. This will be documented as Seth suggested in scala/scala-xml#125

ashawley added a commit to ashawley/scala that referenced this pull request Feb 13, 2017
Nothing should transitively depend on the scala-xml module except for
scaladoc and library-all.

Compiler needs scala-xml as a build dependency, but not at runtime.

The user is supposed to provide scala-xml as a dependency at runtime.
This fixes an issue where the classpath in SBT shadows the scala-xml
module, see scala/scala-module-dependency-sample#14.

Unfortunately, scaladoc needs to be pulled out of the compiler.  This
is a first attempt at mangling the build so that scaladoc is a
separate jar.  Following on, SBT will need to know how to run scaladoc
as a separate jar.
ashawley added a commit to ashawley/scala that referenced this pull request Feb 27, 2018
Nothing should transitively depend on the scala-xml module except for
scaladoc and library-all.

Compiler needs scala-xml as a build dependency, but not at runtime.

The user is supposed to provide scala-xml as a dependency at runtime.
This fixes an issue where the classpath in SBT shadows the scala-xml
module, see scala/scala-module-dependency-sample#14.

Unfortunately, scaladoc needs to be pulled out of the compiler.  This
is a first attempt at mangling the build so that scaladoc is a
separate jar.  Following on, SBT will need to know how to run scaladoc
as a separate jar.
@SethTisue
Copy link
Member

SethTisue commented Mar 2, 2018

we have too many open tickets on this — let's close this one, this repo is not a likely place someone would look

the newest ticket is scala/scala-xml#195, and I just commented there with links to others

@SethTisue SethTisue closed this Mar 2, 2018
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

3 participants