Skip to content

Conversation

@bishabosha
Copy link
Member

@bishabosha bishabosha commented Jul 4, 2023

this prepares the compiler to be able to call new API's in Zinc, by implementing infrastructure to call back into Zinc with VirtualFile.

A good side effect of this change is improved performance when using sbt to "clean compile" code, as extra bridging methods from java.io.File to xsbti.VirtualFile in Zinc are avoided.

Also remains compatible with Zinc 1.3, to do this we introduce a new interface dotty.tools.dotc.sbt.interfaces.IncrementalCallback, this abstracts over VirtualFile, and so the sbt-bridge handles the entire mapping between VirtualFile to AbstractFile, and then back from SourceFile to either VirtualFile or java.io.File, depending on the implementation.

Even if we remove Zinc 1.3 support, we probably want to keep the new interface because all the VirtualFile mapping logic can be contained in sbt-bridge

@bishabosha bishabosha force-pushed the topic/zinc-api-1.8.0-upgrade-only branch from 16f9ef0 to 0c8dcf3 Compare July 10, 2023 08:54
@bishabosha bishabosha force-pushed the topic/zinc-api-1.8.0-upgrade-only branch 3 times, most recently from e29e82a to 16b91ba Compare July 10, 2023 13:32
@bishabosha bishabosha mentioned this pull request Jul 10, 2023
5 tasks
@adpi2 adpi2 linked an issue Jul 10, 2023 that may be closed by this pull request
5 tasks
zinc 1.4 removes the dependency on protobuf-java, so fails
to compile mtags-shared due to the now missing transitive
dependency.

The compiler implements protobuf streams for semanticdb, so reuse
it in the source generator for mtags-shared.
@bishabosha bishabosha force-pushed the topic/zinc-api-1.8.0-upgrade-only branch from 8c22ff5 to 5e9fd97 Compare July 12, 2023 14:21
@bishabosha bishabosha force-pushed the topic/zinc-api-1.8.0-upgrade-only branch from 5e9fd97 to 2458b8f Compare July 12, 2023 17:01
@bishabosha
Copy link
Member Author

bishabosha commented Jul 12, 2023

@smarter the files and sources caches get destroyed on each new run, so the initial source files still need to be stored separately

@bishabosha bishabosha force-pushed the topic/zinc-api-1.8.0-upgrade-only branch from b5c096f to 95ed582 Compare July 13, 2023 13:31
@bishabosha bishabosha requested a review from smarter July 13, 2023 16:04
@bishabosha
Copy link
Member Author

This is ready to go

@bishabosha bishabosha force-pushed the topic/zinc-api-1.8.0-upgrade-only branch from 036107a to 8f128fd Compare July 13, 2023 20:36
@bishabosha bishabosha requested a review from smarter July 13, 2023 20:47
@bishabosha
Copy link
Member Author

bishabosha commented Jul 17, 2023

@smarter I now only do the hash map lookup, no longer underlying, and AbstractZincFile is gone

@bishabosha bishabosha force-pushed the topic/zinc-api-1.8.0-upgrade-only branch from e99b9e5 to 5fde72c Compare July 17, 2023 14:05
@bishabosha bishabosha requested a review from smarter July 17, 2023 14:06
@bishabosha bishabosha requested a review from smarter July 17, 2023 14:53
@bishabosha
Copy link
Member Author

test performance please

@dottybot
Copy link
Member

performance test scheduled: 227 job(s) in queue, 1 running.

@dottybot
Copy link
Member

Performance test finished successfully:

Visit https://dotty-bench.epfl.ch/18137/ to see the changes.

Benchmarks is based on merging with main (046ba60)

@bishabosha
Copy link
Member Author

again not sure if the benchmark regression was this or something older

@bishabosha
Copy link
Member Author

bishabosha commented Jul 18, 2023

I did my own analysis with async-profiler - this is a clear win over the status quo - e.g. on main b7e797d this is the flame graph for binaryDependency:
Screenshot 2023-07-18 at 19 25 12

and with this PR:
Screenshot 2023-07-18 at 19 25 33

so there's an improvement from 9-11% of ExtractDependencies.run being spent on binaryDependency to only 3%, as now we avoid the extra conversions in zinc to convert the sourcefile from java.io.File then to java.nio.file.Path and then to VirtualFile.

Similar improvements exist for usedName and classDependency, but not for api because that's dominated by actually doing the hashing

Copy link
Member

@smarter smarter left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Otherwise LGTM.

@smarter smarter assigned bishabosha and unassigned smarter Jul 19, 2023
@bishabosha bishabosha requested a review from smarter July 21, 2023 11:59
Copy link
Member

@smarter smarter left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

🚀

@smarter smarter merged commit 5afe621 into scala:main Jul 23, 2023
@smarter smarter deleted the topic/zinc-api-1.8.0-upgrade-only branch July 23, 2023 18:58
@bishabosha bishabosha added the backport:nominated If we agree to backport this PR, replace this tag with "backport:accepted", otherwise delete it. label Aug 3, 2023
@Kordyjan Kordyjan removed the backport:nominated If we agree to backport this PR, replace this tag with "backport:accepted", otherwise delete it. label Oct 10, 2023
@bishabosha
Copy link
Member Author

it seems IntelliJ has issues building projects with a compiler version after this was merged, maybe someone else could confirm?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

Follow-up on Zinc upgrade

8 participants