Project

General

Profile

Actions

Bug #15551

closed

The behavior of FIX2INT and FIX2UINT differs by platform

Added by Eregon (Benoit Daloze) about 5 years ago. Updated over 4 years ago.

Status:
Rejected
Assignee:
-
Target version:
-
ruby -v:
ruby 2.4.5p335 (2018-10-18 revision 65137) [x64-mingw32]
[ruby-core:91192]

Description

For instance, when sizeof(int) < sizeof(long) (such as on Linux), then

FIX2INT(nil)

raises TypeError.
But when sizeof(int) == sizeof(long) (such as on Windows), then it returns 4.

So the behavior changes from a call to rb_fix2int() to a raw shift without any checks.
I think it should be consistent between platforms.

Also, the code in ruby.h defining FIX2INT is fairly complicated with conditions like #if SIZEOF_INT < SIZEOF_LONG
spanning many lines, which makes it fairly hard to follow.

See https://github.com/ruby/spec/blob/c661c0ba6a602be6e06768a319bd7d87b2a8eda6/optional/capi/fixnum_spec.rb
and https://ci.appveyor.com/project/eregon/spec-x948i/builds/21753809/job/ed8e8k97m8syp4r7 for more differences.


Files

fix2int-consistent.patch (1017 Bytes) fix2int-consistent.patch jeremyevans0 (Jeremy Evans), 07/30/2019 08:49 PM
Actions

Also available in: Atom PDF

Like0
Like0Like0Like0