mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-06-13 05:05:29 +03:00
ruby: fixes rubygems user installs
* Manage patches in git * Fixes the hook invocation to be more safe. Thanks @Mic92 * Install gems as user by default * Install gem binaries with the /usr/bin/env shebang * Fixes a bug where the passthru.libPath and passthru.gemPath would point to the wrong directory * Overhaul ruby version heuristics
This commit is contained in:
parent
854e00943b
commit
b8bcbec5fd
4 changed files with 102 additions and 64 deletions
|
@ -1,32 +1,35 @@
|
||||||
{ stdenv, lib, fetchurl, fetchFromSavannah, fetchFromGitHub
|
{ stdenv, lib, fetchurl, fetchpatch, fetchFromSavannah, fetchFromGitHub
|
||||||
, zlib, openssl, gdbm, ncurses, readline, groff, libyaml, libffi, autoreconfHook, bison
|
, zlib, openssl, gdbm, ncurses, readline, groff, libyaml, libffi, autoreconfHook, bison
|
||||||
, autoconf, darwin ? null
|
, autoconf, darwin ? null
|
||||||
, buildEnv, bundler, bundix
|
, buildEnv, bundler, bundix
|
||||||
} @ args:
|
} @ args:
|
||||||
|
|
||||||
let
|
let
|
||||||
op = stdenv.lib.optional;
|
op = lib.optional;
|
||||||
ops = stdenv.lib.optionals;
|
ops = lib.optionals;
|
||||||
opString = stdenv.lib.optionalString;
|
opString = lib.optionalString;
|
||||||
patchSet = import ./rvm-patchsets.nix { inherit fetchFromGitHub; };
|
patchSet = import ./rvm-patchsets.nix { inherit fetchFromGitHub; };
|
||||||
config = import ./config.nix { inherit fetchFromSavannah; };
|
config = import ./config.nix { inherit fetchFromSavannah; };
|
||||||
rubygemsSrc = import ./rubygems-src.nix { inherit fetchurl; };
|
rubygemsSrc = import ./rubygems-src.nix { inherit fetchurl; };
|
||||||
|
rubygemsPatch = fetchpatch {
|
||||||
|
url = "https://github.com/zimbatm/rubygems/compare/v2.6.6...v2.6.6-nix.patch";
|
||||||
|
sha256 = "0297rdb1m6v75q8665ry9id1s74p9305dv32l95ssf198liaihhd";
|
||||||
|
};
|
||||||
unpackdir = obj:
|
unpackdir = obj:
|
||||||
lib.removeSuffix ".tgz"
|
lib.removeSuffix ".tgz"
|
||||||
(lib.removeSuffix ".tar.gz" obj.name);
|
(lib.removeSuffix ".tar.gz" obj.name);
|
||||||
|
|
||||||
generic = { majorVersion, minorVersion, teenyVersion, patchLevel, sha256 }: let
|
# Contains the ruby version heuristics
|
||||||
versionNoPatch = "${majorVersion}.${minorVersion}.${teenyVersion}";
|
rubyVersion = import ./ruby-version.nix { inherit lib; };
|
||||||
version = "${versionNoPatch}-p${patchLevel}";
|
|
||||||
fullVersionName = if patchLevel != "0" && stdenv.lib.versionOlder versionNoPatch "2.1"
|
generic = { version, sha256 }: let
|
||||||
then version
|
ver = version;
|
||||||
else versionNoPatch;
|
tag = ver.gitTag;
|
||||||
tag = "v" + stdenv.lib.replaceChars ["." "p" "-"] ["_" "_" ""] fullVersionName;
|
isRuby20 = ver.majMin == "2.0";
|
||||||
isRuby20 = majorVersion == "2" && minorVersion == "0";
|
isRuby21 = ver.majMin == "2.1";
|
||||||
isRuby21 = majorVersion == "2" && minorVersion == "1";
|
|
||||||
baseruby = self.override { useRailsExpress = false; };
|
baseruby = self.override { useRailsExpress = false; };
|
||||||
self = lib.makeOverridable (
|
self = lib.makeOverridable (
|
||||||
{ stdenv, lib, fetchurl, fetchFromSavannah, fetchFromGitHub
|
{ stdenv, lib, fetchurl, fetchpatch, fetchFromSavannah, fetchFromGitHub
|
||||||
, useRailsExpress ? true
|
, useRailsExpress ? true
|
||||||
, zlib, zlibSupport ? true
|
, zlib, zlibSupport ? true
|
||||||
, openssl, opensslSupport ? true
|
, openssl, opensslSupport ? true
|
||||||
|
@ -46,13 +49,11 @@ let
|
||||||
rev = tag;
|
rev = tag;
|
||||||
sha256 = sha256.git;
|
sha256 = sha256.git;
|
||||||
} else fetchurl {
|
} else fetchurl {
|
||||||
url = "http://cache.ruby-lang.org/pub/ruby/${majorVersion}.${minorVersion}/ruby-${fullVersionName}.tar.gz";
|
url = "http://cache.ruby-lang.org/pub/ruby/${ver.majMin}/ruby-${ver}.tar.gz";
|
||||||
sha256 = sha256.src;
|
sha256 = sha256.src;
|
||||||
};
|
};
|
||||||
in
|
in
|
||||||
stdenv.mkDerivation rec {
|
stdenv.mkDerivation rec {
|
||||||
inherit version;
|
|
||||||
|
|
||||||
name = "ruby-${version}";
|
name = "ruby-${version}";
|
||||||
|
|
||||||
srcs = [ rubySrc rubygemsSrc ];
|
srcs = [ rubySrc rubygemsSrc ];
|
||||||
|
@ -85,13 +86,16 @@ let
|
||||||
hardeningDisable = lib.optional isRuby20 [ "format" ];
|
hardeningDisable = lib.optional isRuby20 [ "format" ];
|
||||||
|
|
||||||
patches =
|
patches =
|
||||||
[ ./gem_hook.patch ] ++
|
|
||||||
(import ./patchsets.nix {
|
(import ./patchsets.nix {
|
||||||
inherit patchSet useRailsExpress ops patchLevel;
|
inherit patchSet useRailsExpress ops;
|
||||||
})."${versionNoPatch}";
|
patchLevel = ver.patchLevel;
|
||||||
|
})."${ver.majMinTiny}";
|
||||||
|
|
||||||
postUnpack = ''
|
postUnpack = ''
|
||||||
cp -r ${unpackdir rubygemsSrc} ${sourceRoot}/rubygems
|
cp -r ${unpackdir rubygemsSrc} ${sourceRoot}/rubygems
|
||||||
|
pushd ${sourceRoot}/rubygems
|
||||||
|
patch -p1 < ${rubygemsPatch}
|
||||||
|
popd
|
||||||
'' + opString isRuby21 ''
|
'' + opString isRuby21 ''
|
||||||
rm "$sourceRoot/enc/unicode/name2ctype.h"
|
rm "$sourceRoot/enc/unicode/name2ctype.h"
|
||||||
'';
|
'';
|
||||||
|
@ -152,25 +156,28 @@ let
|
||||||
};
|
};
|
||||||
|
|
||||||
passthru = rec {
|
passthru = rec {
|
||||||
inherit majorVersion minorVersion teenyVersion patchLevel version;
|
version = ver;
|
||||||
rubyEngine = "ruby";
|
rubyEngine = "ruby";
|
||||||
baseRuby = baseruby;
|
baseRuby = baseruby;
|
||||||
libPath = "lib/${rubyEngine}/${versionNoPatch}";
|
libPath = "lib/${rubyEngine}/${ver.libDir}";
|
||||||
gemPath = "lib/${rubyEngine}/gems/${versionNoPatch}";
|
gemPath = "lib/${rubyEngine}/gems/${ver.libDir}";
|
||||||
devEnv = import ./dev.nix {
|
devEnv = import ./dev.nix {
|
||||||
inherit buildEnv bundler bundix;
|
inherit buildEnv bundler bundix;
|
||||||
ruby = self;
|
ruby = self;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
# deprecated 2016-09-21
|
||||||
|
majorVersion = ver.major;
|
||||||
|
minorVersion = ver.minor;
|
||||||
|
teenyVersion = ver.tiny;
|
||||||
|
patchLevel = ver.patchLevel;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
) args; in self;
|
) args; in self;
|
||||||
|
|
||||||
in {
|
in {
|
||||||
ruby_1_9_3 = generic {
|
ruby_1_9_3 = generic {
|
||||||
majorVersion = "1";
|
version = rubyVersion "1" "9" "3" "p551";
|
||||||
minorVersion = "9";
|
|
||||||
teenyVersion = "3";
|
|
||||||
patchLevel = "551";
|
|
||||||
sha256 = {
|
sha256 = {
|
||||||
src = "1s2ibg3s2iflzdv7rfxi1qqkvdbn2dq8gxdn0nxrb77ls5ffanxv";
|
src = "1s2ibg3s2iflzdv7rfxi1qqkvdbn2dq8gxdn0nxrb77ls5ffanxv";
|
||||||
git = "1r9xzzxmci2ajb34qb4y1w424mz878zdgzxkfp9w60agldxnb36s";
|
git = "1r9xzzxmci2ajb34qb4y1w424mz878zdgzxkfp9w60agldxnb36s";
|
||||||
|
@ -178,10 +185,7 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
ruby_2_0_0 = generic {
|
ruby_2_0_0 = generic {
|
||||||
majorVersion = "2";
|
version = rubyVersion "2" "0" "0" "p647";
|
||||||
minorVersion = "0";
|
|
||||||
teenyVersion = "0";
|
|
||||||
patchLevel = "647";
|
|
||||||
sha256 = {
|
sha256 = {
|
||||||
src = "1v2vbvydarcx5801gx9lc6gr6dfi0i7qbzwhsavjqbn79rdsz2n8";
|
src = "1v2vbvydarcx5801gx9lc6gr6dfi0i7qbzwhsavjqbn79rdsz2n8";
|
||||||
git = "186pf4q9xymzn4zn1sjppl1skrl5f0159ixz5cz8g72dmmynq3g3";
|
git = "186pf4q9xymzn4zn1sjppl1skrl5f0159ixz5cz8g72dmmynq3g3";
|
||||||
|
@ -189,10 +193,7 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
ruby_2_1_10 = generic {
|
ruby_2_1_10 = generic {
|
||||||
majorVersion = "2";
|
version = rubyVersion "2" "1" "10" "";
|
||||||
minorVersion = "1";
|
|
||||||
teenyVersion = "10";
|
|
||||||
patchLevel = "0";
|
|
||||||
sha256 = {
|
sha256 = {
|
||||||
src = "086x66w51lg41abjn79xb7f6xsryymkcc3nvakmkjnjyg96labpv";
|
src = "086x66w51lg41abjn79xb7f6xsryymkcc3nvakmkjnjyg96labpv";
|
||||||
git = "133phd5r5y0np5lc9nqif93l7yb13yd52aspyl6c46z5jhvhyvfi";
|
git = "133phd5r5y0np5lc9nqif93l7yb13yd52aspyl6c46z5jhvhyvfi";
|
||||||
|
@ -200,10 +201,7 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
ruby_2_2_5 = generic {
|
ruby_2_2_5 = generic {
|
||||||
majorVersion = "2";
|
version = rubyVersion "2" "2" "5" "";
|
||||||
minorVersion = "2";
|
|
||||||
teenyVersion = "5";
|
|
||||||
patchLevel = "0";
|
|
||||||
sha256 = {
|
sha256 = {
|
||||||
src = "1qrmlcyc0cy9hgafb1wny2h90rjyyh6d72nvr2h4xjm4jwbb7i1h";
|
src = "1qrmlcyc0cy9hgafb1wny2h90rjyyh6d72nvr2h4xjm4jwbb7i1h";
|
||||||
git = "0k0av6ypyq08c9axm721f0xi2bcp1443l7ydbxv4v8x4vsxdkmq2";
|
git = "0k0av6ypyq08c9axm721f0xi2bcp1443l7ydbxv4v8x4vsxdkmq2";
|
||||||
|
@ -211,10 +209,7 @@ in {
|
||||||
};
|
};
|
||||||
|
|
||||||
ruby_2_3_1 = generic {
|
ruby_2_3_1 = generic {
|
||||||
majorVersion = "2";
|
version = rubyVersion "2" "3" "1" "";
|
||||||
minorVersion = "3";
|
|
||||||
teenyVersion = "1";
|
|
||||||
patchLevel = "0";
|
|
||||||
sha256 = {
|
sha256 = {
|
||||||
src = "1kbxg72las93w0y553cxv3lymy2wvij3i3pg1y9g8aq3na676z5q";
|
src = "1kbxg72las93w0y553cxv3lymy2wvij3i3pg1y9g8aq3na676z5q";
|
||||||
git = "0dv1rf5f9lj3icqs51bq7ljdcf17sdclmxm9hilwxps5l69v5q9r";
|
git = "0dv1rf5f9lj3icqs51bq7ljdcf17sdclmxm9hilwxps5l69v5q9r";
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
diff --git a/rubygems/lib/rubygems/installer.rb b/rubygems/lib/rubygems/installer.rb
|
|
||||||
index a88d393..8612901 100644
|
|
||||||
--- a/rubygems/lib/rubygems/installer.rb
|
|
||||||
+++ b/rubygems/lib/rubygems/installer.rb
|
|
||||||
@@ -766,7 +766,15 @@ TEXT
|
|
||||||
# Ensures that files can't be installed outside the gem directory.
|
|
||||||
|
|
||||||
def extract_files
|
|
||||||
- @package.extract_files gem_dir
|
|
||||||
+ ret = @package.extract_files gem_dir
|
|
||||||
+ if ENV['NIX_POST_EXTRACT_FILES_HOOK']
|
|
||||||
+ puts
|
|
||||||
+ puts "running NIX_POST_EXTRACT_FILES_HOOK #{ENV['NIX_POST_EXTRACT_FILES_HOOK']} #{gem_dir}"
|
|
||||||
+ system("#{ENV['NIX_POST_EXTRACT_FILES_HOOK']} #{gem_dir}")
|
|
||||||
+ puts "running NIX_POST_EXTRACT_FILES_HOOK done"
|
|
||||||
+ puts
|
|
||||||
+ end
|
|
||||||
+ ret
|
|
||||||
end
|
|
||||||
|
|
||||||
##
|
|
63
pkgs/development/interpreters/ruby/ruby-version.nix
Normal file
63
pkgs/development/interpreters/ruby/ruby-version.nix
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
# Contains the ruby version heuristics
|
||||||
|
{ lib }:
|
||||||
|
with lib;
|
||||||
|
let
|
||||||
|
# The returned set should be immutable
|
||||||
|
rubyVersion = major: minor: tiny: tail:
|
||||||
|
rec {
|
||||||
|
inherit major minor tiny tail;
|
||||||
|
|
||||||
|
# Contains the patch number "223" if tail is "p223" or null
|
||||||
|
patchLevel =
|
||||||
|
let
|
||||||
|
p = removePrefix "p" tail;
|
||||||
|
isPosInt = num:
|
||||||
|
0 == stringLength
|
||||||
|
(replaceStrings
|
||||||
|
["0" "1" "2" "3" "4" "5" "6" "7" "8" "9"]
|
||||||
|
["" "" "" "" "" "" "" "" "" "" ]
|
||||||
|
num);
|
||||||
|
in
|
||||||
|
if hasPrefix "p" tail && isPosInt p then p
|
||||||
|
else null;
|
||||||
|
|
||||||
|
# Shortcuts
|
||||||
|
majMin = "${major}.${minor}";
|
||||||
|
majMinTiny = "${major}.${minor}.${tiny}";
|
||||||
|
|
||||||
|
# Ruby separates lib and gem folders by ABI version which isn't very
|
||||||
|
# consistent.
|
||||||
|
libDir =
|
||||||
|
if versionAtLeast majMinTiny "2.1.0" then
|
||||||
|
"${majMin}.0"
|
||||||
|
else if versionAtLeast majMinTiny "2.0.0" then
|
||||||
|
"2.0.0"
|
||||||
|
else if versionAtLeast majMinTiny "1.9.1" then
|
||||||
|
"1.9.1"
|
||||||
|
else
|
||||||
|
throw "version ${majMinTiny} is not supported";
|
||||||
|
|
||||||
|
# How ruby releases are tagged on github.com/ruby/ruby
|
||||||
|
gitTag =
|
||||||
|
let
|
||||||
|
base = "v${major}_${minor}_${tiny}";
|
||||||
|
in
|
||||||
|
if patchLevel != null then
|
||||||
|
"${base}_${patchLevel}"
|
||||||
|
else
|
||||||
|
if tail != "" then
|
||||||
|
"${base}_${tail}"
|
||||||
|
else
|
||||||
|
base;
|
||||||
|
|
||||||
|
# Implements the builtins.toString interface.
|
||||||
|
__toString = self:
|
||||||
|
self.majMinTiny + (
|
||||||
|
if self.patchLevel != null then
|
||||||
|
"-p${self.patchLevel}"
|
||||||
|
else if self.tail != "" then
|
||||||
|
"-${self.tail}"
|
||||||
|
else "");
|
||||||
|
};
|
||||||
|
in
|
||||||
|
rubyVersion
|
|
@ -184,6 +184,7 @@ stdenv.mkDerivation (attrs // {
|
||||||
--install-dir "$GEM_HOME" \
|
--install-dir "$GEM_HOME" \
|
||||||
--build-root '/' \
|
--build-root '/' \
|
||||||
--backtrace \
|
--backtrace \
|
||||||
|
--no-env-shebang \
|
||||||
${documentFlag} \
|
${documentFlag} \
|
||||||
$gempkg $gemFlags -- $buildFlags
|
$gempkg $gemFlags -- $buildFlags
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue