mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2025-01-04 09:56:13 +03:00
f41a3e7d7d
* trying to build emscriptenPackages not all fail * reading the console.log it turns out python executable is not in place and that is why emconfigure didnt work * backup commit * much more targets are compiling now * added common revisioning * revision bump to 1.37.36 (not tested) * fixed xmllint * forcing unit testing, will implement the tests after i get home * json_c test working * added tests * tiny fixes * added documentation
69 lines
1.9 KiB
Nix
69 lines
1.9 KiB
Nix
{ pkgs, lib, emscripten, python }:
|
|
|
|
{ buildInputs ? [], nativeBuildInputs ? []
|
|
|
|
, enableParallelBuilding ? true
|
|
|
|
, meta ? {}, ... } @ args:
|
|
|
|
pkgs.stdenv.mkDerivation (
|
|
args //
|
|
{
|
|
|
|
name = "emscripten-${args.name}";
|
|
buildInputs = [ emscripten python ] ++ buildInputs;
|
|
nativeBuildInputs = [ emscripten python ] ++ nativeBuildInputs;
|
|
|
|
# fake conftest results with emscripten's python magic
|
|
EMCONFIGURE_JS=2;
|
|
|
|
configurePhase = args.configurePhase or ''
|
|
# FIXME: Some tests require writing at $HOME
|
|
HOME=$TMPDIR
|
|
runHook preConfigure
|
|
|
|
# probably requires autotools as dependency
|
|
./autogen.sh
|
|
emconfigure ./configure --prefix=$out
|
|
|
|
runHook postConfigure
|
|
'';
|
|
|
|
buildPhase = args.buildPhase or ''
|
|
runHook preBuild
|
|
|
|
HOME=$TMPDIR
|
|
emmake make
|
|
|
|
runHook postBuild
|
|
'';
|
|
|
|
doCheck = true;
|
|
|
|
checkPhase = args.checkPhase or ''
|
|
runHook preCheck
|
|
|
|
echo "Please provide a test for your emscripten based library/tool, see libxml2 as an exmple on how to use emcc/node to verify your build"
|
|
echo ""
|
|
echo "In normal C 'unresolved symbols' would yield an error and a breake of execution. In contrast, in emscripten they are only a warning which is ok given that emscripten assumptions about shared libraries."
|
|
echo " -> https://github.com/kripken/emscripten/wiki/Linking"
|
|
echo "So just assume the dependencies were built using hydra, then YOU WILL NEVER see the warning and your code depending on a library will always fail!"
|
|
exit 1
|
|
|
|
runHook postCheck
|
|
'';
|
|
|
|
enableParallelBuilding = args.enableParallelBuilding or true;
|
|
|
|
meta = {
|
|
# Add default meta information
|
|
platforms = lib.platforms.all;
|
|
# Do not build this automatically
|
|
hydraPlatforms = [];
|
|
} // meta // {
|
|
# add an extra maintainer to every package
|
|
maintainers = (meta.maintainers or []) ++
|
|
[ lib.maintainers.qknight ];
|
|
};
|
|
})
|