<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <parent>
        <groupId>io.trino</groupId>
        <artifactId>trino-root</artifactId>
        <version>433</version>
        <relativePath>../../pom.xml</relativePath>
    </parent>

    <artifactId>trino-spi</artifactId>

    <properties>
        <air.main.basedir>${project.parent.basedir}</air.main.basedir>
        <released-artifacts.dir>${project.build.directory}/released-artifacts</released-artifacts.dir>
        <trino.check.skip-revapi>${air.check.skip-basic}</trino.check.skip-revapi>
    </properties>

    <!-- the SPI should have only minimal dependencies -->
    <dependencies>
        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-annotations</artifactId>
        </dependency>

        <dependency>
            <groupId>com.google.errorprone</groupId>
            <artifactId>error_prone_annotations</artifactId>
            <optional>true</optional>
        </dependency>

        <dependency>
            <groupId>io.airlift</groupId>
            <artifactId>slice</artifactId>
        </dependency>

        <dependency>
            <groupId>io.opentelemetry</groupId>
            <artifactId>opentelemetry-api</artifactId>
        </dependency>

        <dependency>
            <groupId>jakarta.annotation</groupId>
            <artifactId>jakarta.annotation-api</artifactId>
            <optional>true</optional>
        </dependency>

        <dependency>
            <groupId>io.opentelemetry</groupId>
            <artifactId>opentelemetry-context</artifactId>
            <scope>runtime</scope>
        </dependency>

        <dependency>
            <groupId>org.openjdk.jol</groupId>
            <artifactId>jol-core</artifactId>
            <scope>runtime</scope>
        </dependency>

        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-core</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>com.fasterxml.jackson.core</groupId>
            <artifactId>jackson-databind</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>com.google.guava</groupId>
            <artifactId>guava</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>com.google.inject</groupId>
            <artifactId>guice</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>io.airlift</groupId>
            <artifactId>json</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>io.airlift</groupId>
            <artifactId>junit-extensions</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>io.airlift</groupId>
            <artifactId>testing</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>io.trino</groupId>
            <artifactId>trino-testing-services</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>it.unimi.dsi</groupId>
            <artifactId>fastutil</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.assertj</groupId>
            <artifactId>assertj-core</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-api</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.junit.jupiter</groupId>
            <artifactId>junit-jupiter-engine</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.openjdk.jmh</groupId>
            <artifactId>jmh-core</artifactId>
            <scope>test</scope>
        </dependency>

        <dependency>
            <groupId>org.openjdk.jmh</groupId>
            <artifactId>jmh-generator-annprocess</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <resources>
            <resource>
                <filtering>true</filtering>
                <directory>src/main/resources</directory>
                <includes>
                    <include>io/trino/spi/trino-spi-version.txt</include>
                </includes>
            </resource>

            <resource>
                <filtering>false</filtering>
                <directory>src/main/resources</directory>
                <excludes>
                    <exclude>io/trino/spi/trino-spi-version.txt</exclude>
                </excludes>
            </resource>
        </resources>

        <plugins>
            <plugin>
                <groupId>org.revapi</groupId>
                <artifactId>revapi-maven-plugin</artifactId>
                <version>0.15.0</version>
                <configuration>
                    <skip>${trino.check.skip-revapi}</skip>
                    <ignoreSuggestionsFormat>xml</ignoreSuggestionsFormat>
                    <analysisConfiguration>
                        <revapi.filter>
                            <elements>
                                <exclude>
                                    <item>
                                        <matcher>java</matcher>
                                        <match>@io.trino.spi.Experimental(*) ^*;</match>
                                    </item>
                                </exclude>
                            </elements>
                        </revapi.filter>
                        <revapi.differences>
                            <ignore>true</ignore>
                            <differences>
                                <!-- Allow adding new annotations (such as @Nullable) -->
                                <item>
                                    <code>java.annotation.added</code>
                                </item>
                                <!-- Allow changing enum constant order (e.g., StandardErrorCode) -->
                                <item>
                                    <code>java.field.enumConstantOrderChanged</code>
                                </item>
                                <!-- Allow arbitrary changes to unstable APIs -->
                                <item>
                                    <regex>true</regex>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>
                                        <matcher>java</matcher>
                                        <match>@io.trino.spi.Unstable *;</match>
                                    </old>
                                </item>
                                <!-- Allow removing things that were previously deprecated -->
                                <item>
                                    <regex>true</regex>
                                    <code>java\.(class|method|field)\.removed</code>
                                    <old>
                                        <matcher>java</matcher>
                                        <match>@java.lang.Deprecated(*) ^*;</match>
                                    </old>
                                </item>
                                <!-- Backwards incompatible changes since the previous release -->
                                <!-- Any exclusions below can be deleted after each release -->
                                <item>
                                    <code>java.class.nonPublicPartOfAPI</code>
                                    <old>class io.trino.spi.block.SqlMap.HashTableSupplier</old>
                                    <new>class io.trino.spi.block.SqlMap.HashTableSupplier</new>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method void io.trino.spi.block.SqlMap::&lt;init&gt;(io.trino.spi.type.MapType, io.trino.spi.block.Block, io.trino.spi.block.Block, io.trino.spi.block.SqlMap.HashTableSupplier, int, int)</old>
                                    <new>method void io.trino.spi.block.SqlMap::&lt;init&gt;(io.trino.spi.type.MapType, io.trino.spi.block.Block, io.trino.spi.block.Block, io.trino.spi.block.SqlMap.HashTableSupplier, int, int)</new>
                                    <oldVisibility>public</oldVisibility>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.Block io.trino.spi.block.BufferedMapValueBuilder::build(int, io.trino.spi.block.MapValueBuilder&lt;E&gt;) throws E</old>
                                    <new>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.SqlMap io.trino.spi.block.BufferedMapValueBuilder::build(int, io.trino.spi.block.MapValueBuilder&lt;E&gt;) throws E</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.Block io.trino.spi.block.MapValueBuilder&lt;E extends java.lang.Throwable&gt;::buildMapValue(io.trino.spi.type.MapType, int, io.trino.spi.block.MapValueBuilder&lt;E&gt;) throws E</old>
                                    <new>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.SqlMap io.trino.spi.block.MapValueBuilder&lt;E extends java.lang.Throwable&gt;::buildMapValue(io.trino.spi.type.MapType, int, io.trino.spi.block.MapValueBuilder&lt;E&gt;) throws E</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.type.MapType::getObject(io.trino.spi.block.Block, int)</old>
                                    <new>method io.trino.spi.block.SqlMap io.trino.spi.type.MapType::getObject(io.trino.spi.block.Block, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.Block io.trino.spi.block.BufferedMapValueBuilder::build(int, io.trino.spi.block.MapValueBuilder&lt;E&gt;) throws E</old>
                                    <new>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.SqlMap io.trino.spi.block.BufferedMapValueBuilder::build(int, io.trino.spi.block.MapValueBuilder&lt;E&gt;) throws E</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.Block io.trino.spi.block.MapValueBuilder&lt;E extends java.lang.Throwable&gt;::buildMapValue(io.trino.spi.type.MapType, int, io.trino.spi.block.MapValueBuilder&lt;E&gt;) throws E</old>
                                    <new>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.SqlMap io.trino.spi.block.MapValueBuilder&lt;E extends java.lang.Throwable&gt;::buildMapValue(io.trino.spi.type.MapType, int, io.trino.spi.block.MapValueBuilder&lt;E&gt;) throws E</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.type.MapType::getObject(io.trino.spi.block.Block, int)</old>
                                    <new>method io.trino.spi.block.SqlMap io.trino.spi.type.MapType::getObject(io.trino.spi.block.Block, int)</new>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <old>class io.trino.spi.block.SingleRowBlock</old>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <old>class io.trino.spi.block.SingleRowBlockEncoding</old>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.Block io.trino.spi.block.BufferedRowValueBuilder::build(io.trino.spi.block.RowValueBuilder&lt;E&gt;) throws E</old>
                                    <new>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.SqlRow io.trino.spi.block.BufferedRowValueBuilder::build(io.trino.spi.block.RowValueBuilder&lt;E&gt;) throws E</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.Block io.trino.spi.block.RowValueBuilder&lt;E extends java.lang.Throwable&gt;::buildRowValue(io.trino.spi.type.RowType, io.trino.spi.block.RowValueBuilder&lt;E&gt;) throws E</old>
                                    <new>method &lt;E extends java.lang.Throwable&gt; io.trino.spi.block.SqlRow io.trino.spi.block.RowValueBuilder&lt;E extends java.lang.Throwable&gt;::buildRowValue(io.trino.spi.type.RowType, io.trino.spi.block.RowValueBuilder&lt;E&gt;) throws E</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.type.RowType::getObject(io.trino.spi.block.Block, int)</old>
                                    <new>method io.trino.spi.block.SqlRow io.trino.spi.type.RowType::getObject(io.trino.spi.block.Block, int)</new>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <old>class io.trino.spi.block.AbstractVariableWidthBlock</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.airlift.slice.Slice io.trino.spi.block.VariableWidthBlock::getRawSlice(int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.VariableWidthBlock::isEntryNull(int)</old>
                                </item>
                                <item>
                                    <code>java.class.noLongerInheritsFromClass</code>
                                    <old>class io.trino.spi.block.VariableWidthBlock</old>
                                    <new>class io.trino.spi.block.VariableWidthBlock</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractArrayBlock::copyPositions(int[], int, int) @ io.trino.spi.block.ArrayBlock</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractArrayBlock::copyRegion(int, int) @ io.trino.spi.block.ArrayBlock</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::getLoadedBlock()</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::getLoadedBlock()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractArrayBlock::getRegion(int, int) @ io.trino.spi.block.ArrayBlock</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractArrayBlock::getSingleValueBlock(int) @ io.trino.spi.block.ArrayBlock</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ByteArrayBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.ByteArrayBlock io.trino.spi.block.ByteArrayBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ByteArrayBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.ByteArrayBlock io.trino.spi.block.ByteArrayBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ByteArrayBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.ByteArrayBlock io.trino.spi.block.ByteArrayBlock::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ByteArrayBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.ByteArrayBlock io.trino.spi.block.ByteArrayBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ByteArrayBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.ByteArrayBlock io.trino.spi.block.ByteArrayBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Fixed12Block::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.Fixed12Block io.trino.spi.block.Fixed12Block::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Fixed12Block::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.Fixed12Block io.trino.spi.block.Fixed12Block::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Fixed12Block::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.Fixed12Block io.trino.spi.block.Fixed12Block::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Fixed12Block::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.Fixed12Block io.trino.spi.block.Fixed12Block::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Fixed12Block::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.Fixed12Block io.trino.spi.block.Fixed12Block::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Int128ArrayBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.Int128ArrayBlock io.trino.spi.block.Int128ArrayBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Int128ArrayBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.Int128ArrayBlock io.trino.spi.block.Int128ArrayBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Int128ArrayBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.Int128ArrayBlock io.trino.spi.block.Int128ArrayBlock::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Int128ArrayBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.Int128ArrayBlock io.trino.spi.block.Int128ArrayBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Int128ArrayBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.Int128ArrayBlock io.trino.spi.block.Int128ArrayBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.IntArrayBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.IntArrayBlock io.trino.spi.block.IntArrayBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.IntArrayBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.IntArrayBlock io.trino.spi.block.IntArrayBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.IntArrayBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.IntArrayBlock io.trino.spi.block.IntArrayBlock::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.IntArrayBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.IntArrayBlock io.trino.spi.block.IntArrayBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.IntArrayBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.IntArrayBlock io.trino.spi.block.IntArrayBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.LongArrayBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.LongArrayBlock io.trino.spi.block.LongArrayBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.LongArrayBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.LongArrayBlock io.trino.spi.block.LongArrayBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.LongArrayBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.LongArrayBlock io.trino.spi.block.LongArrayBlock::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.LongArrayBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.LongArrayBlock io.trino.spi.block.LongArrayBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.LongArrayBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.LongArrayBlock io.trino.spi.block.LongArrayBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractMapBlock::copyPositions(int[], int, int) @ io.trino.spi.block.MapBlock</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractMapBlock::copyRegion(int, int) @ io.trino.spi.block.MapBlock</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractMapBlock::getRegion(int, int) @ io.trino.spi.block.MapBlock</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractMapBlock::getSingleValueBlock(int) @ io.trino.spi.block.MapBlock</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractRowBlock::copyPositions(int[], int, int) @ io.trino.spi.block.RowBlock</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractRowBlock::copyRegion(int, int) @ io.trino.spi.block.RowBlock</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RowBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractRowBlock::getRegion(int, int) @ io.trino.spi.block.RowBlock</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractRowBlock::getSingleValueBlock(int) @ io.trino.spi.block.RowBlock</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ShortArrayBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.ShortArrayBlock io.trino.spi.block.ShortArrayBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ShortArrayBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.ShortArrayBlock io.trino.spi.block.ShortArrayBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ShortArrayBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.ShortArrayBlock io.trino.spi.block.ShortArrayBlock::copyWithAppendedNull()</new>
                                    <justification>ADD YOUR EXPLANATION FOR THE NECESSITY OF THIS CHANGE</justification>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ShortArrayBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.ShortArrayBlock io.trino.spi.block.ShortArrayBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ShortArrayBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.ShortArrayBlock io.trino.spi.block.ShortArrayBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.VariableWidthBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.VariableWidthBlock io.trino.spi.block.VariableWidthBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.VariableWidthBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.VariableWidthBlock io.trino.spi.block.VariableWidthBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.VariableWidthBlock::copyWithAppendedNull()</old>
                                    <new>method io.trino.spi.block.VariableWidthBlock io.trino.spi.block.VariableWidthBlock::copyWithAppendedNull()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.VariableWidthBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.VariableWidthBlock io.trino.spi.block.VariableWidthBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.AbstractVariableWidthBlock::getSingleValueBlock(int) @ io.trino.spi.block.VariableWidthBlock</old>
                                    <new>method io.trino.spi.block.VariableWidthBlock io.trino.spi.block.VariableWidthBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.addedToInterface</code>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.block.Block::getUnderlyingValueBlock()</new>
                                </item>
                                <item>
                                    <code>java.method.addedToInterface</code>
                                    <new>method int io.trino.spi.block.Block::getUnderlyingValuePosition(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RunLengthEncodedBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.block.RunLengthEncodedBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RunLengthEncodedBlock::getValue()</old>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.block.RunLengthEncodedBlock::getValue()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Block::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.block.Block::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.DictionaryBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.block.DictionaryBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.LazyBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.block.LazyBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.DictionaryBlock::getDictionary()</old>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.block.DictionaryBlock::getDictionary()</new>
                                </item>
                                <item>
                                    <code>java.method.addedToInterface</code>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.block.BlockBuilder::buildValueBlock()</new>
                                </item>
                                <item>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method void io.trino.spi.type.AbstractType::&lt;init&gt;(io.trino.spi.type.TypeSignature, java.lang.Class&lt;?&gt;)</old>
                                    <new>method void io.trino.spi.type.AbstractType::&lt;init&gt;(io.trino.spi.type.TypeSignature, java.lang.Class&lt;?&gt;, java.lang.Class&lt;? extends io.trino.spi.block.ValueBlock&gt;)</new>
                                </item>
                                <item>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method void io.trino.spi.type.TimeWithTimeZoneType::&lt;init&gt;(int, java.lang.Class&lt;?&gt;)</old>
                                    <new>method void io.trino.spi.type.TimeWithTimeZoneType::&lt;init&gt;(int, java.lang.Class&lt;?&gt;, java.lang.Class&lt;? extends io.trino.spi.block.ValueBlock&gt;)</new>
                                </item>
                                <item>
                                    <code>java.method.addedToInterface</code>
                                    <new>method java.lang.Class&lt;? extends io.trino.spi.block.ValueBlock&gt; io.trino.spi.type.Type::getValueBlockType()</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.type.TypeUtils::writeNativeValue(io.trino.spi.type.Type, java.lang.Object)</old>
                                    <new>method io.trino.spi.block.ValueBlock io.trino.spi.type.TypeUtils::writeNativeValue(io.trino.spi.type.Type, java.lang.Object)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::fromElementBlock(int, java.util.Optional&lt;boolean[]&gt;, int[], io.trino.spi.block.Block)</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::fromElementBlock(int, java.util.Optional&lt;boolean[]&gt;, int[], io.trino.spi.block.Block)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.type.MapType::createBlockFromKeyValue(java.util.Optional&lt;boolean[]&gt;, int[], io.trino.spi.block.Block, io.trino.spi.block.Block)</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.type.MapType::createBlockFromKeyValue(java.util.Optional&lt;boolean[]&gt;, int[], io.trino.spi.block.Block, io.trino.spi.block.Block)</new>
                                </item>
                                <item>
                                    <code>java.method.visibilityIncreased</code>
                                    <old>method int[] io.trino.spi.block.DictionaryBlock::getRawIds()</old>
                                    <new>method int[] io.trino.spi.block.DictionaryBlock::getRawIds()</new>
                                    <oldVisibility>package</oldVisibility>
                                    <newVisibility>public</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityIncreased</code>
                                    <old>method int io.trino.spi.block.DictionaryBlock::getRawIdsOffset()</old>
                                    <new>method int io.trino.spi.block.DictionaryBlock::getRawIdsOffset()</new>
                                    <oldVisibility>package</oldVisibility>
                                    <newVisibility>public</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.Block::bytesCompare(int, int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.Block::bytesEqual(int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.Block::compareTo(int, int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.Block::equals(int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.Block::hash(int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.DictionaryBlock::bytesCompare(int, int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.DictionaryBlock::bytesEqual(int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.DictionaryBlock::compareTo(int, int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.DictionaryBlock::equals(int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.DictionaryBlock::hash(int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.LazyBlock::bytesCompare(int, int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.LazyBlock::bytesEqual(int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.LazyBlock::compareTo(int, int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.LazyBlock::equals(int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.LazyBlock::hash(int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.RunLengthEncodedBlock::bytesCompare(int, int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.RunLengthEncodedBlock::bytesEqual(int, int, io.airlift.slice.Slice, int, int)</old>
                                    <justification>ADD YOUR EXPLANATION FOR THE NECESSITY OF THIS CHANGE</justification>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.RunLengthEncodedBlock::compareTo(int, int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.RunLengthEncodedBlock::equals(int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.RunLengthEncodedBlock::hash(int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method void io.trino.spi.block.Block::writeSliceTo(int, int, int, io.airlift.slice.SliceOutput)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method void io.trino.spi.block.DictionaryBlock::writeSliceTo(int, int, int, io.airlift.slice.SliceOutput)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method void io.trino.spi.block.LazyBlock::writeSliceTo(int, int, int, io.airlift.slice.SliceOutput)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method void io.trino.spi.block.RunLengthEncodedBlock::writeSliceTo(int, int, int, io.airlift.slice.SliceOutput)</old>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ByteArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</old>
                                    <new>method io.trino.spi.block.ByteArrayBlock io.trino.spi.block.ByteArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Fixed12BlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</old>
                                    <new>method io.trino.spi.block.Fixed12Block io.trino.spi.block.Fixed12BlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Int128ArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</old>
                                    <new>method io.trino.spi.block.Int128ArrayBlock io.trino.spi.block.Int128ArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.IntArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</old>
                                    <new>method io.trino.spi.block.IntArrayBlock io.trino.spi.block.IntArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.LongArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</old>
                                    <new>method io.trino.spi.block.LongArrayBlock io.trino.spi.block.LongArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ShortArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</old>
                                    <new>method io.trino.spi.block.ShortArrayBlock io.trino.spi.block.ShortArrayBlockEncoding::readBlock(io.trino.spi.block.BlockEncodingSerde, io.airlift.slice.SliceInput)</new>
                                </item>
                                <item>
                                    <code>java.method.nowStatic</code>
                                    <old>method void io.trino.spi.type.AbstractIntType::checkValueValid(long)</old>
                                    <new>method void io.trino.spi.type.AbstractIntType::checkValueValid(long)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.MapBlock io.trino.spi.block.MapBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RowBlock::copyPositions(int[], int, int)</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::copyPositions(int[], int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RowBlock::copyRegion(int, int)</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::copyRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RowBlock::getRegion(int, int)</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::getRegion(int, int)</new>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RowBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.VariableWidthBlock::bytesCompare(int, int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.VariableWidthBlock::bytesEqual(int, int, io.airlift.slice.Slice, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.VariableWidthBlock::compareTo(int, int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.VariableWidthBlock::equals(int, int, io.trino.spi.block.Block, int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChangedCovariantly</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.VariableWidthBlock::getSingleValueBlock(int)</old>
                                    <new>method io.trino.spi.block.VariableWidthBlock io.trino.spi.block.VariableWidthBlock::getSingleValueBlock(int)</new>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.VariableWidthBlock::hash(int, int, int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method void io.trino.spi.block.VariableWidthBlock::writeSliceTo(int, int, int, io.airlift.slice.SliceOutput)</old>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.ArrayBlock</old>
                                    <new>class io.trino.spi.block.ArrayBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.ByteArrayBlock</old>
                                    <new>class io.trino.spi.block.ByteArrayBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.DictionaryBlock</old>
                                    <new>class io.trino.spi.block.DictionaryBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.Fixed12Block</old>
                                    <new>class io.trino.spi.block.Fixed12Block</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.Int128ArrayBlock</old>
                                    <new>class io.trino.spi.block.Int128ArrayBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.IntArrayBlock</old>
                                    <new>class io.trino.spi.block.IntArrayBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.LazyBlock</old>
                                    <new>class io.trino.spi.block.LazyBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.LongArrayBlock</old>
                                    <new>class io.trino.spi.block.LongArrayBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.MapBlock</old>
                                    <new>class io.trino.spi.block.MapBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.RowBlock</old>
                                    <new>class io.trino.spi.block.RowBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.RunLengthEncodedBlock</old>
                                    <new>class io.trino.spi.block.RunLengthEncodedBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.ShortArrayBlock</old>
                                    <new>class io.trino.spi.block.ShortArrayBlock</new>
                                </item>
                                <item>
                                    <code>java.class.nowFinal</code>
                                    <old>class io.trino.spi.block.VariableWidthBlock</old>
                                    <new>class io.trino.spi.block.VariableWidthBlock</new>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method int io.trino.spi.block.ArrayBlock::getOffsetBase()</old>
                                    <new>method int io.trino.spi.block.ArrayBlock::getOffsetBase()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method int[] io.trino.spi.block.ArrayBlock::getOffsets()</old>
                                    <new>method int[] io.trino.spi.block.ArrayBlock::getOffsets()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::getRawElementBlock()</old>
                                    <new>method io.trino.spi.block.Block io.trino.spi.block.ArrayBlock::getRawElementBlock()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method void io.trino.spi.block.MapBlock::ensureHashTableLoaded()</old>
                                    <new>method void io.trino.spi.block.MapBlock::ensureHashTableLoaded()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method io.trino.spi.block.MapHashTables io.trino.spi.block.MapBlock::getHashTables()</old>
                                    <new>method io.trino.spi.block.MapHashTables io.trino.spi.block.MapBlock::getHashTables()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method io.trino.spi.type.MapType io.trino.spi.block.MapBlock::getMapType()</old>
                                    <new>method io.trino.spi.type.MapType io.trino.spi.block.MapBlock::getMapType()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method int io.trino.spi.block.MapBlock::getOffsetBase()</old>
                                    <new>method int io.trino.spi.block.MapBlock::getOffsetBase()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method int[] io.trino.spi.block.MapBlock::getOffsets()</old>
                                    <new>method int[] io.trino.spi.block.MapBlock::getOffsets()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::getRawKeyBlock()</old>
                                    <new>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::getRawKeyBlock()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::getRawValueBlock()</old>
                                    <new>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::getRawValueBlock()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method int[] io.trino.spi.block.RowBlock::getFieldBlockOffsets()</old>
                                    <new>method int[] io.trino.spi.block.RowBlock::getFieldBlockOffsets()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method int io.trino.spi.block.RowBlock::getOffsetBase()</old>
                                    <new>method int io.trino.spi.block.RowBlock::getOffsetBase()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method java.util.List&lt;io.trino.spi.block.Block&gt; io.trino.spi.block.RowBlock::getRawFieldBlocks()</old>
                                    <new>method java.util.List&lt;io.trino.spi.block.Block&gt; io.trino.spi.block.RowBlock::getRawFieldBlocks()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method int io.trino.spi.block.VariableWidthBlock::getPositionOffset(int)</old>
                                    <new>method int io.trino.spi.block.VariableWidthBlock::getPositionOffset(int)</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <old>class io.trino.spi.block.ColumnarRow</old>
                                </item>
                                <item>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::fromFieldBlocks(int, java.util.Optional&lt;boolean[]&gt;, io.trino.spi.block.Block[])</old>
                                    <new>method io.trino.spi.block.RowBlock io.trino.spi.block.RowBlock::fromFieldBlocks(int, io.trino.spi.block.Block[])</new>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int[] io.trino.spi.block.RowBlock::getFieldBlockOffsets()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.RowBlock::getOffsetBase()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method int io.trino.spi.block.RowBlock::getFieldBlockOffset(int)</old>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method java.util.List&lt;io.trino.spi.block.Block&gt; io.trino.spi.block.RowBlock::getRawFieldBlocks()</old>
                                    <new>method io.trino.spi.block.Block[] io.trino.spi.block.RowBlock::getRawFieldBlocks()</new>
                                </item>
                                <item>
                                    <code>java.method.visibilityReduced</code>
                                    <old>method java.util.List&lt;io.trino.spi.block.Block&gt; io.trino.spi.block.RowBlock::getRawFieldBlocks()</old>
                                    <new>method io.trino.spi.block.Block[] io.trino.spi.block.RowBlock::getRawFieldBlocks()</new>
                                    <oldVisibility>protected</oldVisibility>
                                    <newVisibility>package</newVisibility>
                                </item>
                                <item>
                                    <code>java.method.addedToInterface</code>
                                    <new>method java.lang.String io.trino.spi.security.SystemAccessControlFactory.SystemAccessControlContext::getVersion()</new>
                                </item>
                            </differences>
                        </revapi.differences>
                    </analysisConfiguration>
                </configuration>
                <dependencies>
                    <dependency>
                        <groupId>org.revapi</groupId>
                        <artifactId>revapi-java</artifactId>
                        <version>0.28.1</version>
                    </dependency>
                </dependencies>
                <executions>
                    <execution>
                        <goals>
                            <goal>check</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
    </build>
</project>
