diff options
Diffstat (limited to 'sonar-plugin-api')
-rw-r--r-- | sonar-plugin-api/build.gradle | 82 | ||||
-rw-r--r-- | sonar-plugin-api/pom.xml | 282 | ||||
-rw-r--r-- | sonar-plugin-api/src/main/resources/sonar-api-version.txt | 2 | ||||
-rw-r--r-- | sonar-plugin-api/src/main/resources/sq-version.txt | 2 |
4 files changed, 84 insertions, 284 deletions
diff --git a/sonar-plugin-api/build.gradle b/sonar-plugin-api/build.gradle new file mode 100644 index 00000000000..8bf8e28798b --- /dev/null +++ b/sonar-plugin-api/build.gradle @@ -0,0 +1,82 @@ +sonarqube { + properties { + property 'sonar.projectName', "${projectTitle} :: Plugin API" + } +} + +apply plugin: 'com.github.johnrengelman.shadow' + +dependencies { + // please keep the list grouped by configuration and ordered by name + + compile 'commons-codec:commons-codec' + compile 'commons-io:commons-io' + compile 'commons-lang:commons-lang' + compile 'com.google.code.gson:gson' + compile 'com.google.guava:guava' + + // shaded, but not relocated + compile project(':sonar-check-api') + compile(project(':sonar-duplications')) { + exclude group: 'org.slf4', module: 'slf4j-api' + } + + shadow 'org.codehaus.staxmate:staxmate' + shadow 'org.codehaus.woodstox:stax2-api' + shadow 'org.codehaus.woodstox:woodstox-core-lgpl' + + compileOnly 'ch.qos.logback:logback-classic' + compileOnly 'ch.qos.logback:logback-core' + compileOnly 'com.google.code.findbugs:jsr305' + compileOnly 'javax.servlet:javax.servlet-api' + compileOnly 'junit:junit' + compileOnly 'org.slf4j:slf4j-api' + + testCompile 'com.tngtech.java:junit-dataprovider' + testCompile 'org.assertj:assertj-core' + testCompile 'org.mockito:mockito-core' + testCompile project(':sonar-testing-harness') +} + +sourceSets { + // Make the compileOnly dependencies available when compiling/running tests + test.compileClasspath += configurations.compileOnly + configurations.shadow + test.runtimeClasspath += configurations.compileOnly + configurations.shadow +} + +def on3Digits(version) { + def projectversion3digits = version - ~/-\w+/ + projectversion3digits = projectversion3digits.tokenize('.').plus(0).take(3).join('.') +} + +import org.apache.tools.ant.filters.ReplaceTokens +processResources { + filter ReplaceTokens, tokens: [ + // The build version is composed of 4 fields, including the semantic version and the build number provided by Travis. + 'project.buildVersion': project.version.endsWith('SNAPSHOT') ? project.version : on3Digits(project.version) + '.' + System.getProperty("buildNumber"), + 'project.version.3digits': project.version.endsWith('SNAPSHOT') ? project.version : on3Digits(project.version) + ] +} + +shadowJar { + configurations = [project.configurations.default] + relocate('com.google', 'org.sonar.api.internal.google') + relocate('org.apache.commons', 'org.sonar.api.internal.apachecommons') + dependencies { + exclude(dependency('org.codehaus.woodstox:woodstox-core-lgpl')) + exclude(dependency('org.codehaus.woodstox:stax2-api')) + exclude(dependency('org.codehaus.staxmate:staxmate')) + } +} + +artifactoryPublish.skip = false + +publishing { + publications { + mavenJava(MavenPublication) { + artifact source: shadowJar, classifier: null + artifact sourcesJar + artifact javadocJar + } + } +} diff --git a/sonar-plugin-api/pom.xml b/sonar-plugin-api/pom.xml deleted file mode 100644 index ab8dc7cef4f..00000000000 --- a/sonar-plugin-api/pom.xml +++ /dev/null @@ -1,282 +0,0 @@ -<?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>org.sonarsource.sonarqube</groupId> - <artifactId>sonarqube</artifactId> - <version>7.1-SNAPSHOT</version> - </parent> - - <artifactId>sonar-plugin-api</artifactId> - <packaging>jar</packaging> - - <name>SonarQube :: Plugin API</name> - - <properties> - <!-- - version as stored in JAR and displayed in webapp. It is - overridden on Travis when replacing SNAPSHOT version by - build unique version, for instance "6.3.0.12345". - --> - <buildVersion>${project.version}</buildVersion> - - <!-- - a truncated version on three fields is kept for backward-compatibility - with scanners - --> - <buildVersionOnThreeFields>${buildVersion}</buildVersionOnThreeFields> - </properties> - - <dependencies> - - <!-- - The following artifacts are shaded and relocated in an internal package. - They are not visible by plugins - --> - <dependency> - <groupId>com.google.code.gson</groupId> - <artifactId>gson</artifactId> - </dependency> - <dependency> - <groupId>com.google.guava</groupId> - <artifactId>guava</artifactId> - </dependency> - <dependency> - <groupId>commons-codec</groupId> - <artifactId>commons-codec</artifactId> - </dependency> - <dependency> - <groupId>commons-io</groupId> - <artifactId>commons-io</artifactId> - </dependency> - <dependency> - <groupId>commons-lang</groupId> - <artifactId>commons-lang</artifactId> - </dependency> - - <!-- - The following artifacts are shaded but not relocated. They - are provided at runtime, so plugins can use them but - can not change their version. - Long-term target is to remove them from API. They should be - embedded by plugins. - --> - <dependency> - <groupId>${project.groupId}</groupId> - <artifactId>sonar-check-api</artifactId> - <version>${project.version}</version> - </dependency> - <dependency> - <groupId>${project.groupId}</groupId> - <artifactId>sonar-duplications</artifactId> - <version>${project.version}</version> - <exclusions> - <exclusion> - <groupId>org.slf4j</groupId> - <artifactId>slf4j-api</artifactId> - </exclusion> - </exclusions> - </dependency> - - <!-- - Transitive dependencies available at runtime. They are not shaded with API - as they are not managed by SonarSource. Versions should not be - overridden by plugins though. - --> - <dependency> - <groupId>org.codehaus.woodstox</groupId> - <artifactId>woodstox-core-lgpl</artifactId> - <exclusions> - <exclusion> - <groupId>stax</groupId> - <artifactId>stax-api</artifactId> - </exclusion> - </exclusions> - </dependency> - <dependency> - <groupId>org.codehaus.woodstox</groupId> - <artifactId>stax2-api</artifactId> - </dependency> - <dependency> - <groupId>org.codehaus.staxmate</groupId> - <artifactId>staxmate</artifactId> - </dependency> - - <dependency> - <groupId>com.google.code.findbugs</groupId> - <artifactId>jsr305</artifactId> - <scope>provided</scope> - </dependency> - <dependency> - <groupId>org.slf4j</groupId> - <artifactId>slf4j-api</artifactId> - <optional>true</optional> - <scope>provided</scope> - </dependency> - <dependency> - <groupId>javax.servlet</groupId> - <artifactId>javax.servlet-api</artifactId> - <version>3.0.1</version> - <scope>provided</scope> - <optional>true</optional> - </dependency> - <dependency> - <groupId>ch.qos.logback</groupId> - <artifactId>logback-classic</artifactId> - <scope>provided</scope> - <optional>true</optional> - </dependency> - <dependency> - <groupId>ch.qos.logback</groupId> - <artifactId>logback-core</artifactId> - <scope>provided</scope> - <optional>true</optional> - </dependency> - <dependency> - <groupId>junit</groupId> - <artifactId>junit</artifactId> - <scope>provided</scope> - <optional>true</optional> - </dependency> - - <!-- unit tests --> - <dependency> - <groupId>com.tngtech.java</groupId> - <artifactId>junit-dataprovider</artifactId> - <scope>test</scope> - </dependency> - <dependency> - <groupId>org.assertj</groupId> - <artifactId>assertj-core</artifactId> - <scope>test</scope> - </dependency> - <dependency> - <groupId>org.mockito</groupId> - <artifactId>mockito-core</artifactId> - <scope>test</scope> - </dependency> - <dependency> - <groupId>${project.groupId}</groupId> - <artifactId>sonar-testing-harness</artifactId> - <scope>test</scope> - </dependency> - </dependencies> - - <build> - <plugins> - <plugin> - <groupId>org.apache.maven.plugins</groupId> - <artifactId>maven-shade-plugin</artifactId> - <executions> - <execution> - <phase>package</phase> - <goals> - <goal>shade</goal> - </goals> - <configuration> - <minimizeJar>true</minimizeJar> - <createDependencyReducedPom>true</createDependencyReducedPom> - <artifactSet> - <excludes> - <exclude>org.codehaus.woodstox:woodstox-core-lgpl</exclude> - <exclude>org.codehaus.woodstox:stax2-api</exclude> - <exclude>org.codehaus.staxmate:staxmate</exclude> - </excludes> - </artifactSet> - <filters> - <!-- The following deps are used transitively, so make sure they are not minimized --> - <filter> - <artifact>${project.groupId}:sonar-duplications</artifact> - <includes> - <include>**</include> - </includes> - </filter> - <filter> - <artifact>org.codehaus.sonar:sonar-channel</artifact> - <includes> - <include>**</include> - </includes> - </filter> - <filter> - <artifact>org.sonarsource.sonarqube:sonar-check-api</artifact> - <includes> - <include>**</include> - </includes> - </filter> - </filters> - <relocations> - <relocation> - <pattern>com.google</pattern> - <shadedPattern>org.sonar.api.internal.google</shadedPattern> - </relocation> - <relocation> - <pattern>org.apache.commons</pattern> - <shadedPattern>org.sonar.api.internal.apachecommons</shadedPattern> - </relocation> - </relocations> - </configuration> - </execution> - </executions> - </plugin> - <plugin> - <groupId>org.apache.maven.plugins</groupId> - <artifactId>maven-jar-plugin</artifactId> - <executions> - <execution> - <goals> - <goal>test-jar</goal> - </goals> - <configuration> - <excludes> - <exclude>logback-test.xml</exclude> - </excludes> - </configuration> - </execution> - </executions> - </plugin> - <plugin> - <groupId>com.github.genthaler</groupId> - <artifactId>beanshell-maven-plugin</artifactId> - <executions> - <execution> - <id>compute-version-on-three-fields</id> - <phase>generate-resources</phase> - <goals> - <goal>run</goal> - </goals> - <configuration> - <script> - <![CDATA[ - if (! "${buildVersion}".endsWith("-SNAPSHOT")) { - // example: "6.3.0.1234". To be backward-compatible with scanners, only "6.3.0" must be kept - fields = "${buildVersion}".split("\\."); - sj = new StringJoiner("."); - i = 0; - for (String field : fields) { - if (i == 3) { - break; - } - sj.add(field); - ++i; - } - project.getProperties().setProperty("buildVersionOnThreeFields", sj.toString()); - } - ]]> - </script> - </configuration> - </execution> - </executions> - </plugin> - </plugins> - - <resources> - <resource> - <!-- Used to resolve variables in files sq-version.txt and sonar-api-version.txt --> - <directory>src/main/resources</directory> - <filtering>true</filtering> - </resource> - </resources> - </build> - -</project> diff --git a/sonar-plugin-api/src/main/resources/sonar-api-version.txt b/sonar-plugin-api/src/main/resources/sonar-api-version.txt index 6b7ce460f25..d2193c1c60f 100644 --- a/sonar-plugin-api/src/main/resources/sonar-api-version.txt +++ b/sonar-plugin-api/src/main/resources/sonar-api-version.txt @@ -1 +1 @@ -${buildVersion} +@project.buildVersion@
\ No newline at end of file diff --git a/sonar-plugin-api/src/main/resources/sq-version.txt b/sonar-plugin-api/src/main/resources/sq-version.txt index ab8c87a30ad..b3f131da385 100644 --- a/sonar-plugin-api/src/main/resources/sq-version.txt +++ b/sonar-plugin-api/src/main/resources/sq-version.txt @@ -1 +1 @@ -${buildVersionOnThreeFields} +@project.version.3digits@
\ No newline at end of file |