Merge remote-tracking branch 'lass/master'
This commit is contained in:
commit
2761a90fbb
3
.gitmodules
vendored
3
.gitmodules
vendored
@ -7,3 +7,6 @@
|
|||||||
[submodule "lass/5pkgs/autowifi"]
|
[submodule "lass/5pkgs/autowifi"]
|
||||||
path = lass/5pkgs/autowifi
|
path = lass/5pkgs/autowifi
|
||||||
url = https://github.com/Lassulus/autowifi
|
url = https://github.com/Lassulus/autowifi
|
||||||
|
[submodule "submodules/brockman"]
|
||||||
|
path = submodules/brockman
|
||||||
|
url = https://github.com/kmein/brockman.git
|
||||||
|
@ -24,7 +24,12 @@ pkgs.writeDashBin "irc-announce" ''
|
|||||||
# echo2 and cat2 are used output to both, stdout and stderr
|
# echo2 and cat2 are used output to both, stdout and stderr
|
||||||
# This is used to see what we send to the irc server. (debug output)
|
# This is used to see what we send to the irc server. (debug output)
|
||||||
echo2() { echo "$*"; echo "$*" >&2; }
|
echo2() { echo "$*"; echo "$*" >&2; }
|
||||||
cat2() { (read x ; echo "$x" ; echo "$x" >&2) }
|
cat2() {
|
||||||
|
while read -r line; do
|
||||||
|
echo "$line"
|
||||||
|
echo "$line" >&2
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
# privmsg_cat transforms stdin to a privmsg
|
# privmsg_cat transforms stdin to a privmsg
|
||||||
privmsg_cat() { awk '{ print "PRIVMSG "ENVIRON["IRC_CHANNEL"]" :"$0 }'; }
|
privmsg_cat() { awk '{ print "PRIVMSG "ENVIRON["IRC_CHANNEL"]" :"$0 }'; }
|
||||||
|
@ -31,18 +31,19 @@
|
|||||||
};
|
};
|
||||||
};
|
};
|
||||||
stockholm.file = toString ../.;
|
stockholm.file = toString ../.;
|
||||||
stockholm-version.pipe = toString (pkgs.writeDash "${name}-version" ''
|
stockholm-version.pipe =
|
||||||
set -efu
|
toString (pkgs.writers.writeDash "${name}-version" ''
|
||||||
cd ${lib.escapeShellArg stockholm.file}
|
set -efu
|
||||||
V=$(${pkgs.coreutils}/bin/date +%y.%m)
|
cd ${lib.escapeShellArg stockholm.file}
|
||||||
if test -d .git; then
|
V=$(${pkgs.coreutils}/bin/date +%y.%m)
|
||||||
V=$V.git.$(${pkgs.git}/bin/git describe --always --dirty)
|
if test -d .git; then
|
||||||
case $V in (*-dirty)
|
V=$V.git.$(${pkgs.git}/bin/git describe --always --dirty)
|
||||||
V=$V@''${HOSTNAME-$(${pkgs.nettools}/bin/hostname)}
|
case $V in (*-dirty)
|
||||||
esac
|
V=$V@''${HOSTNAME-$(${pkgs.nettools}/bin/hostname)}
|
||||||
fi
|
esac
|
||||||
printf %s "$V"
|
fi
|
||||||
'');
|
printf %s "$V"
|
||||||
|
'');
|
||||||
};
|
};
|
||||||
|
|
||||||
source ={ test }: lib.evalSource [
|
source ={ test }: lib.evalSource [
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"url": "https://github.com/NixOS/nixpkgs-channels",
|
"url": "https://github.com/NixOS/nixpkgs-channels",
|
||||||
"rev": "100012e55bc2a82fc680cba31a426ad38ead6fab",
|
"rev": "55beed9922c2f6b030af61ca7e33bd47850c68f2",
|
||||||
"date": "2020-01-12T00:04:23+00:00",
|
"date": "2020-02-26T03:53:16-05:00",
|
||||||
"sha256": "0cvnx852n0krci9hi1rpcldx1kcpmvi5ihf2awvwfayvzp4wic8z",
|
"sha256": "0jxkb3bl7axa6vmfsfdfx4mxv6wx0pc8iiwgrw2qh8wxhlhbylks",
|
||||||
"fetchSubmodules": false
|
"fetchSubmodules": false
|
||||||
}
|
}
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"url": "https://github.com/NixOS/nixpkgs-channels",
|
"url": "https://github.com/NixOS/nixpkgs-channels",
|
||||||
"rev": "c49da6435f314e04fc58ca29807221817ac2ac6b",
|
"rev": "b7bbc6d37878ed00b6467b574b02e840279f7d3d",
|
||||||
"date": "2020-02-07T12:52:16+01:00",
|
"date": "2020-02-26T11:51:29+01:00",
|
||||||
"sha256": "17zsqhaf098bvcfarnq0h9601z6smkfd1kz1px6xfg6xqfmr80r7",
|
"sha256": "02q10jgi6m0vak3amb50ifw1pj82i17hs0npdkig7lsp8w3is7jq",
|
||||||
"fetchSubmodules": false
|
"fetchSubmodules": false
|
||||||
}
|
}
|
||||||
|
@ -65,7 +65,7 @@ in {
|
|||||||
createHome = true;
|
createHome = true;
|
||||||
useDefaultShell = true;
|
useDefaultShell = true;
|
||||||
packages = with pkgs; [
|
packages = with pkgs; [
|
||||||
minecraft
|
# minecraft
|
||||||
steam-run
|
steam-run
|
||||||
scummvm
|
scummvm
|
||||||
dolphinEmu
|
dolphinEmu
|
||||||
|
@ -2,11 +2,84 @@
|
|||||||
|
|
||||||
let
|
let
|
||||||
|
|
||||||
|
download_subs = pkgs.writers.writePython3 "download_sub" {
|
||||||
|
libraries = [ pkgs.python3Packages.subliminal ];
|
||||||
|
} ''
|
||||||
|
from subliminal import download_best_subtitles, scan_video
|
||||||
|
from babelfish import Language
|
||||||
|
import sys
|
||||||
|
|
||||||
|
video_filename = sys.argv[1]
|
||||||
|
|
||||||
|
vid = scan_video(video_filename)
|
||||||
|
sub = download_best_subtitles([vid], {Language('eng')})[vid][0]
|
||||||
|
|
||||||
|
filename = '/tmp/' + vid.title + '.srt'
|
||||||
|
|
||||||
|
with open(filename, 'wb+') as file:
|
||||||
|
file.write(sub.content)
|
||||||
|
|
||||||
|
print(filename)
|
||||||
|
'';
|
||||||
|
|
||||||
|
autosub = pkgs.writeText "autosub.lua" ''
|
||||||
|
-- Requires Subliminal version 1.0 or newer
|
||||||
|
-- Make sure to specify your system's Subliminal location below:
|
||||||
|
local utils = require 'mp.utils'
|
||||||
|
|
||||||
|
-- Log function: log to both terminal and mpv OSD (On-Screen Display)
|
||||||
|
function log(string, secs)
|
||||||
|
secs = secs or 2 -- secs defaults to 2 when the secs parameter is absent
|
||||||
|
mp.msg.warn(string) -- This logs to the terminal
|
||||||
|
mp.osd_message(string, secs) -- This logs to mpv screen
|
||||||
|
end
|
||||||
|
|
||||||
|
function download()
|
||||||
|
log('Searching subtitles ...', 10)
|
||||||
|
table = { args = {"${download_subs}", mp.get_property('path')} }
|
||||||
|
result = utils.subprocess(table)
|
||||||
|
if result.error == nil then
|
||||||
|
-- remove trailing newline from subtitle filename
|
||||||
|
filename = string.gsub(result.stdout, "\n", "")
|
||||||
|
log(filename)
|
||||||
|
mp.commandv('sub_add', filename)
|
||||||
|
log('Subtitles ready!')
|
||||||
|
else
|
||||||
|
log('Subtitles failed downloading')
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Control function: only download if necessary
|
||||||
|
function control_download()
|
||||||
|
duration = tonumber(mp.get_property('duration'))
|
||||||
|
if duration < 900 then
|
||||||
|
mp.msg.warn('Video is less than 15 minutes\n', '=> NOT downloading any subtitles')
|
||||||
|
return
|
||||||
|
end
|
||||||
|
-- There does not seem to be any documentation for the 'sub' property,
|
||||||
|
-- but it works on both internally encoded as well as external subtitle files!
|
||||||
|
-- -> sub = '1' when subtitles are present
|
||||||
|
-- -> sub = 'no' when subtitles are not present
|
||||||
|
-- -> sub = 'auto' when called before the 'file-loaded' event is triggered
|
||||||
|
sub = mp.get_property('sub')
|
||||||
|
if sub == '1' then
|
||||||
|
mp.msg.warn('Sub track is already present\n', '=> NOT downloading other subtitles')
|
||||||
|
return
|
||||||
|
end
|
||||||
|
mp.msg.warn('No sub track was detected\n', '=> Proceeding to download subtitles:')
|
||||||
|
download()
|
||||||
|
end
|
||||||
|
|
||||||
|
mp.register_event('file-loaded', control_download)
|
||||||
|
mp.add_key_binding('S', "download_subs", download)
|
||||||
|
'';
|
||||||
|
|
||||||
mpv = pkgs.symlinkJoin {
|
mpv = pkgs.symlinkJoin {
|
||||||
name = "mpv";
|
name = "mpv";
|
||||||
paths = [
|
paths = [
|
||||||
(pkgs.writeDashBin "mpv" ''
|
(pkgs.writeDashBin "mpv" ''
|
||||||
exec ${pkgs.mpv}/bin/mpv --no-config "$@"
|
exec ${pkgs.mpv}/bin/mpv --no-config --script=${autosub} "$@"
|
||||||
|
# exec ${pkgs.mpv}/bin/mpv --no-config "$@"
|
||||||
'')
|
'')
|
||||||
pkgs.mpv
|
pkgs.mpv
|
||||||
];
|
];
|
||||||
|
1
submodules/brockman
Submodule
1
submodules/brockman
Submodule
@ -0,0 +1 @@
|
|||||||
|
Subproject commit 1a5b3faa1185f8c0e7861ebadf07e48ac4bdf7e9
|
@ -1 +1 @@
|
|||||||
Subproject commit f1b7112ac3cbe090e96f2c82c525b6db69b82034
|
Subproject commit ed9fc6658226b1525bc008205d76276f0054c6c5
|
Loading…
Reference in New Issue
Block a user