diff options
author | Martin Odersky <odersky@gmail.com> | 2014-03-09 13:35:33 +0100 |
---|---|---|
committer | Martin Odersky <odersky@gmail.com> | 2014-03-09 13:39:22 +0100 |
commit | af337f0667fa559411f9a96355b9ceeabf95b232 (patch) | |
tree | 25d3e9e7c55b9adcce5e744108f0ff219bb7b874 /src/dotty/tools/dotc/core/SymDenotations.scala | |
parent | d827b0180b05e7461856f668c3c4ca0ea6ed5d62 (diff) | |
download | dotty-af337f0667fa559411f9a96355b9ceeabf95b232.tar.gz dotty-af337f0667fa559411f9a96355b9ceeabf95b232.tar.bz2 dotty-af337f0667fa559411f9a96355b9ceeabf95b232.zip |
Fix of #50 - volatile
Volatile checking needs to take all intersections into account; previously these
could be discarded through needsChecking.
Plus several refactorings and additions.
1) Module vals now have Final and Stable flags set
2) All logic around isVolatile is now in TypeOps; some of it was moved from Types.
3) Added stability checking to Select and SelectFromType typings.
Todo: We should find a better name for isVolatile. Maybe define the negation instead under the name
"isRealizable"?.
Diffstat (limited to 'src/dotty/tools/dotc/core/SymDenotations.scala')
-rw-r--r-- | src/dotty/tools/dotc/core/SymDenotations.scala | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/dotty/tools/dotc/core/SymDenotations.scala b/src/dotty/tools/dotc/core/SymDenotations.scala index 5fbf6c2c4..b9eb2f945 100644 --- a/src/dotty/tools/dotc/core/SymDenotations.scala +++ b/src/dotty/tools/dotc/core/SymDenotations.scala @@ -355,7 +355,7 @@ object SymDenotations { final def isStable(implicit ctx: Context) = { val isUnstable = (this is UnstableValue) || - info.isVolatile && !hasAnnotation(defn.uncheckedStableClass) + ctx.isVolatile(info) && !hasAnnotation(defn.uncheckedStableClass) (this is Stable) || isType || { if (isUnstable) false else { setFlag(Stable); true } |