<?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>477</version>
        <relativePath>../../pom.xml</relativePath>
    </parent>

    <artifactId>trino-spi</artifactId>
    <name>${project.artifactId}</name>
    <description>Trino - Service Provider Interface (SPI)</description>

    <properties>
        <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-api-incubator</artifactId>
            <scope>runtime</scope>
        </dependency>

        <dependency>
            <groupId>io.opentelemetry</groupId>
            <artifactId>opentelemetry-common</artifactId>
            <scope>runtime</scope>
        </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>
            <classifier>classes</classifier>
            <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.1</version>
                <configuration>
                    <skip>${trino.check.skip-revapi}</skip>
                    <ignoreSuggestionsFormat>xml</ignoreSuggestionsFormat>
                    <analysisConfiguration>
                        <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.method.removed</code>
                                    <old>method io.trino.spi.Page io.trino.spi.Page::getLoadedPage(int[], int[])</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.block.ArrayBlock io.trino.spi.block.ArrayBlock::getLoadedBlock()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.ArrayBlock::isLoaded()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.Block::getLoadedBlock()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.Block::isLoaded()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.DictionaryBlock::getLoadedBlock()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.DictionaryBlock::isLoaded()</old>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <old>class io.trino.spi.block.LazyBlock</old>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <old>class io.trino.spi.block.LazyBlockEncoding</old>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <old>interface io.trino.spi.block.LazyBlockLoader</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.MapBlock::getLoadedBlock()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.MapBlock::isLoaded()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RowBlock::getLoadedBlock()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.RowBlock::isLoaded()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RunLengthEncodedBlock::getLoadedBlock()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method boolean io.trino.spi.block.RunLengthEncodedBlock::isLoaded()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.Page io.trino.spi.Page::getLoadedPage(int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.Page io.trino.spi.Page::getLoadedPage()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.Page io.trino.spi.Page::getLoadedPage(int[])</old>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.returnTypeTypeParametersChanged</code>
                                    <old>method java.util.List&lt;java.lang.String&gt; io.trino.spi.eventlistener.QueryInputMetadata::getColumns()</old>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.parameterTypeParameterChanged</code>
                                    <old>method void io.trino.spi.eventlistener.QueryInputMetadata::&lt;init&gt;(java.lang.String, io.trino.spi.connector.CatalogHandle.CatalogVersion, java.lang.String, java.lang.String, java.util.List&lt;java.lang.String&gt;, java.util.Optional&lt;java.lang.Object&gt;, io.trino.spi.metrics.Metrics, java.util.OptionalLong, java.util.OptionalLong)</old>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.util.Optional&lt;java.lang.Object&gt; io.trino.spi.connector.ConnectorMetadata::getInfo(io.trino.spi.connector.ConnectorTableHandle)</old>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method void io.trino.spi.eventlistener.QueryStatistics::&lt;init&gt;(java.time.Duration, java.time.Duration, java.time.Duration, java.time.Duration, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, long, long, long, long, long, long, long, long, long, long, long, long, long, long, long, long, double, double, java.util.List&lt;io.trino.spi.eventlistener.StageGcStatistics&gt;, int, boolean, java.util.List&lt;io.trino.spi.eventlistener.StageCpuDistribution&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageOutputBufferUtilization&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageOutputBufferMetrics&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageTaskStatistics&gt;, java.util.function.Supplier&lt;java.util.List&lt;java.lang.String&gt;&gt;, java.util.List&lt;io.trino.spi.eventlistener.QueryPlanOptimizerStatistics&gt;, java.util.Optional&lt;java.lang.String&gt;)</old>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method io.trino.spi.eventlistener.DoubleSymmetricDistribution io.trino.spi.eventlistener.StageTaskStatistics::getGetSplitDistribution()</old>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>method void io.trino.spi.eventlistener.StageTaskStatistics::&lt;init&gt;(int, int, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongDistribution, io.trino.spi.eventlistener.LongSymmetricDistribution, io.trino.spi.eventlistener.LongSymmetricDistribution, io.trino.spi.eventlistener.LongSymmetricDistribution, io.trino.spi.eventlistener.LongSymmetricDistribution, io.trino.spi.eventlistener.LongSymmetricDistribution, io.trino.spi.eventlistener.LongSymmetricDistribution, io.trino.spi.eventlistener.DoubleSymmetricDistribution, io.trino.spi.eventlistener.DoubleSymmetricDistribution, io.trino.spi.eventlistener.DoubleSymmetricDistribution, io.trino.spi.eventlistener.DoubleSymmetricDistribution, io.trino.spi.eventlistener.DoubleSymmetricDistribution, io.trino.spi.eventlistener.DoubleSymmetricDistribution, io.trino.spi.eventlistener.DoubleSymmetricDistribution)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.ArrayBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.ArrayBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.Block::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.Block::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.ByteArrayBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.ByteArrayBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.DictionaryBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.DictionaryBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.Fixed12Block::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.Fixed12Block::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.Int128ArrayBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.Int128ArrayBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.IntArrayBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.IntArrayBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.LongArrayBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.LongArrayBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.MapBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.MapBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.RowBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.RowBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.RunLengthEncodedBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.RunLengthEncodedBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.ShortArrayBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.ShortArrayBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method java.util.OptionalInt io.trino.spi.block.VariableWidthBlock::fixedSizeInBytesPerPosition()</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.block.VariableWidthBlock::getPositionsSizeInBytes(boolean[], int)</old>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.ArrayType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.ArrayType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.BigintType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.BigintType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.BooleanType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.BooleanType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.CharType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.CharType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.DateType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.DateType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.DoubleType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.DoubleType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.HyperLogLogType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.HyperLogLogType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.IntegerType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.IntegerType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.MapType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.MapType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.P4HyperLogLogType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.P4HyperLogLogType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.QuantileDigestType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.QuantileDigestType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.RealType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.RealType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.RowType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.RowType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.SmallintType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.SmallintType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.TimeType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.TimeType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.TinyintType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.TinyintType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.Type::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.Type::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.UuidType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.UuidType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.VarbinaryType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.VarbinaryType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.lang.Object io.trino.spi.type.VarcharType::getObjectValue(io.trino.spi.connector.ConnectorSession, io.trino.spi.block.Block, int)</old>
                                    <new>method java.lang.Object io.trino.spi.type.VarcharType::getObjectValue(io.trino.spi.block.Block, int)</new>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>parameter java.lang.String io.trino.spi.predicate.AllOrNoneValueSet::toString(===io.trino.spi.connector.ConnectorSession===)</old>
                                    <new>parameter java.lang.String io.trino.spi.predicate.AllOrNoneValueSet::toString(===int===)</new>
                                    <parameterIndex>0</parameterIndex>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method java.lang.String io.trino.spi.predicate.AllOrNoneValueSet::toString(io.trino.spi.connector.ConnectorSession, int)</old>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>parameter java.lang.String io.trino.spi.predicate.Domain::toString(===io.trino.spi.connector.ConnectorSession===)</old>
                                    <new>parameter java.lang.String io.trino.spi.predicate.Domain::toString(===int===)</new>
                                    <parameterIndex>0</parameterIndex>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method java.lang.String io.trino.spi.predicate.Domain::toString(io.trino.spi.connector.ConnectorSession, int)</old>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>parameter java.lang.String io.trino.spi.predicate.EquatableValueSet::toString(===io.trino.spi.connector.ConnectorSession===)</old>
                                    <new>parameter java.lang.String io.trino.spi.predicate.EquatableValueSet::toString(===int===)</new>
                                    <parameterIndex>0</parameterIndex>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method java.lang.String io.trino.spi.predicate.EquatableValueSet::toString(io.trino.spi.connector.ConnectorSession, int)</old>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method java.lang.String io.trino.spi.predicate.Range::toString(io.trino.spi.connector.ConnectorSession)</old>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>parameter java.lang.String io.trino.spi.predicate.SortedRangeSet::toString(===io.trino.spi.connector.ConnectorSession===)</old>
                                    <new>parameter java.lang.String io.trino.spi.predicate.SortedRangeSet::toString(===int===)</new>
                                    <parameterIndex>0</parameterIndex>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method java.lang.String io.trino.spi.predicate.SortedRangeSet::toString(io.trino.spi.connector.ConnectorSession, int)</old>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method java.lang.String io.trino.spi.predicate.TupleDomain&lt;T&gt;::toString(io.trino.spi.connector.ConnectorSession)</old>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>parameter java.lang.String io.trino.spi.predicate.ValueSet::toString(===io.trino.spi.connector.ConnectorSession===)</old>
                                    <new>parameter java.lang.String io.trino.spi.predicate.ValueSet::toString(===int===)</new>
                                    <parameterIndex>0</parameterIndex>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method java.lang.String io.trino.spi.predicate.ValueSet::toString(io.trino.spi.connector.ConnectorSession, int)</old>
                                    <justification>Type cleanup</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method java.lang.String io.trino.spi.NodeManager::getEnvironment()</old>
                                    <justification>Unused</justification>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <annotationType>@interface io.trino.spi.Experimental</annotationType>
                                </item>
                                <item>
                                    <code>java.annotation.removed</code>
                                    <annotationType>io.trino.spi.Experimental</annotationType>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.Page io.trino.spi.connector.EmptyPageSource::getNextPage()</old>
                                    <justification>Deprecated</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.Page io.trino.spi.connector.FixedPageSource::getNextPage()</old>
                                    <justification>Deprecated</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.Page io.trino.spi.connector.RecordPageSource::getNextPage()</old>
                                    <justification>Deprecated</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.addedToInterface</code>
                                    <new>method long io.trino.spi.resourcegroups.ResourceGroup::getHardPhysicalDataScanLimitBytes()</new>
                                    <justification>Add physical data scan tracking to resource groups</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.addedToInterface</code>
                                    <new>method void io.trino.spi.resourcegroups.ResourceGroup::setHardPhysicalDataScanLimitBytes(long)</new>
                                    <justification>Add physical data scan tracking to resource groups</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.addedToInterface</code>
                                    <new>method long io.trino.spi.resourcegroups.ResourceGroup::getPhysicalDataScanQuotaGenerationBytesPerSecond()</new>
                                    <justification>Add physical data scan tracking to resource groups</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.addedToInterface</code>
                                    <new>method void io.trino.spi.resourcegroups.ResourceGroup::setPhysicalDataScanQuotaGenerationBytesPerSecond(long)</new>
                                    <justification>Add physical data scan tracking to resource groups</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.visibilityIncreased</code>
                                    <old>method void io.trino.spi.type.Int128Math::multiply(long, long, long, long, long[], int)</old>
                                    <new>method void io.trino.spi.type.Int128Math::multiply(long, long, long, long, long[], int)</new>
                                    <oldVisibility>private</oldVisibility>
                                    <newVisibility>public</newVisibility>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.visibilityIncreased</code>
                                    <old>method long io.trino.spi.type.Int128Math::signExtension(long)</old>
                                    <new>method long io.trino.spi.type.Int128Math::signExtension(long)</new>
                                    <oldVisibility>private</oldVisibility>
                                    <newVisibility>public</newVisibility>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method io.trino.spi.connector.ConnectorInsertTableHandle io.trino.spi.connector.ConnectorMetadata::beginRefreshMaterializedView(io.trino.spi.connector.ConnectorSession, io.trino.spi.connector.ConnectorTableHandle, java.util.List&lt;io.trino.spi.connector.ConnectorTableHandle&gt;, io.trino.spi.connector.RetryMode, io.trino.spi.RefreshType)</old>
                                    <new>method io.trino.spi.connector.ConnectorInsertTableHandle io.trino.spi.connector.ConnectorMetadata::beginRefreshMaterializedView(io.trino.spi.connector.ConnectorSession, io.trino.spi.connector.ConnectorTableHandle, java.util.List&lt;io.trino.spi.connector.ConnectorTableHandle&gt;, boolean, io.trino.spi.connector.RetryMode, io.trino.spi.RefreshType)</new>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method java.util.Optional&lt;io.trino.spi.connector.ConnectorOutputMetadata&gt; io.trino.spi.connector.ConnectorMetadata::finishRefreshMaterializedView(io.trino.spi.connector.ConnectorSession, io.trino.spi.connector.ConnectorTableHandle, io.trino.spi.connector.ConnectorInsertTableHandle, java.util.Collection&lt;io.airlift.slice.Slice&gt;, java.util.Collection&lt;io.trino.spi.statistics.ComputedStatistics&gt;, java.util.List&lt;io.trino.spi.connector.ConnectorTableHandle&gt;, java.util.List&lt;java.lang.String&gt;)</old>
                                    <new>method java.util.Optional&lt;io.trino.spi.connector.ConnectorOutputMetadata&gt; io.trino.spi.connector.ConnectorMetadata::finishRefreshMaterializedView(io.trino.spi.connector.ConnectorSession, io.trino.spi.connector.ConnectorTableHandle, io.trino.spi.connector.ConnectorInsertTableHandle, java.util.Collection&lt;io.airlift.slice.Slice&gt;, java.util.Collection&lt;io.trino.spi.statistics.ComputedStatistics&gt;, java.util.List&lt;io.trino.spi.connector.ConnectorTableHandle&gt;, boolean, boolean)</new>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method void io.trino.spi.eventlistener.QueryStatistics::&lt;init&gt;(java.time.Duration, java.time.Duration, java.time.Duration, java.time.Duration, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, long, long, long, long, long, long, long, long, long, long, long, long, long, long, long, long, double, double, java.util.List&lt;io.trino.spi.eventlistener.StageGcStatistics&gt;, int, boolean, java.util.List&lt;io.trino.spi.eventlistener.StageCpuDistribution&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageOutputBufferUtilization&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageOutputBufferMetrics&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageTaskStatistics&gt;, java.util.List&lt;io.trino.spi.eventlistener.DynamicFilterDomainStatistics&gt;, java.util.function.Supplier&lt;java.util.List&lt;java.lang.String&gt;&gt;, java.util.List&lt;io.trino.spi.eventlistener.QueryPlanOptimizerStatistics&gt;, java.util.Optional&lt;java.lang.String&gt;)</old>
                                    <new>method void io.trino.spi.eventlistener.QueryStatistics::&lt;init&gt;(java.time.Duration, java.time.Duration, java.time.Duration, java.time.Duration, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, java.util.Optional&lt;java.time.Duration&gt;, long, long, long, long, long, long, long, long, long, long, long, long, long, long, double, double, java.util.List&lt;io.trino.spi.eventlistener.StageGcStatistics&gt;, int, boolean, java.util.List&lt;io.trino.spi.eventlistener.StageCpuDistribution&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageOutputBufferUtilization&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageOutputBufferMetrics&gt;, java.util.List&lt;io.trino.spi.eventlistener.StageTaskStatistics&gt;, java.util.List&lt;io.trino.spi.eventlistener.DynamicFilterDomainStatistics&gt;, java.util.function.Supplier&lt;java.util.List&lt;java.lang.String&gt;&gt;, java.util.List&lt;io.trino.spi.eventlistener.QueryPlanOptimizerStatistics&gt;, java.util.Optional&lt;java.lang.String&gt;)</new>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.eventlistener.QueryStatistics::getTotalRows()</old>
                                    <justification>Redundant with QueryStatistics::getProcessedInputRows()</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method long io.trino.spi.eventlistener.QueryStatistics::getTotalBytes()</old>
                                    <justification>Redundant with QueryStatistics::getInternalNetworkBytes() + QueryStatistics::getPhysicalInputBytes()</justification>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.connector.CatalogHandle io.trino.spi.connector.ConnectorContext::getCatalogHandle()</old>
                                </item>
                                <item>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>parameter io.trino.spi.connector.CatalogHandle io.trino.spi.connector.CatalogHandle::createRootCatalogHandle(io.trino.spi.catalog.CatalogName, ===io.trino.spi.connector.CatalogHandle.CatalogVersion===)</old>
                                    <new>parameter io.trino.spi.connector.CatalogHandle io.trino.spi.connector.CatalogHandle::createRootCatalogHandle(io.trino.spi.catalog.CatalogName, ===io.trino.spi.connector.CatalogVersion===)</new>
                                    <parameterIndex>1</parameterIndex>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method io.trino.spi.connector.CatalogHandle.CatalogVersion io.trino.spi.connector.CatalogHandle::getVersion()</old>
                                    <new>method io.trino.spi.connector.CatalogVersion io.trino.spi.connector.CatalogHandle::getVersion()</new>
                                </item>
                                <item>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>parameter void io.trino.spi.eventlistener.QueryInputMetadata::&lt;init&gt;(java.util.Optional&lt;java.lang.String&gt;, java.lang.String, ===io.trino.spi.connector.CatalogHandle.CatalogVersion===, java.lang.String, java.lang.String, java.util.List&lt;io.trino.spi.eventlistener.QueryInputMetadata.Column&gt;, java.util.Optional&lt;java.lang.Object&gt;, io.trino.spi.metrics.Metrics, java.util.OptionalLong, java.util.OptionalLong)</old>
                                    <new>parameter void io.trino.spi.eventlistener.QueryInputMetadata::&lt;init&gt;(java.util.Optional&lt;java.lang.String&gt;, java.lang.String, ===io.trino.spi.connector.CatalogVersion===, java.lang.String, java.lang.String, java.util.List&lt;io.trino.spi.eventlistener.QueryInputMetadata.Column&gt;, java.util.Optional&lt;java.lang.Object&gt;, io.trino.spi.metrics.Metrics, java.util.OptionalLong, java.util.OptionalLong)</new>
                                    <parameterIndex>2</parameterIndex>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method io.trino.spi.connector.CatalogHandle.CatalogVersion io.trino.spi.eventlistener.QueryInputMetadata::getCatalogVersion()</old>
                                    <new>method io.trino.spi.connector.CatalogVersion io.trino.spi.eventlistener.QueryInputMetadata::getCatalogVersion()</new>
                                </item>
                                <item>
                                    <code>java.method.parameterTypeChanged</code>
                                    <old>parameter void io.trino.spi.eventlistener.QueryOutputMetadata::&lt;init&gt;(java.lang.String, ===io.trino.spi.connector.CatalogHandle.CatalogVersion===, java.lang.String, java.lang.String, java.util.Optional&lt;java.util.List&lt;io.trino.spi.eventlistener.OutputColumnMetadata&gt;&gt;, java.util.Optional&lt;java.lang.String&gt;, java.util.Optional&lt;java.lang.Boolean&gt;)</old>
                                    <new>parameter void io.trino.spi.eventlistener.QueryOutputMetadata::&lt;init&gt;(java.lang.String, ===io.trino.spi.connector.CatalogVersion===, java.lang.String, java.lang.String, java.util.Optional&lt;java.util.List&lt;io.trino.spi.eventlistener.OutputColumnMetadata&gt;&gt;, java.util.Optional&lt;java.lang.String&gt;, java.util.Optional&lt;java.lang.Boolean&gt;)</new>
                                    <parameterIndex>1</parameterIndex>
                                </item>
                                <item>
                                    <code>java.method.returnTypeChanged</code>
                                    <old>method io.trino.spi.connector.CatalogHandle.CatalogVersion io.trino.spi.eventlistener.QueryOutputMetadata::getCatalogVersion()</old>
                                    <new>method io.trino.spi.connector.CatalogVersion io.trino.spi.eventlistener.QueryOutputMetadata::getCatalogVersion()</new>
                                </item>
                                <item>
                                    <code>java.method.numberOfParametersChanged</code>
                                    <old>method void io.trino.spi.catalog.CatalogProperties::&lt;init&gt;(io.trino.spi.connector.CatalogHandle, io.trino.spi.connector.ConnectorName, java.util.Map&lt;java.lang.String, java.lang.String&gt;)</old>
                                    <new>method void io.trino.spi.catalog.CatalogProperties::&lt;init&gt;(io.trino.spi.catalog.CatalogName, io.trino.spi.connector.CatalogVersion, io.trino.spi.connector.ConnectorName, java.util.Map&lt;java.lang.String, java.lang.String&gt;)</new>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.connector.CatalogHandle io.trino.spi.catalog.CatalogProperties::catalogHandle()</old>
                                </item>
                                <item>
                                    <code>java.class.removed</code>
                                    <old>io.trino.spi.connector.CatalogHandle</old>
                                </item>
                                <item>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.connector.CatalogHandle io.trino.spi.catalog.CatalogProperties::catalogHandle()</old>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.visibilityIncreased</code>
                                    <old>method io.trino.spi.block.Block[] io.trino.spi.block.RowBlock::getRawFieldBlocks()</old>
                                    <new>method io.trino.spi.block.Block[] io.trino.spi.block.RowBlock::getRawFieldBlocks()</new>
                                    <oldVisibility>package</oldVisibility>
                                    <newVisibility>public</newVisibility>
                                    <justification>getRawFieldBlocks need to be accessed from trino-main</justification>
                                </item>
                                <item>
                                    <ignore>true</ignore>
                                    <code>java.method.removed</code>
                                    <old>method io.trino.spi.block.Block io.trino.spi.block.RowBlock::getFieldBlock(int)</old>
                                </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>
