scala.annotation
Members list
Packages
Type members
Classlikes
A base trait for annotations that yield proper subtypes of the types they annotate. Refining annotations are more "sticky" than normal ones. They are conceptually kept around when normal refinements would also not be stripped away.
A base trait for annotations that yield proper subtypes of the types they annotate. Refining annotations are more "sticky" than normal ones. They are conceptually kept around when normal refinements would also not be stripped away.
Attributes
- Source
- RefiningAnnotation.scala
- Supertypes
An annotation that goes on parameters of classes or traits. It asserts that the parameter is used only for initialization and is not kept in the class as a field. Violations of this assertion are flagged as compile errors. The annotation is particularly useful for implicit parameters since for these a textual scan is not sufficient to know where they are used. Note: the annotation is copied from constructor parameters to corresponding class fields. But it is checked that the field is eliminated before code is generated.
An annotation that goes on parameters of classes or traits. It asserts that the parameter is used only for initialization and is not kept in the class as a field. Violations of this assertion are flagged as compile errors. The annotation is particularly useful for implicit parameters since for these a textual scan is not sufficient to know where they are used. Note: the annotation is copied from constructor parameters to corresponding class fields. But it is checked that the field is eliminated before code is generated.
Attributes
- Source
- constructorOnly.scala
- Supertypes
An annotation that can be used to mark a definition as experimental.
An annotation that can be used to mark a definition as experimental.
Attributes
- See also
- Source
- experimental.scala
- Supertypes
A binary API is a definition that is annotated with @publicInBinary. This annotation can be placed on def, val, lazy val, var, class constructors, object, and given definitions. A binary API will be publicly available in the bytecode. Tools like TASTy MiMa will take this into account to check compatibility.
A binary API is a definition that is annotated with @publicInBinary. This annotation can be placed on def, val, lazy val, var, class constructors, object, and given definitions. A binary API will be publicly available in the bytecode. Tools like TASTy MiMa will take this into account to check compatibility.
This annotation cannot be used on private/private[this] definitions.
@publicInBinary can be used to guarantee access to private[T]/protected definitions:
- within inline definitions,
- against previous binary where this definitions was public or less private,
- or through JVM reflection.
Removing this annotation from a non-public definition is a binary incompatible change. Adding this annotation to a non-public definition can also cause binary incompatibilities if the definition is accessed in an inline definition (these can be checked using -WunstableInlineAccessors).
Attributes
- Source
- publicInBinary.scala
- Supertypes
https://github.com/scala/scala.github.com/pull/491
Attributes
- Source
- static.scala
- Supertypes
An annotation that defines an external name for a definition. If an targetName(extname) annotation is given for a method or some other definition, its implementation will use the name extname instead of the regular name.
An annotation that defines an external name for a definition. If an targetName(extname) annotation is given for a method or some other definition, its implementation will use the name extname instead of the regular name.
Attributes
- Source
- targetName.scala
- Supertypes
This annotation can only be used on a field which defines a lazy val. When this annotation is used, the initialization of the lazy val will use a faster mechanism which is not thread-safe.
This annotation can only be used on a field which defines a lazy val. When this annotation is used, the initialization of the lazy val will use a faster mechanism which is not thread-safe.
Attributes
- Source
- threadUnsafe.scala
- Supertypes
An annotation that can be used from Scala 2 to mark a trait as transparent. Scala 3 code would use the modifier transparent instead. Transparent traits are not inferred when combined with other types in an intersection. See reference/other-new-features/transparent-traits.html for details.
An annotation that can be used from Scala 2 to mark a trait as transparent. Scala 3 code would use the modifier transparent instead. Transparent traits are not inferred when combined with other types in an intersection. See reference/other-new-features/transparent-traits.html for details.
Attributes
- Source
- transparentTrait.scala
- Supertypes
Deprecated classlikes
An annotation that defines an external name for a definition. If an alpha(extname) annotation is given for a method or some other definition, its implementation will use the name extname instead of the regular name. An alpha annotation is mandatory for definitions with symbolic names.
An annotation that defines an external name for a definition. If an alpha(extname) annotation is given for a method or some other definition, its implementation will use the name extname instead of the regular name. An alpha annotation is mandatory for definitions with symbolic names.
Attributes
- Deprecated
- use @targetName instead
- Source
- alpha.scala
- Supertypes
Experimental classlikes
Base trait for macro annotation implementation. Macro annotations can transform definitions and add new definitions.
Base trait for macro annotation implementation. Macro annotations can transform definitions and add new definitions.
See: MacroAnnotation.transform
Attributes
- Experimental
- true
- Source
- MacroAnnotation.scala
- Supertypes
Marks an annotated class as a capability. If the annotation is present and -Ycc is set, any (possibly aliased or refined) instance of the class type is implicitly augmented with the universal capture set. Example
Marks an annotated class as a capability. If the annotation is present and -Ycc is set, any (possibly aliased or refined) instance of the class type is implicitly augmented with the universal capture set. Example
Attributes
- Deprecated
- To make a class a capability, let it derive from the `Capability` trait instead
- Experimental
- true
- Source
- capability.scala
- Supertypes
Annotations to control the behavior of the compiler check for safe initialization of static obects.
Annotations to control the behavior of the compiler check for safe initialization of static obects.
Programmers usually do not need to use any annotations. They are intended for complex initialization code in static objects.
Attributes
- Experimental
- true
- Source
- init.scala
- Supertypes
- Self type
- 
               init.type
An annotation that indicates capture of a set of references under capture checking.
An annotation that indicates capture of a set of references under capture checking.
T @retains[x.type | y.type | z.type]
is the internal representation used for the capturing type
T ^ {x, y, z}
The annotation can also be written explicitly if one wants to avoid the non-standard capturing type syntax.
Attributes
- Experimental
- true
- Source
- retains.scala
- Supertypes
An annotation that indicates capture of an enclosing by-name type
An annotation that indicates capture of an enclosing by-name type
Attributes
- Experimental
- true
- Source
- retainsByName.scala
- Supertypes
Equivalent in meaning to @retains[cap.type], but consumes less bytecode.
Equivalent in meaning to @retains[cap.type], but consumes less bytecode.
Attributes
- Experimental
- true
- Source
- retains.scala
- Supertypes
Attributes
- Experimental
- true
- Source
- unroll.scala
- Supertypes