<html>
    <head>
      <base href="https://llvm.org/bugs/" />
    </head>
    <body><span class="vcard"><a class="email" href="mailto:warp@iki.fi" title="warp@iki.fi">warp@iki.fi</a>
</span> changed
              <a class="bz_bug_link 
          bz_status_REOPENED "
   title="REOPENED --- - int32_t vs. int64_t vs. long ambiguity"
   href="https://llvm.org/bugs/show_bug.cgi?id=23404">bug 23404</a>
        <br>
             <table border="1" cellspacing="0" cellpadding="8">
          <tr>
            <th>What</th>
            <th>Removed</th>
            <th>Added</th>
          </tr>

         <tr>
           <td style="text-align:right;">Status</td>
           <td>RESOLVED
           </td>
           <td>REOPENED
           </td>
         </tr>

         <tr>
           <td style="text-align:right;">Resolution</td>
           <td>INVALID
           </td>
           <td>---
           </td>
         </tr></table>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_REOPENED "
   title="REOPENED --- - int32_t vs. int64_t vs. long ambiguity"
   href="https://llvm.org/bugs/show_bug.cgi?id=23404#c2">Comment # 2</a>
              on <a class="bz_bug_link 
          bz_status_REOPENED "
   title="REOPENED --- - int32_t vs. int64_t vs. long ambiguity"
   href="https://llvm.org/bugs/show_bug.cgi?id=23404">bug 23404</a>
              from <span class="vcard"><a class="email" href="mailto:warp@iki.fi" title="warp@iki.fi">warp@iki.fi</a>
</span></b>
        <pre>The behavior just seems very inconsistent. The overloads work for all signed
integral types, except for 'long', even though there's a perfect match for that
type (ie. std::int64_t). For example a short(123) matches std::int32_t without
problems even though it's not even the same size. In summary:

    foo(char(123)); // Ok, matches std::int32_t
    foo(short(123)); // Ok, matches std::int32_t
    foo(123); // Ok, matches std::int32_t
    foo(123L); // Ambiguous
    foo(123LL); // Ok, matches std::int64_t

The thing is, there seems to be no portable way of supporting all of those
types without the calling code needing to do an explicit cast with that one
single exception, if the interface needs to handle integers of explicit size.

Adding an overloaded version for 'long' works with clang, but will it work with
other compilers? Potentially not. There is no way of adding an overload that
matches 'long' without it potentially clashing with the other overloads in some
compiler.

Is there an actual reason (ie. stated in the C++ standard) that a 64-bit 'long'
can't perfectly match std::int64_t, even though both are signed 64-bit
integers? (And, likewise, a 32-bit 'long' would match std::int32_t, as they are
both identical.)</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are on the CC list for the bug.</li>
      </ul>
    </body>
</html>