Skip to content

Latest commit

 

History

History
94 lines (75 loc) · 4.75 KB

README.md

File metadata and controls

94 lines (75 loc) · 4.75 KB

Java 11+ GitHub License Build Status Coverage Maven Central Documentation Libraries.io dependency status for GitHub repo GitHub Release Date

logo

protobuf-maven-plugin

A scratch-built and modern Maven plugin for seamless protoc integration, with support for custom plugins, including gRPC.

<plugin>
  <groupId>io.github.ascopes</groupId>
  <artifactId>protobuf-maven-plugin</artifactId>
  <version>${protobuf-maven-plugin.version}</version>

  <configuration>
    <protocVersion>${protobuf-java.version}</protocVersion>

    <binaryMavenPlugins>
      <binaryMavenPlugin>
        <groupId>io.grpc</groupId>
        <artifactId>protoc-gen-grpc-java</artifactId>
        <version>${grpc.version}</version>
      </binaryMavenPlugin>
    </binaryMavenPlugins>

    <jvmMavenPlugins>
      <jvmMavenPlugin>
        <groupId>com.salesforce.servicelibs</groupId>
        <artifactId>reactor-grpc</artifactId>
        <version>${reactor-grpc.version}</version>
      </jvmMavenPlugin>
    </jvmMavenPlugins>
  </configuration>

  <executions>
    <execution>
      <goals>
        <goal>generate</goal>
      </goals>
    </execution>
  </executions>
</plugin>

Features

  • Maven 4 support.
  • Pulls protoc from Maven Central directly, given a valid version, meaning the plugin is always up-to-date for your use cases.
  • Can alternatively invoke protoc from the system PATH if you are using an unsupported platform.
  • Supports Java and JVM Kotlin sources out of the box.
  • Plugin support. Need reactive support, Scala support, or gRPC? Just add the plugin and away you go.
    • Ability to use plugins implemented for the JVM (JAR plugins and classpath plugins) without needing them to be bundled as native binaries first.
    • Ability to use regular protoc plugins (native binaries).
    • Plugins can be resolved from Maven repositories, URLs, or the system path.
  • Generation of main and test sources.
  • Importing of *.proto sources from classpath dependencies.
  • Additional support for generating sources targeting C++, C#, Objective C, Python (including optional static typechecking stubs), PHP, Ruby, and Rust.
  • Aims to keep builds reproducible and easily debuggable where possible.
  • Incremental compilation.

Usage

Full documentation with usage examples can be found within the plugin documentation, and examples are present in the integration tests.

Why do we need another plugin?

At the time of writing, the existing Maven plugins that provide Protobuf support are not kept up to date. This poses a risk for any applications depending on these plugins as they are either constrained to outdated versions of Protoc, or are not guaranteed to work in the future.

Many of these existing plugins will not be compatible with the Maven v4.0 APIs.

Some plugins are highly specific to certain CPU architectures as well, which produces issues when using Apple Silicon devices.

All of these issues lingered over the projects I work on that make use of Protobuf. In an attempt to mediate those issues, I have created this Maven plugin with the following requirements:

  • It must support for arbitrary versions of Protoc, including those on the system path.
  • It must support invoking binary Protobuf plugins from dependencies, URLs, or the system path.
  • It must support invoking Protobuf plugins that are packaged as JARs, without the need to compile native binaries first.
  • It must support compiling Protobuf sources from archives and from the local filesystem tree.
  • It must be able to allow Protoc to import Protobuf files from other file trees, archives, and JARs transparently.
  • It must be aware of the Maven project dependencies.
  • It must be compatible with Maven 4.0 once a stable version is released.