Skip to content

Commit

Permalink
Support non gnu libc arm-linux-eabi platforms
Browse files Browse the repository at this point in the history
  • Loading branch information
ntkme committed Aug 31, 2022
1 parent 75e7ff5 commit 394d7a6
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 1 deletion.
2 changes: 1 addition & 1 deletion lib/rubygems/platform.rb
Original file line number Diff line number Diff line change
Expand Up @@ -180,7 +180,7 @@ def ===(other)
# version
(
(@os != "linux" && (@version.nil? || other.version.nil?)) ||
(@os == "linux" && ((@version.nil? && ["gnu", "musl"].include?(other.version)) || (@version == "gnu" && other.version.nil?))) ||
(@os == "linux" && (other.version == "gnu#{@version}" || other.version == "musl#{@version}" || @version == "gnu#{other.version}")) ||
@version == other.version
)
end
Expand Down
32 changes: 32 additions & 0 deletions test/rubygems/test_gem_platform.rb
Original file line number Diff line number Diff line change
Expand Up @@ -138,6 +138,10 @@ def test_initialize
"x86_64-linux-gnu" => ["x86_64", "linux", "gnu"],
"x86_64-linux-musl" => ["x86_64", "linux", "musl"],
"x86_64-linux-uclibc" => ["x86_64", "linux", "uclibc"],
"arm-linux-eabi" => ["arm", "linux", "eabi"],
"arm-linux-gnueabi" => ["arm", "linux", "gnueabi"],
"arm-linux-musleabi" => ["arm", "linux", "musleabi"],
"arm-linux-uclibceabi" => ["arm", "linux", "uclibceabi"],
"x86_64-openbsd3.9" => ["x86_64", "openbsd", "3.9"],
"x86_64-openbsd4.0" => ["x86_64", "openbsd", "4.0"],
"x86_64-openbsd" => ["x86_64", "openbsd", nil],
Expand Down Expand Up @@ -301,6 +305,34 @@ def test_nil_version_is_stricter_for_linux_os
refute(x86_linux_uclibc === x86_linux, "linux-uclibc =~ linux")
end

def test_eabi_version_is_stricter_for_linux_os
arm_linux_eabi = Gem::Platform.new "arm-linux-eabi"
arm_linux_gnueabi = Gem::Platform.new "arm-linux-gnueabi"
arm_linux_musleabi = Gem::Platform.new "arm-linux-musleabi"
arm_linux_uclibceabi = Gem::Platform.new "arm-linux-uclibceabi"

# a naked linux runtime is implicit gnu, as it represents the common glibc-linked runtime
assert(arm_linux_eabi === arm_linux_gnueabi, "linux-eabi =~ linux-gnueabi")
assert(arm_linux_gnueabi === arm_linux_eabi, "linux-gnueabi =~ linux-eabi")

# musl and explicit gnu should differ
refute(arm_linux_gnueabi === arm_linux_musleabi, "linux-gnueabi =~ linux-musleabi")
refute(arm_linux_musleabi === arm_linux_gnueabi, "linux-musleabi =~ linux-gnueabi")

# explicit libc differ
refute(arm_linux_uclibceabi === arm_linux_musleabi, "linux-uclibceabi =~ linux-musleabi")
refute(arm_linux_musleabi === arm_linux_uclibceabi, "linux-musleabi =~ linux-uclibceabi")

# musl host runtime accepts libc-generic or statically linked gems...
assert(arm_linux_eabi === arm_linux_musleabi, "linux-eabi =~ linux-musleabi")
# ...but implicit gnu runtime generally does not accept musl-specific gems
refute(arm_linux_musleabi === arm_linux_eabi, "linux-musleabi =~ linux-eabi")

# other libc are not glibc compatible
refute(arm_linux_eabi === arm_linux_uclibceabi, "linux-eabi =~ linux-uclibceabi")
refute(arm_linux_uclibceabi === arm_linux_eabi, "linux-uclibceabi =~ linux-eabi")
end

def test_equals3_cpu_arm
arm = Gem::Platform.new "arm-linux"
armv5 = Gem::Platform.new "armv5-linux"
Expand Down

0 comments on commit 394d7a6

Please sign in to comment.