<html>
    <head>
      <base href="https://bugs.freedesktop.org/" />
    </head>
    <body>
      <p>
        <div>
            <b><a class="bz_bug_link 
          bz_status_NEW "
   title="NEW --- - shader_query.cpp:49: error: invalid conversion from 'void*' to 'GLuint'"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=66346#c7">Comment # 7</a>
              on <a class="bz_bug_link 
          bz_status_NEW "
   title="NEW --- - shader_query.cpp:49: error: invalid conversion from 'void*' to 'GLuint'"
   href="https://bugs.freedesktop.org/show_bug.cgi?id=66346">bug 66346</a>
              from <span class="vcard"><a class="email" href="mailto:jfonseca@vmware.com" title="José Fonseca <jfonseca@vmware.com>"> <span class="fn">José Fonseca</span></a>
</span></b>
        <pre>(In reply to <a href="show_bug.cgi?id=66346#c4">comment #4</a>)
<span class="quote">> This is in glext.h:

> #ifdef __APPLE__
> typedef void *GLhandleARB;
> #else
> typedef unsigned int GLhandleARB;
> #endif

> Thanks, Apple!

> I think Mesa is just broken on Apple, probably forever, because of this.  We
> assume *everywhere* that GLhandleARB == GLuint... to the point that
> glGetActiveAttrib and glGetActiveAttribARB (and many, many others) are the
> same function.</span >

Although Apple's GLhandleARB are void *, I recall reading that only 32bits are
used. (Unfortunately Apple can't go back in time and replace GLhandleARB with
uints, as that would break binary compatibility.)

Furthermore what Apple does is irrelevant, as Mesa is free to do what it wants
(ie, it's free to assume using GLhandleARB are always 32bits).

In short, all we have to do we fix the compiler errors, either:

1) typedefing GLhandleARB as uintptr_t internally when

  #ifdef __APPLE__
  #  ifdef BUILDING_MESA
  typedef uintptr_t GLhandleARB;
  #  else
  typedef void *GLhandleARB;
  #  endif
  #else
  typedef unsigned int GLhandleARB;
  #endif

2) add intermediate casts to (uintptr_t) between uint<->GLhandleARB
conversions.

<span class="quote">> This occurs in shader_query.cpp, uniforms.c, uniform_query.cpp, shaderapi.c,
> and dlist.c.

> I'm honestly inclined to close this as WONTFIX...</span >

Jeez, it seems nobody has patient for non-Linux platform these days.  Yes,
cross-platform its often a pain, but not really the end of the world.


(In reply to <a href="show_bug.cgi?id=66346#c5">comment #5</a>)
<span class="quote">> Looks like there's about 20 functions which would have be split into ARB
> (GLhandleARB) and non-ARB (GLuint) flavors.

> I might take a crack at it someday...

> I'd like to see Mesa compile on MacOS even if it's not a common thing.</span >

Mesa and MacOS in general no, but compatibility with Gallium and MacOS is
important for VMware down the road.</pre>
        </div>
      </p>
      <hr>
      <span>You are receiving this mail because:</span>
      
      <ul>
          <li>You are the assignee for the bug.</li>
      </ul>
    </body>
</html>