nixpkgs/pkgs/development/libraries/protobuf/generic.nix

62 lines
1.8 KiB
Nix
Raw Normal View History

{ lib, stdenv, version, src
, autoreconfHook, zlib, gtest
, ...
}:
2019-08-13 22:52:01 +01:00
stdenv.mkDerivation {
2019-08-13 22:52:01 +01:00
pname = "protobuf";
inherit version;
inherit src;
postPatch = ''
rm -rf gtest
cp -r ${gtest.src}/googletest gtest
chmod -R a+w gtest
'' + lib.optionalString stdenv.isDarwin ''
2015-10-20 02:40:55 +01:00
substituteInPlace src/google/protobuf/testing/googletest.cc \
--replace 'tmpnam(b)' '"'$TMPDIR'/foo"'
'';
2016-04-14 15:04:49 +01:00
outputs = [ "out" "lib" ];
nativeBuildInputs = [ autoreconfHook ];
buildInputs = [ zlib ];
2016-12-28 05:19:51 +00:00
# The generated C++ code uses static initializers which mutate a global data
# structure. This causes problems for an executable when:
#
# 1) it dynamically links to two libs, both of which contain generated C++ for
# the same proto file, and
# 2) the two aforementioned libs both dynamically link to libprotobuf.
#
# One solution is to statically link libprotobuf, that way the global
# variables are not shared; in fact, this is necessary for the python Mesos
# binding to not crash, as the python lib contains two C extensions which
# both refer to the same proto schema.
#
# See: https://github.com/NixOS/nixpkgs/pull/19064#issuecomment-255082684
# https://github.com/google/protobuf/issues/1489
dontDisableStatic = true;
configureFlags = [
"CFLAGS=-fPIC"
"CXXFLAGS=-fPIC"
];
doCheck = true;
meta = {
description = "Protocol Buffers - Google's data interchange format";
longDescription =
'' Protocol Buffers are a way of encoding structured data in an
efficient yet extensible format. Google uses Protocol Buffers for
almost all of its internal RPC protocols and file formats.
'';
license = "mBSD";
homepage = "https://developers.google.com/protocol-buffers/";
platforms = lib.platforms.unix;
};
2015-02-20 18:36:16 +00:00
passthru.version = version;
}