Fix deserialization of default property accessor flags

In MemberDeserializer.loadProperty, we incorrectly passed 0 to
getAnnotations when loading annotations on property accessors in case
the protobuf field getter_flags/setter_flags was not present. The
correct behavior, as described in metadata.proto, was to pass a special
"default accessor flags" value, constructed from the main property
flags. Otherwise in case there were annotations both on the property and
on the accessor (as in PropertyAndAccessor.kt) and the accessor was
otherwise default, we would assume that it had no annotations and would
not load them in compiler and reflection

 #KT-25499 In Progress
This commit is contained in:
Alexander Udalov
2018-08-31 18:26:23 +02:00
parent a432704c4f
commit 06ce0cb0f0
17 changed files with 142 additions and 34 deletions
@@ -0,0 +1,18 @@
package test
annotation class A(val value: String)
annotation class B(val value: Array<String>)
interface I {
@A("property")
@get:B(["getter"])
var propertyAndGetter: Int
@A("property")
@set:B(["setter"])
var propertyAndSetter: Int
@get:A("getter")
@set:B(["setter"])
var getterAndSetter: Int
}
@@ -0,0 +1,25 @@
package test
public final annotation class A : kotlin.Annotation {
/*primary*/ public constructor A(/*0*/ value: kotlin.String)
public final val value: kotlin.String
public final fun <get-value>(): kotlin.String
}
public final annotation class B : kotlin.Annotation {
/*primary*/ public constructor B(/*0*/ value: kotlin.Array<kotlin.String>)
public final val value: kotlin.Array<kotlin.String>
public final fun <get-value>(): kotlin.Array<kotlin.String>
}
public interface I {
public abstract var getterAndSetter: kotlin.Int
@test.A(value = "getter") public abstract fun <get-getterAndSetter>(): kotlin.Int
@test.B(value = {"setter"}) public abstract fun <set-getterAndSetter>(/*0*/ <set-?>: kotlin.Int): kotlin.Unit
@test.A(value = "property") public abstract var propertyAndGetter: kotlin.Int
@test.B(value = {"getter"}) public abstract fun <get-propertyAndGetter>(): kotlin.Int
public abstract fun <set-propertyAndGetter>(/*0*/ <set-?>: kotlin.Int): kotlin.Unit
@test.A(value = "property") public abstract var propertyAndSetter: kotlin.Int
public abstract fun <get-propertyAndSetter>(): kotlin.Int
@test.B(value = {"setter"}) public abstract fun <set-propertyAndSetter>(/*0*/ <set-?>: kotlin.Int): kotlin.Unit
}