summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLukas Rytz <lukas.rytz@gmail.com>2016-11-25 10:04:12 +0100
committerGitHub <noreply@github.com>2016-11-25 10:04:12 +0100
commiteb7d907f6283f897f6b248bae170bade57969519 (patch)
tree52a4db097a27a496845e56c4a86f605a1d21e127 /src
parentd5f21af9f41d8f4bd22ee6126e1476b4a76c51c2 (diff)
parent824103644337758f2a6a70ea69a33a9671e1e69c (diff)
downloadscala-eb7d907f6283f897f6b248bae170bade57969519.tar.gz
scala-eb7d907f6283f897f6b248bae170bade57969519.tar.bz2
scala-eb7d907f6283f897f6b248bae170bade57969519.zip
Merge pull request #5540 from retronym/ticket/9814
SI-9814 Fix synchronized in specialized overrides
Diffstat (limited to 'src')
-rw-r--r--src/compiler/scala/tools/nsc/transform/SpecializeTypes.scala3
1 files changed, 2 insertions, 1 deletions
diff --git a/src/compiler/scala/tools/nsc/transform/SpecializeTypes.scala b/src/compiler/scala/tools/nsc/transform/SpecializeTypes.scala
index c171050bbd..84f47c1caa 100644
--- a/src/compiler/scala/tools/nsc/transform/SpecializeTypes.scala
+++ b/src/compiler/scala/tools/nsc/transform/SpecializeTypes.scala
@@ -1049,7 +1049,8 @@ abstract class SpecializeTypes extends InfoTransform with TypingTransformers {
}
}
debuglog(s"specialized overload $om for ${overriding.name.decode} in ${pp(env)}: ${om.info}")
- if (overriding.isAbstractOverride) om.setFlag(ABSOVERRIDE)
+ om.setFlag(overriding.flags & (ABSOVERRIDE | SYNCHRONIZED))
+ om.withAnnotations(overriding.annotations.filter(_.symbol == ScalaStrictFPAttr))
typeEnv(om) = env
addConcreteSpecMethod(overriding)
if (overriding.isDeferred) { // abstract override