Merge pull request #57876 from dtzWill/feature/fx_cast

fx_cast: init at 0.0.5
This commit is contained in:
Domen Kožar 2020-02-20 15:18:03 +07:00 committed by GitHub
commit 5f711b6b7e
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 89 additions and 0 deletions

View file

@ -8,6 +8,7 @@
, google_talk_plugin, fribid, gnome3/*.gnome-shell*/
, browserpass, chrome-gnome-shell, uget-integrator, plasma-browser-integration, bukubrow
, tridactyl-native
, fx_cast_bridge
, udev
, kerberos
}:
@ -71,6 +72,7 @@ let
++ lib.optional (cfg.enableGnomeExtensions or false) chrome-gnome-shell
++ lib.optional (cfg.enableUgetIntegrator or false) uget-integrator
++ lib.optional (cfg.enablePlasmaBrowserIntegration or false) plasma-browser-integration
++ lib.optional (cfg.enableFXCastBridge or false) fx_cast_bridge
++ extraNativeMessagingHosts
);
libs = lib.optional stdenv.isLinux udev

View file

@ -0,0 +1,85 @@
{ stdenv, fetchurl, dpkg }:
stdenv.mkDerivation rec {
pname = "fx_cast_bridge";
version = "0.0.5";
src = fetchurl {
url = "https://github.com/hensm/fx_cast/releases/download/v${version}/${pname}-${version}-x64.deb";
sha256 = "1qmp1d7miq7c2q8i4bhfp5ywxdngvyi7rjl6i82is2g5nhr7gbvv";
};
nativeBuildInputs = [ dpkg ];
unpackPhase = ''
runHook preUnpack
dpkg-deb -xv $src ./
runHook postUnpack
'';
dontBuild = true;
dontPatchELF = true;
installPhase = ''
install -DT {opt/fx_cast,$out/bin}/${pname}
install -DT {usr,$out}/lib/mozilla/native-messaging-hosts/${pname}.json
substituteInPlace $out/lib/mozilla/native-messaging-hosts/${pname}.json \
--replace {/opt/fx_cast,$out/bin}/${pname}
'';
# See now-cli/default.nix
dontStrip = true;
preFixup = let
libPath = stdenv.lib.makeLibraryPath [stdenv.cc.cc stdenv.cc.libc];
bin = "$out/bin/${pname}";
in ''
orig_size=$(stat --printf=%s ${bin})
patchelf --set-interpreter "${stdenv.cc.bintools.dynamicLinker}" ${bin}
patchelf --set-rpath ${libPath} ${bin}
chmod +x ${bin}
new_size=$(stat --printf=%s ${bin})
###### zeit-pkg fixing starts here.
# we're replacing plaintext js code that looks like
# PAYLOAD_POSITION = '1234 ' | 0
# [...]
# PRELUDE_POSITION = '1234 ' | 0
# ^-----20-chars-----^^------22-chars------^
# ^-- grep points here
#
# var_* are as described above
# shift_by seems to be safe so long as all patchelf adjustments occur
# before any locations pointed to by hardcoded offsets
var_skip=20
var_select=22
shift_by=$(expr $new_size - $orig_size)
function fix_offset {
# $1 = name of variable to adjust
location=$(grep -obUam1 "$1" ${bin} | cut -d: -f1)
location=$(expr $location + $var_skip)
value=$(dd if=${bin} iflag=count_bytes,skip_bytes skip=$location \
bs=1 count=$var_select status=none)
value=$(expr $shift_by + $value)
echo -n $value | dd of=${bin} bs=1 seek=$location conv=notrunc
}
fix_offset PAYLOAD_POSITION
fix_offset PRELUDE_POSITION
'';
meta = with stdenv.lib; {
description = "Implementation of the Chrome Sender API (Chromecast) within Firefox";
homepage = https://hensm.github.io/fx_cast/;
license = licenses.mit;
maintainers = with maintainers; [ dtzWill ];
};
}

View file

@ -1776,6 +1776,8 @@ in
fwup = callPackage ../tools/misc/fwup { };
fx_cast_bridge = callPackage ../tools/misc/fx_cast { };
fzf = callPackage ../tools/misc/fzf { };
fzf-zsh = callPackage ../shells/zsh/fzf-zsh { };