mirror of
https://github.com/Ryujinx/Opentk.git
synced 2025-01-09 20:55:32 +00:00
Update WrapperTypes values for [Flags]
This commit is contained in:
parent
33874c2d6d
commit
e178f306eb
|
@ -27,60 +27,68 @@ namespace Bind
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function takes bool parameter - C uses Int for bools, so we have to marshal.
|
/// Function takes bool parameter - C uses Int for bools, so we have to marshal.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
BoolParameter,
|
BoolParameter = 1 << 0,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function takes generic parameters - add ref/out generic and generic overloads.
|
/// Function takes generic parameters - add ref/out generic and generic overloads.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
GenericParameter,
|
GenericParameter = 1 << 1,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function takes arrays as parameters - add ref/out and ([Out]) array overloads.
|
/// Function takes arrays as parameters - add ref/out and ([Out]) array overloads.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
ArrayParameter,
|
ArrayParameter = 1 << 2,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function with bitmask parameters. Bitmask parameters map to UInt, but since we can only use signed
|
/// Function with bitmask parameters. Bitmask parameters map to UInt, but since we can only use signed
|
||||||
/// types (for CLS compliance), we must add the unchecked keyword.
|
/// types (for CLS compliance), we must add the unchecked keyword.
|
||||||
/// Usually found in bitmasks
|
/// Usually found in bitmasks
|
||||||
/// </summary>
|
/// </summary>
|
||||||
UncheckedParameter,
|
UncheckedParameter = 1 << 3,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function that takes (in/ref/out) a naked pointer as a parameter - we pass an IntPtr.
|
/// Function that takes (in/ref/out) a naked pointer as a parameter - we pass an IntPtr.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
PointerParameter,
|
PointerParameter = 1 << 4,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function that takes a reference to a struct.
|
/// Function that takes a reference to a struct.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
ReferenceParameter,
|
ReferenceParameter = 1 << 5,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function returns string - needs manual marshalling through IntPtr to prevent the managed GC
|
/// Function returns string - needs manual marshalling through IntPtr to prevent the managed GC
|
||||||
/// from freeing memory allocated on the unmanaged side (e.g. glGetString).
|
/// from freeing memory allocated on the unmanaged side (e.g. glGetString).
|
||||||
/// </summary>
|
/// </summary>
|
||||||
StringReturnType,
|
StringReturnType = 1 << 6,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function returns a void pointer - maps to IntPtr, and the user has to manually marshal the type.
|
/// Function returns a void pointer - maps to IntPtr, and the user has to manually marshal the type.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
GenericReturnType,
|
GenericReturnType = 1 << 7,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function returns a typed pointer - we have to copy the data to an array to protect it from the GC.
|
/// Function returns a typed pointer - we have to copy the data to an array to protect it from the GC.
|
||||||
/// </summary>
|
/// </summary>
|
||||||
ArrayReturnType,
|
ArrayReturnType = 1 << 8,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function normally returns a value via an out parameter.
|
/// Function normally returns a value via an out parameter.
|
||||||
/// This overload returns a single item directly.
|
/// This overload returns a single item directly.
|
||||||
/// e.g. void GetIntegerv(enum pname, out int value) => int GetInteger(enum pname)
|
/// e.g. void GetIntegerv(enum pname, out int value) => int GetInteger(enum pname)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
ConvenienceReturnType,
|
ConvenienceReturnType = 1 << 9,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function normally returns an array via an out parameter.
|
/// Function normally returns an array via an out parameter.
|
||||||
/// This overload returns a single item directly.
|
/// This overload returns a single item directly.
|
||||||
/// e.g. void GenBuffers(int count, int[] ids) => int GenBuffer()
|
/// e.g. void GenBuffers(int count, int[] ids) => int GenBuffer()
|
||||||
/// </summary>
|
/// </summary>
|
||||||
ConvenienceArrayReturnType,
|
ConvenienceArrayReturnType = 1 << 10,
|
||||||
/// <summary>
|
/// <summary>
|
||||||
/// Function normally takes an array in parameter.
|
/// Function normally takes an array in parameter.
|
||||||
/// This overload takes a single item directly.
|
/// This overload takes a single item directly.
|
||||||
/// e.g. void DeleteBuffers(int count, int[] ids) => DeleteBuffer(int id)
|
/// e.g. void DeleteBuffers(int count, int[] ids) => DeleteBuffer(int id)
|
||||||
/// </summary>
|
/// </summary>
|
||||||
ConvenienceArrayType,
|
ConvenienceArrayType = 1 << 11,
|
||||||
|
/// <summary>
|
||||||
|
/// Function takes a String or StringBuilder parameter
|
||||||
|
/// </summary>
|
||||||
|
StringParameter = 1 << 12,
|
||||||
|
/// <summary>
|
||||||
|
/// Function takes a String[] parameter
|
||||||
|
/// </summary>
|
||||||
|
StringArrayParameter = 1 << 13,
|
||||||
}
|
}
|
||||||
|
|
||||||
#endregion
|
#endregion
|
||||||
|
|
Loading…
Reference in a new issue