Merge pull request #57876 from dtzWill/feature/fx_cast
fx_cast: init at 0.0.5
This commit is contained in:
commit
5f711b6b7e
3 changed files with 89 additions and 0 deletions
|
@ -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
|
||||
|
|
85
pkgs/tools/misc/fx_cast/default.nix
Normal file
85
pkgs/tools/misc/fx_cast/default.nix
Normal 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 ];
|
||||
};
|
||||
}
|
|
@ -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 { };
|
||||
|
|
Loading…
Reference in a new issue