Apache Thrift Language Support

Last Modified: 2017-10-05
Version: 0.10.0+

Thrift supports many programming languages and has an impressive test suite that exercises most of the languages, protocols, and transports that represents a matrix of thousands of possible combinations. Each language typically has a minimum required version as well as support libraries - some mandatory and some optional. All of this information is provided below to help you assess whether you can use Apache Thrift with your project. Obviously this is a complex matrix to maintain and may not be correct in all cases - if you spot an error please inform the developers using the mailing list.

Apache Thrift has a choice of two build systems. The autoconf build system is the most complete build and is used to build all supported languages. The cmake build system has been designated by the project to replace autoconf however this transition will take quite some time to complete.

The Language/Library Levels indicate the minimum and maximum versions that are used in the continuous integration environments (Appveyor, Travis) for Apache Thrift. Note that while a language may contain support for protocols, transports, and servers, the extent to which each is tested as part of the overall build process varies. The definitive integration test for the project is called the "cross" test which executes a test matrix with clients and servers communicating across languages.

Language Build Systems Lang/Lib Levels Low-Level Transports Transport Wrappers Protocols Servers Open Issues
autoconfcmake MinMax Domain File Memory Pipe Socket TLS  Framed http  zlib  BinaryCompact JSON Multiplex ForkingNonblockingSimpleThreadedThreadPool
ActionScript ActionScript 3 Yes Yes Yes ActionScript
C (glib) YesYes 2.40.22.54.0 YesYesYesYes Yes YesYesYes Yes C (glib)
C++ YesYes C++98, gcc YesYesYesYesYesYes YesYesYes YesYesYesYes YesYesYesYes C++
C# Yes .NET 3.5 / mono 3.2.8.0.NET 4.6.1 / mono 4.6.2.7 YesYesYesYes YesYes YesYesYesYes YesYesYes C# (.NET)
Cocoa unknown YesYesYesYes YesYes YesYesYes Yes Cocoa
D Yes 2.070.22.076.0 YesYesYesYesYes YesYesYes YesYesYes YesYesYesYes D
Dart Yes 1.20.11.24.2 Yes YesYes YesYesYesYes Dart
Delphi 2010unknown Yes YesYes YesYesYesYes Yes Delphi
.NET Core 2.0.0 YesYesYesYes YesYes YesYesYesYes Yes .NET Core
Erlang Yes R16B0320.0.4 YesYesYesYes YesYes YesYesYesYes Yes Erlang
Go Yes 1.2.11.8.3 YesYesYes YesYesYes YesYesYesYes Yes Go
Haskell YesYes 7.6.38.0.2 YesYesYesYes YesYes YesYesYes YesYes Haskell
Haxe Yes 3.2.1 YesYes YesYes YesYesYesYes Yes Haxe
Java (SE) YesYes 1.7.0_1511.8.0_144 YesYesYesYes YesYesYes YesYesYesYes YesYesYesYes Java SE
Java (ME) unknown YesYesYes Yes YesYes Java ME
Javascript Yes unknown YesYes Yes YesYes Javascript
Lua Yes 5.1.55.3.3 YesYes YesYes YesYesYes Yes Lua
node.js Yes 4.2.68.8.1 YesYes YesYes YesYesYesYes Yes node.js
OCaml 4.02.34.04.0 Yes Yes Yes YesYes OCaml
Perl Yes 5.18.25.26.0 YesYesYesYes YesYes YesYesYes YesYes Perl
PHP Yes 5.5.97.1.8 YesYesYes YesYes YesYesYesYes YesYes PHP
Python YesYes 2.7.6, 3.4.32.7.14, 3.6.3 YesYes YesYes YesYesYesYes YesYesYes Python
Ruby Yes 1.9.3p4842.3.3p222 YesYesYesYes YesYes YesYesYesYes YesYesYesYes Ruby
Rust Yes 1.15.11.18.0 YesYes Yes YesYesYes Yes Rust
Smalltalk unknown Yes Yes Smalltalk
Language autoconfcmake MinMax Domain File Memory Pipe Socket TLS  Framed http  zlib  BinaryCompact JSON Multiplex ForkingNonblockingSimpleThreadedThreadPool Open Issues
Build Systems Lang/Lib Levels Low-Level Transports Transport Wrappers Protocols Servers