Documentation

Mathlib.Tactic.Linter.MinImports

The minImports linter #

The minImports linter incrementally computes the minimal imports needed for each file to build. Whenever it detects that a new command requires an increase in the (transitive) imports that it computed so far, it emits a warning mentioning the bigger minimal imports.

Unlike the related #min_imports command, the linter takes into account notation and tactic information. It also works incrementally, accumulating increasing import information. This is better suited, for instance, to split files.

The "minImports" linter #

The "minImports" linter tracks information about minimal imports over several commands.

ImportState is the structure keeping track of the data that the minImports linter uses.

  • transClosure is the import graph of the current file.
  • minImports is the NameSet of minimal imports to build the file up to the current command.
  • importSize is the number of transitive imports to build the file up to the current command.
  • The transitive closure of the import graph of the current file. The value is none only at initialization time, as the linter immediately sets it to its value for the current file.

  • minImports : Lean.NameSet

    The minimal imports needed to build the file up to the current command.

  • importSize : Nat

    The number of transitive imports needed to build the file up to the current command.

Instances For

    minImportsRef keeps track of cumulative imports across multiple commands, using ImportState.

    #reset_min_imports sets to empty the current list of cumulative imports.

    Equations
    Instances For

      The minImports linter incrementally computes the minimal imports needed for each file to build. Whenever it detects that a new command requires an increase in the (transitive) imports that it computed so far, it emits a warning mentioning the bigger minimal imports.

      Unlike the related #min_imports command, the linter takes into account notation and tactic information. It also works incrementally, providing information that is better suited, for instance, to split files.

      The linter.minImports.increases regulates whether the minImports linter reports the change in number of imports, when it reports import changes. Setting this option to false helps with test stability.

      importsBelow tc ms takes as input a NameMap NameSet tc, representing the transitiveClosure of the imports of the current module, and a NameSet of module names ms. It returns the modules that are transitively imported by ms, using the data in tc.

      Equations
      Instances For

        The minImports linter incrementally computes the minimal imports needed for each file to build. Whenever it detects that a new command requires an increase in the (transitive) imports that it computed so far, it emits a warning mentioning the bigger minimal imports.

        Unlike the related #min_imports command, the linter takes into account notation and tactic information. It also works incrementally, providing information that is better suited, for instance, to split files.

        Equations
        • One or more equations did not get rendered due to their size.
        Instances For