bugs in showMessageBox

Questions about the LÖVE API, installing LÖVE and other support related questions go here.
Forum rules
Before you make a thread asking for help, read this.
akt
Prole
Posts: 5
Joined: Wed Feb 01, 2017 9:30 pm

bugs in showMessageBox

Post by akt »

Hi all. New to LOVE, so hopefully this is the right place to post bug reports. The game I'm working on needs to ask the user if they want to save an unfinished game, so I'm using the following code to create a "save changes" dialog:

Code: Select all

    local title = "Save the current game?"
    local buttons = {"Save", "Cancel", "Don't Save", enterbutton = 1, escapebutton = 2}
    local b = love.window.showMessageBox(title, "", buttons, "info", true)
But I ran into two bugs (I'm using 0.10.2):

1. This bug seems to be Mac-specific (tested on Mac OS 10.12.3). If the user hits the return or escape key to close the dialog then that key event is seen by my love.keypressed callback. Fortunately this bug is easy to avoid by calling love.event.clear() immediately after the showMessageBox call.

2. This bug seems to be Windows-specific (tested on Windows 7, 64-bit). If the user hits the escape key then the button value returned is 3 (should be 2). If they hit the enter key then the button value returned is 2 (should be 1). This is a much more serious bug because I don't see any way to work around it (other than avoid a 3-button dialog).
User avatar
Jasoco
Inner party member
Posts: 3727
Joined: Mon Jun 22, 2009 9:35 am
Location: Pennsylvania, USA
Contact:

Re: bugs in showMessageBox

Post by Jasoco »

I've encountered the Mac bug myself. For some reason Löve processes the keypressed callback when dismissing the message box. It really should ignore it as it can cause unintended things if your game happens to also use escape to do something. Never thought about clearing the events to avoid it. But it could probably easily be fixed by the devs now that it's been mentioned.
User avatar
zorg
Party member
Posts: 3470
Joined: Thu Dec 13, 2012 2:55 pm
Location: Absurdistan, Hungary
Contact:

Re: bugs in showMessageBox

Post by zorg »

akt wrote: Sun Feb 19, 2017 12:59 am 2. This bug seems to be Windows-specific (tested on Windows 7, 64-bit). If the user hits the escape key then the button value returned is 3 (should be 2). If they hit the enter key then the button value returned is 2 (should be 1).
For my Ira Glass Quote project that i posted on the forums a while ago, i did encounter a bug with the escape key, though i haven't tested whether it does return a value or not (i just assumed it didn't) since the enter key supposedly returned the correct 1 for me, instead of 2 like you claim... I gotta go and test this; will report back with this asap (also, you should open an issue on the issue tracker, see the pink button at the top of the forums)

Edit: Yep, Win7 x64, No matter what i set enterbutton and escapebutton to, it's always 2 and 3.
Me and my stuff :3True Neutral Aspirant. Why, yes, i do indeed enjoy sarcastically correcting others when they make the most blatant of spelling mistakes. No bullying or trolling the innocent tho.
User avatar
slime
Solid Snayke
Posts: 3170
Joined: Mon Aug 23, 2010 6:45 am
Location: Nova Scotia, Canada
Contact:

Re: bugs in showMessageBox

Post by slime »

These are bugs inside SDL, so unfortunately there's nothing that can be done inside love's own source code to fix them - but you can and should post a bug report on the SDL bugzilla.
akt
Prole
Posts: 5
Joined: Wed Feb 01, 2017 9:30 pm

Re: bugs in showMessageBox

Post by akt »

slime wrote: Sun Feb 19, 2017 8:44 pm... you can and should post a bug report on the SDL bugzilla.
I'm happy to do that (although I suspect it would carry more weight coming from one of the love devs).

Actually, the Win-specific bug has already been reported here. The report also includes a patch to fix the bug so maybe that fix could be merged into the next love release?
User avatar
darkmetalic
Prole
Posts: 17
Joined: Tue Feb 07, 2017 4:09 pm
Contact:

Re: bugs in showMessageBox

Post by darkmetalic »

We will follow the logic, you have 2 keyboard options (enter and escape), the third would be "none", but if it is nothing then it is "cancel" and should return zero (nil would be more beautiful), but does not return that because don't have an object to close the window. You have to press somehow. Imagine that you are in a touch screen device where there is no mouse and real keyboards, so it is not necessary to have a focus on a specific button for when tight it works. If you move to the side it will make a selection that only exists on specific systems and if you press enter will activate the selected one and not what you set in the table. I would solve this problem by removing the "Cancel", because "Don't save" would already be the same option (and no have bugs with two options). I've determined that if I pressed [enter] it would be the "Save", but I can move to the side in the message box and when pressing the [enter] I want the selected focus and not "save" option. While pressing [escape] (with more than 2 options), you do not cancel. So this is a framework problem that uses true keyboard.
akt
Prole
Posts: 5
Joined: Wed Feb 01, 2017 9:30 pm

Re: bugs in showMessageBox

Post by akt »

Sorry, but I didn't really understand most of your post. This bit is wrong though:
darkmetalic wrote: Tue Feb 21, 2017 10:14 pm I would solve this problem by removing the "Cancel", because "Don't save" would already be the same option...
The game I'm writing is a fairly simple board game. If the user is in the middle of a game and decides to quit the app then I show the above "save changes" dialog. The Cancel button means cancel the decision to quit. The Don't Save button means go ahead and quit. The Save button brings up the standard save file dialog so they can save the unfinished game before quitting (at least it will when I figure out how to do that -- I'm somewhat surprised to find that love doesn't have any support for native save/open file dialogs!). These buttons are familiar to Mac users. On Windows I'll probably change the button order in the dialog to Yes/No/Cancel -- that's what I see in most Win apps (eg. Notepad++).
User avatar
Positive07
Party member
Posts: 1014
Joined: Sun Aug 12, 2012 4:34 pm
Location: Argentina

Re: bugs in showMessageBox

Post by Positive07 »

Do you wanna save before quitting?
Yes / No / Cancel

Sounds good to me... Also there is lua-nativefiledialog which I have compiled and used fine with LÖVE.

Check this post for info on save dialogs
for i, person in ipairs(everybody) do
[tab]if not person.obey then person:setObey(true) end
end
love.system.openURL(github.com/pablomayobre)
CherryBit
Prole
Posts: 2
Joined: Sun Dec 18, 2016 12:48 pm

Re: bugs in showMessageBox

Post by CherryBit »

Positive07 wrote: Wed Feb 22, 2017 1:45 pm Do you wanna save before quitting?
Yes / No / Cancel

[...]
Just to be pedantic: using "Yes"/"No" choices for dialogs is poor UX design and requires the user to read and think more. Using actions ("Save", "Don't Save") as the button labels is much clearer and allows the user to make choices with less reading. It may seem minor but users are easily frustrated, especially when you're forcing them to make a choice.
User avatar
Positive07
Party member
Posts: 1014
Joined: Sun Aug 12, 2012 4:34 pm
Location: Argentina

Re: bugs in showMessageBox

Post by Positive07 »

It is not for native Windows. Since we don't have the new dialogs.
for i, person in ipairs(everybody) do
[tab]if not person.obey then person:setObey(true) end
end
love.system.openURL(github.com/pablomayobre)
Post Reply

Who is online

Users browsing this forum: No registered users and 2 guests