From 631b35a60852813c20045792f7354868f6a9ceeb Mon Sep 17 00:00:00 2001 From: "V." <150687949+vigress8@users.noreply.github.com> Date: Mon, 7 Oct 2024 12:43:27 +0400 Subject: [PATCH] feat: add --test flag, set LC_ALL=C (#27) --- .gitignore | 1 + pacup | 39 +++++++++++++++++++++++++-------------- shell.nix | 2 +- 3 files changed, 27 insertions(+), 15 deletions(-) diff --git a/.gitignore b/.gitignore index 079eef8..bc11eae 100644 --- a/.gitignore +++ b/.gitignore @@ -23,3 +23,4 @@ MYMETA.json MYMETA.yml .tidyall.d/ .vscode/ +.direnv/ diff --git a/pacup b/pacup index 2293f8a..559971b 100755 --- a/pacup +++ b/pacup @@ -4,7 +4,7 @@ package main; use strict; use warnings qw(all -experimental::signatures); use feature qw(say signatures); -our $VERSION = '3.3.6'; +our $VERSION = '3.3.7'; #use Data::Dumper; use open ':std', ':encoding(UTF-8)'; @@ -33,6 +33,7 @@ my $opt_ship = 0; my $opt_origin_remote = 'origin'; my $opt_custom_version; my $opt_push_force = 0; +my $opt_test = 1; my $srcinfo_script = "pacup-srcinfo"; my @HASHTYPES = qw(b2 md5 sha1 sha224 sha256 sha384 sha512); @@ -137,6 +138,7 @@ local $SIG{TERM} = sub { cleanup(); exit 1; }; +local $ENV{LC_ALL} = 'C'; sub getvar ( $file, $name, $isarr, $base = undef ) { my $cmd @@ -533,21 +535,25 @@ sub main ($pkg) { unlink $tmp_distrolist; if ( -x '/usr/bin/pacstall' ) { - info "Installing from $pacscript"; - my $payload = join( ';:', @collected_files ); - local $ENV{'PACSTALL_PAYLOAD'} = $payload; - if ( scalar @pkgnames == 1 ) { - system 'pacstall', ( '--install', $ppath ); - if ($opt_ship) { - return unless ask_wait "Does $pkgname work?"; - } - } else { - for my $pkg (@pkgnames) { - system 'pacstall', ( '--install', $ppath . ':' . $pkg ); + if ($opt_test) { + info "Installing from $pacscript"; + my $payload = join( ';:', @collected_files ); + local $ENV{'PACSTALL_PAYLOAD'} = $payload; + if ( scalar @pkgnames == 1 ) { + system 'pacstall', ( '--install', $ppath ); if ($opt_ship) { - return unless ask_wait "Does $pkg work?"; + return unless ask_wait "Does $pkgname work?"; + } + } else { + for my $pkg (@pkgnames) { + system 'pacstall', ( '--install', $ppath . ':' . $pkg ); + if ($opt_ship) { + return unless ask_wait "Does $pkg work?"; + } } } + } else { + info "Skipping testing of $pacscript"; } } else { warner "Pacstall is not installed or not executable!"; @@ -603,6 +609,7 @@ unless (caller) { 'origin-remote|o=s' => \$opt_origin_remote, 'custom-version|c=s' => \$opt_custom_version, 'push-force|p' => \$opt_push_force, + 'test!' => \$opt_test, ) or pod2usage(2); version_info() if $opt_version; @@ -661,6 +668,10 @@ Set a custom version for the package to fetch, instead of querying Repology. Force push to the branch, overwriting any existing one. +=item B<--[no-]test> + +Prompt to install each package for testing. True by default. + =back =head1 EXAMPLE @@ -675,7 +686,7 @@ Vigress - =head1 VERSION -Pacup (Perl edition) v3.3.6 +Pacup (Perl edition) v3.3.7 =cut diff --git a/shell.nix b/shell.nix index b775715..9e0a8e1 100644 --- a/shell.nix +++ b/shell.nix @@ -1,6 +1,6 @@ { pkgs ? - import (fetchTarball "https://github.com/NixOS/nixpkgs/tarball/nixos-23.11") + import (fetchTarball "https://github.com/NixOS/nixpkgs/tarball/nixos-24.05") { config = {}; overlays = [];