summaryrefslogtreecommitdiffstats
path: root/.local/bin/linkview
diff options
context:
space:
mode:
Diffstat (limited to '.local/bin/linkview')
-rwxr-xr-x.local/bin/linkview242
1 files changed, 174 insertions, 68 deletions
diff --git a/.local/bin/linkview b/.local/bin/linkview
index 0653b27..83b7cc8 100755
--- a/.local/bin/linkview
+++ b/.local/bin/linkview
@@ -32,14 +32,26 @@ use constant PROG_LIST => "" .
"zathura" . "\n" .
"w3m" . "\n" .
"firefox" . "\n";
+use constant QUAL_LIST => "" .
+"1080" . "\n" .
+"720" . "\n" .
+"480" . "\n" .
+"360" . "\n" .
+"240" . "\n" .
+"144" . "\n" .
+"uncap" . "\n";
sub open_link
{
my ($a, $url) = @_;
+ my $count;
my $file_name;
my $i;
+ my $list;
my $pid;
+ my $pid2;
my $pwd;
+ my $quality;
my $ret;
my $tmp;
my $tmpfile;
@@ -65,95 +77,189 @@ sub open_link
$pid = fork();
if (not $pid) {
setsid();
- chdir home() . "/dl" or
- chdir home() . "/Downloads" or
- chdir home() or die $!;
- if (basename(cwd()) eq basename(home())) {
- $pwd = '~/';
- }
- else {
- $pwd = '~/' . basename(cwd());
- }
- $file_name = $url;
- $file_name =~ s/.+\///g;
- if ($file_name =~ m/^watch\?v=.+/) {
+ $ret = -1;
+ if ($a eq "youtube-dl") {
+ $list = QUAL_LIST;
+ $quality = `printf "$list" | dmenu -i -l 7 -m 0`;
+ if (not $quality) {
+ exit 0;
+ }
+ chomp $quality;
+ chdir home() . "/dl" or
+ chdir home() . "/Downloads" or
+ chdir home() or die $!;
+ if (basename(cwd()) eq basename(home())) {
+ $pwd = '~/';
+ }
+ else {
+ $pwd = '~/' . basename(cwd());
+ }
+ $file_name = $url;
+ $file_name =~ s/.+\///g;
$file_name = `youtube-dl -e $url`;
if (not $file_name) {
- $file_name = "Youtube video";
+ $file_name = "YouTube video";
}
chomp $file_name;
- }
- @wc = split / /, $file_name;
- if (@wc > 8) {
- $file_name = "";
- $i = 0;
- while ($i < 8) {
- $file_name .= "$wc[$i] ";
- $i++;
+ @wc = split / /, $file_name;
+ if (@wc > 8) {
+ $file_name = "";
+ $i = 0;
+ while ($i < 8) {
+ $file_name .= "$wc[$i] ";
+ $i++;
+ }
+ $file_name .= "[...]";
}
- $file_name .= "[...]";
- }
- $file_name =~ s/^[0-9]+/\[\.\.\.\]/;
- system(
- NOTIFYSEND_PATH,
- '-u', 'low',
- '-t', '10000',
- 'download started',
- ' <b>' . $file_name . '</b> started downloading'
+ $file_name =~ s/^[0-9]+/\[\.\.\.\]/;
+ system(
+ NOTIFYSEND_PATH,
+ '-u', 'low',
+ '-t', '2000',
+ 'download started',
+ ' <b>' . $file_name . '</b> started downloading'
);
- $ret = -1;
- if ($a eq "youtube-dl") {
$tmpfile = `mktemp`;
chomp $tmpfile;
- (undef, undef, $ret) = capture {
- system(YTDL_PATH . ' --newline --add-metadata ' . $url . ' >' . $tmpfile . ' &');
- };
- while (1) {
- $val = `tail -n 1 "$tmpfile" | awk '{print \$2}' | tr -d '%'`;
- if (looks_like_number($val) != 0) {
- system(
+ $pid2 = fork();
+ if (not $pid2) {
+ (undef, undef, $ret) = capture {
+ if ($quality eq 'uncap') {
+ system(YTDL_PATH . ' --newline --add-metadata ' . $url . ' >' . $tmpfile);
+ }
+ else {
+ system(YTDL_PATH . " -f '[height<=" . $quality . "]' --newline --add-metadata " . $url . ' >' . $tmpfile);
+ }
+ };
+ if ($ret == 0) {
+ system(
+ NOTIFYSEND_PATH,
+ '-u', 'normal',
+ '-t', '10000',
+ 'download complete',
+ ' <b>' . $file_name . '</b> downloaded successfully to ' .
+ '<b>' . $pwd . '</b>'
+ );
+ }
+ else {
+ system(
NOTIFYSEND_PATH,
- '-h',
- 'int:value:' . $val,
- '-u', 'low',
- '-t', '5000',
- 'downloading',
- ' downloading <b>' . $file_name . '</b>'
+ '-u', 'critical',
+ '-t', '10000',
+ 'download failed',
+ ' failed to download <b>' . $file_name . '</b>'
+ );
+ }
+ exit 0;
+ }
+ elsif ($pid2 < 0) {
+ system(
+ NOTIFYSEND_PATH,
+ '-u', 'critical',
+ '-t', '10000',
+ 'download failed',
+ ' failed to <b>fork(2)</b>'
);
- if ($val == 100 || system('pgrep python >/dev/null 2>&1') != 0) {
- last;
+ exit 0;
+ }
+ else {
+ $count = 0;
+ while (1) {
+ $val = `tail -n 1 "$tmpfile" | awk '{print \$2}' | tr -d '%'`;
+ if (looks_like_number($val) != 0) {
+ system(
+ NOTIFYSEND_PATH,
+ '-h',
+ 'int:value:' . $val,
+ '-u', 'low',
+ '-t', '5000',
+ 'downloading',
+ ' downloading <b>' . $file_name . '</b>'
+ );
+ if ($val == 100 || system('pgrep python >/dev/null 2>&1') != 0) {
+ last;
+ }
+ }
+ else {
+ if ($count == 10) {
+ last;
+ }
+ $count += 1;
}
+ sleep 2;
}
- sleep 2;
+ unlink $tmpfile;
}
- unlink $tmpfile;
- }
- else {
- (undef, undef, $ret) = capture {
- system(FETCH_PATH, $url);
- };
- }
- if ($ret == 0) {
- system(
- NOTIFYSEND_PATH,
- '-u', 'normal',
- '-t', '10000',
- 'download complete',
- ' <b>' . $file_name . '</b> downloaded successfully to ' .
- '<b>' . $pwd . '</b>'
- );
+ exit 0;
}
else {
+ chdir home() . "/dl" or
+ chdir home() . "/Downloads" or
+ chdir home() or die $!;
+ if (basename(cwd()) eq basename(home())) {
+ $pwd = '~/';
+ }
+ else {
+ $pwd = '~/' . basename(cwd());
+ }
+ $file_name = $url;
+ $file_name =~ s/.+\///g;
+ @wc = split / /, $file_name;
+ if (@wc > 8) {
+ $file_name = "";
+ $i = 0;
+ while ($i < 8) {
+ $file_name .= "$wc[$i] ";
+ $i++;
+ }
+ $file_name .= "[...]";
+ }
+ $file_name =~ s/^[0-9]+/\[\.\.\.\]/;
system(
NOTIFYSEND_PATH,
- '-u', 'critical',
+ '-u', 'low',
'-t', '10000',
- 'download failed',
- ' failed to download <b>' . $file_name . '</b>'
- );
+ 'download started',
+ ' <b>' . $file_name . '</b> started downloading'
+ );
+ (undef, undef, $ret) = capture {
+ system(FETCH_PATH, $url);
+ };
+ if ($ret == 0) {
+ system(
+ NOTIFYSEND_PATH,
+ '-u', 'normal',
+ '-t', '10000',
+ 'download complete',
+ ' <b>' . $file_name . '</b> downloaded successfully to ' .
+ '<b>' . $pwd . '</b>'
+ );
+ }
+ else {
+ system(
+ NOTIFYSEND_PATH,
+ '-u', 'critical',
+ '-t', '10000',
+ 'download failed',
+ ' failed to download <b>' . $file_name . '</b>'
+ );
+ }
}
exit 0;
}
+ elsif ($pid < 0) {
+ system(
+ NOTIFYSEND_PATH,
+ '-u', 'critical',
+ '-t', '10000',
+ 'download failed',
+ ' failed to <b>fork(2)</b>'
+ );
+ exit 0;
+ }
+ else {
+ exit 0;
+ }
}
elsif ($a eq "youtube-dl thumbnail") {
$pid = fork();