All Downloads are FREE. Search and download functionalities are using the official Maven repository.

scala.scalanative.nir.Attrs.scala Maven / Gradle / Ivy

package scala.scalanative
package nir

import scala.collection.mutable
import nir.Attr._

sealed abstract class Attr {
  final def show: String = nir.Show(this)
}

object Attr {
  sealed abstract class Inline extends Attr
  case object MayInline extends Inline // no information
  case object InlineHint extends Inline // user hinted at inlining
  case object NoInline extends Inline // should never inline
  case object AlwaysInline extends Inline // should always inline

  sealed abstract class Specialize extends Attr
  case object MaySpecialize extends Specialize
  case object NoSpecialize extends Specialize

  sealed abstract class Opt extends Attr
  case object UnOpt extends Opt
  case object NoOpt extends Opt
  case object DidOpt extends Opt
  final case class BailOpt(msg: String) extends Opt

  case object Dyn extends Attr
  case object Stub extends Attr
  case object Extern extends Attr
  final case class Link(name: String) extends Attr
  case object Abstract extends Attr
  case object LinktimeResolved extends Attr
}

final case class Attrs(
    inlineHint: Inline = MayInline,
    specialize: Specialize = MaySpecialize,
    opt: Opt = UnOpt,
    isExtern: Boolean = false,
    isDyn: Boolean = false,
    isStub: Boolean = false,
    isAbstract: Boolean = false,
    links: Seq[Attr.Link] = Seq.empty,
    isLinktimeResolved: Boolean = false
) {
  def toSeq: Seq[Attr] = {
    val out = Seq.newBuilder[Attr]

    if (inlineHint != MayInline) out += inlineHint
    if (specialize != MaySpecialize) out += specialize
    if (opt != UnOpt) out += opt
    if (isExtern) out += Extern
    if (isDyn) out += Dyn
    if (isStub) out += Stub
    if (isAbstract) out += Abstract
    if (isLinktimeResolved) out += LinktimeResolved
    out ++= links

    out.result()
  }

  // backward compatibilty
  def this(
      inlineHint: Inline,
      specialize: Specialize,
      opt: Opt,
      isExtern: Boolean,
      isDyn: Boolean,
      isStub: Boolean,
      isAbstract: Boolean,
      links: Seq[Attr.Link]
  ) = this(
    inlineHint = inlineHint,
    specialize = specialize,
    opt = opt,
    isExtern = isExtern,
    isDyn = isDyn,
    isStub = isStub,
    isAbstract = isAbstract,
    isLinktimeResolved = false,
    links = links
  )
  def copy(
      inlineHint: Inline = this.inlineHint,
      specialize: Specialize = this.specialize,
      opt: Opt = this.opt,
      isExtern: Boolean = this.isExtern,
      isDyn: Boolean = this.isDyn,
      isStub: Boolean = this.isStub,
      isAbstract: Boolean = this.isAbstract,
      links: Seq[Attr.Link] = this.links,
      isLinktimeResolved: Boolean = this.isLinktimeResolved
  ): Attrs = new Attrs(
    inlineHint = inlineHint,
    specialize = specialize,
    opt = opt,
    isExtern = isExtern,
    isDyn = isDyn,
    isStub = isStub,
    isAbstract = isAbstract,
    links = links,
    isLinktimeResolved = isLinktimeResolved
  )
  def copy(
      inlineHint: Inline,
      specialize: Specialize,
      opt: Opt,
      isExtern: Boolean,
      isDyn: Boolean,
      isStub: Boolean,
      isAbstract: Boolean,
      links: Seq[Attr.Link]
  ): Attrs = new Attrs(
    inlineHint = inlineHint,
    specialize = specialize,
    opt = opt,
    isExtern = isExtern,
    isDyn = isDyn,
    isStub = isStub,
    isAbstract = isAbstract,
    links = links,
    isLinktimeResolved = this.isLinktimeResolved
  )
}
object Attrs {
  val None = new Attrs()

  def fromSeq(attrs: Seq[Attr]): Attrs = {
    var inline = None.inlineHint
    var specialize = None.specialize
    var opt = None.opt
    var isExtern = false
    var isDyn = false
    var isStub = false
    var isAbstract = false
    var isLinktimeResolved = false
    val links = Seq.newBuilder[Attr.Link]

    attrs.foreach {
      case attr: Inline     => inline = attr
      case attr: Specialize => specialize = attr
      case attr: Opt        => opt = attr
      case Extern           => isExtern = true
      case Dyn              => isDyn = true
      case Stub             => isStub = true
      case link: Attr.Link  => links += link
      case Abstract         => isAbstract = true
      case LinktimeResolved => isLinktimeResolved = true
    }

    new Attrs(
      inlineHint = inline,
      specialize = specialize,
      opt = opt,
      isExtern = isExtern,
      isDyn = isDyn,
      isStub = isStub,
      isAbstract = isAbstract,
      isLinktimeResolved = isLinktimeResolved,
      links = links.result()
    )
  }

  // backward compatibilty
  def apply(
      inlineHint: Inline,
      specialize: Specialize,
      opt: Opt,
      isExtern: Boolean,
      isDyn: Boolean,
      isStub: Boolean,
      isAbstract: Boolean,
      links: Seq[Attr.Link]
  ): Attrs = new Attrs(
    inlineHint = inlineHint,
    specialize = specialize,
    opt = opt,
    isExtern = isExtern,
    isDyn = isDyn,
    isStub = isStub,
    isAbstract = isAbstract,
    isLinktimeResolved = false,
    links = links
  )
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy