Peculiar behavior in OpenGL concerning Vertex Shaders and input vertices on core profile 330

StackOverflow https://stackoverflow.com/questions/3614630

  •  26-09-2019
  •  | 
  •  

Question

using '#version 330 core' on NVIDIA,

By using glBindAttribLocation(program, 0, "in_Vertex"); the input vertex works with an "in vec4 in_Vertex;". However, I noticed without the OGL function call in the client app, it still works. It appears to be 'the default first input variable'. Why? Should it be omitted or be explicitly connected to it via glBindAttribLocation? [What's the ideal according to the standard?] Also "in vec4 gl_Vertex;" works while the spec calls it deprecated and the compiler of shaders does not give any warning. Why? I would have expected for it to at least warn. I guess the last one may be a bug in the compiler (GLSL compiler) but the first issue is especially puzzling.

Was it helpful?

Solution

  1. if you don't bind attributes to a location, the GL will do it for you. Which locations it uses is unspecified but you happened to have the same value.

    • You can ask the GL which location it's chosen with glGetAttribLocation
    • Even though it's not specified, I've seen implementations choose to bind locations in order of the shader. First is 0, second is 1, ...
  2. The standard leaves those 2 options open because there are valid use cases for each.

  3. As for deprecation, nvidia clearly stated that they thing deprecation was the wrong decision. In the end somebody has to write the code to emit the warning... So it's not that surprising they would not warn, even if they ought to.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top