Update WrapperTypes values for [Flags]

This commit is contained in:
Stefanos A 2013-12-03 09:09:19 +01:00
parent 33874c2d6d
commit e178f306eb

View file

@ -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