GetDelegate does not load OpenGL functions anymore (use the Load and LoadAll methods for that). Added GetDelegate method that takes a simple string (no type information). Deprecated existing GetDelegate method.

This commit is contained in:
the_fiddler 2008-01-19 15:27:15 +00:00
parent 70abd051e8
commit ebf0163cce

View file

@ -33,13 +33,12 @@ namespace OpenTK.OpenGL
/// This class contains all OpenGL enums and functions defined in the 2.1 specification. /// This class contains all OpenGL enums and functions defined in the 2.1 specification.
/// The official .spec files can be found at: http://opengl.org/registry/. /// The official .spec files can be found at: http://opengl.org/registry/.
/// </para> /// </para>
/// <para> /// <para> A valid OpenGL context must be created before calling any OpenGL function.</para>
/// A valid OpenGL context must be created before calling any OpenGL function.
/// </para>
/// <para> /// <para>
/// Use the GL.Load and GL.LoadAll methods to prepare function entry points prior to use. To maintain /// Use the GL.Load and GL.LoadAll methods to prepare function entry points prior to use. To maintain
/// cross-platform compatibility, this must be done for both core and extension functions. The GameWindow /// cross-platform compatibility, this must be done for both core and extension functions. The GameWindow
/// and the GLControl class will take care of this automatically. /// and the GLControl class will take care of this automatically.
/// </para>
/// <para> /// <para>
/// You can use the GL.SupportsExtension method to check whether any given category of extension functions /// You can use the GL.SupportsExtension method to check whether any given category of extension functions
/// exists in the current OpenGL context. Keep in mind that different OpenGL contexts may support different /// exists in the current OpenGL context. Keep in mind that different OpenGL contexts may support different
@ -49,16 +48,17 @@ namespace OpenTK.OpenGL
/// <para> /// <para>
/// You may retrieve the entry point for an OpenGL function using the GL.GetDelegate method. /// You may retrieve the entry point for an OpenGL function using the GL.GetDelegate method.
/// </para> /// </para>
/// <para> /// </remarks>
/// <see href="http://opengl.org/registry/"/> /// <see href="http://opengl.org/registry/"/>
/// <seealso cref="GL.SupportsExtension"/> /// <seealso cref="GL.SupportsExtension"/>
/// <seealso cref="GL.GetDelegate"/> /// <seealso cref="GL.GetDelegate"/>
/// <seealso cref="GL.LoadAll"/> /// <seealso cref="GL.LoadAll"/>
/// <seealso cref="GL.Load"/> /// <seealso cref="GL.Load"/>
/// </para>
/// </remarks>
public static partial class GL public static partial class GL
{ {
delegate void VoidGLDelegate(object @class, object[] parameters);
delegate object ObjectGLDelegate(object @class, object[] parameters);
#region --- Fields --- #region --- Fields ---
internal const string Library = "opengl32.dll"; internal const string Library = "opengl32.dll";
@ -134,10 +134,33 @@ namespace OpenTK.OpenGL
#endregion #endregion
#region public static Delegate GetDelegate(string name)
/// <summary>
/// Returns a System.Delegate wrapping the specified OpenGL function. You must use the
/// base OpenGL name of the function (e.g. "glVertex3fv" instead of "Vertex3").
/// </summary>
/// <param name="name">The name of the OpenGL function (eg. "glNewList")</param>
/// <param name="signature">The signature of the OpenGL function.</param>
/// <returns>
/// A System.Delegate that can be used to call this OpenGL function or null, if the specified
/// function name does not correspond to an OpenGL function or if the function is not
/// supported by the video drivers.
/// </returns>
public static Delegate GetDelegate(string name)
{
FieldInfo info = typeof(Delegates).GetField(name, BindingFlags.Static | BindingFlags.NonPublic);
if (info == null)
return null;
return (Delegate)info.GetValue(null);
}
#endregion
#region public static Delegate GetDelegate(string name, Type signature) #region public static Delegate GetDelegate(string name, Type signature)
/// <summary> /// <summary>
/// Creates a System.Delegate that can be used to call an OpenGL function, core or extension. /// Returns a System.Delegate wrapping an OpenGL function.
/// </summary> /// </summary>
/// <param name="name">The name of the OpenGL function (eg. "glNewList")</param> /// <param name="name">The name of the OpenGL function (eg. "glNewList")</param>
/// <param name="signature">The signature of the OpenGL function.</param> /// <param name="signature">The signature of the OpenGL function.</param>
@ -145,14 +168,10 @@ namespace OpenTK.OpenGL
/// A System.Delegate that can be used to call this OpenGL function, or null if the specified /// A System.Delegate that can be used to call this OpenGL function, or null if the specified
/// function name did not correspond to an OpenGL function. /// function name did not correspond to an OpenGL function.
/// </returns> /// </returns>
[Obsolete("Use GetDelegate(string name) instead.")]
public static Delegate GetDelegate(string name, Type signature) public static Delegate GetDelegate(string name, Type signature)
{ {
MethodInfo m; return LoadDelegate(name, signature);
return
GetExtensionDelegate(name, signature) ??
/*((m = importsClass.GetMethod(name.Substring(2), BindingFlags.Static | BindingFlags.NonPublic)) != null ?*/
(Imports.FunctionMap.TryGetValue((name.Substring(2)), out m) ?
Delegate.CreateDelegate(signature, m) : null);
} }
#endregion #endregion
@ -192,7 +211,7 @@ namespace OpenTK.OpenGL
foreach (FieldInfo f in delegates) foreach (FieldInfo f in delegates)
{ {
Delegate d = GetDelegate(f.Name, f.FieldType); Delegate d = LoadDelegate(f.Name, f.FieldType);
if (d != null) if (d != null)
{ {
++supported; ++supported;
@ -246,7 +265,7 @@ namespace OpenTK.OpenGL
return false; return false;
Delegate old = f.GetValue(null) as Delegate; Delegate old = f.GetValue(null) as Delegate;
Delegate @new = GetDelegate(f.Name, f.FieldType); Delegate @new = LoadDelegate(f.Name, f.FieldType);
if (old.Target != @new.Target) if (old.Target != @new.Target)
{ {
f.SetValue(null, @new); f.SetValue(null, @new);
@ -257,6 +276,30 @@ namespace OpenTK.OpenGL
#endregion #endregion
#region static Delegate LoadDelegate(string name, Type signature)
/// <private />
/// <summary>
/// Loads an OpenGL function into a type-safe System.Delegate.
/// </summary>
/// <param name="name">The name of the OpenGL function (eg. "glNewList")</param>
/// <param name="signature">The signature of the OpenGL function.</param>
/// <returns>
/// A System.Delegate that can be used to call this OpenGL function, or null if the specified
/// function name did not correspond to an OpenGL function.
/// </returns>
static Delegate LoadDelegate(string name, Type signature)
{
MethodInfo m;
return
GetExtensionDelegate(name, signature) ??
/*((m = importsClass.GetMethod(name.Substring(2), BindingFlags.Static | BindingFlags.NonPublic)) != null ?*/
(Imports.FunctionMap.TryGetValue((name.Substring(2)), out m) ?
Delegate.CreateDelegate(signature, m) : null);
}
#endregion
#region public static bool SupportsFunction(string function) #region public static bool SupportsFunction(string function)
/// <summary> /// <summary>