mirror of
				https://github.com/AxioDL/boo.git
				synced 2025-10-25 19:20:27 +00:00 
			
		
		
		
	Major scoped-enum refactor
This commit is contained in:
		
							parent
							
								
									62fae60042
								
							
						
					
					
						commit
						c9edf8dd85
					
				| @ -29,18 +29,18 @@ class IApplication | ||||
| public: | ||||
|     virtual ~IApplication() {} | ||||
|      | ||||
|     enum EPlatformType | ||||
|     enum class EPlatformType : uint8_t | ||||
|     { | ||||
|         PLAT_AUTO        = 0, | ||||
|         PLAT_WAYLAND     = 1, | ||||
|         PLAT_XLIB        = 2, | ||||
|         PLAT_ANDROID     = 3, | ||||
|         PLAT_COCOA       = 4, | ||||
|         PLAT_COCOA_TOUCH = 5, | ||||
|         PLAT_WIN32       = 6, | ||||
|         PLAT_WINRT       = 7, | ||||
|         PLAT_REVOLUTION  = 8, | ||||
|         PLAT_CAFE        = 9 | ||||
|         Auto        = 0, | ||||
|         Wayland     = 1, | ||||
|         Xlib        = 2, | ||||
|         Android     = 3, | ||||
|         Cocoa       = 4, | ||||
|         CocoaTouch  = 5, | ||||
|         Win32       = 6, | ||||
|         WinRT       = 7, | ||||
|         Revolution  = 8, | ||||
|         Cafe        = 9 | ||||
|     }; | ||||
|     virtual EPlatformType getPlatformType() const=0; | ||||
|      | ||||
|  | ||||
| @ -17,27 +17,27 @@ class IGraphicsContext | ||||
| 
 | ||||
| public: | ||||
|      | ||||
|     enum EGraphicsAPI | ||||
|     enum class EGraphicsAPI | ||||
|     { | ||||
|         API_NONE       = 0, | ||||
|         API_OPENGL_3_3 = 1, | ||||
|         API_OPENGL_4_2 = 2, | ||||
|         API_OPENGLES_3 = 3, | ||||
|         API_VULKAN     = 4, | ||||
|         API_D3D11      = 5, | ||||
|         API_D3D12      = 6, | ||||
|         API_METAL      = 7, | ||||
|         API_GX         = 8, | ||||
|         API_GX2        = 9 | ||||
|         None       = 0, | ||||
|         OpenGL3_3  = 1, | ||||
|         OpenGL4_2  = 2, | ||||
|         OpenGLES3  = 3, | ||||
|         Vulkan     = 4, | ||||
|         D3D11      = 5, | ||||
|         D3D12      = 6, | ||||
|         Metal      = 7, | ||||
|         GX         = 8, | ||||
|         GX2        = 9 | ||||
|     }; | ||||
|      | ||||
|     enum EPixelFormat | ||||
|     enum class EPixelFormat | ||||
|     { | ||||
|         PF_NONE        = 0, | ||||
|         PF_RGBA8       = 1, /* Default */ | ||||
|         PF_RGBA8_Z24   = 2, | ||||
|         PF_RGBAF32     = 3, | ||||
|         PF_RGBAF32_Z24 = 4 | ||||
|         None        = 0, | ||||
|         RGBA8       = 1, /* Default */ | ||||
|         RGBA8_Z24   = 2, | ||||
|         RGBAF32     = 3, | ||||
|         RGBAF32_Z24 = 4 | ||||
|     }; | ||||
|      | ||||
|     virtual ~IGraphicsContext() {} | ||||
|  | ||||
| @ -8,14 +8,14 @@ namespace boo | ||||
| struct IGraphicsCommandQueue; | ||||
| struct IGraphicsDataFactory; | ||||
| 
 | ||||
| enum EMouseButton | ||||
| enum class EMouseButton | ||||
| { | ||||
|     BUTTON_NONE      = 0, | ||||
|     BUTTON_PRIMARY   = 1, | ||||
|     BUTTON_SECONDARY = 2, | ||||
|     BUTTON_MIDDLE    = 3, | ||||
|     BUTTON_AUX1      = 4, | ||||
|     BUTTON_AUX2      = 5 | ||||
|     None      = 0, | ||||
|     Primary   = 1, | ||||
|     Secondary = 2, | ||||
|     Middle    = 3, | ||||
|     Aux1      = 4, | ||||
|     Aux2      = 5 | ||||
| }; | ||||
| 
 | ||||
| struct SWindowRect | ||||
| @ -48,45 +48,70 @@ struct SScrollDelta | ||||
|     void zeroOut() {delta[0] = 0.0; delta[1] = 0.0;} | ||||
| }; | ||||
| 
 | ||||
| enum ESpecialKey | ||||
| enum class ESpecialKey | ||||
| { | ||||
|     KEY_NONE       = 0, | ||||
|     KEY_F1         = 1, | ||||
|     KEY_F2         = 2, | ||||
|     KEY_F3         = 3, | ||||
|     KEY_F4         = 4, | ||||
|     KEY_F5         = 5, | ||||
|     KEY_F6         = 6, | ||||
|     KEY_F7         = 7, | ||||
|     KEY_F8         = 8, | ||||
|     KEY_F9         = 9, | ||||
|     KEY_F10        = 10, | ||||
|     KEY_F11        = 11, | ||||
|     KEY_F12        = 12, | ||||
|     KEY_ESC        = 13, | ||||
|     KEY_ENTER      = 14, | ||||
|     KEY_BACKSPACE  = 15, | ||||
|     KEY_INSERT     = 16, | ||||
|     KEY_DELETE     = 17, | ||||
|     KEY_HOME       = 18, | ||||
|     KEY_END        = 19, | ||||
|     KEY_PGUP       = 20, | ||||
|     KEY_PGDOWN     = 21, | ||||
|     KEY_LEFT       = 22, | ||||
|     KEY_RIGHT      = 23, | ||||
|     KEY_UP         = 24, | ||||
|     KEY_DOWN       = 25 | ||||
|     None       = 0, | ||||
|     F1         = 1, | ||||
|     F2         = 2, | ||||
|     F3         = 3, | ||||
|     F4         = 4, | ||||
|     F5         = 5, | ||||
|     F6         = 6, | ||||
|     F7         = 7, | ||||
|     F8         = 8, | ||||
|     F9         = 9, | ||||
|     F10        = 10, | ||||
|     F11        = 11, | ||||
|     F12        = 12, | ||||
|     Esc        = 13, | ||||
|     Enter      = 14, | ||||
|     Backspace  = 15, | ||||
|     Insert     = 16, | ||||
|     Delete     = 17, | ||||
|     Home       = 18, | ||||
|     End        = 19, | ||||
|     PgUp       = 20, | ||||
|     PgDown     = 21, | ||||
|     Left       = 22, | ||||
|     Right      = 23, | ||||
|     Up         = 24, | ||||
|     Down       = 25 | ||||
| }; | ||||
| 
 | ||||
| enum EModifierKey | ||||
| enum class EModifierKey | ||||
| { | ||||
|     MKEY_NONE    = 0, | ||||
|     MKEY_CTRL    = 1<<0, | ||||
|     MKEY_ALT     = 1<<2, | ||||
|     MKEY_SHIFT   = 1<<3, | ||||
|     MKEY_COMMAND = 1<<4 | ||||
|     None    = 0, | ||||
|     Ctrl    = 1<<0, | ||||
|     Alt     = 1<<2, | ||||
|     Shift   = 1<<3, | ||||
|     Command = 1<<4 | ||||
| }; | ||||
| 
 | ||||
| inline EModifierKey operator|(EModifierKey a, EModifierKey b) | ||||
| { | ||||
|     using T = std::underlying_type_t<EModifierKey>; | ||||
|     return EModifierKey(static_cast<T>(a) | static_cast<T>(b)); | ||||
| } | ||||
| 
 | ||||
| inline EModifierKey operator&(EModifierKey a, EModifierKey b) | ||||
| { | ||||
|     using T = std::underlying_type_t<EModifierKey>; | ||||
|     return EModifierKey(static_cast<T>(a) & static_cast<T>(b)); | ||||
| } | ||||
| 
 | ||||
| inline EModifierKey& operator|=(EModifierKey& a, const EModifierKey& b) | ||||
| { | ||||
|     using T = std::underlying_type_t<EModifierKey>; | ||||
|     a = EModifierKey(static_cast<T>(a) | static_cast<T>(b)); | ||||
|     return a; | ||||
| } | ||||
| 
 | ||||
| inline EModifierKey operator~(const EModifierKey& key) | ||||
| { | ||||
|     using T = std::underlying_type_t<EModifierKey>; | ||||
|     return EModifierKey(~static_cast<T>(key)); | ||||
| } | ||||
| 
 | ||||
| class IWindowCallback | ||||
| { | ||||
| public: | ||||
| @ -132,23 +157,35 @@ public: | ||||
|     {} | ||||
| }; | ||||
| 
 | ||||
| enum ETouchType | ||||
| enum class ETouchType | ||||
| { | ||||
|     TOUCH_NONE     = 0, | ||||
|     TOUCH_DISPLAY  = 1, | ||||
|     TOUCH_TRACKPAD = 2 | ||||
|     None     = 0, | ||||
|     Display  = 1, | ||||
|     Trackpad = 2 | ||||
| }; | ||||
| 
 | ||||
| enum EWindowStyle | ||||
| enum class EWindowStyle | ||||
| { | ||||
|     STYLE_NONE     = 0, | ||||
|     STYLE_TITLEBAR = 1<<0, | ||||
|     STYLE_RESIZE   = 1<<1, | ||||
|     STYLE_CLOSE    = 1<<2, | ||||
|     None     = 0, | ||||
|     Titlebar = 1<<0, | ||||
|     Resize   = 1<<1, | ||||
|     Close    = 1<<2, | ||||
| 
 | ||||
|     STYLE_DEFAULT = STYLE_TITLEBAR | STYLE_RESIZE | STYLE_CLOSE | ||||
|     Default = Titlebar | Resize | Close | ||||
| }; | ||||
| 
 | ||||
| inline EWindowStyle operator|(EWindowStyle a, EWindowStyle b) | ||||
| { | ||||
|     using T = std::underlying_type_t<EWindowStyle>; | ||||
|     return EWindowStyle(static_cast<T>(a) | static_cast<T>(b)); | ||||
| } | ||||
| 
 | ||||
| inline EWindowStyle operator&(EWindowStyle a, EWindowStyle b) | ||||
| { | ||||
|     using T = std::underlying_type_t<EWindowStyle>; | ||||
|     return EWindowStyle(static_cast<T>(a) & static_cast<T>(b)); | ||||
| } | ||||
| 
 | ||||
| class IWindow | ||||
| { | ||||
| public: | ||||
|  | ||||
| @ -3,6 +3,35 @@ | ||||
| 
 | ||||
| #include <string> | ||||
| 
 | ||||
| #define ENABLE_BITWISE_ENUM(type)\ | ||||
| inline type operator|(type a, type b)\ | ||||
| {\ | ||||
|     using T = std::underlying_type_t<type>;\ | ||||
|     return type(static_cast<T>(a) | static_cast<T>(b));\ | ||||
| }\ | ||||
| inline type operator&(type a, type b)\ | ||||
| {\ | ||||
|     using T = std::underlying_type_t<type>;\ | ||||
|     return type(static_cast<T>(a) & static_cast<T>(b));\ | ||||
| }\ | ||||
| inline type& operator|=(type& a, const type& b)\ | ||||
| {\ | ||||
|     using T = std::underlying_type_t<type>;\ | ||||
|     a = type(static_cast<T>(a) | static_cast<T>(b));\ | ||||
|     return a;\ | ||||
| }\ | ||||
| inline type& operator&=(type& a, const type& b)\ | ||||
| {\ | ||||
|     using T = std::underlying_type_t<type>;\ | ||||
|     a = type(static_cast<T>(a) & static_cast<T>(b));\ | ||||
|     return a;\ | ||||
| }\ | ||||
| inline type operator~(const type& key)\ | ||||
| {\ | ||||
|     using T = std::underlying_type_t<type>;\ | ||||
|     return type(~static_cast<T>(key));\ | ||||
| } | ||||
| 
 | ||||
| namespace boo | ||||
| { | ||||
| 
 | ||||
| @ -28,4 +57,4 @@ template <class T> | ||||
| using ComPtr = Microsoft::WRL::ComPtr<T>; | ||||
| #endif | ||||
| 
 | ||||
| #endif | ||||
| #endif | ||||
|  | ||||
| @ -20,7 +20,7 @@ public: | ||||
|     GLDataFactory(IGraphicsContext* parent); | ||||
|     ~GLDataFactory() {} | ||||
| 
 | ||||
|     Platform platform() const {return PlatformOGL;} | ||||
|     Platform platform() const {return Platform::OGL;} | ||||
|     const SystemChar* platformName() const {return _S("OGL");} | ||||
| 
 | ||||
|     IGraphicsBufferS* newStaticBuffer(BufferUse use, const void* data, size_t stride, size_t count); | ||||
|  | ||||
| @ -6,10 +6,10 @@ | ||||
| 
 | ||||
| namespace boo | ||||
| { | ||||
| enum Primitive | ||||
| enum class Primitive | ||||
| { | ||||
|     PrimitiveTriangles, | ||||
|     PrimitiveTriStrips | ||||
|     Triangles, | ||||
|     TriStrips | ||||
| }; | ||||
| 
 | ||||
| struct IGraphicsCommandQueue | ||||
|  | ||||
| @ -35,32 +35,27 @@ protected: | ||||
| }; | ||||
| 
 | ||||
| /** Supported buffer uses */ | ||||
| enum BufferUse | ||||
| enum class BufferUse | ||||
| { | ||||
|     BufferUseNull, | ||||
|     BufferUseVertex, | ||||
|     BufferUseIndex, | ||||
|     BufferUseUniform | ||||
|     Null, | ||||
|     Vertex, | ||||
|     Index, | ||||
|     Uniform | ||||
| }; | ||||
| 
 | ||||
| enum TextureType | ||||
| enum class TextureType | ||||
| { | ||||
|     TextureStatic, | ||||
|     Texture | ||||
|     Static, | ||||
|     Dynamic, | ||||
|     Render | ||||
| }; | ||||
| 
 | ||||
| struct ITexture | ||||
| { | ||||
|     enum Type | ||||
|     { | ||||
|         TextureStatic, | ||||
|         TextureDynamic, | ||||
|         TextureRender | ||||
|     }; | ||||
|     Type type() const {return m_type;} | ||||
|     TextureType type() const {return m_type;} | ||||
| protected: | ||||
|     Type m_type; | ||||
|     ITexture(Type type) : m_type(type) {} | ||||
|     TextureType m_type; | ||||
|     ITexture(TextureType type) : m_type(type) {} | ||||
|     virtual ~ITexture() {} | ||||
| }; | ||||
| 
 | ||||
| @ -68,7 +63,7 @@ protected: | ||||
| struct ITextureS : ITexture | ||||
| { | ||||
| protected: | ||||
|     ITextureS() : ITexture(TextureStatic) {} | ||||
|     ITextureS() : ITexture(TextureType::Static) {} | ||||
| }; | ||||
| 
 | ||||
| /** Dynamic resource buffer for textures */ | ||||
| @ -78,22 +73,22 @@ struct ITextureD : ITexture | ||||
|     virtual void* map(size_t sz)=0; | ||||
|     virtual void unmap()=0; | ||||
| protected: | ||||
|     ITextureD() : ITexture(TextureDynamic) {} | ||||
|     ITextureD() : ITexture(TextureType::Dynamic) {} | ||||
| }; | ||||
| 
 | ||||
| /** Resource buffer for render-target textures */ | ||||
| struct ITextureR : ITexture | ||||
| { | ||||
| protected: | ||||
|     ITextureR() : ITexture(TextureRender) {} | ||||
|     ITextureR() : ITexture(TextureType::Render) {} | ||||
| }; | ||||
| 
 | ||||
| /** Supported texture formats */ | ||||
| enum TextureFormat | ||||
| enum class TextureFormat | ||||
| { | ||||
|     TextureFormatRGBA8, | ||||
|     TextureFormatDXT1, | ||||
|     TextureFormatPVRTC4 | ||||
|     RGBA8, | ||||
|     DXT1, | ||||
|     PVRTC4 | ||||
| }; | ||||
| 
 | ||||
| /** Opaque token for representing the data layout of a vertex
 | ||||
| @ -102,13 +97,13 @@ enum TextureFormat | ||||
| struct IVertexFormat {}; | ||||
| 
 | ||||
| /** Types of vertex attributes */ | ||||
| enum VertexSemantic | ||||
| enum class VertexSemantic | ||||
| { | ||||
|     VertexSemanticPosition, | ||||
|     VertexSemanticNormal, | ||||
|     VertexSemanticColor, | ||||
|     VertexSemanticUV, | ||||
|     VertexSemanticWeight | ||||
|     Position, | ||||
|     Normal, | ||||
|     Color, | ||||
|     UV, | ||||
|     Weight | ||||
| }; | ||||
| 
 | ||||
| /** Used to create IVertexFormat */ | ||||
| @ -140,18 +135,18 @@ struct IGraphicsData | ||||
| }; | ||||
| 
 | ||||
| /** Used by platform shader pipeline constructors */ | ||||
| enum BlendFactor | ||||
| enum class BlendFactor | ||||
| { | ||||
|     BlendFactorZero, | ||||
|     BlendFactorOne, | ||||
|     BlendFactorSrcColor, | ||||
|     BlendFactorInvSrcColor, | ||||
|     BlendFactorDstColor, | ||||
|     BlendFactorInvDstColor, | ||||
|     BlendFactorSrcAlpha, | ||||
|     BlendFactorInvSrcAlpha, | ||||
|     BlendFactorDstAlpha, | ||||
|     BlendFactorInvDstAlpha | ||||
|     Zero, | ||||
|     One, | ||||
|     SrcColor, | ||||
|     InvSrcColor, | ||||
|     DstColor, | ||||
|     InvDstColor, | ||||
|     SrcAlpha, | ||||
|     InvSrcAlpha, | ||||
|     DstAlpha, | ||||
|     InvDstAlpha | ||||
| }; | ||||
| 
 | ||||
| /** Factory object for creating batches of resources as an IGraphicsData token */ | ||||
| @ -159,15 +154,15 @@ struct IGraphicsDataFactory | ||||
| { | ||||
|     virtual ~IGraphicsDataFactory() {} | ||||
| 
 | ||||
|     enum Platform | ||||
|     enum class Platform | ||||
|     { | ||||
|         PlatformNull, | ||||
|         PlatformOGL, | ||||
|         PlatformD3D11, | ||||
|         PlatformD3D12, | ||||
|         PlatformMetal, | ||||
|         PlatformGX, | ||||
|         PlatformGX2 | ||||
|         Null, | ||||
|         OGL, | ||||
|         D3D11, | ||||
|         D3D12, | ||||
|         Metal, | ||||
|         GX, | ||||
|         GX2 | ||||
|     }; | ||||
|     virtual Platform platform() const=0; | ||||
|     virtual const SystemChar* platformName() const=0; | ||||
|  | ||||
| @ -4,6 +4,7 @@ | ||||
| #include <stdint.h> | ||||
| #include <stdlib.h> | ||||
| #include <stdio.h> | ||||
| #include "../System.hpp" | ||||
| 
 | ||||
| namespace boo | ||||
| { | ||||
|  | ||||
| @ -11,16 +11,16 @@ namespace boo | ||||
| class DeviceToken | ||||
| { | ||||
| public: | ||||
|     enum TDeviceType | ||||
|     enum class DeviceType | ||||
|     { | ||||
|         DEVTYPE_NONE       = 0, | ||||
|         DEVTYPE_USB        = 1, | ||||
|         DEVTYPE_BLUETOOTH  = 2, | ||||
|         DEVTYPE_GENERICHID = 3 | ||||
|         None       = 0, | ||||
|         USB        = 1, | ||||
|         Bluetooth  = 2, | ||||
|         GenericHID = 3 | ||||
|     }; | ||||
| 
 | ||||
| private: | ||||
|     TDeviceType m_devType; | ||||
|     DeviceType m_devType; | ||||
|     unsigned m_vendorId; | ||||
|     unsigned m_productId; | ||||
|     std::string m_vendorName; | ||||
| @ -50,7 +50,7 @@ public: | ||||
|       m_devPath(other.m_devPath), | ||||
|       m_connectedDev(other.m_connectedDev) | ||||
|     {} | ||||
|     inline DeviceToken(enum TDeviceType devType, unsigned vid, unsigned pid, const char* vname, const char* pname, const char* path) | ||||
|     inline DeviceToken(DeviceType devType, unsigned vid, unsigned pid, const char* vname, const char* pname, const char* path) | ||||
|     : m_devType(devType), | ||||
|       m_vendorId(vid), | ||||
|       m_productId(pid), | ||||
| @ -63,7 +63,7 @@ public: | ||||
|             m_productName = pname; | ||||
|     } | ||||
|      | ||||
|     inline TDeviceType getDeviceType() const {return m_devType;} | ||||
|     inline DeviceType getDeviceType() const {return m_devType;} | ||||
|     inline unsigned getVendorId() const {return m_vendorId;} | ||||
|     inline unsigned getProductId() const {return m_productId;} | ||||
|     inline const std::string& getVendorName() const {return m_vendorName;} | ||||
|  | ||||
| @ -7,28 +7,30 @@ | ||||
| namespace boo | ||||
| { | ||||
| 
 | ||||
| enum EDolphinControllerType | ||||
| enum class EDolphinControllerType | ||||
| { | ||||
|     DOL_TYPE_NONE     = 0, | ||||
|     DOL_TYPE_NORMAL   = 0x10, | ||||
|     DOL_TYPE_WAVEBIRD = 0x20, | ||||
|     None     = 0, | ||||
|     Normal   = 0x10, | ||||
|     Wavebird = 0x20, | ||||
| }; | ||||
| ENABLE_BITWISE_ENUM(EDolphinControllerType) | ||||
| 
 | ||||
| enum EDolphinControllerButtons | ||||
| enum class EDolphinControllerButtons | ||||
| { | ||||
|     DOL_START  = 1<<0, | ||||
|     DOL_Z      = 1<<1, | ||||
|     DOL_L      = 1<<2, | ||||
|     DOL_R      = 1<<3, | ||||
|     DOL_A      = 1<<8, | ||||
|     DOL_B      = 1<<9, | ||||
|     DOL_X      = 1<<10, | ||||
|     DOL_Y      = 1<<11, | ||||
|     DOL_LEFT   = 1<<12, | ||||
|     DOL_RIGHT  = 1<<13, | ||||
|     DOL_DOWN   = 1<<14, | ||||
|     DOL_UP     = 1<<15 | ||||
|     Start  = 1<<0, | ||||
|     Z      = 1<<1, | ||||
|     L      = 1<<2, | ||||
|     R      = 1<<3, | ||||
|     A      = 1<<8, | ||||
|     B      = 1<<9, | ||||
|     X      = 1<<10, | ||||
|     Y      = 1<<11, | ||||
|     Left   = 1<<12, | ||||
|     Right  = 1<<13, | ||||
|     Down   = 1<<14, | ||||
|     Up     = 1<<15 | ||||
| }; | ||||
| ENABLE_BITWISE_ENUM(EDolphinControllerButtons) | ||||
| 
 | ||||
| struct DolphinControllerState | ||||
| { | ||||
|  | ||||
| @ -39,40 +39,43 @@ union DualshockOutReport | ||||
|     uint8_t buf[36]; | ||||
| }; | ||||
| 
 | ||||
| enum EDualshockPadButtons | ||||
| enum class EDualshockPadButtons | ||||
| { | ||||
|     DS3_SELECT   = 1<< 0, | ||||
|     DS3_L3       = 1<< 1, | ||||
|     DS3_R3       = 1<< 2, | ||||
|     DS3_START    = 1<< 3, | ||||
|     DS3_UP       = 1<< 4, | ||||
|     DS3_RIGHT    = 1<< 5, | ||||
|     DS3_DOWN     = 1<< 6, | ||||
|     DS3_LEFT     = 1<< 7, | ||||
|     DS3_L2       = 1<< 8, | ||||
|     DS3_R2       = 1<< 9, | ||||
|     DS3_L1       = 1<<10, | ||||
|     DS3_R1       = 1<<11, | ||||
|     DS3_TRIANGLE = 1<<12, | ||||
|     DS3_CIRCLE   = 1<<13, | ||||
|     DS3_CROSS    = 1<<14, | ||||
|     DS3_SQUARE   = 1<<15 | ||||
|     Select   = 1<< 0, | ||||
|     L3       = 1<< 1, | ||||
|     R3       = 1<< 2, | ||||
|     Start    = 1<< 3, | ||||
|     Up       = 1<< 4, | ||||
|     Right    = 1<< 5, | ||||
|     Down     = 1<< 6, | ||||
|     Left     = 1<< 7, | ||||
|     L2       = 1<< 8, | ||||
|     R2       = 1<< 9, | ||||
|     L1       = 1<<10, | ||||
|     R1       = 1<<11, | ||||
|     Triangle = 1<<12, | ||||
|     Circle   = 1<<13, | ||||
|     Cross    = 1<<14, | ||||
|     Square   = 1<<15 | ||||
| }; | ||||
| 
 | ||||
| enum EDualshockMotor : int | ||||
| enum class EDualshockMotor : uint8_t | ||||
| { | ||||
|     DS3_MOTOR_RIGHT = 1<<0, | ||||
|     DS3_MOTOR_LEFT  = 1<<1, | ||||
|     None  = 0, | ||||
|     Right = 1<<0, | ||||
|     Left  = 1<<1, | ||||
| }; | ||||
| ENABLE_BITWISE_ENUM(EDualshockMotor) | ||||
| 
 | ||||
| enum EDualshockLED | ||||
| enum class EDualshockLED | ||||
| { | ||||
|     DS3_LED_OFF = 0, | ||||
|     DS3_LED_1   = 1<<1, | ||||
|     DS3_LED_2   = 1<<2, | ||||
|     DS3_LED_3   = 1<<3, | ||||
|     DS3_LED_4   = 1<<4 | ||||
|     LED_OFF = 0, | ||||
|     LED_1   = 1<<1, | ||||
|     LED_2   = 1<<2, | ||||
|     LED_3   = 1<<3, | ||||
|     LED_4   = 1<<4 | ||||
| }; | ||||
| ENABLE_BITWISE_ENUM(EDualshockLED) | ||||
| 
 | ||||
| struct DualshockPadState | ||||
| { | ||||
| @ -120,11 +123,11 @@ struct IDualshockPadCallback | ||||
| class DualshockPad final : public DeviceBase | ||||
| { | ||||
|     IDualshockPadCallback* m_callback; | ||||
|     uint8_t m_rumbleRequest; | ||||
|     uint8_t m_rumbleState; | ||||
|     EDualshockMotor m_rumbleRequest; | ||||
|     EDualshockMotor m_rumbleState; | ||||
|     uint8_t m_rumbleDuration[2]; | ||||
|     uint8_t m_rumbleIntensity[2]; | ||||
|     uint8_t m_led; | ||||
|     EDualshockLED m_led; | ||||
|     DualshockOutReport m_report; | ||||
|     uint8_t m_btAddress[6]; | ||||
|     void deviceDisconnected(); | ||||
| @ -135,45 +138,45 @@ public: | ||||
|     DualshockPad(DeviceToken* token); | ||||
|     ~DualshockPad(); | ||||
| 
 | ||||
|     inline void setCallback(IDualshockPadCallback* cb) | ||||
|     void setCallback(IDualshockPadCallback* cb) | ||||
|     { m_callback = cb; if (m_callback) m_callback->ctrl = this; } | ||||
| 
 | ||||
|     inline void startRumble(int motor, uint8_t duration = 254, uint8_t intensity=255) | ||||
|     void startRumble(EDualshockMotor motor, uint8_t duration = 254, uint8_t intensity=255) | ||||
|     { | ||||
|         m_rumbleRequest |= motor; | ||||
|         if (motor & DS3_MOTOR_LEFT) | ||||
|         if ((EDualshockMotor(motor) & EDualshockMotor::Left) != EDualshockMotor::None) | ||||
|         { | ||||
|             m_rumbleDuration[0] = duration; | ||||
|             m_rumbleIntensity[0] = intensity; | ||||
|         } | ||||
|         if (motor & DS3_MOTOR_RIGHT) | ||||
|         if ((EDualshockMotor(motor) & EDualshockMotor::Right) != EDualshockMotor::None) | ||||
|         { | ||||
|             m_rumbleDuration[1] = duration; | ||||
|             m_rumbleIntensity[1] = intensity; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     inline void stopRumble(int motor) | ||||
|     void stopRumble(int motor) | ||||
|     { | ||||
|         m_rumbleRequest &= ~motor; | ||||
|         m_rumbleRequest &= ~EDualshockMotor(motor); | ||||
|     } | ||||
| 
 | ||||
|     inline int getLED() | ||||
|     EDualshockLED getLED() | ||||
|     { | ||||
|         return m_led; | ||||
|     } | ||||
| 
 | ||||
|     inline void setLED(int led, bool on = true) | ||||
|     void setLED(EDualshockLED led, bool on = true) | ||||
|     { | ||||
|         if (on) | ||||
|             m_led |= led; | ||||
|         else | ||||
|             m_led &= ~led; | ||||
| 
 | ||||
|         setRawLED(led); | ||||
|         setRawLED(int(led)); | ||||
|     } | ||||
| 
 | ||||
|     inline void setRawLED(int led) | ||||
|     void setRawLED(int led) | ||||
|     { | ||||
|         m_report.leds = led; | ||||
|         sendHIDReport(m_report.buf, sizeof(m_report), 0x0201); | ||||
|  | ||||
| @ -40,7 +40,7 @@ class GLGraphicsBufferS : public IGraphicsBufferS | ||||
|     GLenum m_target; | ||||
|     GLGraphicsBufferS(BufferUse use, const void* data, size_t sz) | ||||
|     { | ||||
|         m_target = USE_TABLE[use]; | ||||
|         m_target = USE_TABLE[int(use)]; | ||||
|         glGenBuffers(1, &m_buf); | ||||
|         glBindBuffer(m_target, m_buf); | ||||
|         glBufferData(m_target, sz, data, GL_STATIC_DRAW); | ||||
| @ -68,7 +68,7 @@ class GLGraphicsBufferD : public IGraphicsBufferD | ||||
|     GLGraphicsBufferD(GLCommandQueue* q, BufferUse use) | ||||
|     : m_q(q) | ||||
|     { | ||||
|         m_target = USE_TABLE[use]; | ||||
|         m_target = USE_TABLE[int(use)]; | ||||
|         glGenBuffers(3, m_bufs); | ||||
|     } | ||||
| public: | ||||
| @ -105,7 +105,7 @@ class GLTextureS : public ITextureS | ||||
|     friend class GLDataFactory; | ||||
|     GLuint m_tex; | ||||
|     GLTextureS(size_t width, size_t height, size_t mips, | ||||
|                   TextureFormat fmt, const void* data, size_t sz) | ||||
|                TextureFormat fmt, const void* data, size_t sz) | ||||
|     { | ||||
|         const uint8_t* dataIt = static_cast<const uint8_t*>(data); | ||||
|         glGenTextures(1, &m_tex); | ||||
| @ -115,7 +115,7 @@ class GLTextureS : public ITextureS | ||||
|             glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR_MIPMAP_LINEAR); | ||||
|         else | ||||
|             glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); | ||||
|         if (fmt == TextureFormatRGBA8) | ||||
|         if (fmt == TextureFormat::RGBA8) | ||||
|         { | ||||
|             for (size_t i=0 ; i<mips ; ++i) | ||||
|             { | ||||
| @ -326,8 +326,8 @@ IShaderPipeline* GLDataFactory::newShaderPipeline | ||||
|         Log.report(LogVisor::Error, "unable to create shader objects\n"); | ||||
|         return nullptr; | ||||
|     } | ||||
|     shader.m_sfactor = BLEND_FACTOR_TABLE[srcFac]; | ||||
|     shader.m_dfactor = BLEND_FACTOR_TABLE[dstFac]; | ||||
|     shader.m_sfactor = BLEND_FACTOR_TABLE[int(srcFac)]; | ||||
|     shader.m_dfactor = BLEND_FACTOR_TABLE[int(dstFac)]; | ||||
|     shader.m_depthTest = depthTest; | ||||
|     shader.m_depthWrite = depthWrite; | ||||
|     shader.m_backfaceCulling = backfaceCulling; | ||||
| @ -456,9 +456,9 @@ struct GLShaderDataBinding : IShaderDataBinding | ||||
|         for (size_t i=0 ; i<m_texCount ; ++i) | ||||
|         { | ||||
|             ITexture* tex = m_texs[i]; | ||||
|             if (tex->type() == ITexture::TextureDynamic) | ||||
|             if (tex->type() == TextureType::Dynamic) | ||||
|                 static_cast<GLTextureD*>(tex)->bind(i); | ||||
|             else if (tex->type() == ITexture::TextureStatic) | ||||
|             else if (tex->type() == TextureType::Static) | ||||
|                 static_cast<GLTextureS*>(tex)->bind(i); | ||||
|         } | ||||
|     } | ||||
| @ -541,25 +541,25 @@ static const GLenum SEMANTIC_TYPE_TABLE[] = | ||||
| 
 | ||||
| struct GLCommandQueue : IGraphicsCommandQueue | ||||
| { | ||||
|     Platform platform() const {return IGraphicsDataFactory::PlatformOGL;} | ||||
|     Platform platform() const {return IGraphicsDataFactory::Platform::OGL;} | ||||
|     const SystemChar* platformName() const {return _S("OGL");} | ||||
|     IGraphicsContext* m_parent = nullptr; | ||||
| 
 | ||||
|     struct Command | ||||
|     { | ||||
|         enum Op | ||||
|         enum class Op | ||||
|         { | ||||
|             OpSetShaderDataBinding, | ||||
|             OpSetRenderTarget, | ||||
|             OpSetViewport, | ||||
|             OpSetClearColor, | ||||
|             OpClearTarget, | ||||
|             OpSetDrawPrimitive, | ||||
|             OpDraw, | ||||
|             OpDrawIndexed, | ||||
|             OpDrawInstances, | ||||
|             OpDrawInstancesIndexed, | ||||
|             OpPresent | ||||
|             SetShaderDataBinding, | ||||
|             SetRenderTarget, | ||||
|             SetViewport, | ||||
|             SetClearColor, | ||||
|             ClearTarget, | ||||
|             SetDrawPrimitive, | ||||
|             Draw, | ||||
|             DrawIndexed, | ||||
|             DrawInstances, | ||||
|             DrawInstancesIndexed, | ||||
|             Present | ||||
|         } m_op; | ||||
|         union | ||||
|         { | ||||
| @ -614,7 +614,7 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|         for (size_t i=0 ; i<fmt->m_elementCount ; ++i) | ||||
|         { | ||||
|             const VertexElementDescriptor* desc = &fmt->m_elements[i]; | ||||
|             stride += SEMANTIC_SIZE_TABLE[desc->semantic]; | ||||
|             stride += SEMANTIC_SIZE_TABLE[int(desc->semantic)]; | ||||
|         } | ||||
| 
 | ||||
|         size_t offset = 0; | ||||
| @ -641,9 +641,9 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|                     static_cast<const GLGraphicsBufferS*>(lastEBO)->bindIndex(); | ||||
|             } | ||||
|             glEnableVertexAttribArray(i); | ||||
|             glVertexAttribPointer(i, SEMANTIC_COUNT_TABLE[desc->semantic], | ||||
|                     SEMANTIC_TYPE_TABLE[desc->semantic], GL_TRUE, stride, (void*)offset); | ||||
|             offset += SEMANTIC_SIZE_TABLE[desc->semantic]; | ||||
|             glVertexAttribPointer(i, SEMANTIC_COUNT_TABLE[int(desc->semantic)], | ||||
|                     SEMANTIC_TYPE_TABLE[int(desc->semantic)], GL_TRUE, stride, (void*)offset); | ||||
|             offset += SEMANTIC_SIZE_TABLE[int(desc->semantic)]; | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
| @ -715,10 +715,10 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|             { | ||||
|                 switch (cmd.m_op) | ||||
|                 { | ||||
|                 case Command::OpSetShaderDataBinding: | ||||
|                 case Command::Op::SetShaderDataBinding: | ||||
|                     static_cast<const GLShaderDataBinding*>(cmd.binding)->bind(); | ||||
|                     break; | ||||
|                 case Command::OpSetRenderTarget: | ||||
|                 case Command::Op::SetRenderTarget: | ||||
|                 { | ||||
|                     const GLTextureR* tex = static_cast<const GLTextureR*>(cmd.target); | ||||
|                     if (!tex) | ||||
| @ -727,32 +727,32 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|                         glBindFramebuffer(GL_DRAW_FRAMEBUFFER, tex->m_fbo); | ||||
|                     break; | ||||
|                 } | ||||
|                 case Command::OpSetViewport: | ||||
|                 case Command::Op::SetViewport: | ||||
|                     glViewport(cmd.rect.location[0], cmd.rect.location[1], | ||||
|                                cmd.rect.size[0], cmd.rect.size[1]); | ||||
|                     break; | ||||
|                 case Command::OpSetClearColor: | ||||
|                 case Command::Op::SetClearColor: | ||||
|                     glClearColor(cmd.rgba[0], cmd.rgba[1], cmd.rgba[2], cmd.rgba[3]); | ||||
|                     break; | ||||
|                 case Command::OpClearTarget: | ||||
|                 case Command::Op::ClearTarget: | ||||
|                     glClear(cmd.flags); | ||||
|                     break; | ||||
|                 case Command::OpSetDrawPrimitive: | ||||
|                 case Command::Op::SetDrawPrimitive: | ||||
|                     prim = cmd.prim; | ||||
|                     break; | ||||
|                 case Command::OpDraw: | ||||
|                 case Command::Op::Draw: | ||||
|                     glDrawArrays(prim, cmd.start, cmd.count); | ||||
|                     break; | ||||
|                 case Command::OpDrawIndexed: | ||||
|                 case Command::Op::DrawIndexed: | ||||
|                     glDrawElements(prim, cmd.count, GL_UNSIGNED_INT, (void*)cmd.start); | ||||
|                     break; | ||||
|                 case Command::OpDrawInstances: | ||||
|                 case Command::Op::DrawInstances: | ||||
|                     glDrawArraysInstanced(prim, cmd.start, cmd.count, cmd.instCount); | ||||
|                     break; | ||||
|                 case Command::OpDrawInstancesIndexed: | ||||
|                 case Command::Op::DrawInstancesIndexed: | ||||
|                     glDrawElementsInstanced(prim, cmd.count, GL_UNSIGNED_INT, (void*)cmd.start, cmd.instCount); | ||||
|                     break; | ||||
|                 case Command::OpPresent: | ||||
|                 case Command::Op::Present: | ||||
|                 { | ||||
|                     const GLTextureR* tex = static_cast<const GLTextureR*>(cmd.source); | ||||
|                     if (tex) | ||||
| @ -791,21 +791,21 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|     void setShaderDataBinding(IShaderDataBinding* binding) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpSetShaderDataBinding); | ||||
|         cmds.emplace_back(Command::Op::SetShaderDataBinding); | ||||
|         cmds.back().binding = binding; | ||||
|     } | ||||
| 
 | ||||
|     void setRenderTarget(ITextureR* target) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpSetRenderTarget); | ||||
|         cmds.emplace_back(Command::Op::SetRenderTarget); | ||||
|         cmds.back().target = target; | ||||
|     } | ||||
| 
 | ||||
|     void setViewport(const SWindowRect& rect) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpSetViewport); | ||||
|         cmds.emplace_back(Command::Op::SetViewport); | ||||
|         cmds.back().rect = rect; | ||||
|     } | ||||
|      | ||||
| @ -824,7 +824,7 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|     void setClearColor(const float rgba[4]) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpSetClearColor); | ||||
|         cmds.emplace_back(Command::Op::SetClearColor); | ||||
|         cmds.back().rgba[0] = rgba[0]; | ||||
|         cmds.back().rgba[1] = rgba[1]; | ||||
|         cmds.back().rgba[2] = rgba[2]; | ||||
| @ -834,7 +834,7 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|     void clearTarget(bool render=true, bool depth=true) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpClearTarget); | ||||
|         cmds.emplace_back(Command::Op::ClearTarget); | ||||
|         cmds.back().flags = 0; | ||||
|         if (render) | ||||
|             cmds.back().flags |= GL_COLOR_BUFFER_BIT; | ||||
| @ -845,17 +845,17 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|     void setDrawPrimitive(Primitive prim) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpSetDrawPrimitive); | ||||
|         if (prim == PrimitiveTriangles) | ||||
|         cmds.emplace_back(Command::Op::SetDrawPrimitive); | ||||
|         if (prim == Primitive::Triangles) | ||||
|             cmds.back().prim = GL_TRIANGLES; | ||||
|         else if (prim == PrimitiveTriStrips) | ||||
|         else if (prim == Primitive::TriStrips) | ||||
|             cmds.back().prim = GL_TRIANGLE_STRIP; | ||||
|     } | ||||
| 
 | ||||
|     void draw(size_t start, size_t count) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpDraw); | ||||
|         cmds.emplace_back(Command::Op::Draw); | ||||
|         cmds.back().start = start; | ||||
|         cmds.back().count = count; | ||||
|     } | ||||
| @ -863,7 +863,7 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|     void drawIndexed(size_t start, size_t count) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpDrawIndexed); | ||||
|         cmds.emplace_back(Command::Op::DrawIndexed); | ||||
|         cmds.back().start = start; | ||||
|         cmds.back().count = count; | ||||
|     } | ||||
| @ -871,7 +871,7 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|     void drawInstances(size_t start, size_t count, size_t instCount) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpDrawInstances); | ||||
|         cmds.emplace_back(Command::Op::DrawInstances); | ||||
|         cmds.back().start = start; | ||||
|         cmds.back().count = count; | ||||
|         cmds.back().instCount = instCount; | ||||
| @ -880,7 +880,7 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|     void drawInstancesIndexed(size_t start, size_t count, size_t instCount) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpDrawInstancesIndexed); | ||||
|         cmds.emplace_back(Command::Op::DrawInstancesIndexed); | ||||
|         cmds.back().start = start; | ||||
|         cmds.back().count = count; | ||||
|         cmds.back().instCount = instCount; | ||||
| @ -889,7 +889,7 @@ struct GLCommandQueue : IGraphicsCommandQueue | ||||
|     void resolveDisplay(ITextureR* source) | ||||
|     { | ||||
|         std::vector<Command>& cmds = m_cmdBufs[m_fillBuf]; | ||||
|         cmds.emplace_back(Command::OpPresent); | ||||
|         cmds.emplace_back(Command::Op::Present); | ||||
|         cmds.back().source = source; | ||||
|     } | ||||
|      | ||||
|  | ||||
| @ -11,7 +11,7 @@ extern const DeviceSignature BOO_DEVICE_SIGS[]; | ||||
| 
 | ||||
| bool DeviceSignature::DeviceMatchToken(const DeviceToken& token, const TDeviceSignatureSet& sigSet) | ||||
| { | ||||
|     if (token.getDeviceType() == DeviceToken::DEVTYPE_GENERICHID) | ||||
|     if (token.getDeviceType() == DeviceToken::DeviceType::GenericHID) | ||||
|         return true; | ||||
|     for (const DeviceSignature* sig : sigSet) | ||||
|     { | ||||
| @ -27,7 +27,7 @@ DeviceBase* DeviceSignature::DeviceNew(DeviceToken& token) | ||||
|     DeviceBase* retval = NULL; | ||||
| 
 | ||||
|     /* Early-return for generic HID devices */ | ||||
|     if (token.getDeviceType() == DeviceToken::DEVTYPE_GENERICHID) | ||||
|     if (token.getDeviceType() == DeviceToken::DeviceType::GenericHID) | ||||
|     { | ||||
|         retval = new GenericPad(&token); | ||||
|         if (!retval) | ||||
|  | ||||
| @ -20,14 +20,15 @@ DolphinSmashAdapter::~DolphinSmashAdapter() | ||||
| 
 | ||||
| static inline EDolphinControllerType parseType(unsigned char status) | ||||
| { | ||||
|     unsigned char type = status & (DOL_TYPE_NORMAL | DOL_TYPE_WAVEBIRD); | ||||
|     EDolphinControllerType type = EDolphinControllerType(status) & | ||||
|             (EDolphinControllerType::Normal | EDolphinControllerType::Wavebird); | ||||
|     switch (type) | ||||
|     { | ||||
|         case DOL_TYPE_NORMAL: | ||||
|         case DOL_TYPE_WAVEBIRD: | ||||
|             return (EDolphinControllerType)type; | ||||
|         case EDolphinControllerType::Normal: | ||||
|         case EDolphinControllerType::Wavebird: | ||||
|             return type; | ||||
|         default: | ||||
|             return DOL_TYPE_NONE; | ||||
|             return EDolphinControllerType::None; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| @ -77,12 +78,12 @@ void DolphinSmashAdapter::transferCycle() | ||||
|         DolphinControllerState state; | ||||
|         bool rumble = false; | ||||
|         EDolphinControllerType type = parseState(&state, controller, rumble); | ||||
|         if (type && !(m_knownControllers & 1<<i)) | ||||
|         if (type != EDolphinControllerType::None && !(m_knownControllers & 1<<i)) | ||||
|         { | ||||
|             m_knownControllers |= 1<<i; | ||||
|             m_callback->controllerConnected(i, type); | ||||
|         } | ||||
|         else if (!type && (m_knownControllers & 1<<i)) | ||||
|         else if (type == EDolphinControllerType::None && (m_knownControllers & 1<<i)) | ||||
|         { | ||||
|             m_knownControllers &= ~(1<<i); | ||||
|             m_callback->controllerDisconnected(i); | ||||
|  | ||||
| @ -49,8 +49,8 @@ static const uint8_t defaultReport[35] = { | ||||
| DualshockPad::DualshockPad(DeviceToken* token) | ||||
|     : DeviceBase(token), | ||||
|       m_callback(nullptr), | ||||
|       m_rumbleRequest(0), | ||||
|       m_rumbleState(0) | ||||
|       m_rumbleRequest(EDualshockMotor::None), | ||||
|       m_rumbleState(EDualshockMotor::None) | ||||
| { | ||||
|     memcpy(m_report.buf, defaultReport, 35); | ||||
| } | ||||
| @ -96,7 +96,7 @@ void DualshockPad::transferCycle() | ||||
| 
 | ||||
|     if (m_rumbleRequest != m_rumbleState) | ||||
|     { | ||||
|         if (m_rumbleRequest & DS3_MOTOR_LEFT) | ||||
|         if ((m_rumbleRequest & EDualshockMotor::Left) != EDualshockMotor::None) | ||||
|         { | ||||
|             m_report.rumble.leftDuration = m_rumbleDuration[0]; | ||||
|             m_report.rumble.leftForce = m_rumbleIntensity[0]; | ||||
| @ -107,7 +107,7 @@ void DualshockPad::transferCycle() | ||||
|             m_report.rumble.leftForce = 0; | ||||
|         } | ||||
| 
 | ||||
|         if (m_rumbleRequest & DS3_MOTOR_RIGHT) | ||||
|         if ((m_rumbleRequest & EDualshockMotor::Right) != EDualshockMotor::None) | ||||
|         { | ||||
|             m_report.rumble.rightDuration = m_rumbleDuration[0]; | ||||
|             m_report.rumble.rightOn = true; | ||||
| @ -123,9 +123,9 @@ void DualshockPad::transferCycle() | ||||
|     else | ||||
|     { | ||||
|         if (state.m_reserved5[8] & 0x80) | ||||
|             m_rumbleRequest &= ~DS3_MOTOR_RIGHT; | ||||
|             m_rumbleRequest &= ~EDualshockMotor::Right; | ||||
|         if (state.m_reserved5[7] & 0x01) | ||||
|             m_rumbleRequest &= ~DS3_MOTOR_LEFT; | ||||
|             m_rumbleRequest &= ~EDualshockMotor::Left; | ||||
|         m_rumbleState = m_rumbleRequest; | ||||
|         const double zeroG = 511.5; // 1.65/3.3*1023 (1,65V);
 | ||||
|         float accXval = -((double)state.m_accelerometer[0] - zeroG); | ||||
|  | ||||
| @ -243,12 +243,12 @@ public: | ||||
|     { | ||||
|         devImp.m_hidDev = this; | ||||
|         std::unique_lock<std::mutex> lk(m_initMutex); | ||||
|         DeviceToken::TDeviceType dType = token.getDeviceType(); | ||||
|         if (dType == DeviceToken::DEVTYPE_USB) | ||||
|         DeviceToken::DeviceType dType = token.getDeviceType(); | ||||
|         if (dType == DeviceToken::DeviceType::USB) | ||||
|             m_thread = new std::thread(_threadProcUSBLL, this); | ||||
|         else if (dType == DeviceToken::DEVTYPE_BLUETOOTH) | ||||
|         else if (dType == DeviceToken::DeviceType::Bluetooth) | ||||
|             m_thread = new std::thread(_threadProcBTLL, this); | ||||
|         else if (dType == DeviceToken::DEVTYPE_GENERICHID) | ||||
|         else if (dType == DeviceToken::DeviceType::GenericHID) | ||||
|             m_thread = new std::thread(_threadProcHID, this); | ||||
|         else | ||||
|         { | ||||
|  | ||||
| @ -34,11 +34,11 @@ class HIDListenerUdev final : public IHIDListener | ||||
| 
 | ||||
|         /* Filter to USB/BT */ | ||||
|         const char* dt = udev_device_get_devtype(device); | ||||
|         DeviceToken::TDeviceType type; | ||||
|         DeviceToken::DeviceType type; | ||||
|         if (!strcmp(dt, "usb_device")) | ||||
|             type = DeviceToken::DEVTYPE_USB; | ||||
|             type = DeviceToken::DeviceType::USB; | ||||
|         else if (!strcmp(dt, "bluetooth_device")) | ||||
|             type = DeviceToken::DEVTYPE_BLUETOOTH; | ||||
|             type = DeviceToken::DeviceType::Bluetooth; | ||||
|         else | ||||
|             return; | ||||
| 
 | ||||
| @ -82,9 +82,9 @@ class HIDListenerUdev final : public IHIDListener | ||||
|         { | ||||
|             /* Matched-insertion failed; see if generic HID interface is available */ | ||||
|             udev_list_entry* devInterfaces = nullptr; | ||||
|             if (type == DeviceToken::DEVTYPE_USB) | ||||
|             if (type == DeviceToken::DeviceType::USB) | ||||
|                 devInterfaces = udev_list_entry_get_by_name(attrs, "ID_USB_INTERFACES"); | ||||
|             else if (type == DeviceToken::DEVTYPE_BLUETOOTH) | ||||
|             else if (type == DeviceToken::DeviceType::Bluetooth) | ||||
|                 devInterfaces = udev_list_entry_get_by_name(attrs, "ID_BLUETOOTH_INTERFACES"); | ||||
|             if (devInterfaces) | ||||
|             { | ||||
| @ -101,7 +101,7 @@ class HIDListenerUdev final : public IHIDListener | ||||
|                     { | ||||
|                         const char* hidPath = udev_list_entry_get_name(hidEnt); | ||||
|                         if (!listener->m_finder._hasToken(hidPath)) | ||||
|                             listener->m_finder._insertToken(DeviceToken(DeviceToken::DEVTYPE_GENERICHID, | ||||
|                             listener->m_finder._insertToken(DeviceToken(DeviceToken::DeviceType::GenericHID, | ||||
|                                                                          vid, pid, manuf, product, hidPath)); | ||||
|                     } | ||||
|                     udev_enumerate_unref(hidEnum); | ||||
|  | ||||
| @ -58,10 +58,10 @@ int ApplicationRun(IApplication::EPlatformType platform, | ||||
| { | ||||
|     if (APP) | ||||
|         return 1; | ||||
|     if (platform == IApplication::PLAT_WAYLAND) | ||||
|     if (platform == IApplication::EPlatformType::Wayland) | ||||
|         APP = new ApplicationWayland(cb, uniqueName, friendlyName, pname, args, singleInstance); | ||||
|     else if (platform == IApplication::PLAT_XLIB || | ||||
|              platform == IApplication::PLAT_AUTO) | ||||
|     else if (platform == IApplication::EPlatformType::Xlib || | ||||
|              platform == IApplication::EPlatformType::Auto) | ||||
|         APP = new ApplicationXlib(cb, uniqueName, friendlyName, pname, args, singleInstance); | ||||
|     else | ||||
|         return 1; | ||||
|  | ||||
| @ -43,7 +43,7 @@ public: | ||||
|      | ||||
|     EPlatformType getPlatformType() const | ||||
|     { | ||||
|         return PLAT_WAYLAND; | ||||
|         return EPlatformType::Wayland; | ||||
|     } | ||||
|      | ||||
|     int run() | ||||
|  | ||||
| @ -220,7 +220,7 @@ public: | ||||
|      | ||||
|     EPlatformType getPlatformType() const | ||||
|     { | ||||
|         return PLAT_XLIB; | ||||
|         return EPlatformType::Xlib; | ||||
|     } | ||||
|      | ||||
|     /* Empty handler for SIGINT */ | ||||
|  | ||||
| @ -2,6 +2,7 @@ | ||||
| #include "boo/IGraphicsContext.hpp" | ||||
| 
 | ||||
| #include <X11/Xlib.h> | ||||
| #undef None | ||||
| 
 | ||||
| namespace boo | ||||
| { | ||||
| @ -18,7 +19,7 @@ public: | ||||
| 
 | ||||
|     GraphicsContextWayland(EGraphicsAPI api, IWindow* parentWindow) | ||||
|     : m_api(api), | ||||
|       m_pf(PF_RGBA8), | ||||
|       m_pf(EPixelFormat::RGBA8), | ||||
|       m_parentWindow(parentWindow) | ||||
|     {} | ||||
| 
 | ||||
| @ -44,7 +45,7 @@ public: | ||||
| 
 | ||||
|     void setPixelFormat(EPixelFormat pf) | ||||
|     { | ||||
|         if (pf > PF_RGBAF32_Z24) | ||||
|         if (pf > EPixelFormat::RGBAF32_Z24) | ||||
|             return; | ||||
|         m_pf = pf; | ||||
|     } | ||||
| @ -93,7 +94,7 @@ struct WindowWayland : IWindow | ||||
|     GraphicsContextWayland m_gfxCtx; | ||||
| 
 | ||||
|     WindowWayland(const std::string& title) | ||||
|     : m_gfxCtx(IGraphicsContext::API_OPENGL_3_3, this) | ||||
|         : m_gfxCtx(IGraphicsContext::EGraphicsAPI::OpenGL3_3, this) | ||||
|     { | ||||
|          | ||||
|     } | ||||
| @ -163,7 +164,7 @@ struct WindowWayland : IWindow | ||||
| 
 | ||||
|     EWindowStyle getStyle() const | ||||
|     { | ||||
|         return STYLE_NONE; | ||||
|         return EWindowStyle::None; | ||||
|     } | ||||
| 
 | ||||
|     bool isFullscreen() const | ||||
| @ -187,7 +188,7 @@ struct WindowWayland : IWindow | ||||
|      | ||||
|     ETouchType getTouchType() const | ||||
|     { | ||||
|         return TOUCH_NONE; | ||||
|         return ETouchType::None; | ||||
|     } | ||||
|      | ||||
| 
 | ||||
|  | ||||
| @ -42,6 +42,7 @@ | ||||
| #define MWM_FUNC_MAXIMIZE     (1L<<4) | ||||
| #define MWM_FUNC_CLOSE        (1L<<5) | ||||
| 
 | ||||
| #undef None | ||||
| 
 | ||||
| typedef GLXContext (*glXCreateContextAttribsARBProc)(Display*, GLXFBConfig, GLXContext, Bool, const int*); | ||||
| static glXCreateContextAttribsARBProc glXCreateContextAttribsARB = 0; | ||||
| @ -54,7 +55,7 @@ static const int ContextAttribs[] = | ||||
|     GLX_CONTEXT_FLAGS_ARB, GLX_CONTEXT_CORE_PROFILE_BIT_ARB, | ||||
|     //GLX_CONTEXT_FLAGS_ARB, GLX_CONTEXT_DEBUG_BIT_ARB,
 | ||||
|     //GLX_CONTEXT_FLAGS_ARB, GLX_CONTEXT_FORWARD_COMPATIBLE_BIT_ARB,
 | ||||
|     None | ||||
|     0 | ||||
| }; | ||||
| 
 | ||||
| namespace boo | ||||
| @ -67,75 +68,78 @@ void GLXEnableVSync(Display* disp, GLXWindow drawable); | ||||
| 
 | ||||
| extern int XINPUT_OPCODE; | ||||
| 
 | ||||
| static uint32_t translateKeysym(KeySym sym, int& specialSym, int& modifierSym) | ||||
| static uint32_t translateKeysym(KeySym sym, ESpecialKey& specialSym, EModifierKey& modifierSym) | ||||
| { | ||||
|     specialSym = KEY_NONE; | ||||
|     modifierSym = MKEY_NONE; | ||||
|     specialSym = ESpecialKey::None; | ||||
|     modifierSym = EModifierKey::None; | ||||
|     if (sym >= XK_F1 && sym <= XK_F12) | ||||
|         specialSym = KEY_F1 + sym - XK_F1; | ||||
|         specialSym = ESpecialKey(int(ESpecialKey::F1) + sym - XK_F1); | ||||
|     else if (sym == XK_Escape) | ||||
|         specialSym = KEY_ESC; | ||||
|         specialSym = ESpecialKey::Esc; | ||||
|     else if (sym == XK_Return) | ||||
|         specialSym = KEY_ENTER; | ||||
|         specialSym = ESpecialKey::Enter; | ||||
|     else if (sym == XK_BackSpace) | ||||
|         specialSym = KEY_BACKSPACE; | ||||
|         specialSym = ESpecialKey::Backspace; | ||||
|     else if (sym == XK_Insert) | ||||
|         specialSym = KEY_INSERT; | ||||
|         specialSym = ESpecialKey::Insert; | ||||
|     else if (sym == XK_Delete) | ||||
|         specialSym = KEY_DELETE; | ||||
|         specialSym = ESpecialKey::Delete; | ||||
|     else if (sym == XK_Home) | ||||
|         specialSym = KEY_HOME; | ||||
|         specialSym = ESpecialKey::Home; | ||||
|     else if (sym == XK_End) | ||||
|         specialSym = KEY_END; | ||||
|         specialSym = ESpecialKey::End; | ||||
|     else if (sym == XK_Page_Up) | ||||
|         specialSym = KEY_PGUP; | ||||
|         specialSym = ESpecialKey::PgUp; | ||||
|     else if (sym == XK_Page_Down) | ||||
|         specialSym = KEY_PGDOWN; | ||||
|         specialSym = ESpecialKey::PgDown; | ||||
|     else if (sym == XK_Left) | ||||
|         specialSym = KEY_LEFT; | ||||
|         specialSym = ESpecialKey::Left; | ||||
|     else if (sym == XK_Right) | ||||
|         specialSym = KEY_RIGHT; | ||||
|         specialSym = ESpecialKey::Right; | ||||
|     else if (sym == XK_Up) | ||||
|         specialSym = KEY_UP; | ||||
|         specialSym = ESpecialKey::Up; | ||||
|     else if (sym == XK_Down) | ||||
|         specialSym = KEY_DOWN; | ||||
|         specialSym = ESpecialKey::Down; | ||||
|     else if (sym == XK_Shift_L || sym == XK_Shift_R) | ||||
|         modifierSym = MKEY_SHIFT; | ||||
|         modifierSym = EModifierKey::Shift; | ||||
|     else if (sym == XK_Control_L || sym == XK_Control_R) | ||||
|         modifierSym = MKEY_CTRL; | ||||
|         modifierSym = EModifierKey::Ctrl; | ||||
|     else if (sym == XK_Alt_L || sym == XK_Alt_R) | ||||
|         modifierSym = MKEY_ALT; | ||||
|         modifierSym = EModifierKey::Alt; | ||||
|     else | ||||
|         return xkb_keysym_to_utf32(sym); | ||||
|     return 0; | ||||
| } | ||||
| 
 | ||||
| static int translateModifiers(unsigned state) | ||||
| static EModifierKey translateModifiers(unsigned state) | ||||
| { | ||||
|     int retval = 0; | ||||
|     EModifierKey retval = EModifierKey::None; | ||||
|     if (state & ShiftMask) | ||||
|         retval |= MKEY_SHIFT; | ||||
|         retval |= EModifierKey::Shift; | ||||
|     if (state & ControlMask) | ||||
|         retval |= MKEY_CTRL; | ||||
|         retval |= EModifierKey::Ctrl; | ||||
|     if (state & Mod1Mask) | ||||
|         retval |= MKEY_ALT; | ||||
|         retval |= EModifierKey::Alt; | ||||
|     return retval; | ||||
| } | ||||
| 
 | ||||
| static int translateButton(unsigned detail) | ||||
| static EMouseButton translateButton(unsigned detail) | ||||
| { | ||||
|     int retval = 0; | ||||
|     if (detail == 1) | ||||
|         retval = BUTTON_PRIMARY; | ||||
|     else if (detail == 3) | ||||
|         retval = BUTTON_SECONDARY; | ||||
|     else if (detail == 2) | ||||
|         retval = BUTTON_MIDDLE; | ||||
|     else if (detail == 8) | ||||
|         retval = BUTTON_AUX1; | ||||
|     else if (detail == 9) | ||||
|         retval = BUTTON_AUX2; | ||||
|     return retval; | ||||
|     switch (detail) | ||||
|     { | ||||
|     case 1: | ||||
|         return EMouseButton::Primary; | ||||
|     case 3: | ||||
|         return EMouseButton::Secondary; | ||||
|     case 2: | ||||
|         return EMouseButton::Middle; | ||||
|     case 8: | ||||
|         return EMouseButton::Aux1; | ||||
|     case 9: | ||||
|         return EMouseButton::Aux2; | ||||
|     default: break; | ||||
|     } | ||||
|     return EMouseButton::None; | ||||
| } | ||||
| 
 | ||||
| struct XCBAtoms | ||||
| @ -198,7 +202,7 @@ public: | ||||
|                        Display* display, int defaultScreen, | ||||
|                        GLXContext lastCtx, uint32_t& visualIdOut) | ||||
|     : m_api(api), | ||||
|       m_pf(PF_RGBA8_Z24), | ||||
|       m_pf(EPixelFormat::RGBA8_Z24), | ||||
|       m_parentWindow(parentWindow), | ||||
|       m_xDisp(display), | ||||
|       m_lastCtx(lastCtx) | ||||
| @ -228,25 +232,25 @@ public: | ||||
|             if (!doubleBuffer) | ||||
|                 continue; | ||||
| 
 | ||||
|             if (m_pf == PF_RGBA8 && colorSize >= 32) | ||||
|             if (m_pf == EPixelFormat::RGBA8 && colorSize >= 32) | ||||
|             { | ||||
|                 m_fbconfig = config; | ||||
|                 m_visualid = visualId; | ||||
|                 break; | ||||
|             } | ||||
|             else if (m_pf == PF_RGBA8_Z24 && colorSize >= 32 && depthSize >= 24) | ||||
|             else if (m_pf == EPixelFormat::RGBA8_Z24 && colorSize >= 32 && depthSize >= 24) | ||||
|             { | ||||
|                 m_fbconfig = config; | ||||
|                 m_visualid = visualId; | ||||
|                 break; | ||||
|             } | ||||
|             else if (m_pf == PF_RGBAF32 && colorSize >= 128) | ||||
|             else if (m_pf == EPixelFormat::RGBAF32 && colorSize >= 128) | ||||
|             { | ||||
|                 m_fbconfig = config; | ||||
|                 m_visualid = visualId; | ||||
|                 break; | ||||
|             } | ||||
|             else if (m_pf == PF_RGBAF32_Z24 && colorSize >= 128 && depthSize >= 24) | ||||
|             else if (m_pf == EPixelFormat::RGBAF32_Z24 && colorSize >= 128 && depthSize >= 24) | ||||
|             { | ||||
|                 m_fbconfig = config; | ||||
|                 m_visualid = visualId; | ||||
| @ -293,7 +297,7 @@ public: | ||||
| 
 | ||||
|     void setPixelFormat(EPixelFormat pf) | ||||
|     { | ||||
|         if (pf > PF_RGBAF32_Z24) | ||||
|         if (pf > EPixelFormat::RGBAF32_Z24) | ||||
|             return; | ||||
|         m_pf = pf; | ||||
|     } | ||||
| @ -342,7 +346,7 @@ public: | ||||
|                 if (!vsyncDisp) | ||||
|                     Log.report(LogVisor::FatalError, "unable to open new vsync display"); | ||||
| 
 | ||||
|                 static int attributeList[] = { GLX_RGBA, GLX_DOUBLEBUFFER, GLX_RED_SIZE, 1, GLX_GREEN_SIZE, 1, GLX_BLUE_SIZE, 1, None }; | ||||
|                 static int attributeList[] = { GLX_RGBA, GLX_DOUBLEBUFFER, GLX_RED_SIZE, 1, GLX_GREEN_SIZE, 1, GLX_BLUE_SIZE, 1, 0 }; | ||||
|                 XVisualInfo *vi = glXChooseVisual(vsyncDisp, DefaultScreen(vsyncDisp),attributeList); | ||||
| 
 | ||||
|                 vsyncCtx = glXCreateContext(vsyncDisp, vi, nullptr, True); | ||||
| @ -363,7 +367,7 @@ public: | ||||
|                 m_vsynccv.notify_one(); | ||||
|             } | ||||
| 
 | ||||
|             glXMakeCurrent(vsyncDisp, None, nullptr); | ||||
|             glXMakeCurrent(vsyncDisp, 0, nullptr); | ||||
|             glXDestroyContext(vsyncDisp, vsyncCtx); | ||||
|             XCloseDisplay(vsyncDisp); | ||||
|         }); | ||||
| @ -448,7 +452,7 @@ class WindowXlib : public IWindow | ||||
| 
 | ||||
|     /* Last known input device id (0xffff if not yet set) */ | ||||
|     int m_lastInputID = 0xffff; | ||||
|     ETouchType m_touchType = TOUCH_NONE; | ||||
|     ETouchType m_touchType = ETouchType::None; | ||||
| 
 | ||||
|     /* Scroll valuators */ | ||||
|     int m_hScrollValuator = -1; | ||||
| @ -470,7 +474,7 @@ public: | ||||
|               Display* display, int defaultScreen, | ||||
|               GLXContext lastCtx) | ||||
|     : m_xDisp(display), m_callback(nullptr), | ||||
|       m_gfxCtx(IGraphicsContext::API_OPENGL_3_3, | ||||
|       m_gfxCtx(IGraphicsContext::EGraphicsAPI::OpenGL3_3, | ||||
|                this, display, defaultScreen, | ||||
|                lastCtx, m_visualId) | ||||
|     { | ||||
| @ -504,7 +508,7 @@ public: | ||||
|         genFrameDefault(screen, x, y, w, h); | ||||
|         XSetWindowAttributes swa; | ||||
|         swa.colormap = m_colormapId; | ||||
|         swa.border_pixmap = None; | ||||
|         swa.border_pixmap = 0; | ||||
|         swa.event_mask = FocusChangeMask | KeyPressMask | KeyReleaseMask | ButtonPressMask | ButtonReleaseMask | PointerMotionMask | ExposureMask | StructureNotifyMask | LeaveWindowMask | EnterWindowMask; | ||||
| 
 | ||||
|         m_windowId = XCreateWindow(display, screen->root, x, y, w, h, 10, | ||||
| @ -538,7 +542,7 @@ public: | ||||
|         XMapWindow(m_xDisp, m_windowId); | ||||
|         XFlush(m_xDisp); | ||||
| 
 | ||||
|         setStyle(STYLE_DEFAULT); | ||||
|         setStyle(EWindowStyle::Default); | ||||
| 
 | ||||
|         m_gfxCtx.initializeContext(); | ||||
|     } | ||||
| @ -701,18 +705,18 @@ public: | ||||
|         if (S_ATOMS->m_motifWmHints) | ||||
|         { | ||||
|             wmHints.flags = MWM_HINTS_DECORATIONS | MWM_HINTS_FUNCTIONS; | ||||
|             if (style & STYLE_TITLEBAR) | ||||
|             if ((style & EWindowStyle::Titlebar) != EWindowStyle::None) | ||||
|             { | ||||
|                 wmHints.decorations |= MWM_DECOR_BORDER | MWM_DECOR_TITLE | MWM_DECOR_MINIMIZE | MWM_DECOR_MENU; | ||||
|                 wmHints.functions  |= MWM_FUNC_MOVE | MWM_FUNC_MINIMIZE; | ||||
|             } | ||||
|             if (style & STYLE_RESIZE) | ||||
|             if ((style & EWindowStyle::Resize) != EWindowStyle::None) | ||||
|             { | ||||
|                 wmHints.decorations |= MWM_DECOR_MAXIMIZE | MWM_DECOR_RESIZEH; | ||||
|                 wmHints.functions  |= MWM_FUNC_RESIZE | MWM_FUNC_MAXIMIZE; | ||||
|             } | ||||
| 
 | ||||
|             if (style & STYLE_CLOSE) | ||||
|             if ((style & EWindowStyle::Close) != EWindowStyle::None) | ||||
|                 wmHints.functions |= MWM_FUNC_CLOSE; | ||||
| 
 | ||||
|             XLockDisplay(m_xDisp); | ||||
| @ -813,11 +817,11 @@ public: | ||||
|                 { | ||||
|                     XITouchClassInfo* touchClass = (XITouchClassInfo*)dclass; | ||||
|                     if (touchClass->mode == XIDirectTouch) | ||||
|                         m_touchType = TOUCH_DISPLAY; | ||||
|                         m_touchType = ETouchType::Display; | ||||
|                     else if (touchClass->mode == XIDependentTouch) | ||||
|                         m_touchType = TOUCH_TRACKPAD; | ||||
|                         m_touchType = ETouchType::Trackpad; | ||||
|                     else | ||||
|                         m_touchType = TOUCH_NONE; | ||||
|                         m_touchType = ETouchType::None; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| @ -880,19 +884,17 @@ public: | ||||
|         { | ||||
|             if (m_callback) | ||||
|             { | ||||
|                 int specialKey; | ||||
|                 int modifierKey; | ||||
|                 ESpecialKey specialKey; | ||||
|                 EModifierKey modifierKey; | ||||
|                 uint32_t charCode = translateKeysym(XLookupKeysym(&event->xkey, 0), | ||||
|                                                     specialKey, modifierKey); | ||||
|                 int modifierMask = translateModifiers(event->xkey.state); | ||||
|                 EModifierKey modifierMask = translateModifiers(event->xkey.state); | ||||
|                 if (charCode) | ||||
|                     m_callback->charKeyDown(charCode, | ||||
|                                             (EModifierKey)modifierMask, false); | ||||
|                 else if (specialKey) | ||||
|                     m_callback->specialKeyDown((ESpecialKey)specialKey, | ||||
|                                                (EModifierKey)modifierMask, false); | ||||
|                 else if (modifierKey) | ||||
|                     m_callback->modKeyDown((EModifierKey)modifierKey, false); | ||||
|                     m_callback->charKeyDown(charCode, modifierMask, false); | ||||
|                 else if (specialKey != ESpecialKey::None) | ||||
|                     m_callback->specialKeyDown(specialKey, modifierMask, false); | ||||
|                 else if (modifierKey != EModifierKey::None) | ||||
|                     m_callback->modKeyDown(modifierKey, false); | ||||
|             } | ||||
|             return; | ||||
|         } | ||||
| @ -900,19 +902,17 @@ public: | ||||
|         { | ||||
|             if (m_callback) | ||||
|             { | ||||
|                 int specialKey; | ||||
|                 int modifierKey; | ||||
|                 ESpecialKey specialKey; | ||||
|                 EModifierKey modifierKey; | ||||
|                 uint32_t charCode = translateKeysym(XLookupKeysym(&event->xkey, 0), | ||||
|                                                     specialKey, modifierKey); | ||||
|                 int modifierMask = translateModifiers(event->xkey.state); | ||||
|                 EModifierKey modifierMask = translateModifiers(event->xkey.state); | ||||
|                 if (charCode) | ||||
|                     m_callback->charKeyUp(charCode, | ||||
|                                           (EModifierKey)modifierMask); | ||||
|                 else if (specialKey) | ||||
|                     m_callback->specialKeyUp((ESpecialKey)specialKey, | ||||
|                                              (EModifierKey)modifierMask); | ||||
|                 else if (modifierKey) | ||||
|                     m_callback->modKeyUp((EModifierKey)modifierKey); | ||||
|                     m_callback->charKeyUp(charCode, modifierMask); | ||||
|                 else if (specialKey != ESpecialKey::None) | ||||
|                     m_callback->specialKeyUp(specialKey, modifierMask); | ||||
|                 else if (modifierKey != EModifierKey::None) | ||||
|                     m_callback->modKeyUp(modifierKey); | ||||
|             } | ||||
|             return; | ||||
|         } | ||||
| @ -921,10 +921,10 @@ public: | ||||
|             if (m_callback) | ||||
|             { | ||||
|                 getWindowFrame(m_wx, m_wy, m_ww, m_wh); | ||||
|                 int button = translateButton(event->xbutton.button); | ||||
|                 if (button) | ||||
|                 EMouseButton button = translateButton(event->xbutton.button); | ||||
|                 if (button != EMouseButton::None) | ||||
|                 { | ||||
|                     int modifierMask = translateModifiers(event->xbutton.state); | ||||
|                     EModifierKey modifierMask = translateModifiers(event->xbutton.state); | ||||
|                     SWindowCoord coord = | ||||
|                     { | ||||
|                         {(unsigned)event->xbutton.x, (unsigned)event->xbutton.y}, | ||||
| @ -968,10 +968,10 @@ public: | ||||
|             if (m_callback) | ||||
|             { | ||||
|                 getWindowFrame(m_wx, m_wy, m_ww, m_wh); | ||||
|                 int button = translateButton(event->xbutton.button); | ||||
|                 if (button) | ||||
|                 EMouseButton button = translateButton(event->xbutton.button); | ||||
|                 if (button != EMouseButton::None) | ||||
|                 { | ||||
|                     int modifierMask = translateModifiers(event->xbutton.state); | ||||
|                     EModifierKey modifierMask = translateModifiers(event->xbutton.state); | ||||
|                     SWindowCoord coord = | ||||
|                     { | ||||
|                         {(unsigned)event->xbutton.x, (unsigned)event->xbutton.y}, | ||||
|  | ||||
| @ -62,8 +62,8 @@ class DualshockPadCallback : public IDualshockPadCallback | ||||
|         { | ||||
|             if (timeDif >= 1) // wait 30 seconds before issuing another rumble event
 | ||||
|             { | ||||
|                 ctrl->startRumble(DS3_MOTOR_LEFT); | ||||
|                 ctrl->startRumble(DS3_MOTOR_RIGHT, 100); | ||||
|                 ctrl->startRumble(EDualshockMotor::Left); | ||||
|                 ctrl->startRumble(EDualshockMotor::Right, 100); | ||||
|                 lastTime = timeTotal; | ||||
|             } | ||||
|         } | ||||
| @ -101,7 +101,7 @@ public: | ||||
|         if (ds3) | ||||
|         { | ||||
|             ds3->setCallback(&m_ds3CB); | ||||
|             ds3->setLED(DS3_LED_1); | ||||
|             ds3->setLED(EDualshockLED::LED_1); | ||||
|         } | ||||
|     } | ||||
|     void deviceDisconnected(DeviceToken&, DeviceBase* device) | ||||
| @ -136,11 +136,11 @@ struct CTestWindowCallback : IWindowCallback | ||||
| 
 | ||||
|     void mouseDown(const SWindowCoord& coord, EMouseButton button, EModifierKey mods) | ||||
|     { | ||||
|         fprintf(stderr, "Mouse Down %d (%f,%f)\n", button, coord.norm[0], coord.norm[1]); | ||||
|         fprintf(stderr, "Mouse Down %d (%f,%f)\n", int(button), coord.norm[0], coord.norm[1]); | ||||
|     } | ||||
|     void mouseUp(const SWindowCoord& coord, EMouseButton button, EModifierKey mods) | ||||
|     { | ||||
|         fprintf(stderr, "Mouse Up %d (%f,%f)\n", button, coord.norm[0], coord.norm[1]); | ||||
|         fprintf(stderr, "Mouse Up %d (%f,%f)\n", int(button), coord.norm[0], coord.norm[1]); | ||||
|     } | ||||
|     void mouseMove(const SWindowCoord& coord) | ||||
|     { | ||||
| @ -182,7 +182,7 @@ struct CTestWindowCallback : IWindowCallback | ||||
|     } | ||||
|     void specialKeyDown(ESpecialKey key, EModifierKey mods, bool isRepeat) | ||||
|     { | ||||
|         if (key == boo::KEY_ENTER && (mods & boo::MKEY_ALT)) | ||||
|         if (key == ESpecialKey::Enter && (mods & EModifierKey::Alt) != EModifierKey::None) | ||||
|             m_fullscreenToggleRequested = true; | ||||
|     } | ||||
|     void specialKeyUp(ESpecialKey key, EModifierKey mods) | ||||
| @ -251,13 +251,13 @@ struct TestApplicationCallback : IApplicationCallback | ||||
|             {{-0.5,-0.5},{0.0,0.0}} | ||||
|         }; | ||||
|         IGraphicsBuffer* vbo = | ||||
|         factory->newStaticBuffer(BufferUseVertex, quad, sizeof(Vert), 4); | ||||
|         factory->newStaticBuffer(BufferUse::Vertex, quad, sizeof(Vert), 4); | ||||
| 
 | ||||
|         /* Make vertex format */ | ||||
|         VertexElementDescriptor descs[2] = | ||||
|         { | ||||
|             {vbo, nullptr, VertexSemanticPosition}, | ||||
|             {vbo, nullptr, VertexSemanticUV} | ||||
|             {vbo, nullptr, VertexSemantic::Position}, | ||||
|             {vbo, nullptr, VertexSemantic::UV} | ||||
|         }; | ||||
|         IVertexFormat* vfmt = factory->newVertexFormat(2, descs); | ||||
| 
 | ||||
| @ -273,11 +273,11 @@ struct TestApplicationCallback : IApplicationCallback | ||||
|                 tex[i][j][3] = 0xff; | ||||
|             } | ||||
|         ITexture* texture = | ||||
|         factory->newStaticTexture(256, 256, 1, TextureFormatRGBA8, tex, 256*256*4); | ||||
|         factory->newStaticTexture(256, 256, 1, TextureFormat::RGBA8, tex, 256*256*4); | ||||
| 
 | ||||
|         /* Make shader pipeline */ | ||||
|         IShaderPipeline* pipeline = nullptr; | ||||
|         if (factory->platform() == IGraphicsDataFactory::PlatformOGL) | ||||
|         if (factory->platform() == IGraphicsDataFactory::Platform::OGL) | ||||
|         { | ||||
|             GLDataFactory* glF = dynamic_cast<GLDataFactory*>(factory); | ||||
| 
 | ||||
| @ -304,7 +304,7 @@ struct TestApplicationCallback : IApplicationCallback | ||||
|             "}\n"; | ||||
| 
 | ||||
|             pipeline = glF->newShaderPipeline(VS, FS, 1, "texs", 0, nullptr, | ||||
|                                               BlendFactorOne, BlendFactorZero, | ||||
|                                               BlendFactor::One, BlendFactor::Zero, | ||||
|                                               true, true, false); | ||||
|         } | ||||
| #if _WIN32 | ||||
| @ -444,7 +444,7 @@ struct TestApplicationCallback : IApplicationCallback | ||||
|             float rgba[] = {sinf(frameIdx / 60.0), cosf(frameIdx / 60.0), 0.0, 1.0}; | ||||
|             gfxQ->setClearColor(rgba); | ||||
|             gfxQ->clearTarget(); | ||||
|             gfxQ->setDrawPrimitive(PrimitiveTriStrips); | ||||
|             gfxQ->setDrawPrimitive(Primitive::TriStrips); | ||||
| 
 | ||||
|             gfxQ->setShaderDataBinding(m_binding); | ||||
|             gfxQ->draw(0, 4); | ||||
| @ -486,11 +486,15 @@ struct TestApplicationCallback : IApplicationCallback | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| #if _WIN32 | ||||
| int wmain(int argc, const boo::SystemChar** argv) | ||||
| #else | ||||
| int main(int argc, const boo::SystemChar** argv) | ||||
| #endif | ||||
| { | ||||
|     LogVisor::RegisterConsoleLogger(); | ||||
|     boo::TestApplicationCallback appCb; | ||||
|     int ret = ApplicationRun(boo::IApplication::PLAT_AUTO, | ||||
|     int ret = ApplicationRun(boo::IApplication::EPlatformType::Auto, | ||||
|         appCb, _S("boo"), _S("Boo"), argc, argv); | ||||
|     printf("IM DYING!!\n"); | ||||
|     return ret; | ||||
| @ -509,9 +513,7 @@ int APIENTRY wWinMain(HINSTANCE hInstance, HINSTANCE, LPWSTR lpCmdLine, int) | ||||
|         booArgv[i+1] = argv[i]; | ||||
| 
 | ||||
|     LogVisor::CreateWin32Console(); | ||||
|     return main(argc+1, booArgv); | ||||
|     return wmain(argc+1, booArgv); | ||||
| } | ||||
| #else | ||||
| 
 | ||||
| #endif | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user