mercurial: 4.9.1 -> 5.2.1 + python3 🚀 (#76126)
mercurial: 4.9.1 -> 5.2.1 + python3 🚀
This commit is contained in:
commit
d5a81030ec
@ -1,21 +1,19 @@
|
|||||||
{ stdenv, fetchurl, python2Packages, makeWrapper, unzip
|
{ stdenv, fetchurl, python3Packages, makeWrapper, unzip
|
||||||
, guiSupport ? false, tk ? null
|
, guiSupport ? false, tk ? null
|
||||||
, ApplicationServices
|
, ApplicationServices
|
||||||
, mercurialSrc ? fetchurl rec {
|
|
||||||
meta.name = "mercurial-${meta.version}";
|
|
||||||
meta.version = "4.9.1";
|
|
||||||
url = "https://mercurial-scm.org/release/${meta.name}.tar.gz";
|
|
||||||
sha256 = "0iybbkd9add066729zg01kwz5hhc1s6lhp9rrnsmzq6ihyxj3p8v";
|
|
||||||
}
|
|
||||||
}:
|
}:
|
||||||
|
|
||||||
let
|
let
|
||||||
inherit (python2Packages) docutils hg-git dulwich python;
|
inherit (python3Packages) docutils dulwich python;
|
||||||
|
|
||||||
in python2Packages.buildPythonApplication {
|
in python3Packages.buildPythonApplication rec {
|
||||||
|
pname = "mercurial";
|
||||||
|
version = "5.2.1";
|
||||||
|
|
||||||
inherit (mercurialSrc.meta) name version;
|
src = fetchurl {
|
||||||
src = mercurialSrc;
|
url = "https://mercurial-scm.org/release/mercurial-${version}.tar.gz";
|
||||||
|
sha256 = "1pxkd37b0a1mi2zakk1hi122lgz1ffy2fxdnbs8acwlqpw55bc8q";
|
||||||
|
};
|
||||||
|
|
||||||
format = "other";
|
format = "other";
|
||||||
|
|
||||||
@ -24,41 +22,39 @@ in python2Packages.buildPythonApplication {
|
|||||||
buildInputs = [ makeWrapper docutils unzip ]
|
buildInputs = [ makeWrapper docutils unzip ]
|
||||||
++ stdenv.lib.optionals stdenv.isDarwin [ ApplicationServices ];
|
++ stdenv.lib.optionals stdenv.isDarwin [ ApplicationServices ];
|
||||||
|
|
||||||
propagatedBuildInputs = [ hg-git dulwich ];
|
propagatedBuildInputs = [ dulwich ];
|
||||||
|
|
||||||
makeFlags = [ "PREFIX=$(out)" ];
|
makeFlags = [ "PREFIX=$(out)" ];
|
||||||
|
|
||||||
postInstall = (stdenv.lib.optionalString guiSupport
|
postInstall = (stdenv.lib.optionalString guiSupport ''
|
||||||
''
|
mkdir -p $out/etc/mercurial
|
||||||
mkdir -p $out/etc/mercurial
|
cp contrib/hgk $out/bin
|
||||||
cp contrib/hgk $out/bin
|
cat >> $out/etc/mercurial/hgrc << EOF
|
||||||
cat >> $out/etc/mercurial/hgrc << EOF
|
[extensions]
|
||||||
[extensions]
|
hgk=$out/lib/${python.libPrefix}/site-packages/hgext/hgk.py
|
||||||
hgk=$out/lib/${python.libPrefix}/site-packages/hgext/hgk.py
|
EOF
|
||||||
EOF
|
# setting HG so that hgk can be run itself as well (not only hg view)
|
||||||
# setting HG so that hgk can be run itself as well (not only hg view)
|
WRAP_TK=" --set TK_LIBRARY ${tk}/lib/${tk.libPrefix}
|
||||||
WRAP_TK=" --set TK_LIBRARY ${tk}/lib/${tk.libPrefix}
|
--set HG $out/bin/hg
|
||||||
--set HG $out/bin/hg
|
--prefix PATH : ${tk}/bin "
|
||||||
--prefix PATH : ${tk}/bin "
|
'') + ''
|
||||||
'') +
|
for i in $(cd $out/bin && ls); do
|
||||||
''
|
wrapProgram $out/bin/$i \
|
||||||
for i in $(cd $out/bin && ls); do
|
$WRAP_TK
|
||||||
wrapProgram $out/bin/$i \
|
done
|
||||||
$WRAP_TK
|
|
||||||
done
|
|
||||||
|
|
||||||
# copy hgweb.cgi to allow use in apache
|
# copy hgweb.cgi to allow use in apache
|
||||||
mkdir -p $out/share/cgi-bin
|
mkdir -p $out/share/cgi-bin
|
||||||
cp -v hgweb.cgi contrib/hgweb.wsgi $out/share/cgi-bin
|
cp -v hgweb.cgi contrib/hgweb.wsgi $out/share/cgi-bin
|
||||||
chmod u+x $out/share/cgi-bin/hgweb.cgi
|
chmod u+x $out/share/cgi-bin/hgweb.cgi
|
||||||
|
|
||||||
# install bash/zsh completions
|
# install bash/zsh completions
|
||||||
install -v -m644 -D contrib/bash_completion $out/share/bash-completion/completions/_hg
|
install -v -m644 -D contrib/bash_completion $out/share/bash-completion/completions/_hg
|
||||||
install -v -m644 -D contrib/zsh_completion $out/share/zsh/site-functions/_hg
|
install -v -m644 -D contrib/zsh_completion $out/share/zsh/site-functions/_hg
|
||||||
'';
|
'';
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
inherit (mercurialSrc.meta) version;
|
inherit version;
|
||||||
description = "A fast, lightweight SCM system for very large distributed projects";
|
description = "A fast, lightweight SCM system for very large distributed projects";
|
||||||
homepage = https://www.mercurial-scm.org;
|
homepage = https://www.mercurial-scm.org;
|
||||||
downloadPage = https://www.mercurial-scm.org/release/;
|
downloadPage = https://www.mercurial-scm.org/release/;
|
||||||
|
@ -1,43 +1,38 @@
|
|||||||
{ lib, fetchurl, python2Packages
|
{ lib, fetchurl, python3Packages
|
||||||
, mercurial
|
, mercurial, qt5
|
||||||
}@args:
|
}@args:
|
||||||
let
|
let
|
||||||
tortoisehgSrc = fetchurl rec {
|
tortoisehgSrc = fetchurl rec {
|
||||||
meta.name = "tortoisehg-${meta.version}";
|
meta.name = "tortoisehg-${meta.version}";
|
||||||
meta.version = "5.0.2";
|
meta.version = "5.2.1";
|
||||||
url = "https://bitbucket.org/tortoisehg/targz/downloads/${meta.name}.tar.gz";
|
url = "https://bitbucket.org/tortoisehg/thg/get/14221e991a5b623e0072d3bd340b759dbe9072ca.tar.gz";
|
||||||
sha256 = "1fkawx4ymaacah2wpv2w7rxmv1mx08mg4x4r4fxh41jz1njjb8sz";
|
sha256 = "01rpzf5z99izcdda1ps9bhqvhw6qghagd8c1y7x19rv223zi05dv";
|
||||||
};
|
};
|
||||||
|
|
||||||
mercurial =
|
tortoiseMercurial = mercurial.overridePythonAttrs (old: rec {
|
||||||
if args.mercurial.meta.version == tortoisehgSrc.meta.version
|
inherit (tortoisehgSrc.meta) version;
|
||||||
then args.mercurial
|
src = fetchurl {
|
||||||
else args.mercurial.override {
|
url = "https://mercurial-scm.org/release/mercurial-${version}.tar.gz";
|
||||||
mercurialSrc = fetchurl rec {
|
sha256 = "1pxkd37b0a1mi2zakk1hi122lgz1ffy2fxdnbs8acwlqpw55bc8q";
|
||||||
meta.name = "mercurial-${meta.version}";
|
};
|
||||||
meta.version = tortoisehgSrc.meta.version;
|
});
|
||||||
url = "https://mercurial-scm.org/release/${meta.name}.tar.gz";
|
|
||||||
sha256 = "1y60hfc8gh4ha9sw650qs7hndqmvbn0qxpmqwpn4q18z5xwm1f19";
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
in python2Packages.buildPythonApplication {
|
|
||||||
|
|
||||||
|
in python3Packages.buildPythonApplication {
|
||||||
inherit (tortoisehgSrc.meta) name version;
|
inherit (tortoisehgSrc.meta) name version;
|
||||||
src = tortoisehgSrc;
|
src = tortoisehgSrc;
|
||||||
|
|
||||||
pythonPath = with python2Packages; [ pyqt4 mercurial qscintilla iniparse ];
|
propagatedBuildInputs = with python3Packages; [
|
||||||
|
tortoiseMercurial qscintilla-qt5 iniparse
|
||||||
propagatedBuildInputs = with python2Packages; [ qscintilla iniparse ];
|
];
|
||||||
|
nativeBuildInputs = [ qt5.wrapQtAppsHook ];
|
||||||
|
|
||||||
doCheck = false; # tests fail with "thg: cannot connect to X server"
|
doCheck = false; # tests fail with "thg: cannot connect to X server"
|
||||||
dontStrip = true;
|
postInstall = ''
|
||||||
buildPhase = "";
|
|
||||||
installPhase = ''
|
|
||||||
${python2Packages.python.executable} setup.py install --prefix=$out
|
|
||||||
mkdir -p $out/share/doc/tortoisehg
|
mkdir -p $out/share/doc/tortoisehg
|
||||||
cp COPYING.txt $out/share/doc/tortoisehg/Copying.txt.gz
|
cp COPYING.txt $out/share/doc/tortoisehg/Copying.txt
|
||||||
ln -s $out/bin/thg $out/bin/tortoisehg #convenient alias
|
# convenient alias
|
||||||
|
ln -s $out/bin/thg $out/bin/tortoisehg
|
||||||
|
wrapQtApp $out/bin/thg
|
||||||
'';
|
'';
|
||||||
|
|
||||||
checkPhase = ''
|
checkPhase = ''
|
||||||
@ -45,7 +40,7 @@ in python2Packages.buildPythonApplication {
|
|||||||
$out/bin/thg version
|
$out/bin/thg version
|
||||||
'';
|
'';
|
||||||
|
|
||||||
passthru.mercurial = mercurial;
|
passthru.mercurial = tortoiseMercurial;
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
description = "Qt based graphical tool for working with Mercurial";
|
description = "Qt based graphical tool for working with Mercurial";
|
||||||
|
@ -12,8 +12,7 @@ buildPythonPackage {
|
|||||||
format = "other";
|
format = "other";
|
||||||
|
|
||||||
nativeBuildInputs = [ lndir sip qtbase ];
|
nativeBuildInputs = [ lndir sip qtbase ];
|
||||||
buildInputs = [ qscintilla ];
|
buildInputs = [ qscintilla pyqt5 ];
|
||||||
propagatedBuildInputs = [ pyqt5 ];
|
|
||||||
|
|
||||||
postPatch = ''
|
postPatch = ''
|
||||||
substituteInPlace Python/configure.py \
|
substituteInPlace Python/configure.py \
|
||||||
|
Loading…
Reference in New Issue
Block a user