5c5367d377
The following updates in the JVM/IR plugin were made: * Lots of refactoring with preparation for K/N support: commonization of transformations. * Improved error handling (checks for visibility constraints, appending message about usage constraints in case of an error). * Explicit requirements for the visibility of atomic properties: to prevent leaking they should be private/internal or be members of private/internal classes. * Fixed visibility of generated properties: volatile properties are always private and atomic updaters have the same visibility as the original atomic property. * Volatile fields are generated from scratch and original atomic properties are removed. * Delegated properties support is fixed (only declaration in the same scope is allowed). * Non-inline atomic extensions are forbidden. * For top-level atomics: only one wrapper class per file (with corresponding visibility) is generated. * Bug fixes. The corresponding tickets: https://github.com/Kotlin/kotlinx-atomicfu/issues/322 KT-60528 Merge-request: KT-MR-10579 Merged-by: Maria Sokolova <maria.sokolova@jetbrains.com>
52 lines
4.3 KiB
Plaintext
Vendored
52 lines
4.3 KiB
Plaintext
Vendored
@kotlin.Metadata
|
|
public final class ArrayInlineExtensionTest$A {
|
|
// source: 'ArrayInlineExtensionTest.kt'
|
|
private final @org.jetbrains.annotations.NotNull field s: java.lang.String
|
|
public method <init>(@org.jetbrains.annotations.NotNull p0: java.lang.String): void
|
|
public final @org.jetbrains.annotations.NotNull method getS(): java.lang.String
|
|
public final inner class ArrayInlineExtensionTest$A
|
|
}
|
|
|
|
@kotlin.Metadata
|
|
public final class ArrayInlineExtensionTest {
|
|
// source: 'ArrayInlineExtensionTest.kt'
|
|
private synthetic final static field a$volatile$FU: java.util.concurrent.atomic.AtomicIntegerFieldUpdater
|
|
private synthetic volatile field a$volatile: int
|
|
private synthetic final field intArr: java.util.concurrent.atomic.AtomicIntegerArray
|
|
private synthetic final field longArr: java.util.concurrent.atomic.AtomicLongArray
|
|
private synthetic final field refArr: java.util.concurrent.atomic.AtomicReferenceArray
|
|
static method <clinit>(): void
|
|
public method <init>(): void
|
|
private synthetic final method bar$atomicfu$array(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerArray, p2: int, p3: int): int
|
|
private synthetic final method bar$atomicfu(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerFieldUpdater, p2: int): int
|
|
private final method casLoop(p0: int): int
|
|
private final method casLoopExpression(p0: long): long
|
|
private synthetic final method extensionLoop$atomicfu$array(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerArray, p2: int, p3: int): int
|
|
private synthetic final method extensionLoop$atomicfu(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerFieldUpdater, p2: int): int
|
|
private synthetic final method extensionLoopExpression$atomicfu$array(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerArray, p2: int, p3: int): int
|
|
private synthetic final method extensionLoopExpression$atomicfu(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerFieldUpdater, p2: int): int
|
|
private synthetic final method extensionLoopMixedReceivers$atomicfu$array(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerArray, p2: int, p3: int, p4: int, p5: int): int
|
|
private synthetic final method extensionLoopMixedReceivers$atomicfu(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerFieldUpdater, p2: int, p3: int, p4: int): int
|
|
private synthetic final method extensionLoopRecursive$atomicfu$array(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerArray, p2: int, p3: int): int
|
|
private synthetic final method extensionLoopRecursive$atomicfu(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerFieldUpdater, p2: int): int
|
|
private synthetic final method foo$atomicfu$array(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerArray, p2: int, p3: int): int
|
|
private synthetic final method foo$atomicfu(p0: java.lang.Object, p1: java.util.concurrent.atomic.AtomicIntegerFieldUpdater, p2: int): int
|
|
private synthetic final static method getA$volatile$FU(): java.util.concurrent.atomic.AtomicIntegerFieldUpdater
|
|
private synthetic final method getA$volatile(): int
|
|
private synthetic final method getIntArr(): java.util.concurrent.atomic.AtomicIntegerArray
|
|
private synthetic final method getLongArr(): java.util.concurrent.atomic.AtomicLongArray
|
|
private synthetic final method getRefArr(): java.util.concurrent.atomic.AtomicReferenceArray
|
|
private synthetic final method loop$atomicfu$array(p0: java.util.concurrent.atomic.AtomicIntegerArray, p1: int, p2: kotlin.jvm.functions.Function1): void
|
|
private synthetic final method loop$atomicfu$array(p0: java.util.concurrent.atomic.AtomicLongArray, p1: int, p2: kotlin.jvm.functions.Function1): void
|
|
private synthetic final method loop$atomicfu(p0: java.util.concurrent.atomic.AtomicIntegerFieldUpdater, p1: kotlin.jvm.functions.Function1, p2: java.lang.Object): void
|
|
private synthetic final method setA$volatile(p0: int): void
|
|
public final method testIntExtensionLoops(): void
|
|
public final inner class ArrayInlineExtensionTest$A
|
|
}
|
|
|
|
@kotlin.Metadata
|
|
public final class ArrayInlineExtensionTestKt {
|
|
// source: 'ArrayInlineExtensionTest.kt'
|
|
public final static @org.jetbrains.annotations.NotNull method box(): java.lang.String
|
|
}
|