Merge remote-tracking branch 'lass/master'

This commit is contained in:
makefu 2020-03-19 13:16:27 +01:00
commit 2761a90fbb
No known key found for this signature in database
GPG Key ID: 36F7711F3FC0F225
9 changed files with 105 additions and 22 deletions

3
.gitmodules vendored
View File

@ -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

View File

@ -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 }'; }

View File

@ -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 [

View File

@ -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
} }

View File

@ -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
} }

View File

@ -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

View File

@ -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

@ -0,0 +1 @@
Subproject commit 1a5b3faa1185f8c0e7861ebadf07e48ac4bdf7e9

@ -1 +1 @@
Subproject commit f1b7112ac3cbe090e96f2c82c525b6db69b82034 Subproject commit ed9fc6658226b1525bc008205d76276f0054c6c5