##// END OF EJS Templates
nix: Move shell hook: default.nix -> shell.nix and set custom prompt....
Martin Bornhold -
r1130:328807b4 default
parent child Browse files
Show More
@@ -1,250 +1,238 b''
1 1 # Nix environment for the community edition
2 2 #
3 3 # This shall be as lean as possible, just producing the Enterprise
4 4 # derivation. For advanced tweaks to pimp up the development environment we use
5 5 # "shell.nix" so that it does not have to clutter this file.
6 6
7 7 args@
8 8 { pythonPackages ? "python27Packages"
9 9 , pythonExternalOverrides ? self: super: {}
10 10 , doCheck ? true
11 11 , ...
12 12 }:
13 13
14 14 let
15 15
16 16 # Use nixpkgs from args or import them. We use this indirect approach
17 17 # through args to be able to use the name `pkgs` for our customized packages.
18 18 # Otherwise we will end up with an infinite recursion.
19 19 nixpkgs = args.pkgs or (import <nixpkgs> { });
20 20
21 21 # johbo: Interim bridge which allows us to build with the upcoming
22 22 # nixos.16.09 branch (unstable at the moment of writing this note) and the
23 23 # current stable nixos-16.03.
24 24 backwardsCompatibleFetchgit = { ... }@args:
25 25 let
26 26 origSources = nixpkgs.fetchgit args;
27 27 in
28 28 nixpkgs.lib.overrideDerivation origSources (oldAttrs: {
29 29 NIX_PREFETCH_GIT_CHECKOUT_HOOK = ''
30 30 find $out -name '.git*' -print0 | xargs -0 rm -rf
31 31 '';
32 32 });
33 33
34 34 # Create a customized version of nixpkgs which should be used throughout the
35 35 # rest of this file.
36 36 pkgs = nixpkgs.overridePackages (self: super: {
37 37 fetchgit = backwardsCompatibleFetchgit;
38 38 });
39 39
40 40 # Evaluates to the last segment of a file system path.
41 41 basename = path: with pkgs.lib; last (splitString "/" path);
42 42
43 43 # source code filter used as arugment to builtins.filterSource.
44 44 src-filter = path: type: with pkgs.lib;
45 45 let
46 46 ext = last (splitString "." path);
47 47 in
48 48 !builtins.elem (basename path) [
49 49 ".git" ".hg" "__pycache__" ".eggs"
50 50 "bower_components" "node_modules"
51 51 "build" "data" "result" "tmp"] &&
52 52 !builtins.elem ext ["egg-info" "pyc"] &&
53 53 # TODO: johbo: This check is wrong, since "path" contains an absolute path,
54 54 # it would still be good to restore it since we want to ignore "result-*".
55 55 !hasPrefix "result" path;
56 56
57 57 basePythonPackages = with builtins; if isAttrs pythonPackages
58 58 then pythonPackages
59 59 else getAttr pythonPackages pkgs;
60 60
61 61 buildBowerComponents =
62 62 pkgs.buildBowerComponents or
63 63 (import ./pkgs/backport-16.03-build-bower-components.nix { inherit pkgs; });
64 64
65 65 sources = pkgs.config.rc.sources or {};
66 66 version = builtins.readFile ./rhodecode/VERSION;
67 67 rhodecode-enterprise-ce-src = builtins.filterSource src-filter ./.;
68 68
69 69 nodeEnv = import ./pkgs/node-default.nix {
70 70 inherit pkgs;
71 71 };
72 72 nodeDependencies = nodeEnv.shell.nodeDependencies;
73 73
74 74 bowerComponents = buildBowerComponents {
75 75 name = "enterprise-ce-${version}";
76 76 generated = ./pkgs/bower-packages.nix;
77 77 src = rhodecode-enterprise-ce-src;
78 78 };
79 79
80 80 pythonGeneratedPackages = self: basePythonPackages.override (a: {
81 81 inherit self;
82 82 })
83 83 // (scopedImport {
84 84 self = self;
85 85 super = basePythonPackages;
86 86 inherit pkgs;
87 87 inherit (pkgs) fetchurl fetchgit;
88 88 } ./pkgs/python-packages.nix);
89 89
90 90 pythonOverrides = import ./pkgs/python-packages-overrides.nix {
91 91 inherit
92 92 basePythonPackages
93 93 pkgs;
94 94 };
95 95
96 96 pythonLocalOverrides = self: super: {
97 97 rhodecode-enterprise-ce =
98 98 let
99 99 linkNodeAndBowerPackages = ''
100 100 echo "Export RhodeCode CE path"
101 101 export RHODECODE_CE_PATH=${rhodecode-enterprise-ce-src}
102 102 echo "Link node packages"
103 103 rm -fr node_modules
104 104 mkdir node_modules
105 105 # johbo: Linking individual packages allows us to run "npm install"
106 106 # inside of a shell to try things out. Re-entering the shell will
107 107 # restore a clean environment.
108 108 ln -s ${nodeDependencies}/lib/node_modules/* node_modules/
109 109
110 110 echo "DONE: Link node packages"
111 111
112 112 echo "Link bower packages"
113 113 rm -fr bower_components
114 114 mkdir bower_components
115 115
116 116 ln -s ${bowerComponents}/bower_components/* bower_components/
117 117 echo "DONE: Link bower packages"
118 118 '';
119 119 in super.rhodecode-enterprise-ce.override (attrs: {
120 120
121 121 inherit
122 122 doCheck
123 123 version;
124 124 name = "rhodecode-enterprise-ce-${version}";
125 125 releaseName = "RhodeCodeEnterpriseCE-${version}";
126 126 src = rhodecode-enterprise-ce-src;
127 127
128 128 buildInputs =
129 129 attrs.buildInputs ++
130 130 (with self; [
131 131 pkgs.nodePackages.bower
132 132 pkgs.nodePackages.grunt-cli
133 133 pkgs.subversion
134 134 pytest-catchlog
135 135 rhodecode-testdata
136 136 ]);
137 137
138 138 propagatedBuildInputs = attrs.propagatedBuildInputs ++ (with self; [
139 139 rhodecode-tools
140 140 ]);
141 141
142 142 # TODO: johbo: Make a nicer way to expose the parts. Maybe
143 143 # pkgs/default.nix?
144 144 passthru = {
145 145 inherit
146 146 bowerComponents
147 147 linkNodeAndBowerPackages
148 148 myPythonPackagesUnfix
149 149 pythonLocalOverrides;
150 150 pythonPackages = self;
151 151 };
152 152
153 153 LC_ALL = "en_US.UTF-8";
154 154 LOCALE_ARCHIVE =
155 155 if pkgs.stdenv ? glibc
156 156 then "${pkgs.glibcLocales}/lib/locale/locale-archive"
157 157 else "";
158 158
159 # Somewhat snappier setup of the development environment
160 # TODO: move into shell.nix
161 # TODO: think of supporting a stable path again, so that multiple shells
162 # can share it.
163 shellHook = ''
164 tmp_path=$(mktemp -d)
165 export PATH="$tmp_path/bin:$PATH"
166 export PYTHONPATH="$tmp_path/${self.python.sitePackages}:$PYTHONPATH"
167 mkdir -p $tmp_path/${self.python.sitePackages}
168 python setup.py develop --prefix $tmp_path --allow-hosts ""
169 '' + linkNodeAndBowerPackages;
170
171 159 preCheck = ''
172 160 export PATH="$out/bin:$PATH"
173 161 '';
174 162
175 163 postCheck = ''
176 164 rm -rf $out/lib/${self.python.libPrefix}/site-packages/pytest_pylons
177 165 rm -rf $out/lib/${self.python.libPrefix}/site-packages/rhodecode/tests
178 166 '';
179 167
180 168 preBuild = linkNodeAndBowerPackages + ''
181 169 grunt
182 170 rm -fr node_modules
183 171 '';
184 172
185 173 postInstall = ''
186 174 # python based programs need to be wrapped
187 175 ln -s ${self.supervisor}/bin/supervisor* $out/bin/
188 176 ln -s ${self.gunicorn}/bin/gunicorn $out/bin/
189 177 ln -s ${self.PasteScript}/bin/paster $out/bin/
190 178 ln -s ${self.channelstream}/bin/channelstream $out/bin/
191 179 ln -s ${self.pyramid}/bin/* $out/bin/ #*/
192 180
193 181 # rhodecode-tools
194 182 # TODO: johbo: re-think this. Do the tools import anything from enterprise?
195 183 ln -s ${self.rhodecode-tools}/bin/rhodecode-* $out/bin/
196 184
197 185 # note that condition should be restricted when adding further tools
198 186 for file in $out/bin/*; do #*/
199 187 wrapProgram $file \
200 188 --prefix PYTHONPATH : $PYTHONPATH \
201 189 --prefix PATH : $PATH \
202 190 --set PYTHONHASHSEED random
203 191 done
204 192
205 193 mkdir $out/etc
206 194 cp configs/production.ini $out/etc
207 195
208 196 echo "Writing meta information for rccontrol to nix-support/rccontrol"
209 197 mkdir -p $out/nix-support/rccontrol
210 198 cp -v rhodecode/VERSION $out/nix-support/rccontrol/version
211 199 echo "DONE: Meta information for rccontrol written"
212 200
213 201 # TODO: johbo: Make part of ac-tests
214 202 if [ ! -f rhodecode/public/js/scripts.js ]; then
215 203 echo "Missing scripts.js"
216 204 exit 1
217 205 fi
218 206 if [ ! -f rhodecode/public/css/style.css ]; then
219 207 echo "Missing style.css"
220 208 exit 1
221 209 fi
222 210 '';
223 211
224 212 });
225 213
226 214 rhodecode-testdata = import "${rhodecode-testdata-src}/default.nix" {
227 215 inherit
228 216 doCheck
229 217 pkgs
230 218 pythonPackages;
231 219 };
232 220
233 221 };
234 222
235 223 rhodecode-testdata-src = sources.rhodecode-testdata or (
236 224 pkgs.fetchhg {
237 225 url = "https://code.rhodecode.com/upstream/rc_testdata";
238 226 rev = "v0.9.0";
239 227 sha256 = "0k0ccb7cncd6mmzwckfbr6l7fsymcympwcm948qc3i0f0m6bbg1y";
240 228 });
241 229
242 230 # Apply all overrides and fix the final package set
243 231 myPythonPackagesUnfix = with pkgs.lib;
244 232 (extends pythonExternalOverrides
245 233 (extends pythonLocalOverrides
246 234 (extends pythonOverrides
247 235 pythonGeneratedPackages)));
248 236 myPythonPackages = (pkgs.lib.fix myPythonPackagesUnfix);
249 237
250 238 in myPythonPackages.rhodecode-enterprise-ce
@@ -1,57 +1,70 b''
1 1 { pkgs ? (import <nixpkgs> {})
2 2 , vcsserverPath ? "./../rhodecode-vcsserver"
3 3 , vcsserverNix ? "shell.nix"
4 4 , doCheck ? true
5 5 }:
6 6
7 7 let
8 8
9 9 # Convert vcsserverPath to absolute path.
10 10 vcsserverAbsPath =
11 11 if pkgs.lib.strings.hasPrefix "/" vcsserverPath then
12 12 builtins.toPath "${vcsserverPath}"
13 13 else
14 14 builtins.toPath ("${builtins.getEnv "PWD"}/${vcsserverPath}");
15 15
16 16 # Import vcsserver if nix file exists, otherwise set it to null.
17 17 vcsserver =
18 18 let
19 19 nixFile = "${vcsserverAbsPath}/${vcsserverNix}";
20 20 in
21 21 if pkgs.lib.pathExists "${nixFile}" then
22 22 builtins.trace
23 23 "Using local vcsserver from ${nixFile}"
24 24 import "${nixFile}" {inherit pkgs;}
25 25 else
26 26 null;
27 27
28 28 hasVcsserver = !isNull vcsserver;
29 29
30 enterprise = import ./default.nix {
30 enterprise-ce = import ./default.nix {
31 31 inherit pkgs doCheck;
32 32 };
33 33
34 pythonPackages = enterprise.pythonPackages;
34 ce-pythonPackages = enterprise-ce.pythonPackages;
35 35
36 in enterprise.override (attrs: {
36 in enterprise-ce.override (attrs: {
37 37 # Avoid that we dump any sources into the store when entering the shell and
38 38 # make development a little bit more convenient.
39 39 src = null;
40 40
41 41 buildInputs =
42 42 attrs.buildInputs ++
43 43 pkgs.lib.optionals (hasVcsserver) vcsserver.propagatedNativeBuildInputs ++
44 (with pythonPackages; [
44 (with ce-pythonPackages; [
45 45 bumpversion
46 46 invoke
47 47 ipdb
48 48 ]);
49 49
50 shellHook = attrs.shellHook +
50 # Somewhat snappier setup of the development environment
51 # TODO: think of supporting a stable path again, so that multiple shells
52 # can share it.
53 postShellHook = ''
54 # Custom prompt to distinguish from other dev envs.
55 export PS1="\n\[\033[1;32m\][CE-shell:\w]$\[\033[0m\] "
56
57 tmp_path=$(mktemp -d)
58 export PATH="$tmp_path/bin:$PATH"
59 export PYTHONPATH="$tmp_path/${ce-pythonPackages.python.sitePackages}:$PYTHONPATH"
60 mkdir -p $tmp_path/${ce-pythonPackages.python.sitePackages}
61 python setup.py develop --prefix $tmp_path --allow-hosts ""
62 '' + enterprise-ce.linkNodeAndBowerPackages +
51 63 pkgs.lib.strings.optionalString (hasVcsserver) ''
52 64 # Setup the vcsserver development egg.
53 65 pushd ${vcsserverAbsPath}
54 66 python setup.py develop --prefix $tmp_path --allow-hosts ""
55 67 popd
56 68 '';
69
57 70 })
General Comments 0
You need to be logged in to leave comments. Login now