summaryrefslogtreecommitdiff
path: root/pkgs/development/em-modules/generic/default.nix
blob: 262e0bd1abf016fcbba069a70a5cf47b1fc69588 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
{
  pkgs,
  lib,
  emscripten,
  python3,
}:

argsFun:

let
  wrapDerivation = f: pkgs.stdenv.mkDerivation (finalAttrs: f (lib.toFunction argsFun finalAttrs));
in
wrapDerivation (
  {
    buildInputs ? [ ],
    nativeBuildInputs ? [ ],

    enableParallelBuilding ? true,

    meta ? { },
    ...
  }@args:

  args
  // {

    pname = "emscripten-${lib.getName args}";
    version = lib.getVersion args;
    buildInputs = [
      emscripten
      python3
    ]
    ++ buildInputs;
    nativeBuildInputs = [
      emscripten
      python3
    ]
    ++ nativeBuildInputs;

    env = args.env or { } // {
      # fake conftest results with emscripten's python magic
      EMCONFIGURE_JS = 2;
    };

    # removes archive indices
    dontStrip = args.dontStrip or true;

    configurePhase =
      args.configurePhase or ''
        # FIXME: Some tests require writing at $HOME
        HOME=$TMPDIR
        runHook preConfigure

        emconfigure ./configure --prefix=$out

        mkdir -p .emscriptencache
        export EM_CACHE=$(pwd)/.emscriptencache

        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 ];
    };
  }
)