Merge pull request #12425 from DamienCassou/pharo-vm-no-conflict-v3
Refactor Pharo to allow co-installation of VMs
This commit is contained in:
commit
61d7fde27c
@ -1,4 +1,4 @@
|
|||||||
{ stdenv, fetchurl, cmake, bash, unzip, glibc, openssl, gcc, mesa, freetype, xorg, alsaLib, cairo }:
|
{ stdenv, fetchurl, cmake, bash, unzip, glibc, openssl, gcc, mesa, freetype, xorg, alsaLib, cairo, makeDesktopItem }:
|
||||||
|
|
||||||
{ name, src, binary-basename, ... }:
|
{ name, src, binary-basename, ... }:
|
||||||
|
|
||||||
@ -6,24 +6,19 @@ stdenv.mkDerivation rec {
|
|||||||
|
|
||||||
inherit name src binary-basename;
|
inherit name src binary-basename;
|
||||||
|
|
||||||
sources10Zip = fetchurl {
|
pharo-share = import ./share.nix { inherit stdenv fetchurl unzip; };
|
||||||
url = http://files.pharo.org/sources/PharoV10.sources.zip;
|
|
||||||
sha256 = "0aijhr3w5w3jzmnpl61g6xkwyi2l1mxy0qbvr9k3whz8zlrsijh2";
|
|
||||||
};
|
|
||||||
|
|
||||||
sources20Zip = fetchurl {
|
desktopItem = makeDesktopItem {
|
||||||
url = http://files.pharo.org/sources/PharoV20.sources.zip;
|
inherit name;
|
||||||
sha256 = "1xsc0p361pp8iha5zckppw29sbapd706wbvzvgjnkv2n6n1q5gj7";
|
desktopName = "Pharo VM";
|
||||||
};
|
genericName = "Pharo Virtual Machine";
|
||||||
|
exec = "${binary-basename}-x %F";
|
||||||
sources30Zip = fetchurl {
|
icon = "pharo";
|
||||||
url = http://files.pharo.org/sources/PharoV30.sources.zip;
|
terminal = "false";
|
||||||
sha256 = "08d9a7gggwpwgrfbp7iv5896jgqz3vgjfrq19y3jw8k10pva98ak";
|
type="Application";
|
||||||
};
|
startupNotify = "false";
|
||||||
|
categories = "Development;";
|
||||||
sources40Zip = fetchurl {
|
mimeType = "application/x-pharo-image";
|
||||||
url = http://files.pharo.org/sources/PharoV40.sources.zip;
|
|
||||||
sha256 = "1xq1721ql19hpgr8ir372h92q7g8zwd6k921b21dap4wf8djqnpd";
|
|
||||||
};
|
};
|
||||||
|
|
||||||
# Building
|
# Building
|
||||||
@ -32,9 +27,7 @@ stdenv.mkDerivation rec {
|
|||||||
'';
|
'';
|
||||||
resources = ./resources;
|
resources = ./resources;
|
||||||
installPhase = ''
|
installPhase = ''
|
||||||
echo Current directory $(pwd)
|
mkdir -p "$prefix/lib/$name"
|
||||||
echo Creating prefix "$prefix"
|
|
||||||
mkdir -p "$prefix/lib/pharo-vm"
|
|
||||||
|
|
||||||
cd ../../results
|
cd ../../results
|
||||||
|
|
||||||
@ -44,9 +37,10 @@ stdenv.mkDerivation rec {
|
|||||||
mv vm-sound-ALSA vm-sound-ALSA.so
|
mv vm-sound-ALSA vm-sound-ALSA.so
|
||||||
mv pharo pharo-vm
|
mv pharo pharo-vm
|
||||||
|
|
||||||
cp * "$prefix/lib/pharo-vm"
|
cp * "$prefix/lib/$name"
|
||||||
|
|
||||||
cp -R "$resources/"* "$prefix/"
|
mkdir -p "$prefix/share/applications"
|
||||||
|
cp "${desktopItem}/share/applications/"* $prefix/share/applications
|
||||||
|
|
||||||
mkdir $prefix/bin
|
mkdir $prefix/bin
|
||||||
|
|
||||||
@ -57,7 +51,7 @@ stdenv.mkDerivation rec {
|
|||||||
# disable parameter expansion to forward all arguments unprocessed to the VM
|
# disable parameter expansion to forward all arguments unprocessed to the VM
|
||||||
set -f
|
set -f
|
||||||
|
|
||||||
exec $prefix/lib/pharo-vm/pharo-vm "\$@"
|
exec $prefix/lib/$name/pharo-vm "\$@"
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
cat > $prefix/bin/${binary-basename}-nox <<EOF
|
cat > $prefix/bin/${binary-basename}-nox <<EOF
|
||||||
@ -66,18 +60,15 @@ stdenv.mkDerivation rec {
|
|||||||
# disable parameter expansion to forward all arguments unprocessed to the VM
|
# disable parameter expansion to forward all arguments unprocessed to the VM
|
||||||
set -f
|
set -f
|
||||||
|
|
||||||
exec $prefix/lib/pharo-vm/pharo-vm -vm-display-null "\$@"
|
exec $prefix/lib/$name/pharo-vm -vm-display-null "\$@"
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
chmod +x $prefix/bin/${binary-basename}-x $prefix/bin/${binary-basename}-nox
|
chmod +x $prefix/bin/${binary-basename}-x $prefix/bin/${binary-basename}-nox
|
||||||
|
|
||||||
unzip ${sources10Zip} -d $prefix/lib/pharo-vm/
|
ln -s "${pharo-share}/lib/"*.sources $prefix/lib/$name
|
||||||
unzip ${sources20Zip} -d $prefix/lib/pharo-vm/
|
|
||||||
unzip ${sources30Zip} -d $prefix/lib/pharo-vm/
|
|
||||||
unzip ${sources40Zip} -d $prefix/lib/pharo-vm/
|
|
||||||
'';
|
'';
|
||||||
|
|
||||||
buildInputs = [ bash unzip cmake glibc openssl gcc mesa freetype xorg.libX11 xorg.libICE xorg.libSM alsaLib cairo ];
|
buildInputs = [ bash unzip cmake glibc openssl gcc mesa freetype xorg.libX11 xorg.libICE xorg.libSM alsaLib cairo pharo-share ];
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
description = "Clean and innovative Smalltalk-inspired environment";
|
description = "Clean and innovative Smalltalk-inspired environment";
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
{ stdenv, fetchurl, cmake, bash, unzip, glibc, openssl, gcc, mesa, freetype, xorg, alsaLib, cairo } @args:
|
{ stdenv, fetchurl, cmake, bash, unzip, glibc, openssl, gcc, mesa, freetype, xorg, alsaLib, cairo, makeDesktopItem } @args:
|
||||||
|
|
||||||
rec {
|
rec {
|
||||||
pharo-vm-build = import ./build-vm.nix args;
|
pharo-vm-build = import ./build-vm.nix args;
|
||||||
@ -10,7 +10,7 @@ rec {
|
|||||||
name = "pharo-vm-i386-${version}";
|
name = "pharo-vm-i386-${version}";
|
||||||
binary-basename = "pharo-vm";
|
binary-basename = "pharo-vm";
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "$base-url/pharo-vm-${version}.tar.bz2";
|
url = "${base-url}/pharo-vm-${version}.tar.bz2";
|
||||||
sha256 = "1kmb6phxb94d37awwldwbkj704l6m0c6sv0m54mcz6d4rx41fqgp";
|
sha256 = "1kmb6phxb94d37awwldwbkj704l6m0c6sv0m54mcz6d4rx41fqgp";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
@ -20,7 +20,7 @@ rec {
|
|||||||
name = "pharo-vm-spur-i386-${version}";
|
name = "pharo-vm-spur-i386-${version}";
|
||||||
binary-basename = "pharo-spur-vm";
|
binary-basename = "pharo-spur-vm";
|
||||||
src = fetchurl {
|
src = fetchurl {
|
||||||
url = "$base-url/pharo-vm-spur-${version}.tar.bz2";
|
url = "${base-url}/pharo-vm-spur-${version}.tar.bz2";
|
||||||
sha256 = "1746kisa3wkhg1kwgjs544s3f17r8h99kr728qc4nk035dxkjfbx";
|
sha256 = "1746kisa3wkhg1kwgjs544s3f17r8h99kr728qc4nk035dxkjfbx";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
@ -1,11 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Name=Pharo VM
|
|
||||||
GenericName=Pharo Virtual Machine
|
|
||||||
Exec=pharo-vm-x %F
|
|
||||||
Icon=pharo
|
|
||||||
Terminal=false
|
|
||||||
Type=Application
|
|
||||||
StartupNotify=false
|
|
||||||
Categories=Development;
|
|
||||||
MimeType=application/x-pharo-image;
|
|
||||||
NoDisplay=true
|
|
48
pkgs/development/pharo/vm/share.nix
Normal file
48
pkgs/development/pharo/vm/share.nix
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
{ stdenv, fetchurl, unzip }:
|
||||||
|
|
||||||
|
stdenv.mkDerivation rec {
|
||||||
|
version = "1.0";
|
||||||
|
name = "pharo-share-${version}";
|
||||||
|
|
||||||
|
src = ./resources;
|
||||||
|
|
||||||
|
sources10Zip = fetchurl {
|
||||||
|
url = http://files.pharo.org/sources/PharoV10.sources.zip;
|
||||||
|
sha256 = "0aijhr3w5w3jzmnpl61g6xkwyi2l1mxy0qbvr9k3whz8zlrsijh2";
|
||||||
|
};
|
||||||
|
|
||||||
|
sources20Zip = fetchurl {
|
||||||
|
url = http://files.pharo.org/sources/PharoV20.sources.zip;
|
||||||
|
sha256 = "1xsc0p361pp8iha5zckppw29sbapd706wbvzvgjnkv2n6n1q5gj7";
|
||||||
|
};
|
||||||
|
|
||||||
|
sources30Zip = fetchurl {
|
||||||
|
url = http://files.pharo.org/sources/PharoV30.sources.zip;
|
||||||
|
sha256 = "08d9a7gggwpwgrfbp7iv5896jgqz3vgjfrq19y3jw8k10pva98ak";
|
||||||
|
};
|
||||||
|
|
||||||
|
sources40Zip = fetchurl {
|
||||||
|
url = http://files.pharo.org/sources/PharoV40.sources.zip;
|
||||||
|
sha256 = "1xq1721ql19hpgr8ir372h92q7g8zwd6k921b21dap4wf8djqnpd";
|
||||||
|
};
|
||||||
|
|
||||||
|
buildInputs = [ unzip ];
|
||||||
|
|
||||||
|
installPhase = ''
|
||||||
|
mkdir -p $prefix/lib
|
||||||
|
|
||||||
|
cp -R "$src/"* "$prefix/"
|
||||||
|
|
||||||
|
unzip ${sources10Zip} -d $prefix/lib/
|
||||||
|
unzip ${sources20Zip} -d $prefix/lib/
|
||||||
|
unzip ${sources30Zip} -d $prefix/lib/
|
||||||
|
unzip ${sources40Zip} -d $prefix/lib/
|
||||||
|
'';
|
||||||
|
|
||||||
|
meta = {
|
||||||
|
description = "Shared files for Pharo";
|
||||||
|
homepage = http://pharo.org;
|
||||||
|
license = stdenv.lib.licenses.mit;
|
||||||
|
maintainers = [ stdenv.lib.maintainers.DamienCassou ];
|
||||||
|
};
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user