Class/Object

scalafix.v0

Rule

Related Docs: object Rule | package v0

Permalink

abstract class Rule extends AnyRef

A Scalafix Rule.

To provide automatic fixes for this rule, override the fix method. Example:

object ReverseNames extends Rule("ReverseNames") {
  override def fix(ctx: RuleCtx) =
    ctx.tree.collect {
      case name @ Name(value) => ctx.replaceTree(name, value.reverse)
    }.asPatch
}

To report violations of this rule (without automatic fix), override the check method. Example:

// example syntactic linter
object NoNulls extends Rule("NoNulls") {
  val error = LintCategory.error("Nulls are not allowed.")
  override def check(ctx: RuleCtx): List[LintMessage] = ctx.tree.collect {
    case nil @ q"null" => error.at(nil.pos)
  }
}
Self Type
Rule
Linear Supertypes
Known Subclasses
Ordering
  1. Alphabetic
  2. By Inheritance
Inherited
  1. Rule
  2. AnyRef
  3. Any
  1. Hide All
  2. Show All
Visibility
  1. Public
  2. All

Instance Constructors

  1. new Rule(ruleName: v0.RuleName)

    Permalink

    ruleName

    Name of this rule that users call via .scalafix.conf or in the sbt shell. By convention, a name should be PascalCase matching the class name of the rule. Example good name: NoVars, ExplicitUnit. Example bad name: no-vars, noVars, FixVars.

Value Members

  1. final def !=(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  2. final def ##(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  3. final def ==(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  4. final def apply(ctx: RuleCtx, patches: Map[v0.RuleName, v0.Patch]): String

    Permalink
  5. final def apply(ctx: RuleCtx, patch: v0.Patch): String

    Permalink
  6. final def apply(input: String): String

    Permalink
  7. final def apply(input: scala.meta.Input, config: ScalafixConfig = ScalafixConfig.default): String

    Permalink
  8. final def apply(ctx: RuleCtx): String

    Permalink

    Returns string output of applying this single patch.

  9. final def applyAndLint(ctx: RuleCtx): (String, List[v0.LintMessage])

    Permalink
  10. final def asInstanceOf[T0]: T0

    Permalink
    Definition Classes
    Any
  11. def check(ctx: RuleCtx): Seq[v0.LintMessage]

    Permalink

    Returns linter messages to report violations of this rule.

  12. def clone(): AnyRef

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  13. def description: String

    Permalink

    A single sentence summary of what this rule does.

  14. final def diff(ctx: RuleCtx, patch: v0.Patch): String

    Permalink
    Attributes
    protected
  15. final def diff(ctx: RuleCtx): String

    Permalink

    Returns unified diff from applying this patch

  16. final def eq(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  17. def equals(arg0: Any): Boolean

    Permalink
    Definition Classes
    AnyRef → Any
  18. def finalize(): Unit

    Permalink
    Attributes
    protected[java.lang]
    Definition Classes
    AnyRef
    Annotations
    @throws( classOf[java.lang.Throwable] )
  19. def fix(ctx: RuleCtx): v0.Patch

    Permalink

    Returns a patch to fix violations of this rule.

  20. def fixWithName(ctx: RuleCtx): Map[v0.RuleName, v0.Patch]

    Permalink
    Attributes
    protected[scalafix]
  21. final def getClass(): Class[_]

    Permalink
    Definition Classes
    AnyRef → Any
  22. def hashCode(): Int

    Permalink
    Definition Classes
    AnyRef → Any
  23. def init(config: Conf): Configured[Rule]

    Permalink

    Initialize this rule with the given user configuration.

    Initialize this rule with the given user configuration.

    This method is called once by scalafix before rule is called. Use this method to either read custom configuration or to build expensive indices.

    config

    The .scalafix.conf configuration.

    returns

    the initialized rule or an error. If no initialization is needed, return Configured.Ok(this).

  24. final def isInstanceOf[T0]: Boolean

    Permalink
    Definition Classes
    Any
  25. final def merge(other: Rule): Rule

    Permalink

    Combine this rule with another rule.

  26. final def name: v0.RuleName

    Permalink
  27. final def ne(arg0: AnyRef): Boolean

    Permalink
    Definition Classes
    AnyRef
  28. final def notify(): Unit

    Permalink
    Definition Classes
    AnyRef
  29. final def notifyAll(): Unit

    Permalink
    Definition Classes
    AnyRef
  30. def semanticOption: Option[SemanticdbIndex]

    Permalink
    Attributes
    protected[scalafix]
  31. final def synchronized[T0](arg0: ⇒ T0): T0

    Permalink
    Definition Classes
    AnyRef
  32. final def toString(): String

    Permalink
    Definition Classes
    Rule → AnyRef → Any
  33. final def wait(): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  34. final def wait(arg0: Long, arg1: Int): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )
  35. final def wait(arg0: Long): Unit

    Permalink
    Definition Classes
    AnyRef
    Annotations
    @throws( ... )

Inherited from AnyRef

Inherited from Any

Ungrouped