mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-20 03:43:45 +00:00
google-chrome: add -beta and -unstable variants
It is a little weird that chromium has chromium, chromiumBeta, chromiumDev but this one is google-chrome, google-chrome-beta, google-chrome-dev. Not quite sure what the best resolution is, if any.
This commit is contained in:
parent
7195e6e14f
commit
c8368cf124
@ -35,8 +35,6 @@ with (import ../chromium/source/update.nix {
|
||||
}).getChannel channel;
|
||||
|
||||
let
|
||||
dist = if channel == "dev" then "unstable" else channel;
|
||||
|
||||
opusWithCustomModes = libopus.override {
|
||||
withCustomModes = true;
|
||||
};
|
||||
@ -71,7 +69,13 @@ in stdenv.mkDerivation rec {
|
||||
'';
|
||||
|
||||
installPhase = ''
|
||||
exe=$out/bin/google-chrome-${dist}
|
||||
case ${channel} in
|
||||
beta) appname=chrome-beta dist=beta ;;
|
||||
dev) appname=chrome-unstable dist=unstable ;;
|
||||
*) appname=chrome dist=stable ;;
|
||||
esac
|
||||
|
||||
exe=$out/bin/google-chrome-$dist
|
||||
rpath="${env}/lib:${env}/lib64"
|
||||
|
||||
mkdir -p $out/bin $out/share
|
||||
@ -79,32 +83,32 @@ in stdenv.mkDerivation rec {
|
||||
cp -a opt/* $out/share
|
||||
cp -a usr/share/* $out/share
|
||||
|
||||
substituteInPlace $out/share/applications/google-chrome.desktop \
|
||||
--replace /usr/bin/google-chrome-${dist} $exe
|
||||
substituteInPlace $out/share/gnome-control-center/default-apps/google-chrome.xml \
|
||||
--replace /opt/google/chrome/google-chrome $exe
|
||||
substituteInPlace $out/share/menu/google-chrome.menu \
|
||||
substituteInPlace $out/share/applications/google-$appname.desktop \
|
||||
--replace /usr/bin/google-chrome-$dist $exe
|
||||
substituteInPlace $out/share/gnome-control-center/default-apps/google-$appname.xml \
|
||||
--replace /opt/google/$appname/google-$appname $exe
|
||||
substituteInPlace $out/share/menu/google-$appname.menu \
|
||||
--replace /opt $out/share \
|
||||
--replace $out/share/google/chrome/google-chrome $exe
|
||||
--replace $out/share/google/chrome/google-$appname $exe
|
||||
|
||||
for icon_file in $out/share/google/chrome/product_logo_*[0-9].png; do
|
||||
for icon_file in $out/share/google/chrome*/product_logo_*[0-9].png; do
|
||||
num_and_suffix="''${icon_file##*logo_}"
|
||||
icon_size="''${num_and_suffix%.*}"
|
||||
logo_output_prefix="$out/share/icons/hicolor"
|
||||
logo_output_path="$logo_output_prefix/''${icon_size}x''${icon_size}/apps"
|
||||
mkdir -p "$logo_output_path"
|
||||
mv "$icon_file" "$logo_output_path/google-chrome.png"
|
||||
mv "$icon_file" "$logo_output_path/google-$appname.png"
|
||||
done
|
||||
|
||||
cat > $exe << EOF
|
||||
#!${bash}/bin/sh
|
||||
export LD_LIBRARY_PATH=$rpath\''${LD_LIBRARY_PATH:+:\$LD_LIBRARY_PATH}
|
||||
export PATH=${env}/bin\''${PATH:+:\$PATH}
|
||||
$out/share/google/chrome/google-chrome "\$@"
|
||||
$out/share/google/$appname/google-$appname "\$@"
|
||||
EOF
|
||||
chmod +x $exe
|
||||
|
||||
for elf in $out/share/google/chrome/{chrome,chrome-sandbox,nacl_helper}; do
|
||||
for elf in $out/share/google/$appname/{chrome,chrome-sandbox,nacl_helper}; do
|
||||
patchelf --set-rpath $rpath $elf
|
||||
patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" $elf
|
||||
done
|
||||
@ -112,7 +116,7 @@ in stdenv.mkDerivation rec {
|
||||
|
||||
meta = {
|
||||
description = "A freeware web browser developed by Google";
|
||||
homepage = "https://www.google.com/chrome/browser/";
|
||||
homepage = https://www.google.com/chrome/browser/;
|
||||
license = licenses.unfree;
|
||||
maintainers = [ maintainers.msteen ];
|
||||
platforms = platforms.linux;
|
||||
|
@ -12025,6 +12025,10 @@ let
|
||||
|
||||
google-chrome = callPackage ../applications/networking/browsers/google-chrome { gconf = gnome.GConf; };
|
||||
|
||||
google-chrome-beta = google-chrome.override { channel = "beta"; };
|
||||
|
||||
google-chrome-dev = google-chrome.override { channel = "dev"; };
|
||||
|
||||
googleearth = callPackage_i686 ../applications/misc/googleearth { };
|
||||
|
||||
google_talk_plugin = callPackage ../applications/networking/browsers/mozilla-plugins/google-talk-plugin {
|
||||
|
Loading…
Reference in New Issue
Block a user