This Java package is a collection of "lints" (aka "checkers") for XMIR (an intermediate representation of a EO program). This is not about static analysis or code formatting. This is about best practices and readiness of code for successful compilation and execution.
We use this package as a dependency in the EO-to-Java compiler:
<dependency>
<groupId>org.eolang</groupId>
<artifactId>lints</artifactId>
<version>0.0.34</version>
</dependency>
You can also use it in order to validate the validity of XMIR documents your software may generate:
import com.jcabi.xml.StrictXML;
import org.eolang.lints.Program;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
final class Foo {
@Test
void testValidProgram() {
Assertions.assertTrue(
new Program(
new StrictXML("<program> your XMIR goes here </program>")
).defects().isEmpty()
);
}
}
Then, you can run a whole-program analysis of XMIR files
in your project, using the Programs
class (there is a
different set of lints to be executed here!):
import java.nio.file.Paths;
import org.eolang.lints.Programs;
import org.junit.jupiter.api.Assertions;
import org.junit.jupiter.api.Test;
final class Foo {
@Test
void testSetOfPrograms() {
Assertions.assertTrue(
new Programs(
Paths.get("xmir-files") // directory with XMIR files
).defects().isEmpty()
);
}
}
It is possible to disable any particular linter in a program,
with the help of the +unlint
meta.
The library is designed as a set of lints, each of which
is a separate class implementing the Lint
interface.
Each lint is responsible for checking one particular aspect
of the XMIR document. The Program
class is responsible for
running all lints and collecting defects for a single XMIR file.
The Programs
class is responsible for running all lints and
collecting defects for a set of XMIR files. All in all,
there are only four classes and interfaces that are supposed to
be exposed to a user of the library:
Program
- checker of a single XMIRPrograms
- checker of a set of XMIRDefect
- a single defect discoveredSeverity
- a severity of a defect
There are also a few classes that implement Iterable<Lint>
:
PkMono
, PkWpa
, and PkByXsl
.
They are supposed to be used only by the Program
and Programs
,
and are not supposed to be exposed to the user of the library.
They are responsible for providing a set of lints to be executed,
building them from the information in classpath.
Here is the result of linting XMIRs:
Input: com/sun/jna/Pointer.class
Size of .class: 22Kb (22Kb bytes)
Size of .xmir after disassemble: 1Mb (1Mb bytes, 29630 lines)
Lint time: 10s (10477 ms)
empty-object (2678 ms)
name-outside-of-abstract-object (222 ms)
line-is-absent (130 ms)
incorrect-bytes-format (107 ms)
unsorted-metas (103 ms)
unknown-name (84 ms)
duplicate-names (79 ms)
object-has-data (78 ms)
self-naming (60 ms)
duplicate-aliases (53 ms)
broken-alias-first (51 ms)
sparse-decoration (48 ms)
duplicate-metas (47 ms)
decorated-formation (39 ms)
unknown-rt (38 ms)
many-free-attributes (34 ms)
The results were calculated in this GHA job on 2025-01-14 at 12:24, on Linux with 4 CPUs.
Fork repository, make changes, then send us
a pull request.
We will review your changes and apply them to the master
branch shortly,
provided they don't violate our quality standards. To avoid frustration,
before sending us your pull request please run full Maven build:
mvn clean install -Pqulice
Also, run this and make sure your changes don't slow us down:
mvn jmh:benchmark
You will need Maven 3.3+ and Java 11+ installed.