Skip to content

Commit 81059f6

Browse files
committed
DRY source and destination dirs
1 parent 887c920 commit 81059f6

File tree

2 files changed

+24
-18
lines changed

2 files changed

+24
-18
lines changed

Diff for: configs/components/_base-ruby.rb

+7-5
Original file line numberDiff line numberDiff line change
@@ -127,13 +127,15 @@
127127
# RE-7593. However, Windows paths were changed to match *nix in puppet 6, see
128128
# commit 4b9d126dd5b. So only the pdk has this issue.
129129
if platform.is_windows? && settings[:bindir] != ruby_bindir
130+
bindir = settings[:bindir]
131+
130132
# Ruby 3+
131133
if Gem::Version.new(pkg.get_version) >= Gem::Version.new('3.0')
132134
pkg.install do
133135
[
134136
"cp #{settings[:gcc_bindir]}/libssp-0.dll #{ruby_bindir}",
135-
"cp #{settings[:bindir]}/libffi-8.dll #{ruby_bindir}",
136-
"cp #{settings[:bindir]}/libyaml-0-2.dll #{ruby_bindir}"
137+
"cp #{bindir}/libffi-8.dll #{ruby_bindir}",
138+
"cp #{bindir}/libyaml-0-2.dll #{ruby_bindir}"
137139
]
138140
end
139141
end
@@ -160,9 +162,9 @@
160162

161163
pkg.install do
162164
[
163-
"cp #{settings[:bindir]}/libgcc_s_#{gcc_postfix}-1.dll #{ruby_bindir}",
164-
"cp #{settings[:bindir]}/#{ssl_lib} #{ruby_bindir}",
165-
"cp #{settings[:bindir]}/#{crypto_lib} #{ruby_bindir}",
165+
"cp #{bindir}/libgcc_s_#{gcc_postfix}-1.dll #{ruby_bindir}",
166+
"cp #{bindir}/#{ssl_lib} #{ruby_bindir}",
167+
"cp #{bindir}/#{crypto_lib} #{ruby_bindir}"
166168
]
167169
end
168170

Diff for: configs/components/runtime-pdk.rb

+17-13
Original file line numberDiff line numberDiff line change
@@ -7,26 +7,30 @@
77
pkg.install_file File.join(settings[:gcc_bindir], dll), File.join(settings[:bindir], dll)
88
end
99

10-
# Ruby needs zlib
10+
tools_bindir = File.join(settings[:tools_root], 'bin')
11+
12+
# curl, openssl, etc need zlib, so install in *main* bin dir
1113
pkg.build_requires "pl-zlib-#{platform.architecture}"
12-
pkg.install_file "#{settings[:tools_root]}/bin/zlib1.dll", "#{settings[:bindir]}/zlib1.dll"
14+
pkg.install_file "#{tools_bindir}/zlib1.dll", "#{settings[:bindir]}/zlib1.dll"
1315

1416
# zlib, gdbm, yaml-cpp and iconv are all runtime dependancies of ruby, and their libraries need
15-
# To exist inside our vendored ruby
16-
pkg.install_file "#{settings[:tools_root]}/bin/zlib1.dll", "#{settings[:ruby_bindir]}/zlib1.dll"
17-
pkg.install_file "#{settings[:tools_root]}/bin/libgdbm-4.dll", "#{settings[:ruby_bindir]}/libgdbm-4.dll"
18-
pkg.install_file "#{settings[:tools_root]}/bin/libgdbm_compat-4.dll", "#{settings[:ruby_bindir]}/libgdbm_compat-4.dll"
19-
pkg.install_file "#{settings[:tools_root]}/bin/libiconv-2.dll", "#{settings[:ruby_bindir]}/libiconv-2.dll"
20-
pkg.install_file "#{settings[:tools_root]}/bin/libffi-6.dll", "#{settings[:ruby_bindir]}/libffi-6.dll" if settings[:ruby_version].start_with?('2')
17+
# to exist inside our primary ruby's bin dir
18+
ruby_bindir = settings[:ruby_bindir]
19+
pkg.install_file "#{tools_bindir}/zlib1.dll", "#{ruby_bindir}/zlib1.dll"
20+
pkg.install_file "#{tools_bindir}/libgdbm-4.dll", "#{ruby_bindir}/libgdbm-4.dll"
21+
pkg.install_file "#{tools_bindir}/libgdbm_compat-4.dll", "#{ruby_bindir}/libgdbm_compat-4.dll"
22+
pkg.install_file "#{tools_bindir}/libiconv-2.dll", "#{ruby_bindir}/libiconv-2.dll"
23+
pkg.install_file "#{tools_bindir}/libffi-6.dll", "#{ruby_bindir}/libffi-6.dll" if settings[:ruby_version].start_with?('2')
2124

2225
# Copy the DLLs into additional ruby install bindirs as well.
2326
if settings.has_key?(:additional_rubies)
2427
settings[:additional_rubies].each do |rubyver, local_settings|
25-
pkg.install_file "#{settings[:tools_root]}/bin/zlib1.dll", "#{local_settings[:ruby_bindir]}/zlib1.dll"
26-
pkg.install_file "#{settings[:tools_root]}/bin/libgdbm-4.dll", "#{local_settings[:ruby_bindir]}/libgdbm-4.dll"
27-
pkg.install_file "#{settings[:tools_root]}/bin/libgdbm_compat-4.dll", "#{local_settings[:ruby_bindir]}/libgdbm_compat-4.dll"
28-
pkg.install_file "#{settings[:tools_root]}/bin/libiconv-2.dll", "#{local_settings[:ruby_bindir]}/libiconv-2.dll"
29-
pkg.install_file "#{settings[:tools_root]}/bin/libffi-6.dll", "#{local_settings[:ruby_bindir]}/libffi-6.dll" if rubyver.start_with?('2')
28+
local_bindir = local_settings[:ruby_bindir]
29+
pkg.install_file "#{tools_bindir}/zlib1.dll", "#{local_bindir}/zlib1.dll"
30+
pkg.install_file "#{tools_bindir}/libgdbm-4.dll", "#{local_bindir}/libgdbm-4.dll"
31+
pkg.install_file "#{tools_bindir}/libgdbm_compat-4.dll", "#{local_bindir}/libgdbm_compat-4.dll"
32+
pkg.install_file "#{tools_bindir}/libiconv-2.dll", "#{local_bindir}/libiconv-2.dll"
33+
pkg.install_file "#{tools_bindir}/libffi-6.dll", "#{local_bindir}/libffi-6.dll" if rubyver.start_with?('2')
3034
end
3135
end
3236

0 commit comments

Comments
 (0)