Upgrading problem

If you found a bug in our library or on our website, please report it in this section. In this forum you can also make concrete suggestions or feature requests.

Moderators: CEGUI MVP, CEGUI Team

Progger
Just popping in
Just popping in
Posts: 8
Joined: Tue Aug 19, 2008 16:50

Upgrading problem

Postby Progger » Wed Dec 10, 2008 19:20

Hi,
I've upgraded to OGRE (Shoggoth) and CEGUI (v. 0.6.2) recently and got some probems that I cannot solve.
Always when I click on a menu item the application crashes on the method CEGUI::System::.injectMouseButtonUp(...);.
I've tried a lot of things but nothing helps. Are there any big changes in CEGUI done that cause such a behaviour?
Thanks.

User avatar
CrazyEddie
CEGUI Project Lead
Posts: 6760
Joined: Wed Jan 12, 2005 12:06
Location: England
Contact:

Postby CrazyEddie » Wed Dec 10, 2008 20:31

Hi,

Which version of CEGUI did you upgrade from?

Which OS / Platform?

Which compiler are you using? Are you using pre-built binaries?

Is there a handler subscribed to the menu items? Is this C++ or lua or something else?

When you say it crashes, what is the error exactly? Are there any errors - especially at the end - in CEGUI.log? Can you surround your CEGUI code in a try/catch construct and catch any CEGUI::Exceptions and output the error?

If it's not a CEGUI::Exception, but maybe a segfault / access violation, can we see a backtrace / callstack and any other relevant debugging information?

CE.

Progger
Just popping in
Just popping in
Posts: 8
Joined: Tue Aug 19, 2008 16:50

Postby Progger » Fri Dec 12, 2008 17:55

Hi, thank you for the reply ;)

I'm using CEGUI under windows, msvc and I have upgraded from version 0.6.1 (pre-build binaries). The menu is created via CEGUI editor.

Unfortunately, try/catch construct throws no exceptions at all. And the logfile too doesn't point to any errors.

Here the method that invokes the error-prone function:

Code: Select all

bool CFrameListener::mouseReleased(const OIS::MouseEvent &Mouse, OIS::MouseButtonID mID)
{
   if(CEGUI::MouseCursor::getSingletonPtr()->isVisible())
   {
      CEGUI::System::getSingleton().injectMouseButtonUp(ConvertButton(mID));
   }


   return true;
}

ConvertButton just converts the OIS mouse buttons to CEGUI Mouse buttons.

If I run the application in debugger, this error emerges (I translated it from German):
unhandled exception at 0x0237b4a6 in XXX.exe: 0xC0000005: access violation reading at position 0x000005fc.


The strange thing about this issue is that I can run the application succesfully with the older 0.6.1 CEGUIBase.dll althought I built the app with the new 0.6.2 CEGUIBase.lib

User avatar
CrazyEddie
CEGUI Project Lead
Posts: 6760
Joined: Wed Jan 12, 2005 12:06
Location: England
Contact:

Postby CrazyEddie » Fri Dec 12, 2008 19:40

Thanks for the extra info, I don't have any insight right at the moment, so I'll try to run some tests tomorrow and see if anything comes up.

Although it seems you should not be affected, did you upgrade to the reissued 0.6.2b and try that?

Also, no chance of seeing a callstack from the point it dies, then? :)

CE.

User avatar
CrazyEddie
CEGUI Project Lead
Posts: 6760
Joined: Wed Jan 12, 2005 12:06
Location: England
Contact:

Postby CrazyEddie » Mon Dec 15, 2008 13:56

I got around to testing this a little today, but was unable to reproduce any issue. Here's what I did:

Download Ogre source & dependencies
Build Ogre.
Download CEGUI SDK
Overwrite CEGUI headers, libs and DLLs in the Ogre tree with those from the CEGUI SDK.
Rebuild Ogre renderer module (and the samples that use it - for testing purposes)

All was ok. I'm also able to interchange 0.6.1 and 0.6.2 DLLs successfully without any issues (not including the lua module, that does require a rebuild of the client app).

CE.

Progger
Just popping in
Just popping in
Posts: 8
Joined: Tue Aug 19, 2008 16:50

Postby Progger » Mon Dec 15, 2008 18:46

Hi, thanks for your help
I appreciate it ;)

Unfortunately it could not solve my problem with the menu construct :(
I've dealt now some more time with the issue and found something that could help. For some time past I went throught this tutorial and found out that my application crashes in the debug configuration. Now, with the new 0.6.2 CEGUI release it crashes even in debug configuration when I click on one of the menu items.

Quote from the tutorial:
The demo subscribes to the MenuItem::EventMouseEnters event for two features. The first is to display a message when the mouse hovers over a menuitem. The text displayed is stored within the Tooltip property within the Layout Editor. The second is to automatically open a submenu. This code is within the onMouseEntersMenuItem() function.

The code to automatically close a menu (when the mouse leaves) is within the onMouseLeavesMenuItem() and onMouseLeavesPopupMenuItem() functions, called in response to a MenuItem::EventMouseLeaves event.

As mentioned, the code shown in the tutorial lets the menubar open its menu item entries automatically.
Without these both event functions (from the tutorial): - onMouseEntersMenuItem and onMouseLeavesMenuItem - the aplication runs well.

Conclusion: it has something to do with the both functions ::openPopupMenu and ::closePopupMenu that were changed in the newest release in some way and that manipulate this method CEGUI::System::getSingleton().injectMouseButtonUp to make the application crash.
I think the best bet would be to dispense with the automatically opened-menu-items although, this functionality is very comfortable :wink:

cu

User avatar
CrazyEddie
CEGUI Project Lead
Posts: 6760
Joined: Wed Jan 12, 2005 12:06
Location: England
Contact:

Postby CrazyEddie » Mon Dec 15, 2008 20:10

Hi,

Thanks for the new info, this is actually really helpful as it gives me more of an idea as to what you're trying to do, amongst other things.

With regards to changes to the menu components between 0.6.1 and 0.6.2, there were none.

I suggest the issue is most likely that you have some uninitialised data somewhere in your code. When using the new CEGUI DLLs the overall memory layout has probably changed slightly within the app, so what was once a lucky 'safe' value, is now no longer safe and so you're seeing the crash.

You mentioned previous issues in debug mode (presumably this is why you couldn't generate any decent debugging information for us to look at?), which reinforces the above suggestion; differences in debug / release configurations are usually highly indicative of issues relating to uninitialised data (because VC++ does different things under debug than it does under release - the idea being to force a crash in debug mode so you can fix it, not so you can ignore it and use release mode instead!).

I'm not sure if this comes across as being a harsh response. That's not the intention, the intention is to help you find the cause of the issue ;)

CE.

mijikenda
Just popping in
Just popping in
Posts: 2
Joined: Mon Mar 02, 2009 17:16

Postby mijikenda » Mon Mar 02, 2009 17:50

Hello,

I can approve the problem that Progger described. I get exactly the same error when using some of the code from the MenuAndPopup tutorial.

When clicking on a MenuItem, it seems that the OnMouseLeavesMenuItem() event is processed first (which closes the popup menu) and returns fine. After that a segfault occures. My OnMenuItemClicked() call-back method is never called.

I have a backtrace here, using gdb on linux.

Code: Select all

Program terminated with signal 11, Segmentation fault.
#0  0xb7876dd3 in CEGUI::MenuBase::changePopupMenuItem () from /usr/lib/libCEGUIBase.so.1
(gdb) bt
#0  0xb7876dd3 in CEGUI::MenuBase::changePopupMenuItem () from /usr/lib/libCEGUIBase.so.1
#1  0xb787838e in CEGUI::MenuItem::closePopupMenu () from /usr/lib/libCEGUIBase.so.1
#2  0xb78785d8 in CEGUI::MenuItem::closeAllMenuItemPopups () from /usr/lib/libCEGUIBase.so.1
#3  0xb78786dc in CEGUI::MenuItem::onClicked () from /usr/lib/libCEGUIBase.so.1
#4  0xb7877fab in CEGUI::MenuItem::onMouseButtonUp () from /usr/lib/libCEGUIBase.so.1
#5  0xb77fabb9 in CEGUI::System::injectMouseButtonUp () from /usr/lib/libCEGUIBase.so.1
#6  0x0805bb0d in AO::Application::mouseReleased (this=0xbfc5a150, mEvt=@0xbfc59f9c,
    butId=OIS::MB_Left) at [...]/src/Application.cpp:553
#7  0xb7f171a4 in OIS::LinuxMouse::_processXEvents () from /usr/lib/libOIS-1.2.0.so
#8  0xb7f17423 in OIS::LinuxMouse::capture () from /usr/lib/libOIS-1.2.0.so
#9  0x0805c376 in AO::Application::frameStarted (this=0xbfc5a150, fEvt=@0xbfc5a0a4)
    at [...]/src/Application.cpp:351
#10 0xb7cbe164 in Ogre::Root::_fireFrameStarted () from /usr/lib/libOgreMain-1.6.1.so
#11 0xb7cbe927 in Ogre::Root::_fireFrameStarted () from /usr/lib/libOgreMain-1.6.1.so
#12 0xb7cbe962 in Ogre::Root::renderOneFrame () from /usr/lib/libOgreMain-1.6.1.so
#13 0xb7cbe9e1 in Ogre::Root::startRendering () from /usr/lib/libOgreMain-1.6.1.so
#14 0x0805c46c in AO::Application::_StartMainLoop (this=0xbfc5a150)
    at [...]/src/Application.cpp:344
#15 0x0805f2e5 in AO::Application::Start (this=0xbfc5a150)
    at [...]/src/Application.cpp:89
#16 0x0805b5a9 in main () at [...]/src/main.cpp:34


So I experimented a little with my code and found out, that if I change

Code: Select all

popupMenu->closePopupMenu();

to

Code: Select all

popupMenu->closePopupMenu(false);

in OnMouseLeavesMenuItem(), the segfault does not occure. However, the popup menu won't open the next time I hover the mouse over it or click it. I first have to open another popup menu from the menu bar first. To my understanding, this seems valid behavior, because the parent is not notified about it. But this is not a fine solution to the problem...

I didn't take a look into the CEGUI code, but maybe the internal mouse clicked event handling doesn't check if the menu was already closed?!

Greetings,
mijikenda

User avatar
CrazyEddie
CEGUI Project Lead
Posts: 6760
Joined: Wed Jan 12, 2005 12:06
Location: England
Contact:

Postby CrazyEddie » Mon Mar 02, 2009 19:06

Hi, and welcome :)

Thanks very much for posting your experience with this issue, and - most importantly for me - the backtrace; this is the essential piece of missing data from the earlier report :)

I'll add a ticket in order that this can now get looked into more thoroughly and fixed.

CE.

mijikenda
Just popping in
Just popping in
Posts: 2
Joined: Mon Mar 02, 2009 17:16

Postby mijikenda » Wed Mar 04, 2009 19:16

I just compiled CEGUI from scratch to get the line numbers in the backtrace:

Code: Select all

Program terminated with signal 11, Segmentation fault.
#0  CEGUI::MenuBase::changePopupMenuItem (this=0x86a66b0, item=0x0)
    at elements/CEGUIMenuBase.cpp:86
86                      WindowEventArgs we(d_popupItem->getPopupMenu());


Unfortunately, I won't have the time to dig into other people's code deeply in the next weeks. So it's up to you (or someone else) to fix it... :-)

User avatar
CrazyEddie
CEGUI Project Lead
Posts: 6760
Joined: Wed Jan 12, 2005 12:06
Location: England
Contact:

Postby CrazyEddie » Thu Mar 05, 2009 09:34

Thanks again for the extra info.

mijikenda wrote:So it's up to you (or someone else) to fix it... :-)

No problemo, it should get done this coming weekend.

CE.


Return to “Bug Reports, Suggestions, Feature Requests”

Who is online

Users browsing this forum: No registered users and 6 guests