diff options
Diffstat (limited to '.local/bin/linkview')
| -rwxr-xr-x | .local/bin/linkview | 71 | 
1 files changed, 48 insertions, 23 deletions
| diff --git a/.local/bin/linkview b/.local/bin/linkview index abc470d..916e0c5 100755 --- a/.local/bin/linkview +++ b/.local/bin/linkview @@ -2,6 +2,7 @@  use strict;  use warnings; +use Sys::Hostname;  use Scalar::Util qw(looks_like_number);  use File::HomeDir qw(home);  use File::Basename qw(basename); @@ -9,24 +10,27 @@ use Cwd qw(cwd);  use Term::ReadKey;  use Capture::Tiny qw(capture);  use POSIX qw(setsid); +use feature qw(switch); +no warnings qw(experimental::smartmatch);  use constant { -	TERMINAL_PATH	=> '/usr/local/bin/st', -	MPVIEW_PATH		=> home() . '/.local/bin/mpview', -	MPV_PATH		=> '/usr/local/bin/mpv', -	YTDL_PATH		=> '/usr/local/bin/yt-dlp', -	FETCH_PATH		=> '/usr/bin/fetch', -	IMGVIEW_PATH	=> '/usr/local/bin/nsxiv', -	ZATHURA_PATH	=> '/usr/local/bin/zathura', -	W3M_PATH		=> '/usr/local/bin/w3m', -	BROWSER_PATH	=> '/usr/local/bin/iridium', -	NOTIFYSEND_PATH	=> '/usr/local/bin/notify-send' +	TERMINAL_PATH	=> 'st', +	MPV_PATH		=> 'mpv', +	YTDL_PATH		=> 'yt-dlp', +	FETCH_PATH		=> 'fetch', +	CURL_PATH		=> 'curl', +	IMGVIEW_PATH	=> 'nsxiv', +	ZATHURA_PATH	=> 'zathura', +	W3M_PATH		=> 'w3m', +	BROWSER_PATH	=> 'firefox', +	NOTIFYSEND_PATH	=> 'notify-send', +	HOSTNAME		=> (split /\./, hostname())  };  use constant PROG_LIST	=> "" .  "mpv"					. "\n" .  "mpv-term"				. "\n" . -"youtube-dl"			. "\n" . -"youtube-dl thumbnail"	. "\n" . +"ytdl"					. "\n" . +"ytdl thumbnail"		. "\n" .  "fetch"					. "\n" .  "nsxiv"					. "\n" .  "zathura"				. "\n" . @@ -60,7 +64,7 @@ sub open_link  	my @wc;  	if ($a eq "mpv") { -		if (system(MPVIEW_PATH, $url) != 0) { +		if (system(MPV_PATH, $url) != 0) {  			system(  				NOTIFYSEND_PATH,  				'-u', 'critical', @@ -74,12 +78,12 @@ sub open_link  	elsif ($a eq "mpv-term") {  		exec(TERMINAL_PATH, '-e', MPV_PATH, '--audio-channels=stereo', $url);  	} -	elsif ($a eq "fetch" || $a eq "youtube-dl") { +	elsif ($a eq "fetch" || $a eq "ytdl") {  		$pid = fork();  		if (not $pid) {  			setsid();  			$ret = -1; -			if ($a eq "youtube-dl") { +			if ($a eq "ytdl") {  				$list = QUAL_LIST;  				$quality = `printf "$list" | dmenu -i -l 8 -m 0`;  				if (not $quality) { @@ -97,7 +101,7 @@ sub open_link  				}  				$file_name = $url;  				$file_name =~ s/.+\///g; -				$file_name = `youtube-dl -e $url`; +				$file_name = `yt-dlp -e $url`;  				if (not $file_name) {  					$file_name = "YouTube video";  				} @@ -233,7 +237,14 @@ sub open_link  					'  <b>' . $file_name . '</b> started downloading'  				);  				(undef, undef, $ret) = capture { -					system(FETCH_PATH, $url); +					given (HOSTNAME) { +						when(["mother", "po-rbo"]) { +							system(CURL_PATH, "-fsSLO", $url); +						} +						when("mars") { +							system(FETCH_PATH, $url); +						} +					}  				};  				if ($ret == 0) {  					system( @@ -271,7 +282,7 @@ sub open_link  			exit 0;  		}  	} -	elsif ($a eq "youtube-dl thumbnail") { +	elsif ($a eq "ytdl thumbnail") {  		$pid = fork();  		if (not $pid) {  			setsid(); @@ -279,7 +290,7 @@ sub open_link  			$file_name = $url;  			$file_name =~ s/.+\///g;  			if ($file_name =~ m/^watch\?v=.+/) { -				$file_name = `youtube-dl -e $url`; +				$file_name = `yt-dlp -e $url`;  				if (not $file_name) {  					$file_name = "Youtube video";  				} @@ -306,11 +317,18 @@ sub open_link  					);  				exit 0;  			} -			system(FETCH_PATH, '-q', $tmp); +			given (HOSTNAME) { +				when(["mother", "po-rbo"]) { +					system(CURL_PATH, "-fsSLO", $tmp); +				} +				when("mars") { +					system(FETCH_PATH, '-q', $tmp); +				} +			}  			$file_name = $tmp;  			$file_name =~ s/.+\///g;  			chomp $file_name; -			system(IMGVIEW_PATH, '-f', '-b', '-a', $file_name); +			system(IMGVIEW_PATH, '-b', '-a', $file_name);  			unlink($file_name);  			exit 0;  		} @@ -329,8 +347,15 @@ sub open_link  				'download started',  				'  fetching <b>'. $file_name . '</b> to <b>/tmp</b>'  				); -			system(FETCH_PATH, '-q', $url); -			if ($a == "nsxiv") { +			given (HOSTNAME) { +				when(["mother", "po-rbo"]) { +					system(CURL_PATH, "-fsSLO", $url); +				} +				when("mars") { +					system(FETCH_PATH, '-q', $url); +				} +			} +			if ($a eq "nsxiv") {  				exec(IMGVIEW_PATH, '-b', '-a', $file_name);  			}  			else { | 
