glValidateProgram — プログラムオブジェクトを検証する
void glValidateProgram(
|
GLuint program) ; |
program
検証するプログラムオブジェクトのハンドルを指定します。
glValidateProgram
は、program
に含まれる実行可能オブジェクトが、現在のOpenGLの状態で実行できるかどうかを確認します。
検証プロセスで生成された情報は、 program
の情報ログに保存されます。
検証情報は、空文字列の場合と、現在のプログラムオブジェクトが現在のOpenGL状態とどのように相互作用するかについての情報を含む文字列である場合があります。
これにより、現在のプログラムが非効率である、最適ではない、実行できないなどの理由に関する詳細情報をOpenGLの実装者へ伝えます。
The status of the validation operation will be stored as
part of the program object's state. This value will be set to
GL_TRUE
if the validation succeeded, and
GL_FALSE
otherwise. It can be queried by
calling
glGetProgram
with arguments program
and
GL_VALIDATE_STATUS
. If validation is
successful, program
is guaranteed to
execute given the current state. Otherwise,
program
is guaranteed to not execute.
This function is typically useful only during application development. The informational string stored in the information log is completely implementation dependent; therefore, an application should not expect different OpenGL implementations to produce identical information strings.
This function mimics the validation operation that OpenGL
implementations must perform when rendering commands are issued
while programmable shaders are part of current state. The error
GL_INVALID_OPERATION
will be generated by
any command that triggers the rendering of geometry if:
any two active samplers in the current program object are of different types, but refer to the same texture image unit,
the number of active samplers in the program exceeds the maximum number of texture image units allowed.
It may be difficult or cause a performance degradation for
applications to catch these errors when rendering commands are
issued. Therefore, applications are advised to make calls to
glValidateProgram
to detect these issues
during application development.
GL_INVALID_VALUE
is generated if
program
is not a value generated by
OpenGL.
GL_INVALID_OPERATION
is generated if
program
is not a program object.
glGetProgram
with arguments program
and
GL_VALIDATE_STATUS
glGetProgramInfoLog
with argument program
OpenGL Version | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Function / Feature Name | 2.0 | 2.1 | 3.0 | 3.1 | 3.2 | 3.3 | 4.0 | 4.1 | 4.2 | 4.3 | 4.4 | 4.5 |
glValidateProgram
|
✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ | ✔ |
Copyright © 2003-2005 3Dlabs Inc. Ltd. Copyright © 2010-2014 Khronos Group. This material may be distributed subject to the terms and conditions set forth in the Open Publication License, v 1.0, 8 June 1999. http://opencontent.org/openpub/.