diff options
author | Adriaan Moors <adriaan.moors@epfl.ch> | 2012-11-14 11:24:54 -0800 |
---|---|---|
committer | Adriaan Moors <adriaan.moors@epfl.ch> | 2012-11-14 11:26:18 -0800 |
commit | 65778d760fd7b80b8f0fb9e3cfe87cc87e3523ae (patch) | |
tree | cfdd8370a0285d695e2a5c53703576a04d48a655 /tools/quickcp | |
parent | 850108886765e99e894f7613f49c1bab3650a0c2 (diff) | |
download | scala-65778d760fd7b80b8f0fb9e3cfe87cc87e3523ae.tar.gz scala-65778d760fd7b80b8f0fb9e3cfe87cc87e3523ae.tar.bz2 scala-65778d760fd7b80b8f0fb9e3cfe87cc87e3523ae.zip |
SI-5330, SI-6014 deal with existential self-type
This has been broken since https://github.com/scala/scala/commit/b7b81ca2#L0L567.
The existential rash is treated in a similar manner as in fc24db4c.
Conceptually, the fix would be `def selfTypeSkolemized =
widen.skolemizeExistential.narrow`, but simply widening before
narrowing achieves the same thing. Since we're in existential voodoo
territory, let's go for the minimal fix: replacing `this.narrow` by
`widen.narrow`.
--
Original patch by @retronym in #1074, refined by @paulp to
only perform widen.narrow incantation if there are
existentials present in the widened type, as
narrowing is expensive when the type is not a singleton.
The result is that compiling the entirety of quick, that
code path is hit only 143 times. All the other calls hit
.narrow directly as before. It looks like the definition
of negligible in the diff of -Ystatistics when compiling
src/library/scala/collection:
< #symbols : 306315
---
> #symbols : 306320
12c13
< #unique types : 293859
---
> #unique types : 293865
I'm assuming based on the 2/1000ths of a percent increase
in symbol and type creation that wall clock is manageable,
but I didn't measure it.
Diffstat (limited to 'tools/quickcp')
0 files changed, 0 insertions, 0 deletions