[Issue 23147] New: Integer division may cause undefined behavior in @safe code
    d-bugmail at puremagic.com 
    d-bugmail at puremagic.com
       
    Sun May 29 16:18:26 UTC 2022
    
    
  
https://issues.dlang.org/show_bug.cgi?id=23147
          Issue ID: 23147
           Summary: Integer division may cause undefined behavior in @safe
                    code
           Product: D
           Version: D2
          Hardware: All
                OS: All
            Status: NEW
          Severity: normal
          Priority: P1
         Component: dlang.org
          Assignee: nobody at puremagic.com
          Reporter: snarwin+bugzilla at gmail.com
According to the language spec [1], the behavior of integer division is
undefined when
* the denominator is 0, or
* the .min value of a signed integer type is divided by -1
However, both of these operations are allowed in @safe code. As of DMD 2.100.0,
the following program compiles without errors:
---
int div(int n, int m) @safe { return n/m; }
void main() @safe
{
    auto a = div(1, 0);
    auto b = div(int.min, -1);
}
---
If integer division is to remain allowed in @safe code, the behavior of these
divisions must be defined.
[1] https://dlang.org/spec/expression.html#division
--
    
    
More information about the Digitalmars-d-bugs
mailing list