diff --git a/Source/OpenTK/Audio/OpenAL/Alc/Alc.cs b/Source/OpenTK/Audio/OpenAL/Alc/Alc.cs index 086db09b..ca58d089 100644 --- a/Source/OpenTK/Audio/OpenAL/Alc/Alc.cs +++ b/Source/OpenTK/Audio/OpenAL/Alc/Alc.cs @@ -83,13 +83,13 @@ namespace OpenTK.Audio.OpenAL #region CreateContext + [DllImport(Alc.Lib, EntryPoint = "alcCreateContext", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity] + unsafe static extern IntPtr sys_CreateContext([In] IntPtr device, [In] int* attrlist); + /// This function creates a context using a specified device. /// a pointer to a device /// a pointer to a set of attributes: ALC_FREQUENCY, ALC_MONO_SOURCES, ALC_REFRESH, ALC_STEREO_SOURCES, ALC_SYNC /// Returns a pointer to the new context (NULL on failure). The attribute list can be NULL, or a zero terminated list of integer pairs composed of valid ALC attribute tokens and requested values. - [DllImport(Alc.Lib, EntryPoint = "alcCreateContext", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity] - unsafe static extern IntPtr sys_CreateContext([In] IntPtr device, [In] int* attrlist); - [CLSCompliant(false)] unsafe public static ContextHandle CreateContext([In] IntPtr device, [In] int* attrlist) { @@ -116,63 +116,68 @@ namespace OpenTK.Audio.OpenAL #endregion + [DllImport(Alc.Lib, EntryPoint = "alcMakeContextCurrent", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity()] + static extern bool MakeContextCurrent(IntPtr context); + /// This function makes a specified context the current context. /// A pointer to the new context. /// Returns True on success, or False on failure. - [DllImport(Alc.Lib, EntryPoint = "alcMakeContextCurrent", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity()] - static extern bool MakeContextCurrent(IntPtr context); - public static bool MakeContextCurrent(ContextHandle context) + public static bool MakeContextCurrent(ContextHandle context) { return MakeContextCurrent(context.Handle); } // ALC_API ALCboolean ALC_APIENTRY alcMakeContextCurrent( ALCcontext *context ); - /// This function tells a context to begin processing. When a context is suspended, changes in OpenAL state will be accepted but will not be processed. alcSuspendContext can be used to suspend a context, and then all the OpenAL state changes can be applied at once, followed by a call to alcProcessContext to apply all the state changes immediately. In some cases, this procedure may be more efficient than application of properties in a non-suspended state. In some implementations, process and suspend calls are each a NOP. - /// a pointer to the new context [DllImport(Alc.Lib, EntryPoint = "alcProcessContext", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity()] static extern void ProcessContext(IntPtr context); + + /// This function tells a context to begin processing. When a context is suspended, changes in OpenAL state will be accepted but will not be processed. alcSuspendContext can be used to suspend a context, and then all the OpenAL state changes can be applied at once, followed by a call to alcProcessContext to apply all the state changes immediately. In some cases, this procedure may be more efficient than application of properties in a non-suspended state. In some implementations, process and suspend calls are each a NOP. + /// a pointer to the new context public static void ProcessContext(ContextHandle context) { ProcessContext(context.Handle); } // ALC_API void ALC_APIENTRY alcProcessContext( ALCcontext *context ); - /// This function suspends processing on a specified context. When a context is suspended, changes in OpenAL state will be accepted but will not be processed. A typical use of alcSuspendContext would be to suspend a context, apply all the OpenAL state changes at once, and then call alcProcessContext to apply all the state changes at once. In some cases, this procedure may be more efficient than application of properties in a non-suspended state. In some implementations, process and suspend calls are each a NOP. - /// a pointer to the context to be suspended. [DllImport(Alc.Lib, EntryPoint = "alcSuspendContext", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity()] static extern void SuspendContext(IntPtr context); + + /// This function suspends processing on a specified context. When a context is suspended, changes in OpenAL state will be accepted but will not be processed. A typical use of alcSuspendContext would be to suspend a context, apply all the OpenAL state changes at once, and then call alcProcessContext to apply all the state changes at once. In some cases, this procedure may be more efficient than application of properties in a non-suspended state. In some implementations, process and suspend calls are each a NOP. + /// a pointer to the context to be suspended. public static void SuspendContext(ContextHandle context) { SuspendContext(context.Handle); } // ALC_API void ALC_APIENTRY alcSuspendContext( ALCcontext *context ); - /// This function destroys a context. - /// a pointer to the new context. [DllImport(Alc.Lib, EntryPoint = "alcDestroyContext", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity()] static extern void DestroyContext(IntPtr context); + + /// This function destroys a context. + /// a pointer to the new context. public static void DestroyContext(ContextHandle context) { DestroyContext(context.Handle); } // ALC_API void ALC_APIENTRY alcDestroyContext( ALCcontext *context ); - /// This function retrieves the current context. - /// Returns a pointer to the current context. [DllImport(Alc.Lib, EntryPoint = "alcGetCurrentContext", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity()] private static extern IntPtr sys_GetCurrentContext(); + /// This function retrieves the current context. + /// Returns a pointer to the current context. public static ContextHandle GetCurrentContext() { return new ContextHandle(sys_GetCurrentContext()); } // ALC_API ALCcontext * ALC_APIENTRY alcGetCurrentContext( void ); + [DllImport(Alc.Lib, EntryPoint = "alcGetContextsDevice", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity()] + static extern IntPtr GetContextsDevice(IntPtr context); + /// This function retrieves a context's device pointer. /// a pointer to a context. /// Returns a pointer to the specified context's device. - [DllImport(Alc.Lib, EntryPoint = "alcGetContextsDevice", ExactSpelling = true, CallingConvention = Alc.Style), SuppressUnmanagedCodeSecurity()] - static extern IntPtr GetContextsDevice(IntPtr context); public static IntPtr GetContextsDevice(ContextHandle context) { return GetContextsDevice(context.Handle); diff --git a/Source/OpenTK/Compute/CL10/CLHelper.cs b/Source/OpenTK/Compute/CL10/CLHelper.cs index 22e488fa..0f8799db 100644 --- a/Source/OpenTK/Compute/CL10/CLHelper.cs +++ b/Source/OpenTK/Compute/CL10/CLHelper.cs @@ -79,7 +79,7 @@ namespace OpenTK.Compute.CL10 /// The name of the extension function. /// A pointer to the extension function, if available; IntPtr.Zero otherwise. /// - /// Use to turn this function pointer + /// Use to turn this function pointer /// into a callable delegate. /// A non-zero return value does not mean that this extension function is supported. You also /// need to query available extensions through . diff --git a/Source/OpenTK/GameWindow.cs b/Source/OpenTK/GameWindow.cs index f2573eac..6ccf3124 100644 --- a/Source/OpenTK/GameWindow.cs +++ b/Source/OpenTK/GameWindow.cs @@ -261,7 +261,7 @@ namespace OpenTK #region Exit /// - /// Closes the GameWindow. Equivalent to method. + /// Closes the GameWindow. Equivalent to method. /// /// /// Override if you are not using . diff --git a/Source/OpenTK/Math/Point.cs b/Source/OpenTK/Math/Point.cs index e5c89a07..52e387ba 100644 --- a/Source/OpenTK/Math/Point.cs +++ b/Source/OpenTK/Math/Point.cs @@ -186,7 +186,7 @@ namespace OpenTK /// /// Indicates whether this instance is equal to the specified object. /// - /// The object instance to compare to. + /// The object instance to compare to. /// True, if both instances are equal; false otherwise. public override bool Equals(object obj) { @@ -199,7 +199,7 @@ namespace OpenTK /// /// Returns the hash code for this instance. /// - /// A + /// A that represents the hash code for this instance./> public override int GetHashCode() { return X.GetHashCode() ^ Y.GetHashCode(); diff --git a/Source/OpenTK/Math/Rectangle.cs b/Source/OpenTK/Math/Rectangle.cs index b6f45a24..6d604319 100644 --- a/Source/OpenTK/Math/Rectangle.cs +++ b/Source/OpenTK/Math/Rectangle.cs @@ -148,6 +148,10 @@ namespace OpenTK /// public int Left { get { return X; } } + /// + /// Gets a that indicates whether this + /// Rectangle is equal to the empty Rectangle. + /// public bool IsEmpty { get { return Location.IsEmpty && Size.IsEmpty; } @@ -192,7 +196,7 @@ namespace OpenTK /// /// Tests whether this instance contains the specified Rectangle. /// - /// The to test. + /// The to test. /// True if this instance contains rect; false otherwise. /// The left and top edges are inclusive. The right and bottom edges /// are exclusive. @@ -268,7 +272,7 @@ namespace OpenTK /// /// Indicates whether this instance is equal to the specified object. /// - /// The object instance to compare to. + /// The object instance to compare to. /// True, if both instances are equal; false otherwise. public override bool Equals(object obj) { @@ -281,7 +285,7 @@ namespace OpenTK /// /// Returns the hash code for this instance. /// - /// A + /// A that represents the hash code for this instance./> public override int GetHashCode() { return Location.GetHashCode() & Size.GetHashCode(); diff --git a/Source/OpenTK/Math/Size.cs b/Source/OpenTK/Math/Size.cs index 89500702..0459a03f 100644 --- a/Source/OpenTK/Math/Size.cs +++ b/Source/OpenTK/Math/Size.cs @@ -173,7 +173,7 @@ namespace OpenTK /// /// Indicates whether this instance is equal to the specified object. /// - /// The object instance to compare to. + /// The object instance to compare to. /// True, if both instances are equal; false otherwise. public override bool Equals(object obj) { @@ -186,7 +186,7 @@ namespace OpenTK /// /// Returns the hash code for this instance. /// - /// A + /// A that represents the hash code for this instance./> public override int GetHashCode() { return Width.GetHashCode() ^ Height.GetHashCode();