Remove dependencies on Hash::Merge and Clone::Choose (#60)
Remove dependencies on Hash::Merge and Clone::Choose
This commit is contained in:
commit
9f59494d4e
8 changed files with 57 additions and 27 deletions
2
Build.PL
2
Build.PL
|
@ -60,8 +60,6 @@ my $build = Module::Build->new(
|
||||||
'perl' => '5.006',
|
'perl' => '5.006',
|
||||||
'Carp' => 0,
|
'Carp' => 0,
|
||||||
'IO::File' => 0,
|
'IO::File' => 0,
|
||||||
'Hash::Merge' => 0,
|
|
||||||
'Clone' => 0,
|
|
||||||
},
|
},
|
||||||
script_files => [ 'bin/stow', 'bin/chkstow' ],
|
script_files => [ 'bin/stow', 'bin/chkstow' ],
|
||||||
all_from => 'lib/Stow.pm.in',
|
all_from => 'lib/Stow.pm.in',
|
||||||
|
|
|
@ -29,8 +29,6 @@
|
||||||
"runtime" : {
|
"runtime" : {
|
||||||
"requires" : {
|
"requires" : {
|
||||||
"Carp" : "0",
|
"Carp" : "0",
|
||||||
"Clone" : "0",
|
|
||||||
"Hash::Merge" : "0",
|
|
||||||
"IO::File" : "0",
|
"IO::File" : "0",
|
||||||
"perl" : "5.006"
|
"perl" : "5.006"
|
||||||
}
|
}
|
||||||
|
@ -39,11 +37,11 @@
|
||||||
"provides" : {
|
"provides" : {
|
||||||
"Stow" : {
|
"Stow" : {
|
||||||
"file" : "lib/Stow.pm",
|
"file" : "lib/Stow.pm",
|
||||||
"version" : "v2.3.0"
|
"version" : "v2.3.1"
|
||||||
},
|
},
|
||||||
"Stow::Util" : {
|
"Stow::Util" : {
|
||||||
"file" : "lib/Stow/Util.pm",
|
"file" : "lib/Stow/Util.pm",
|
||||||
"version" : "v2.3.0"
|
"version" : "v2.3.1"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"release_status" : "stable",
|
"release_status" : "stable",
|
||||||
|
@ -57,6 +55,6 @@
|
||||||
"url" : "git://git.savannah.gnu.org/stow.git"
|
"url" : "git://git.savannah.gnu.org/stow.git"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"version" : "v2.3.0",
|
"version" : "v2.3.1",
|
||||||
"x_serialization_backend" : "JSON::PP version 4.00"
|
"x_serialization_backend" : "JSON::PP version 4.00"
|
||||||
}
|
}
|
||||||
|
|
8
META.yml
8
META.yml
|
@ -18,19 +18,17 @@ name: Stow
|
||||||
provides:
|
provides:
|
||||||
Stow:
|
Stow:
|
||||||
file: lib/Stow.pm
|
file: lib/Stow.pm
|
||||||
version: v2.3.0
|
version: v2.3.1
|
||||||
Stow::Util:
|
Stow::Util:
|
||||||
file: lib/Stow/Util.pm
|
file: lib/Stow/Util.pm
|
||||||
version: v2.3.0
|
version: v2.3.1
|
||||||
requires:
|
requires:
|
||||||
Carp: '0'
|
Carp: '0'
|
||||||
Clone: '0'
|
|
||||||
Hash::Merge: '0'
|
|
||||||
IO::File: '0'
|
IO::File: '0'
|
||||||
perl: '5.006'
|
perl: '5.006'
|
||||||
resources:
|
resources:
|
||||||
homepage: https://savannah.gnu.org/projects/stow
|
homepage: https://savannah.gnu.org/projects/stow
|
||||||
license: http://www.gnu.org/licenses/gpl-2.0.html
|
license: http://www.gnu.org/licenses/gpl-2.0.html
|
||||||
repository: git://git.savannah.gnu.org/stow.git
|
repository: git://git.savannah.gnu.org/stow.git
|
||||||
version: v2.3.0
|
version: v2.3.1
|
||||||
x_serialization_backend: 'CPAN::Meta::YAML version 0.018'
|
x_serialization_backend: 'CPAN::Meta::YAML version 0.018'
|
||||||
|
|
21
NEWS
21
NEWS
|
@ -1,5 +1,26 @@
|
||||||
News file for Stow.
|
News file for Stow.
|
||||||
|
|
||||||
|
* Changes in version 2.3.1
|
||||||
|
|
||||||
|
*** Remove dependencies on Hash::Merge and Clone::Choose
|
||||||
|
|
||||||
|
stow 2.3.0 added external runtime dependencies on Hash::Merge and
|
||||||
|
Clone::Choose. Historically stow hasn't had runtime dependencies
|
||||||
|
other than Perl itself, which is a useful property if you're
|
||||||
|
managing the installation of Perl using stow; the bootstrapping
|
||||||
|
instructions in stow's manual would need updating to describe how
|
||||||
|
to install these two modules (and any dependencies they have now
|
||||||
|
or in the future) as well.
|
||||||
|
|
||||||
|
However, Hash::Merge is much more general than stow actually
|
||||||
|
needs, so replace the merge() call with a few lines of equivalent
|
||||||
|
code -- this avoids the external dependencies, and is clearer than
|
||||||
|
the merge() call.
|
||||||
|
|
||||||
|
Many thanks to Adam Sampson for this patch!
|
||||||
|
|
||||||
|
https://lists.gnu.org/archive/html/bug-stow/2019-06/msg00001.html
|
||||||
|
|
||||||
* Changes in version 2.3.0
|
* Changes in version 2.3.0
|
||||||
|
|
||||||
*** New features / changes in behaviour
|
*** New features / changes in behaviour
|
||||||
|
|
24
bin/stow.in
24
bin/stow.in
|
@ -457,16 +457,12 @@ require 5.006_001;
|
||||||
|
|
||||||
use POSIX qw(getcwd);
|
use POSIX qw(getcwd);
|
||||||
use Getopt::Long qw(GetOptionsFromArray);
|
use Getopt::Long qw(GetOptionsFromArray);
|
||||||
|
use Scalar::Util qw(reftype);
|
||||||
|
|
||||||
@USE_LIB_PMDIR@
|
@USE_LIB_PMDIR@
|
||||||
use Stow;
|
use Stow;
|
||||||
use Stow::Util qw(parent error);
|
use Stow::Util qw(parent error);
|
||||||
|
|
||||||
# Need to avoid Storable backend, since it can't deal with regexps:
|
|
||||||
# https://rt.perl.org/Public/Bug/Display.html?id=50608
|
|
||||||
use Clone::Choose qw(:Clone);
|
|
||||||
use Hash::Merge qw(merge);
|
|
||||||
|
|
||||||
my $ProgramName = $0;
|
my $ProgramName = $0;
|
||||||
$ProgramName =~ s{.*/}{};
|
$ProgramName =~ s{.*/}{};
|
||||||
|
|
||||||
|
@ -530,17 +526,27 @@ sub process_options {
|
||||||
|
|
||||||
# Merge .stowrc and command line options.
|
# Merge .stowrc and command line options.
|
||||||
# Preference is given to cli options.
|
# Preference is given to cli options.
|
||||||
|
my %options = %$rc_options;
|
||||||
|
foreach my $option (keys %$cli_options) {
|
||||||
|
my $rc_value = $rc_options->{$option};
|
||||||
|
my $cli_value = $cli_options->{$option};
|
||||||
|
my $type = reftype($cli_value);
|
||||||
|
|
||||||
|
if (defined $type && $type eq 'ARRAY' && defined $rc_value) {
|
||||||
# rc options come first in merged arrays.
|
# rc options come first in merged arrays.
|
||||||
|
$options{$option} = [@{$rc_value}, @{$cli_value}];
|
||||||
|
} else {
|
||||||
# cli options overwrite conflicting rc options.
|
# cli options overwrite conflicting rc options.
|
||||||
Hash::Merge::set_behavior('RIGHT_PRECEDENT');
|
$options{$option} = $cli_value;
|
||||||
my $options = merge($rc_options, $cli_options);
|
}
|
||||||
|
}
|
||||||
|
|
||||||
# Run checks on the merged options.
|
# Run checks on the merged options.
|
||||||
sanitize_path_options($options);
|
sanitize_path_options(\%options);
|
||||||
check_packages($pkgs_to_unstow, $pkgs_to_stow);
|
check_packages($pkgs_to_unstow, $pkgs_to_stow);
|
||||||
|
|
||||||
# Return merged and processed options.
|
# Return merged and processed options.
|
||||||
return ($options, $pkgs_to_unstow, $pkgs_to_stow);
|
return (\%options, $pkgs_to_unstow, $pkgs_to_stow);
|
||||||
}
|
}
|
||||||
|
|
||||||
#===== SUBROUTINE ===========================================================
|
#===== SUBROUTINE ===========================================================
|
||||||
|
|
|
@ -15,7 +15,7 @@ dnl along with this program. If not, see https://www.gnu.org/licenses/.
|
||||||
|
|
||||||
dnl Process this file with Autoconf to produce configure dnl
|
dnl Process this file with Autoconf to produce configure dnl
|
||||||
|
|
||||||
AC_INIT([stow], [2.3.0], [bug-stow@gnu.org])
|
AC_INIT([stow], [2.3.1], [bug-stow@gnu.org])
|
||||||
AC_PREREQ([2.61])
|
AC_PREREQ([2.61])
|
||||||
AC_CONFIG_AUX_DIR([automake])
|
AC_CONFIG_AUX_DIR([automake])
|
||||||
# Unfortunately we have to disable warnings for overrides, because we
|
# Unfortunately we have to disable warnings for overrides, because we
|
||||||
|
|
|
@ -140,10 +140,14 @@ Release procedure
|
||||||
|
|
||||||
- Increment the patchlevel of the version number in configure.ac.
|
- Increment the patchlevel of the version number in configure.ac.
|
||||||
|
|
||||||
|
- Run this again:
|
||||||
|
|
||||||
|
version=$( tools/get-version ) && echo $version
|
||||||
|
|
||||||
- Repeat the same procedure listed in the Module::Build section
|
- Repeat the same procedure listed in the Module::Build section
|
||||||
above, in order to update META.yaml and META.json.
|
above, in order to update META.yaml and META.json.
|
||||||
|
|
||||||
- git commit -m "Bump version to X.Y.Z for development of next release"
|
- git commit -m "Bump version to $version for development of next release"
|
||||||
|
|
||||||
- git push savannah
|
- git push savannah
|
||||||
|
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
use Test::More tests => 33;
|
use Test::More tests => 34;
|
||||||
|
|
||||||
use testutil;
|
use testutil;
|
||||||
|
|
||||||
|
@ -120,16 +120,19 @@ is($options->{dir}, "$ABS_TEST_DIR/stow"
|
||||||
=> "-d from \$HOME/.stowrc");
|
=> "-d from \$HOME/.stowrc");
|
||||||
|
|
||||||
#
|
#
|
||||||
# Test ~/.stowrc file is overridden by .stowrc in cwd.
|
# Test that some but not all options ~/.stowrc file are overridden by
|
||||||
|
# .stowrc in cwd.
|
||||||
#
|
#
|
||||||
local @ARGV = ('dummy');
|
local @ARGV = ('dummy');
|
||||||
make_file($HOME_RC_FILE, <<HERE);
|
make_file($HOME_RC_FILE, <<HERE);
|
||||||
-d $ABS_TEST_DIR/stow-will-be-overridden
|
-d $ABS_TEST_DIR/stow-will-be-overridden
|
||||||
--target $ABS_TEST_DIR/target-will-be-overridden
|
--target $ABS_TEST_DIR/target-will-be-overridden
|
||||||
|
--defer=info
|
||||||
HERE
|
HERE
|
||||||
make_file($CWD_RC_FILE, <<HERE);
|
make_file($CWD_RC_FILE, <<HERE);
|
||||||
-d $ABS_TEST_DIR/stow
|
-d $ABS_TEST_DIR/stow
|
||||||
--target $ABS_TEST_DIR/target
|
--target $ABS_TEST_DIR/target
|
||||||
|
--defer=man
|
||||||
HERE
|
HERE
|
||||||
|
|
||||||
($options, $pkgs_to_delete, $pkgs_to_stow) = process_options();
|
($options, $pkgs_to_delete, $pkgs_to_stow) = process_options();
|
||||||
|
@ -137,6 +140,8 @@ is($options->{target}, "$ABS_TEST_DIR/target"
|
||||||
=> "--target overridden by \$PWD/.stowrc");
|
=> "--target overridden by \$PWD/.stowrc");
|
||||||
is($options->{dir}, "$ABS_TEST_DIR/stow"
|
is($options->{dir}, "$ABS_TEST_DIR/stow"
|
||||||
=> "-d overridden \$PWD/.stowrc");
|
=> "-d overridden \$PWD/.stowrc");
|
||||||
|
is_deeply($options->{defer}, [qr(\Ainfo), qr(\Aman)],
|
||||||
|
'defer man and info');
|
||||||
unlink($CWD_RC_FILE) or die "Failed to unlink $CWD_RC_FILE";
|
unlink($CWD_RC_FILE) or die "Failed to unlink $CWD_RC_FILE";
|
||||||
|
|
||||||
#
|
#
|
||||||
|
|
Loading…
Reference in a new issue