mirror of
https://github.com/minetest/irrlicht.git
synced 2025-01-12 02:50:18 +01:00
Merging r6173 through r6176 from trunk to ogl-es branch
Also adding -DPNG_ARM_NEON_OPT=0 to other places in Makefile as we don't have arm optimization for neon currently in our png lib. git-svn-id: svn://svn.code.sf.net/p/irrlicht/code/branches/ogl-es@6177 dfc29bdd-3216-0410-991c-e03cc46cb475
This commit is contained in:
parent
124cc0be1e
commit
1e6fe54cf5
@ -9,6 +9,7 @@ Changes in ogl-es (not yet released - will be merged with trunk at some point)
|
|||||||
|
|
||||||
--------------------------
|
--------------------------
|
||||||
Changes in 1.9 (not yet released)
|
Changes in 1.9 (not yet released)
|
||||||
|
- Slightly changed close window handling on X11 (optimized and avoids problems on some shells). Thanks @TheBrokenRail for a patch (was part of patch #322).
|
||||||
- Add getActiveColor functions to IGUIStaticText and IGUIButton (get currently used color).
|
- Add getActiveColor functions to IGUIStaticText and IGUIButton (get currently used color).
|
||||||
- Add IGUIEnvironment::addToDeletionQueue to allow save removal of gui elements while iterating over them (like the same named function in ISceneManager).
|
- Add IGUIEnvironment::addToDeletionQueue to allow save removal of gui elements while iterating over them (like the same named function in ISceneManager).
|
||||||
- IGUIEnvironment::drawAll has now a parameter to allow disabling automatic resize to screensize. Makes it easier to use partial screens with full alignment support.
|
- IGUIEnvironment::drawAll has now a parameter to allow disabling automatic resize to screensize. Makes it easier to use partial screens with full alignment support.
|
||||||
|
@ -89,13 +89,12 @@ namespace
|
|||||||
Atom X_ATOM_NETWM_MAXIMIZE_VERT;
|
Atom X_ATOM_NETWM_MAXIMIZE_VERT;
|
||||||
Atom X_ATOM_NETWM_MAXIMIZE_HORZ;
|
Atom X_ATOM_NETWM_MAXIMIZE_HORZ;
|
||||||
Atom X_ATOM_NETWM_STATE;
|
Atom X_ATOM_NETWM_STATE;
|
||||||
|
|
||||||
|
Atom X_ATOM_WM_DELETE_WINDOW;
|
||||||
};
|
};
|
||||||
|
|
||||||
namespace irr
|
namespace irr
|
||||||
{
|
{
|
||||||
|
|
||||||
const char wmDeleteWindow[] = "WM_DELETE_WINDOW";
|
|
||||||
|
|
||||||
//! constructor
|
//! constructor
|
||||||
CIrrDeviceLinux::CIrrDeviceLinux(const SIrrlichtCreationParameters& param)
|
CIrrDeviceLinux::CIrrDeviceLinux(const SIrrlichtCreationParameters& param)
|
||||||
: CIrrDeviceStub(param),
|
: CIrrDeviceStub(param),
|
||||||
@ -489,9 +488,8 @@ bool CIrrDeviceLinux::createWindow()
|
|||||||
|
|
||||||
XMapRaised(XDisplay, XWindow);
|
XMapRaised(XDisplay, XWindow);
|
||||||
CreationParams.WindowId = (void*)XWindow;
|
CreationParams.WindowId = (void*)XWindow;
|
||||||
Atom wmDelete;
|
X_ATOM_WM_DELETE_WINDOW = XInternAtom(XDisplay, "WM_DELETE_WINDOW", True);
|
||||||
wmDelete = XInternAtom(XDisplay, wmDeleteWindow, True);
|
XSetWMProtocols(XDisplay, XWindow, &X_ATOM_WM_DELETE_WINDOW, 1);
|
||||||
XSetWMProtocols(XDisplay, XWindow, &wmDelete, 1);
|
|
||||||
if (CreationParams.Fullscreen)
|
if (CreationParams.Fullscreen)
|
||||||
{
|
{
|
||||||
XSetInputFocus(XDisplay, XWindow, RevertToParent, CurrentTime);
|
XSetInputFocus(XDisplay, XWindow, RevertToParent, CurrentTime);
|
||||||
@ -1046,8 +1044,7 @@ bool CIrrDeviceLinux::run()
|
|||||||
|
|
||||||
case ClientMessage:
|
case ClientMessage:
|
||||||
{
|
{
|
||||||
char *atom = XGetAtomName(XDisplay, event.xclient.message_type);
|
if (static_cast<Atom>(event.xclient.data.l[0]) == X_ATOM_WM_DELETE_WINDOW && X_ATOM_WM_DELETE_WINDOW != None)
|
||||||
if (*atom == *wmDeleteWindow)
|
|
||||||
{
|
{
|
||||||
os::Printer::log("Quit message received.", ELL_INFORMATION);
|
os::Printer::log("Quit message received.", ELL_INFORMATION);
|
||||||
Close = true;
|
Close = true;
|
||||||
@ -1060,7 +1057,6 @@ bool CIrrDeviceLinux::run()
|
|||||||
irrevent.UserEvent.UserData2 = static_cast<size_t>(event.xclient.data.l[1]);
|
irrevent.UserEvent.UserData2 = static_cast<size_t>(event.xclient.data.l[1]);
|
||||||
postEventFromUser(irrevent);
|
postEventFromUser(irrevent);
|
||||||
}
|
}
|
||||||
XFree(atom);
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
@ -94,15 +94,15 @@ endif
|
|||||||
ifdef EMSCRIPTEN
|
ifdef EMSCRIPTEN
|
||||||
CXXFLAGS += -std=gnu++11 -U__STRICT_ANSI__
|
CXXFLAGS += -std=gnu++11 -U__STRICT_ANSI__
|
||||||
ifndef NDEBUG
|
ifndef NDEBUG
|
||||||
CFLAGS := -DPNG_THREAD_UNSAFE_OK -DPNG_NO_MMX_CODE -DPNG_NO_MNG_FEATURES
|
CFLAGS := -DPNG_THREAD_UNSAFE_OK -DPNG_NO_MMX_CODE -DPNG_NO_MNG_FEATURES -DPNG_ARM_NEON_OPT=0
|
||||||
else
|
else
|
||||||
CFLAGS := -O3 -DPNG_THREAD_UNSAFE_OK -DPNG_NO_MMX_CODE -DPNG_NO_MNG_FEATURES
|
CFLAGS := -O3 -DPNG_THREAD_UNSAFE_OK -DPNG_NO_MMX_CODE -DPNG_NO_MNG_FEATURES -DPNG_ARM_NEON_OPT=0
|
||||||
endif
|
endif
|
||||||
ifdef WASM
|
ifdef WASM
|
||||||
CXXFLAGS += -s WASM=1
|
CXXFLAGS += -s WASM=1
|
||||||
endif
|
endif
|
||||||
else
|
else
|
||||||
CFLAGS := -O3 -fexpensive-optimizations -DPNG_THREAD_UNSAFE_OK -DPNG_NO_MMX_CODE -DPNG_NO_MNG_FEATURES
|
CFLAGS := -O3 -fexpensive-optimizations -DPNG_THREAD_UNSAFE_OK -DPNG_NO_MMX_CODE -DPNG_NO_MNG_FEATURES -DPNG_ARM_NEON_OPT=0
|
||||||
endif
|
endif
|
||||||
|
|
||||||
sharedlib sharedlib_osx: CXXFLAGS += -fPIC
|
sharedlib sharedlib_osx: CXXFLAGS += -fPIC
|
||||||
|
Loading…
Reference in New Issue
Block a user