pkupzj / maven-thrift-plugin Goto Github PK
View Code? Open in Web Editor NEWThis project forked from dtrott/maven-thrift-plugin
Maven Thrift Plugin that executes the thrift code generator (base on protocol buffers plugin)
This project forked from dtrott/maven-thrift-plugin
Maven Thrift Plugin that executes the thrift code generator (base on protocol buffers plugin)
*********************** *** VERSION WARNING *** *********************** Drop to the command line and type: thrift -version To find out what version of the compiler you are using. Older Compiler Versions (Less than 0.7.0) === You must use version 0.1.10 of this plugin. + Check out the source. + Switch to the old branch: git checkout -b old maven-thrift-plugin-0.1.10 And build/use that version. Newer Compiler Versions (0.7.0 or newer) === 0.7.0 should work fine with the latest version of this plugin. However I have seen incompatibilities between the compiler and libthrift. To resolve these check out the source for the compiler from the 0.7.0 branch (Do not trust the TAR BALLS) svn co http://svn.apache.org/repos/asf/thrift/tags/thrift-0.7.0 That version should work fine with the maven version of lib thrift: <dependency> <groupId>org.apache.thrift</groupId> <artifactId>libthrift</artifactId> <version>0.7.0</version> </dependency> Note: If you have problems building on OSX you might want to look at this article: http://lueb.be/2009/02/23/installing-apache-thrift-on-mac-os-x-105-leopard/ The fastest way to build the compiler is: $ svn co http://svn.apache.org/repos/asf/thrift/tags/thrift-0.7.0 $ cd thrift-0.7.0 $ cp /usr/X11/share/aclocal/pkg.m4 aclocal/ $ ./bootstrap.sh $ ./configure $ cd compiler/cpp/ $ make *************************** *** Maven Thrift Plugin *** *************************** A minimal configuration to invoke this plugin would be: <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/maven-v4_0_0.xsd"> <modelVersion>4.0.0</modelVersion> <groupId>com.mycompany.example</groupId> <artifactId>example-thrift</artifactId> <packaging>jar</packaging> <version>1.0-SNAPSHOT</version> <name>thrift-example</name> <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <configuration> <source>1.5</source> <target>1.5</target> </configuration> </plugin> <plugin> <groupId>org.apache.thrift.tools</groupId> <artifactId>maven-thrift-plugin</artifactId> <version>0.1.10</version> <configuration> <thriftExecutable>/usr/local/bin/thrift</thriftExecutable> </configuration> <executions> <execution> <id>thrift-sources</id> <phase>generate-sources</phase> <goals> <goal>compile</goal> </goals> </execution> <execution> <id>thrift-test-sources</id> <phase>generate-test-sources</phase> <goals> <goal>testCompile</goal> </goals> </execution> </executions> </plugin> </plugins> </build> <dependencies> <dependency> <groupId>org.apache.hadoop</groupId> <artifactId>libthrift</artifactId> <version>0.5.0.0</version> </dependency> <dependency> <groupId>org.slf4j</groupId> <artifactId>slf4j-api</artifactId> <version>1.5.8</version> </dependency> <dependency> <groupId>log4j</groupId> <artifactId>log4j</artifactId> <version>1.2.14</version> </dependency> </dependencies> </project> You must: + Use Java 1.5 or newer due to the usage of Generics + Either ensure the "thrift" executable is in your PATH or set the <thriftExecutable> parameter to the correct location. + Define the executions you want (you probably don't need the testCompile unless you have custom thrift objects in your tests. + Include the dependencies on libthrift and slf4j or your compile will fail. Once this is all done add your *.thrift files to the directory: src/main/thrift Everything should then build with a: mvn clean install You may also need to add the following to your settings.xml to download the plugin: <pluginRepositories> <pluginRepository> <id>dtrott</id> <url>http://maven.davidtrott.com/repository</url> </pluginRepository> </pluginRepositories>
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.