summaryrefslogtreecommitdiff
path: root/src
Commit message (Collapse)AuthorAgeFilesLines
* fix SI-1247: don't create a thunk for a by-name argument if the argument ↵Johannes Rudolph2012-05-081-1/+9
| | | | expression is a Function0 application
*-. Merge commit 'refs/pull/512/head'; commit 'refs/pull/513/head' into developPaul Phillips2012-05-087-46/+46
|\ \
| | * Fixes SI-5564.Aleksandar Prokopec2012-05-081-8/+23
| | | | | | | | | | | | Catching typer errors in specialization.
| * | Fixed positions in named default applications (no hyperlinking in ↵Iulian Dragos2012-05-084-35/+19
| | | | | | | | | | | | | | | | | | conjunction with implicit arguments). Removed even more code in the presentation compiler testing infrastructure. One less level of indirection, and a top-level object gone!
| * | Making the locator more robust in the face of weird originals. And changed ↵Martin Odersky2012-05-082-3/+4
| |/ | | | | | | | | | | | | | | positions in AnnotationInfo to avoid position-less trees there. Conflicts: src/compiler/scala/tools/nsc/typechecker/Typers.scala
| |
| \
*-. | Merge commit 'refs/pull/510/head'; commit 'refs/pull/511/head'Paul Phillips2012-05-081-1/+1
|\ \|
| * | Appendix. Typo that wasn't covered by the test suite.Hubert Plociniczak2012-05-081-1/+1
| | |
| | |
| \ \
| \ \
| \ \
| \ \
| \ \
*-----. \ \ Merge commit 'refs/pull/504/head'; commit 'refs/pull/505/head'; commit ↵Paul Phillips2012-05-08312-3146/+39776
|\ \ \ \ \ \ | | | |_|/ / | | |/| | / | | |_|_|/ | |/| | | 'refs/pull/506/head'; commit 'refs/pull/507/head'; commit 'refs/pull/508/head' into develop
| | | | * GenASM activated via -target:jvm-1.6 or -target:jvm-1.5-asmMiguel Garcia2012-05-088-8/+3349
| | | | |
| | | | * glue ASM <-> GenASM, the only part of scala.tools.asm to maintain manuallyMiguel Garcia2012-05-082-0/+67
| | | | |
| | | | * subset of the ASM framework, re-namespaced as scala.tools.asmMiguel Garcia2012-05-0875-0/+27954
| | | | |
| | | | * documentation about BasicBlock and InlinerMiguel Garcia2012-05-082-16/+19
| | | | |
| | | | * BytecodeWriters can do without the FJBG dependencyMiguel Garcia2012-05-082-23/+30
| | | | |
| | | | * overriding rather than pattern matching in icode.OpcodesMiguel Garcia2012-05-081-29/+30
| | |_|/ | |/| |
| | | * Changes scala.math.signum to return negative zeros.Dominik Gruntz2012-05-081-14/+3
| | | |
| | * | Part IV of the Lazy Vals Saga: Optimized local vals. That's all folks.Hubert Plociniczak2012-05-083-45/+75
| | | |
| | * | Part III of the Lazy Vals Saga: Inliner strikes back. Or at least let's hope ↵Hubert Plociniczak2012-05-075-33/+77
| | | | | | | | | | | | | | | | it will.
| | * | Part II of the Lazy Vals Saga: Saving bitmap by the Three Musketeers: Byte, ↵Hubert Plociniczak2012-05-046-39/+83
| | | | | | | | | | | | | | | | Int and Long. And Boolean (hey, he also deserves some credit!).
| | * | Part I of the Lazy Vals Saga: Bitmaps are no longer inherited.Hubert Plociniczak2012-05-034-84/+6
| | | |
| * | | A little sketchiness in recent commit.Paul Phillips2012-05-081-1/+1
| | |/ | |/| | | | | | | Retro-reviewing.
| * | Fix for aliasing bug in reifier.Paul Phillips2012-05-081-9/+10
| | | | | | | | | | | | Closes SI-5769.
| * | Merge commit 'refs/pull/491/head' into developPaul Phillips2012-05-071-13/+19
| |\ \
| | * | Fixes SI-5629.Aleksandar Prokopec2012-05-071-13/+19
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Adds an additional argument to the unify method in specialization - `tparams`. When this parameter is set to `true`, unification is done over type parameters in poly types as well. Additionally, the unification in specialization now works over type bounds. This ensures that in the below example: trait Foo[@specialized(Int) A] { def bar[B <: A](b: B) {} } class IntFoo extends Foo[Int] { override def bar[B <: Int](b: B) {} } the method `bar` gets correctly determined as a method that needs a special override for its `bar$mcI$sp`.
| | | |
| | \ \
| *-. \ \ Merge commit 'refs/pull/486/head'; commit 'refs/pull/487/head'; commit ↵Paul Phillips2012-05-079-34/+60
| |\ \ \ \ | | |_|/ / | |/| | | | | | | | 'refs/pull/488/head'; commit 'refs/pull/489/head'; commit 'refs/pull/490/head' into develop
| | | * | minor tag-related fixesEugene Burmako2012-05-078-31/+31
| | | | |
| | * | | Fixes SI-5199 through improved API docsHeather Miller2012-05-071-3/+29
| | |/ /
| * | | Merge commit 'refs/pull/479/head'; commit 'refs/pull/480/head'; commit ↵Paul Phillips2012-05-064-10/+60
| |\ \ \ | | |/ / | |/| | | | | | 'refs/pull/481/head'; commit 'refs/pull/482/head'; commit 'refs/pull/483/head'; commit 'refs/pull/484/head'; commit 'refs/pull/485/head' into develop
| | * | Add missing methods to GenTraversableLike.Aleksandar2012-05-064-10/+60
| | | |
| | | |
| | \ \
| *-. \ \ Merge commit 'refs/pull/477/head'; commit 'refs/pull/478/head' into developPaul Phillips2012-05-053-8/+15
| |\ \ \ \
| | | * | | Don't admit primitive arrays as a generic Java varargs param.Jason Zaugg2012-05-053-8/+15
| | |/ / / | | | | | | | | | | | | | | | | | | | | | | | | | They were sneaking through as polymorphic Arrays and avoiding boxing. Closes SI-4216
| * | | | Merge commit 'refs/pull/124/head' into developPaul Phillips2012-05-051-9/+10
| |\ \ \ \ | | |/ / / | |/| | | | | | | | | | | | | Conflicts: src/library/scala/util/parsing/combinator/Parsers.scala
| | * | | Fixes SI-4929, with a test to verify.Stephen Judkins2012-01-211-14/+15
| | | | | | | | | | | | | | | | | | | | Also fixes potential issue with Parsers.phrase not being reentrant; however, I was unable to actually reproduce this issue in practice. (The order in which lastNoSuccess was being set and compared seemed to guarantee that it would never actually be a problem).
| * | | | Working around the VerifyErrors.Paul Phillips2012-05-042-2/+6
| | | | | | | | | | | | | | | | | | | | Since the optimizer seems to have lost its mind.
| * | | | Put corresponds on Iterator.Paul Phillips2012-05-041-0/+18
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | I guess we can look forward to more and more duplication in the collections. I had to cut and paste the doc comment too, or at least I have no idea how to avoid that given the file I took it from was in parallel somewhere.
| * | | | Have ArrayCharSequence reuse its Array.Paul Phillips2012-05-041-5/+20
| | | | | | | | | | | | | | | | | | | | Your know, for performance. Closes SI-5641.
| * | | | Updated Symbol to record classfile origin.Paul Phillips2012-05-049-33/+74
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | This change should be transparent to anything using sourceFile, unless it was drinking from the inheritance well too deeply. Rather than squander the already allocated field for every ClassSymbol not being compiled from source, I'm now populating it with the file representing the class. This will make a broad range of things easier, like debugging, issuing useful error messages, symbol invalidation, signature verification, you name it. def sourceFile - still returns only source code files def binaryFile - returns only class files def associatedFile - returns whatever is there, if anything Performance: I may be mistaken, but I believe this is a zero-impact change. No new fields are allocated; fields which were null now hold a useful reference. The reference is to a file instance which was already being allocated and already long-lived. Compare error messages: // Version 1 % scalac a.scala error: type _$1 is defined twice // Version 2 % scalac a.scala error: type _$1 is defined twice conflicting symbols both originated in file './foo/package.class' Note: this may be due to a bug in the compiler involving wildcards in package objects one error found Bonus for people who read commit logs. Try this in the repl after starting power mode. ListClass.info.members groupBy (_.associatedFile) foreach { case (k, vs) => println("%s\n %s\n".format(k, vs map (_.defString) mkString "\n ")) }
| * | | | Reluctant surgery on partest.Paul Phillips2012-05-042-112/+57
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Now neg tests are treated like all the other tests in terms of grouping, so if you have a negative test which requires more than one pass (like the one enclosed with the next commit) you can actually test it.
| | | | |
| | \ \ \
| | \ \ \
| | \ \ \
| | \ \ \
| | \ \ \
| | \ \ \
| | \ \ \
| *-------. \ \ \ Merge commit 'refs/pull/471/head'; commit 'refs/pull/473/head'; commit ↵Paul Phillips2012-05-047-11/+31
| |\ \ \ \ \ \ \ \ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | 'refs/pull/474/head'; commit 'refs/pull/475/head'; commit 'refs/pull/476/head' into develop
| | | | | | * | | | Fixes SI-5514.Aleksandar Prokopec2012-05-041-2/+4
| | | | | | | |/ / | | | | | | |/| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | The acceptIf and acceptMatch parsers now check for end of input. Review by moors.
| | | | | * / | | Fixes si-5656.Aleksandar Prokopec2012-05-041-5/+13
| | | | | |/ / /
| | | | * / / / Fix for si-5577.Aleksandar Prokopec2012-05-041-0/+2
| | | | |/ / /
| | | * / / / Fix for si-5590.Aleksandar Prokopec2012-05-042-1/+9
| | | |/ / /
| | * / / / Fix for si-5018.Aleksandar Prokopec2012-05-042-3/+3
| | |/ / / | | | | | | | | | | | | | | | Methods keySet, values and withDefault now return serializable collections.
| * | | | run patmat after typer, but not *right* afterAdriaan Moors2012-05-041-2/+4
| | | | | | | | | | | | | | | | | | | | sbt needs that spot right after type for its phase xsbt-api
| * | | | Fix for one of the oldest open soundness bugs.Paul Phillips2012-05-042-10/+11
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Closes SI-963, since it was one of my random 30 it won the prize. The trick after adding the stability check (which has been sitting there commented out for 3+ years) was that implicit search depended on the wrongness, because memberWildcardType would create scopes with members of the form ?{ val name: tp } And since a def shouldn't match that, fixing it broke everything until I flipped it around: memberWildcardType should be seeking ?{ def name: tp } It could also search for a mutable value: the relevant quality is that it not be stable so it doesn't have a tighter type than the members it hopes to match.
| * | | | Fix for broken non-local returns.Paul Phillips2012-05-041-3/+11
| |/ / / | | | | | | | | | | | | | | | | Don't change the owner of a return if the new owner is nested inside the old owner. Closes SI-5612.
| * | | Fix for implicit class / value class collision.Paul Phillips2012-05-031-6/+13
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | New this week, on SCALA. Implicit class: "Spin me up an implicit method with my name." Value class: "I need a companion object, pronto." Narrator: "All was well with this arrangement... UNTIL." What happens when these two wacky SIPs get together in the very same class? You'll laugh until, eventually, you cry! Weeknights at 9:30pm, only on SCALA. Closes SI-5667.
| * | | Pushing ClassfileParser toward a new day.Paul Phillips2012-05-036-329/+141
| | | | | | | | | | | | | | | | | | | | | | | | Removed JacoMetaATTR. Removed MetaParser.
| * | | Improving organization of classfile parser.Paul Phillips2012-05-033-293/+298
| | | |
| * | | Fix for Dynamic interaction with private methods.Paul Phillips2012-05-031-10/+11
| | | | | | | | | | | | | | | | | | | | | | | | Don't let inaccessible methods prevent calls to *Dynamic, otherwise we are at the mercy of every "private" alteration in every class we inherit. Closes SI-5040.