mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-19 22:53:50 +00:00
Merge pull request #899 from scrawl/bullet283
Raise the required bullet version to 2.83
This commit is contained in:
commit
b5dc3953a4
9 changed files with 1291 additions and 37 deletions
|
@ -229,11 +229,7 @@ IF(BOOST_STATIC)
|
||||||
set(Boost_USE_STATIC_LIBS ON)
|
set(Boost_USE_STATIC_LIBS ON)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if (USE_QT)
|
find_package(OpenSceneGraph 3.3.4 REQUIRED osgDB osgViewer osgText osgGA osgAnimation osgParticle osgUtil osgFX)
|
||||||
set (OSG_QT osgQt)
|
|
||||||
endif()
|
|
||||||
|
|
||||||
find_package(OpenSceneGraph 3.3.4 REQUIRED osgDB osgViewer osgText osgGA osgAnimation osgParticle ${OSG_QT} osgUtil osgFX)
|
|
||||||
|
|
||||||
include_directories(${OPENSCENEGRAPH_INCLUDE_DIRS})
|
include_directories(${OPENSCENEGRAPH_INCLUDE_DIRS})
|
||||||
|
|
||||||
|
@ -304,6 +300,9 @@ find_package(Boost REQUIRED COMPONENTS ${BOOST_COMPONENTS})
|
||||||
find_package(SDL2 REQUIRED)
|
find_package(SDL2 REQUIRED)
|
||||||
find_package(OpenAL REQUIRED)
|
find_package(OpenAL REQUIRED)
|
||||||
find_package(Bullet REQUIRED)
|
find_package(Bullet REQUIRED)
|
||||||
|
if (NOT BULLET_FOUND OR BULLET_VERSION VERSION_LESS 283)
|
||||||
|
message(FATAL_ERROR "OpenMW requires Bullet version 2.83 or later")
|
||||||
|
endif()
|
||||||
|
|
||||||
include_directories("."
|
include_directories("."
|
||||||
SYSTEM
|
SYSTEM
|
||||||
|
@ -567,6 +566,7 @@ endif(WIN32)
|
||||||
# Extern
|
# Extern
|
||||||
add_subdirectory (extern/osg-ffmpeg-videoplayer)
|
add_subdirectory (extern/osg-ffmpeg-videoplayer)
|
||||||
add_subdirectory (extern/oics)
|
add_subdirectory (extern/oics)
|
||||||
|
add_subdirectory (extern/osgQt)
|
||||||
|
|
||||||
# Components
|
# Components
|
||||||
add_subdirectory (components)
|
add_subdirectory (components)
|
||||||
|
|
|
@ -197,7 +197,7 @@ target_link_libraries(openmw-cs
|
||||||
${OSGVIEWER_LIBRARIES}
|
${OSGVIEWER_LIBRARIES}
|
||||||
${OSGGA_LIBRARIES}
|
${OSGGA_LIBRARIES}
|
||||||
${OSGFX_LIBRARIES}
|
${OSGFX_LIBRARIES}
|
||||||
${OSGQT_LIBRARIES}
|
${EXTERN_OSGQT_LIBRARY}
|
||||||
${Boost_SYSTEM_LIBRARY}
|
${Boost_SYSTEM_LIBRARY}
|
||||||
${Boost_FILESYSTEM_LIBRARY}
|
${Boost_FILESYSTEM_LIBRARY}
|
||||||
${Boost_PROGRAM_OPTIONS_LIBRARY}
|
${Boost_PROGRAM_OPTIONS_LIBRARY}
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
#include <QShortcut>
|
#include <QShortcut>
|
||||||
#include <QLayout>
|
#include <QLayout>
|
||||||
|
|
||||||
#include <osgQt/GraphicsWindowQt>
|
#include <extern/osgQt/GraphicsWindowQt>
|
||||||
#include <osg/GraphicsContext>
|
#include <osg/GraphicsContext>
|
||||||
#include <osgViewer/CompositeViewer>
|
#include <osgViewer/CompositeViewer>
|
||||||
#include <osgViewer/ViewerEventHandlers>
|
#include <osgViewer/ViewerEventHandlers>
|
||||||
|
|
|
@ -765,18 +765,11 @@ namespace MWPhysics
|
||||||
mLeastDistSqr(std::numeric_limits<float>::max())
|
mLeastDistSqr(std::numeric_limits<float>::max())
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
#if BT_BULLET_VERSION >= 281
|
|
||||||
virtual btScalar addSingleResult(btManifoldPoint& cp,
|
virtual btScalar addSingleResult(btManifoldPoint& cp,
|
||||||
const btCollisionObjectWrapper* col0Wrap,int partId0,int index0,
|
const btCollisionObjectWrapper* col0Wrap,int partId0,int index0,
|
||||||
const btCollisionObjectWrapper* col1Wrap,int partId1,int index1)
|
const btCollisionObjectWrapper* col1Wrap,int partId1,int index1)
|
||||||
{
|
{
|
||||||
const btCollisionObject* collisionObject = col1Wrap->m_collisionObject;
|
const btCollisionObject* collisionObject = col1Wrap->m_collisionObject;
|
||||||
#else
|
|
||||||
virtual btScalar addSingleResult(btManifoldPoint& cp, const btCollisionObject* col0, int partId0, int index0,
|
|
||||||
const btCollisionObject* col1, int partId1, int index1)
|
|
||||||
{
|
|
||||||
const btCollisionObject* collisionObject = col1;
|
|
||||||
#endif
|
|
||||||
if (collisionObject != mMe)
|
if (collisionObject != mMe)
|
||||||
{
|
{
|
||||||
btScalar distsqr = mOrigin.distance2(cp.getPositionWorldOnA());
|
btScalar distsqr = mOrigin.distance2(cp.getPositionWorldOnA());
|
||||||
|
@ -1026,7 +1019,6 @@ namespace MWPhysics
|
||||||
|
|
||||||
std::vector<MWWorld::Ptr> mResult;
|
std::vector<MWWorld::Ptr> mResult;
|
||||||
|
|
||||||
#if BT_BULLET_VERSION >= 281
|
|
||||||
virtual btScalar addSingleResult(btManifoldPoint& cp,
|
virtual btScalar addSingleResult(btManifoldPoint& cp,
|
||||||
const btCollisionObjectWrapper* col0Wrap,int partId0,int index0,
|
const btCollisionObjectWrapper* col0Wrap,int partId0,int index0,
|
||||||
const btCollisionObjectWrapper* col1Wrap,int partId1,int index1)
|
const btCollisionObjectWrapper* col1Wrap,int partId1,int index1)
|
||||||
|
@ -1034,14 +1026,6 @@ namespace MWPhysics
|
||||||
const btCollisionObject* collisionObject = col0Wrap->m_collisionObject;
|
const btCollisionObject* collisionObject = col0Wrap->m_collisionObject;
|
||||||
if (collisionObject == mTestedAgainst)
|
if (collisionObject == mTestedAgainst)
|
||||||
collisionObject = col1Wrap->m_collisionObject;
|
collisionObject = col1Wrap->m_collisionObject;
|
||||||
#else
|
|
||||||
virtual btScalar addSingleResult(btManifoldPoint& cp, const btCollisionObject* col0, int partId0, int index0,
|
|
||||||
const btCollisionObject* col1, int partId1, int index1)
|
|
||||||
{
|
|
||||||
const btCollisionObject* collisionObject = col0;
|
|
||||||
if (collisionObject == mTestedAgainst)
|
|
||||||
collisionObject = col1;
|
|
||||||
#endif
|
|
||||||
PtrHolder* holder = static_cast<PtrHolder*>(collisionObject->getUserPointer());
|
PtrHolder* holder = static_cast<PtrHolder*>(collisionObject->getUserPointer());
|
||||||
if (holder)
|
if (holder)
|
||||||
mResult.push_back(holder->getPtr());
|
mResult.push_back(holder->getPtr());
|
||||||
|
|
|
@ -14,11 +14,14 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
# Copyright (c) 2009, Philip Lowman <philip at yhbt.com>
|
# Copyright (c) 2009, Philip Lowman <philip at yhbt.com>
|
||||||
|
# Modified for OpenMW to parse BT_BULLET_VERSION.
|
||||||
#
|
#
|
||||||
# Redistribution AND use is allowed according to the terms of the New
|
# Redistribution AND use is allowed according to the terms of the New
|
||||||
# BSD license.
|
# BSD license.
|
||||||
# For details see the accompanying COPYING-CMAKE-SCRIPTS file.
|
# For details see the accompanying COPYING-CMAKE-SCRIPTS file.
|
||||||
|
|
||||||
|
include(PreprocessorUtils)
|
||||||
|
|
||||||
set(BULLET_ROOT $ENV{BULLET_ROOT})
|
set(BULLET_ROOT $ENV{BULLET_ROOT})
|
||||||
|
|
||||||
macro(_FIND_BULLET_LIBRARY _var)
|
macro(_FIND_BULLET_LIBRARY _var)
|
||||||
|
@ -75,4 +78,9 @@ if(BULLET_FOUND)
|
||||||
#_BULLET_APPEND_LIBRARIES(BULLET_LIBRARIES BULLET_DYNAMICS_LIBRARY)
|
#_BULLET_APPEND_LIBRARIES(BULLET_LIBRARIES BULLET_DYNAMICS_LIBRARY)
|
||||||
_BULLET_APPEND_LIBRARIES(BULLET_LIBRARIES BULLET_COLLISION_LIBRARY)
|
_BULLET_APPEND_LIBRARIES(BULLET_LIBRARIES BULLET_COLLISION_LIBRARY)
|
||||||
_BULLET_APPEND_LIBRARIES(BULLET_LIBRARIES BULLET_MATH_LIBRARY)
|
_BULLET_APPEND_LIBRARIES(BULLET_LIBRARIES BULLET_MATH_LIBRARY)
|
||||||
|
|
||||||
|
find_file(BULLET_BTSCALAR_FILE NAMES btScalar.h PATHS "${BULLET_INCLUDE_DIR}/LinearMath")
|
||||||
|
file(READ ${BULLET_BTSCALAR_FILE} BULLET_BTSCALAR_CONTENT)
|
||||||
|
get_preprocessor_entry(BULLET_BTSCALAR_CONTENT BT_BULLET_VERSION BULLET_VERSION)
|
||||||
|
message(STATUS "Bullet version: ${BULLET_VERSION}")
|
||||||
endif()
|
endif()
|
||||||
|
|
|
@ -65,21 +65,7 @@ btCollisionShape* BulletShape::duplicateCollisionShape(const btCollisionShape *s
|
||||||
|
|
||||||
if(const btBvhTriangleMeshShape* trishape = dynamic_cast<const btBvhTriangleMeshShape*>(shape))
|
if(const btBvhTriangleMeshShape* trishape = dynamic_cast<const btBvhTriangleMeshShape*>(shape))
|
||||||
{
|
{
|
||||||
#if BT_BULLET_VERSION >= 283
|
|
||||||
btScaledBvhTriangleMeshShape* newShape = new btScaledBvhTriangleMeshShape(const_cast<btBvhTriangleMeshShape*>(trishape), btVector3(1.f, 1.f, 1.f));
|
btScaledBvhTriangleMeshShape* newShape = new btScaledBvhTriangleMeshShape(const_cast<btBvhTriangleMeshShape*>(trishape), btVector3(1.f, 1.f, 1.f));
|
||||||
#else
|
|
||||||
// work around btScaledBvhTriangleMeshShape bug ( https://code.google.com/p/bullet/issues/detail?id=371 ) in older bullet versions
|
|
||||||
const btTriangleMesh* oldMesh = static_cast<const btTriangleMesh*>(trishape->getMeshInterface());
|
|
||||||
btTriangleMesh* newMesh = new btTriangleMesh(*oldMesh);
|
|
||||||
|
|
||||||
// Do not build a new bvh (not needed, since it's the same as the original shape's bvh)
|
|
||||||
btOptimizedBvh* bvh = const_cast<btBvhTriangleMeshShape*>(trishape)->getOptimizedBvh();
|
|
||||||
TriangleMeshShape* newShape = new TriangleMeshShape(newMesh, true, bvh == NULL);
|
|
||||||
// Set original shape's bvh via pointer
|
|
||||||
// The pointer is safe because the BulletShapeInstance keeps a ref_ptr to the original BulletShape
|
|
||||||
if (bvh)
|
|
||||||
newShape->setOptimizedBvh(bvh);
|
|
||||||
#endif
|
|
||||||
return newShape;
|
return newShape;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
20
extern/osgQt/CMakeLists.txt
vendored
Normal file
20
extern/osgQt/CMakeLists.txt
vendored
Normal file
|
@ -0,0 +1,20 @@
|
||||||
|
set(OSGQT_LIBRARY "osgQt")
|
||||||
|
|
||||||
|
# Sources
|
||||||
|
|
||||||
|
set(OSGQT_SOURCE_FILES
|
||||||
|
GraphicsWindowQt.cpp
|
||||||
|
)
|
||||||
|
|
||||||
|
add_library(${OSGQT_LIBRARY} STATIC ${OSGQT_SOURCE_FILES})
|
||||||
|
|
||||||
|
if (DESIRED_QT_VERSION MATCHES 4)
|
||||||
|
include(${QT_USE_FILE})
|
||||||
|
target_link_libraries(${OSGQT_LIBRARY} ${QT_QTCORE_LIBRARY} ${QT_QTOPENGL_LIBRARY})
|
||||||
|
else()
|
||||||
|
qt5_use_modules(${OSGQT_LIBRARY} Core OpenGL)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
link_directories(${CMAKE_CURRENT_BINARY_DIR})
|
||||||
|
|
||||||
|
set(EXTERN_OSGQT_LIBRARY ${OSGQT_LIBRARY} PARENT_SCOPE)
|
193
extern/osgQt/GraphicsWindowQt
vendored
Normal file
193
extern/osgQt/GraphicsWindowQt
vendored
Normal file
|
@ -0,0 +1,193 @@
|
||||||
|
/* -*-c++-*- OpenSceneGraph - Copyright (C) 2009 Wang Rui
|
||||||
|
*
|
||||||
|
* This library is open source and may be redistributed and/or modified under
|
||||||
|
* the terms of the OpenSceneGraph Public License (OSGPL) version 0.0 or
|
||||||
|
* (at your option) any later version. The full license is in LICENSE file
|
||||||
|
* included with this distribution, and on the openscenegraph.org website.
|
||||||
|
*
|
||||||
|
* This library is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* OpenSceneGraph Public License for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef OSGVIEWER_GRAPHICSWINDOWQT
|
||||||
|
#define OSGVIEWER_GRAPHICSWINDOWQT
|
||||||
|
|
||||||
|
#include <QGLWidget>
|
||||||
|
|
||||||
|
#include <osgViewer/GraphicsWindow>
|
||||||
|
|
||||||
|
#include <QMutex>
|
||||||
|
#include <QEvent>
|
||||||
|
#include <QQueue>
|
||||||
|
#include <QSet>
|
||||||
|
#include <QGLWidget>
|
||||||
|
|
||||||
|
class QInputEvent;
|
||||||
|
class QGestureEvent;
|
||||||
|
|
||||||
|
namespace osgViewer {
|
||||||
|
class ViewerBase;
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace osgQt
|
||||||
|
{
|
||||||
|
|
||||||
|
// forward declarations
|
||||||
|
class GraphicsWindowQt;
|
||||||
|
|
||||||
|
/// The function sets the WindowingSystem to Qt.
|
||||||
|
void initQtWindowingSystem();
|
||||||
|
|
||||||
|
/** The function sets the viewer that will be used after entering
|
||||||
|
* the Qt main loop (QCoreApplication::exec()).
|
||||||
|
*
|
||||||
|
* The function also initializes internal structures required for proper
|
||||||
|
* scene rendering.
|
||||||
|
*
|
||||||
|
* The method must be called from main thread. */
|
||||||
|
void setViewer( osgViewer::ViewerBase *viewer );
|
||||||
|
|
||||||
|
|
||||||
|
class GLWidget : public QGLWidget
|
||||||
|
{
|
||||||
|
typedef QGLWidget inherited;
|
||||||
|
|
||||||
|
public:
|
||||||
|
|
||||||
|
GLWidget( QWidget* parent = NULL, const QGLWidget* shareWidget = NULL, Qt::WindowFlags f = 0, bool forwardKeyEvents = false );
|
||||||
|
GLWidget( QGLContext* context, QWidget* parent = NULL, const QGLWidget* shareWidget = NULL, Qt::WindowFlags f = 0, bool forwardKeyEvents = false );
|
||||||
|
GLWidget( const QGLFormat& format, QWidget* parent = NULL, const QGLWidget* shareWidget = NULL, Qt::WindowFlags f = 0, bool forwardKeyEvents = false );
|
||||||
|
virtual ~GLWidget();
|
||||||
|
|
||||||
|
inline void setGraphicsWindow( GraphicsWindowQt* gw ) { _gw = gw; }
|
||||||
|
inline GraphicsWindowQt* getGraphicsWindow() { return _gw; }
|
||||||
|
inline const GraphicsWindowQt* getGraphicsWindow() const { return _gw; }
|
||||||
|
|
||||||
|
inline bool getForwardKeyEvents() const { return _forwardKeyEvents; }
|
||||||
|
virtual void setForwardKeyEvents( bool f ) { _forwardKeyEvents = f; }
|
||||||
|
|
||||||
|
inline bool getTouchEventsEnabled() const { return _touchEventsEnabled; }
|
||||||
|
void setTouchEventsEnabled( bool e );
|
||||||
|
|
||||||
|
void setKeyboardModifiers( QInputEvent* event );
|
||||||
|
|
||||||
|
virtual void keyPressEvent( QKeyEvent* event );
|
||||||
|
virtual void keyReleaseEvent( QKeyEvent* event );
|
||||||
|
virtual void mousePressEvent( QMouseEvent* event );
|
||||||
|
virtual void mouseReleaseEvent( QMouseEvent* event );
|
||||||
|
virtual void mouseDoubleClickEvent( QMouseEvent* event );
|
||||||
|
virtual void mouseMoveEvent( QMouseEvent* event );
|
||||||
|
virtual void wheelEvent( QWheelEvent* event );
|
||||||
|
virtual bool gestureEvent( QGestureEvent* event );
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
int getNumDeferredEvents()
|
||||||
|
{
|
||||||
|
QMutexLocker lock(&_deferredEventQueueMutex);
|
||||||
|
return _deferredEventQueue.count();
|
||||||
|
}
|
||||||
|
void enqueueDeferredEvent(QEvent::Type eventType, QEvent::Type removeEventType = QEvent::None)
|
||||||
|
{
|
||||||
|
QMutexLocker lock(&_deferredEventQueueMutex);
|
||||||
|
|
||||||
|
if (removeEventType != QEvent::None)
|
||||||
|
{
|
||||||
|
if (_deferredEventQueue.removeOne(removeEventType))
|
||||||
|
_eventCompressor.remove(eventType);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (_eventCompressor.find(eventType) == _eventCompressor.end())
|
||||||
|
{
|
||||||
|
_deferredEventQueue.enqueue(eventType);
|
||||||
|
_eventCompressor.insert(eventType);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
void processDeferredEvents();
|
||||||
|
|
||||||
|
friend class GraphicsWindowQt;
|
||||||
|
GraphicsWindowQt* _gw;
|
||||||
|
|
||||||
|
QMutex _deferredEventQueueMutex;
|
||||||
|
QQueue<QEvent::Type> _deferredEventQueue;
|
||||||
|
QSet<QEvent::Type> _eventCompressor;
|
||||||
|
|
||||||
|
bool _touchEventsEnabled;
|
||||||
|
|
||||||
|
bool _forwardKeyEvents;
|
||||||
|
qreal _devicePixelRatio;
|
||||||
|
|
||||||
|
virtual void resizeEvent( QResizeEvent* event );
|
||||||
|
virtual void moveEvent( QMoveEvent* event );
|
||||||
|
virtual void glDraw();
|
||||||
|
virtual bool event( QEvent* event );
|
||||||
|
};
|
||||||
|
|
||||||
|
class GraphicsWindowQt : public osgViewer::GraphicsWindow
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
GraphicsWindowQt( osg::GraphicsContext::Traits* traits, QWidget* parent = NULL, const QGLWidget* shareWidget = NULL, Qt::WindowFlags f = 0 );
|
||||||
|
GraphicsWindowQt( GLWidget* widget );
|
||||||
|
virtual ~GraphicsWindowQt();
|
||||||
|
|
||||||
|
inline GLWidget* getGLWidget() { return _widget; }
|
||||||
|
inline const GLWidget* getGLWidget() const { return _widget; }
|
||||||
|
|
||||||
|
/// deprecated
|
||||||
|
inline GLWidget* getGraphWidget() { return _widget; }
|
||||||
|
/// deprecated
|
||||||
|
inline const GLWidget* getGraphWidget() const { return _widget; }
|
||||||
|
|
||||||
|
struct WindowData : public osg::Referenced
|
||||||
|
{
|
||||||
|
WindowData( GLWidget* widget = NULL, QWidget* parent = NULL ): _widget(widget), _parent(parent) {}
|
||||||
|
GLWidget* _widget;
|
||||||
|
QWidget* _parent;
|
||||||
|
};
|
||||||
|
|
||||||
|
bool init( QWidget* parent, const QGLWidget* shareWidget, Qt::WindowFlags f );
|
||||||
|
|
||||||
|
static QGLFormat traits2qglFormat( const osg::GraphicsContext::Traits* traits );
|
||||||
|
static void qglFormat2traits( const QGLFormat& format, osg::GraphicsContext::Traits* traits );
|
||||||
|
static osg::GraphicsContext::Traits* createTraits( const QGLWidget* widget );
|
||||||
|
|
||||||
|
virtual bool setWindowRectangleImplementation( int x, int y, int width, int height );
|
||||||
|
virtual void getWindowRectangle( int& x, int& y, int& width, int& height );
|
||||||
|
virtual bool setWindowDecorationImplementation( bool windowDecoration );
|
||||||
|
virtual bool getWindowDecoration() const;
|
||||||
|
virtual void grabFocus();
|
||||||
|
virtual void grabFocusIfPointerInWindow();
|
||||||
|
virtual void raiseWindow();
|
||||||
|
virtual void setWindowName( const std::string& name );
|
||||||
|
virtual std::string getWindowName();
|
||||||
|
virtual void useCursor( bool cursorOn );
|
||||||
|
virtual void setCursor( MouseCursor cursor );
|
||||||
|
inline bool getTouchEventsEnabled() const { return _widget->getTouchEventsEnabled(); }
|
||||||
|
virtual void setTouchEventsEnabled( bool e ) { _widget->setTouchEventsEnabled(e); }
|
||||||
|
|
||||||
|
|
||||||
|
virtual bool valid() const;
|
||||||
|
virtual bool realizeImplementation();
|
||||||
|
virtual bool isRealizedImplementation() const;
|
||||||
|
virtual void closeImplementation();
|
||||||
|
virtual bool makeCurrentImplementation();
|
||||||
|
virtual bool releaseContextImplementation();
|
||||||
|
virtual void swapBuffersImplementation();
|
||||||
|
virtual void runOperations();
|
||||||
|
|
||||||
|
virtual void requestWarpPointer( float x, float y );
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
friend class GLWidget;
|
||||||
|
GLWidget* _widget;
|
||||||
|
bool _ownsWidget;
|
||||||
|
QCursor _currentCursor;
|
||||||
|
bool _realized;
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
1063
extern/osgQt/GraphicsWindowQt.cpp
vendored
Normal file
1063
extern/osgQt/GraphicsWindowQt.cpp
vendored
Normal file
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue