| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434 | <?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">  <!-- This module was also published with a richer model, Gradle metadata,  -->  <!-- which should be used instead. Do not delete the following line which  -->  <!-- is to indicate to Gradle or any Gradle module metadata file consumer  -->  <!-- that they should prefer consuming it instead. -->  <!-- do_not_remove: published-with-gradle-metadata -->  <modelVersion>4.0.0</modelVersion>  <parent>    <groupId>com.fasterxml.jackson</groupId>    <artifactId>jackson-base</artifactId>    <version>2.14.0</version>  </parent>  <groupId>com.fasterxml.jackson.core</groupId>  <artifactId>jackson-databind</artifactId>  <version>2.14.0</version>  <name>jackson-databind</name>  <packaging>bundle</packaging>  <description>General data-binding functionality for Jackson: works on core streaming API</description>  <url>https://github.com/FasterXML/jackson</url>  <inceptionYear>2008</inceptionYear>  <licenses>    <license>      <name>The Apache Software License, Version 2.0</name>      <url>https://www.apache.org/licenses/LICENSE-2.0.txt</url>      <distribution>repo</distribution>    </license>  </licenses>    <scm>    <connection>scm:git:git@github.com:FasterXML/jackson-databind.git</connection>    <developerConnection>scm:git:git@github.com:FasterXML/jackson-databind.git</developerConnection>    <url>https://github.com/FasterXML/jackson-databind</url>    <tag>jackson-databind-2.14.0</tag>  </scm>  <properties>    <!-- Until Jackson 2.11 (inclusive) baseline was JDK 7 (except for annotations/streaming),         with 2.12 baseline became JDK8      -->    <javac.src.version>1.8</javac.src.version>    <javac.target.version>1.8</javac.target.version>    <!-- Can not use default, since group id != Java package name here -->    <osgi.export>com.fasterxml.jackson.databind.*;version=${project.version}</osgi.export>    <!-- fix for databind#2299: using jackson-databind in an OSGi environment under Android -->     <osgi.import>        org.w3c.dom.bootstrap;resolution:=optional,        *    </osgi.import>    <!-- Generate PackageVersion.java into this directory. -->    <packageVersion.dir>com/fasterxml/jackson/databind/cfg</packageVersion.dir>    <packageVersion.package>com.fasterxml.jackson.databind.cfg</packageVersion.package>    <version.powermock>2.0.9</version.powermock>    <!-- for Reproducible Builds -->    <project.build.outputTimestamp>2022-11-05T20:38:26Z</project.build.outputTimestamp>  </properties>  <dependencies>    <!-- Builds on core streaming API; also needs core annotations -->    <dependency>      <groupId>com.fasterxml.jackson.core</groupId>      <artifactId>jackson-annotations</artifactId>      <!-- 06-Mar-2017, tatu: Although bom provides for dependencies, some legacy             usage seems to benefit from actually specifying version here in case             it is dependent on transitively        -->      <version>${jackson.version.annotations}</version>    </dependency>    <dependency>      <groupId>com.fasterxml.jackson.core</groupId>      <artifactId>jackson-core</artifactId>      <version>${jackson.version.core}</version>    </dependency>    <!-- and for testing we need a few libraries         libs for which we use reflection for code, but direct dep for testing      -->    <dependency>      <groupId>org.powermock</groupId>      <artifactId>powermock-core</artifactId>      <version>${version.powermock}</version>      <scope>test</scope>    </dependency>    <dependency>      <groupId>org.powermock</groupId>      <artifactId>powermock-module-junit4</artifactId>      <version>${version.powermock}</version>      <scope>test</scope>    </dependency>    <dependency>      <groupId>org.powermock</groupId>      <artifactId>powermock-api-mockito2</artifactId>      <version>${version.powermock}</version>      <scope>test</scope>    </dependency>    <dependency>      <groupId>com.google.guava</groupId>      <artifactId>guava-testlib</artifactId>      <version>31.1-jre</version>      <scope>test</scope>    </dependency>    <!-- For testing TestNoClassDefFoundDeserializer -->    <dependency>      <groupId>javax.measure</groupId>      <artifactId>jsr-275</artifactId>      <version>0.9.1</version>      <scope>test</scope>    </dependency>  </dependencies>  <!-- Alas, need to include snapshot reference since otherwise can not find       snapshot of parent... -->  <repositories>    <repository>      <id>sonatype-nexus-snapshots</id>      <name>Sonatype Nexus Snapshots</name>      <url>https://oss.sonatype.org/content/repositories/snapshots</url>      <releases><enabled>false</enabled></releases>      <snapshots><enabled>true</enabled></snapshots>    </repository>  </repositories>  <build>     <plugins>    <plugin>      <groupId>org.jacoco</groupId>      <artifactId>jacoco-maven-plugin</artifactId>      <executions>	<execution>	  <goals>	    <goal>prepare-agent</goal>	    </goals>	  </execution>	<!-- attached to Maven test phase -->	<execution>	  <id>report</id>	  <phase>test</phase>	  <goals>	    <goal>report</goal>	    </goals>	  </execution>	</executions>      </plugin>      <!-- Important: enable enforcer plug-in: -->      <plugin>        <artifactId>maven-enforcer-plugin</artifactId>        <executions> <!-- or?  combine.children="merge"> -->          <execution>            <id>enforce-properties</id>	    <phase>validate</phase>            <goals><goal>enforce</goal></goals>          </execution>        </executions>      </plugin>      <plugin>        <groupId>org.apache.maven.plugins</groupId>        <version>${version.plugin.surefire}</version>        <artifactId>maven-surefire-plugin</artifactId>        <configuration>          <classpathDependencyExcludes>            <exclude>javax.measure:jsr-275</exclude>          </classpathDependencyExcludes>          <excludes>            <exclude>**/failing/**/*.java</exclude>          </excludes>          <!-- 26-Nov-2019, tatu: moar parallelism! Per-class basis, safe, efficient enough                  ... although not 100% sure this makes much difference TBH            -->          <threadCount>4</threadCount>          <parallel>classes</parallel>        </configuration>      </plugin>      <!-- parent definitions should be ok, but need to add more links -->      <plugin>        <groupId>org.apache.maven.plugins</groupId>        <artifactId>maven-javadoc-plugin</artifactId>        <configuration>          <links combine.children="append">            <link>https://fasterxml.github.io/jackson-annotations/javadoc/2.14</link>            <link>https://fasterxml.github.io/jackson-core/javadoc/2.14</link>          </links>        </configuration>      </plugin>      <!-- settings are fine, but needed to trigger execution! -->      <plugin>        <groupId>com.google.code.maven-replacer-plugin</groupId>        <artifactId>replacer</artifactId>      </plugin>      <!--  04-Mar-2019, tatu: Add rudimentary JDK9+ module info. To build with JDK 8             will have to use `moduleInfoFile` as anything else requires JDK 9+        -->      <plugin>        <groupId>org.moditect</groupId>        <artifactId>moditect-maven-plugin</artifactId>      </plugin>      <!-- 03-Nov-2020, tatu: Add LICENSE from main level -->      <plugin>        <groupId>org.codehaus.mojo</groupId>        <artifactId>build-helper-maven-plugin</artifactId>      </plugin>      <plugin>        <groupId>de.jjohannes</groupId>        <artifactId>gradle-module-metadata-maven-plugin</artifactId>      </plugin>     </plugins>  </build>  <profiles>    <profile>      <id>release</id>      <properties>        <maven.test.skip>true</maven.test.skip>        <skipTests>true</skipTests>      </properties>    </profile>    <!-- 07-Dec-2021, tatu: This is a huge mess, sorry folks... -->    <profile>      <id>java14</id>      <activation>        <jdk>14</jdk>      </activation>      <build>        <plugins>          <plugin>            <groupId>org.codehaus.mojo</groupId>            <artifactId>build-helper-maven-plugin</artifactId>            <executions>              <execution>                <id>add-test-source</id>                <phase>generate-test-sources</phase>                <goals>                  <goal>add-test-source</goal>                </goals>                <configuration>                  <sources>                    <source>src/test-jdk14/java</source>                  </sources>                </configuration>              </execution>            </executions>          </plugin>          <plugin>            <groupId>org.apache.maven.plugins</groupId>            <artifactId>maven-compiler-plugin</artifactId>            <inherited>true</inherited>            <configuration>              <optimize>true</optimize>              <!-- Enable Java 14+ for all sources so that Intellij picks the right language level -->              <source>14</source>              <release>14</release>              <compilerArgs>                <arg>-parameters</arg>                <arg>--enable-preview</arg>              </compilerArgs>            	<fork>true</fork>            	<useIncrementalCompilation>true</useIncrementalCompilation>            </configuration>          </plugin>          <plugin>            <groupId>org.apache.maven.plugins</groupId>            <artifactId>maven-surefire-plugin</artifactId>            <configuration>              <argLine>--enable-preview</argLine>            </configuration>          </plugin>        </plugins>      </build>    </profile>    <profile>      <!-- And different set up for JDK 17 -->      <id>java17</id>      <activation>        <jdk>17</jdk>      </activation>      <build>        <plugins>          <plugin>            <groupId>org.codehaus.mojo</groupId>            <artifactId>build-helper-maven-plugin</artifactId>            <executions>              <execution>                <id>add-test-source</id>                <phase>generate-test-sources</phase>                <goals>                  <goal>add-test-source</goal>                </goals>                <configuration>                  <sources>                    <source>src/test-jdk14/java</source>                  </sources>                </configuration>              </execution>            </executions>          </plugin>          <plugin>            <groupId>org.apache.maven.plugins</groupId>            <artifactId>maven-compiler-plugin</artifactId>            <inherited>true</inherited>            <configuration>              <optimize>true</optimize>              <!-- Enable Java 17 for all sources so that Intellij picks the right language level -->              <source>17</source>              <release>17</release>              <compilerArgs>                <arg>-parameters</arg>                <arg>--add-opens=java.base/java.lang=ALL-UNNAMED</arg>                <arg>--add-opens=java.base/java.util=ALL-UNNAMED</arg>              </compilerArgs>            </configuration>          </plugin>          <plugin>            <groupId>org.apache.maven.plugins</groupId>            <artifactId>maven-surefire-plugin</artifactId>            <configuration>              <argLine>--add-opens=java.base/java.lang=ALL-UNNAMED --add-opens=java.base/java.util=ALL-UNNAMED</argLine>            </configuration>          </plugin>        </plugins>      </build>    </profile>    <profile>      <id>errorprone</id>      <build>        <plugins>          <plugin>            <groupId>org.apache.maven.plugins</groupId>            <artifactId>maven-compiler-plugin</artifactId>            <configuration>              <compilerArgs>                <arg>-XDcompilePolicy=simple</arg>                <arg>                  -Xplugin:ErrorProne                  <!--                  Disable all checks in test code. Bugs in tests can hide runtime failures,                  however these can be enabled later on. Many issues may require sub-optional                  code to reproduce failures.                  -->                  -XepExcludedPaths:.*/src/test/java/.*                  <!-- ############### -->                  <!-- UPGRADED CHECKS -->                  <!-- ############### -->                  <!-- Boxed primitive equality checks can be dangerous when presented with unexpected inputs -->                  -Xep:BoxedPrimitiveEquality:ERROR                  <!-- ############### -->                  <!-- DISABLED CHECKS -->                  <!-- ############### -->                  <!-- UnusedVariable is great at catching mistakes quickly, but                  requires a few suppressions to avoid noise. Deferring to avoid noise                  with the introduction of ErrorProne. -->                  -Xep:UnusedVariable:OFF                  <!--                  Disabled to avoid potential API changes. It's not clear if custom JsonNode types                  exist, and if any do implement equals without hashCode, it's likely they cause bugs.                  I plan to try fixing this separately.                  -->                  -Xep:EqualsHashCode:OFF                  <!-- Style: javadoc tag validation -->                  -Xep:MissingSummary:OFF                  -Xep:InvalidInlineTag:OFF                  -Xep:EmptyBlockTag:OFF                  -Xep:AlmostJavadoc:OFF                  -Xep:InvalidLink:OFF                  <!-- Style: low reward for enabling. -->                  -Xep:UnnecessaryParentheses:OFF                  <!-- Style: low signal -->                  -Xep:InconsistentCapitalization:OFF                  <!-- Style: requires specific comments when switch branches neither break nor return -->                  -Xep:FallThrough:OFF                  <!-- Style: disable noisy check for importing common names from nested classes -->                  -Xep:BadImport:OFF                  <!-- Style: requires a default case when not all cases are handled -->                  -Xep:MissingCasesInEnumSwitch:OFF                  <!-- Style: avoid clashes with java.lang. Possibly worth enabling, but this can be done later -->                  -Xep:JavaLangClash:OFF                  <!-- These can likely be updated from protected to private, but it's relatively low signal -->                  -Xep:ProtectedMembersInFinalClass:OFF                  <!-- These can likely be updated from public to protected, but it's relatively low signal -->                  -Xep:PublicConstructorForAbstractClass:OFF                  <!-- jackson-databind doesn't have a logger, in many cases there's no way to pre-validate inputs -->                  -Xep:EmptyCatch:OFF                  -Xep:EqualsGetClass:OFF                  <!-- Noisy check that's largely unnecessary unless the result is mutated.                  Returning only immutable collections requires additional overhead and                  impact must be carefully considered. -->                  -Xep:MixedMutabilityReturnType:OFF                  <!-- Noisy in jackson and libraries which must interact with generics -->                  -Xep:TypeParameterUnusedInFormals:OFF                  <!-- Check is noisy around code that's meant to handle types that are considered obsolete -->                  -Xep:JdkObsolete:OFF                  <!-- Avoid noise from tests -->                  -Xep:JUnit3FloatingPointComparisonWithoutDelta:OFF                  <!-- Disable the StringSplitter check because it requires a guava dependency -->                  -Xep:StringSplitter:OFF                  <!-- Disable checks which require custom annotations -->                  -Xep:AnnotateFormatMethod:OFF                  -Xep:GuardedBy:OFF                  <!-- This check is generally high signal, however it is noisy in                  low level projects which implement caches and interning. -->                  -Xep:ReferenceEquality:OFF                </arg>              </compilerArgs>              <annotationProcessorPaths>                <path>                  <groupId>com.google.errorprone</groupId>                  <artifactId>error_prone_core</artifactId>                  <version>2.4.0</version>                </path>              </annotationProcessorPaths>            	<fork>true</fork>            	<useIncrementalCompilation>true</useIncrementalCompilation>            </configuration>          </plugin>        </plugins>      </build>    </profile>  </profiles></project>
 |