3.6.1: Difference between revisions

From vice-emu
Jump to navigation Jump to search
mNo edit summary
mNo edit summary
 
(18 intermediate revisions by 3 users not shown)
Line 1: Line 1:
We have some regressions and annoying bugs in 3.6 that should be fixed ASAP in a 3.6.1 service release:
We have some regressions and annoying bugs in 3.6 that should be fixed ASAP in a 3.6.1 service release:


* <s>the sound disables itself on buffer underrun. it should not do this - a short hickup is much less annoying. instead it should display a message in the statusbar and leave sound enabled.</s> (fixed in trunk)
* for making a release, the copyright date must be changed manually in a bunch of files, this should be automatic/scripted: README, index.html, vice.texi, src/sounddrv/soundflac.c, src/arch/gtk3/uiabout.c
** <s>old behaviour restored in trunk, sound keeps playing - however, now we get underrun warnings at shutdown, we should guard this with a "are we shutting down" flag</s> (fixed in trunk)


* Saving/restoring window positions with multi-display setups is reportedly broken.
:: The code in trunk has been altered to allow negative coordinates, using `INT_MIN` as the flag to NOT restore window position, this requires testing on various OSes and window managers.
:: After testing with two displays set to provide a single desktop (3840x1080 pixels), it appears the code works fine on Debian with Wayland and also works on a Windows 7 VM running on that machine. I (compyx) expected Win7 to use negative coordinates for the secondary (left) display, but coordinates for that display start at 0,0 and the second display starts at 1920,0. So this requires further testing by someone with a bare metal Windows installation.


* the popups on the statusbar should open also on right-click, not just left-click


* <s>the sound disables itself on buffer underrun. it should not do this - a short hickup is much less annoying. instead it should display a message in the statusbar and leave sound enabled.</s> (<b>fixed in trunk</b>)
** <s>old behaviour restored in trunk, sound keeps playing - however, now we get underrun warnings at shutdown, we should guard this with a "are we shutting down" flag</s> (<b>fixed in trunk</b>)


* The "Maximum Speed" submenu should be added to the regular main menu (where the pause/warp stuff is)
* <s>Related to the above (Gtk3): when a sound output driver fails, sound is disabled and the output driver selection greyed out. This means one cannot re-enable sound by selecting another driver. So the driver selection should never be greyed out.</s> (<b>fixed in trunk</b>)


* <s>the popups on the statusbar should open also on right-click, not just left-click</s> (<b>fixed in trunk</b>)


* for making a release, the copyright date must be changed manually in a bunch of files, this should be automatic/scripted: README, index.html, vice.texi,
* <s>Status bar drive widgets show "Attach to #8:0" and "Directory of unit 8 drive 0" for single-drive devices, the references to drive 0 should be omitted.</s> (<b>fixed in trunk</b>)
  src/sounddrv/soundflac.c, src/arch/gtk3/uiabout.c


* <s>The "Maximum Speed" submenu should be added to the regular main menu (where the pause/warp stuff is)</s> (<b>fixed in trunk</b>)


* In the Hotkey editor there are weird things going on with ALT-GR (tested on linux)
* <s>The "Control Port" dialog does not immediately update itself when an option was changed. eg change port 1 to "inception" adapter - it should show 8 extra joystick ports without having to go to another tab and back</s> (<b>fixed in trunk</b>)
 
* <s>In the Hotkey editor there are weird things going on with ALT-GR (tested on linux)
** ALT-GR produces a MOD5 modifier (so that probably should not be filtered)
** ALT-GR produces a MOD5 modifier (so that probably should not be filtered)
** ALT-GR produces a GDK_KEY_ISO_Level3_Shift (0xfe03) event, but ONLY on release (wth). This however makes it impossible to actually define a hotkey with ALT-GR
** ALT-GR produces a GDK_KEY_ISO_Level3_Shift (0xfe03) event, but ONLY on release (wth). This however makes it impossible to actually define a hotkey with ALT-GR
::(gpz) i played around with this and came to the conclusion that it is not useful to try to support Alt-Gr for hotkeys. The keyboard handler already does some stunts to support it for mapping regular keys, and that is also what the expected use for this key is.
* On Windows it behaves differently, but does not need further fixing
* On Windows it behaves differently, but does not need further fixing
** ALT-GR+key produces CTRL+ALT+MOD2+key
** ALT-GR+key produces CTRL+ALT+MOD2+key
** strange enough, CTRL+ALT+key also produces CTRL+ALT+MOD2+key
** strange enough, CTRL+ALT+key also produces CTRL+ALT+MOD2+key
*** so in windows we can filter MOD2 and ignore the existance of ALT-GR
*** so in windows we can filter MOD2 and ignore the existance of ALT-GR</s> (<b>fixed in trunk</b>, we simply ignore MOD2 and Alt-Gr, too much trouble with Alt-Gr)


* <s>on macOS the emulator seems to not work when the binary (or the data folder?) is in a directory with space in it</s> (<b>fixed in trunk</b>)


* <s>on macOS the emulator seems to not work when the binary (or the data folder?) is in a directory with space in it</s> (fixed in trunk)
* <s>Monitor window and position can not be saved/restored</s> (<b>fixed in trunk</b>)
 
* <s>Monitor window and position can not be saved/restored</s> (fixed in trunk)
 
* Saving/restoring window positions with multi-display setups is reportedly broken.
:: The code in trunk has been altered to allow negative coordinates, using `INT_MIN` as the flag to NOT restore window position, this requires testing on various OSes and window managers.
:: After testing with two displays set to provide a single desktop (3840x1080 pixels), it appears the code works fine on Debian with Wayland and also works on a Windows 7 VM running on that machine. I (compyx) expected Win7 to use negative coordinates for the secondary (left) display, but coordinates for that display start at 0,0 and the second display starts at 1920,0. So this requires further testing by someone with a bare metal Windows installation.
 
 
* <s>the hotkeys are at least partially broken in the SDL port. they must be tested and fixed</s> (fixed in trunk)
**ideally the hotkey definitions are rewritten to work on named actions instead of menu pathes


* <s>the hotkeys are at least partially broken in the SDL port. they must be tested and fixed</s> (<b>fixed in trunk</b>)
:: ideally the hotkey definitions are rewritten to work on named actions instead of menu paths


<s>
* the tarball has a top dir named vice-3.6.0 - this screws up packaging, it shouldnt have this
* the tarball has a top dir named vice-3.6.0 - this screws up packaging, it shouldnt have this
** to rephrase: the top dir should match the package name exactly, so vice-3.6 for 3.6 and vice-3.6.1 for 3.6.1
:: to rephrase: the top dir should match the package name exactly, so vice-3.6 for 3.6 and vice-3.6.1 for 3.6.1</s> (<b>fixed in trunk</b>)
 


* <s>Joystick/Gamecontroller input is broken on macOS. The generic code (default mapping) now ignores extra axes on macOS like it does on windows, however its still broken.</s>
* <s>Joystick/Gamecontroller input is broken on macOS. The generic code (default mapping) now ignores extra axes on macOS like it does on windows, however its still broken.</s> (<b>fixed in trunk</b>)


* Some clickable widgets on the status bar don't change the mouse pointer to inform the user they can be clicked (mouse pointer doesn't change).
* <s>Some clickable widgets on the status bar don't change the mouse pointer to inform the user they can be clicked (mouse pointer doesn't change).</s> (<b>fixed in trunk</b>)
** Warp and Pause leds don't change the pointer at all. (fixed in trunk)
** <s>Warp and Pause leds don't change the pointer at all.</s> (fixed in trunk)
** Tape (motor) status indicator doesn't change the pointer, the "Tape:" and counter labels do.
** <s>Tape (motor) status indicator doesn't change the pointer, the "Tape:" and counter labels do.</s> (<b>fixed in trunk</b>)
** Individual joystick status widgets don't change the pointer, the "Joysticks:" label does.
** <s>Individual joystick status widgets don't change the pointer, the "Joysticks:" label does.</s> (<b>fixed in trunk</b>)
** Drive leds don't change the pointer, the unit[:drive] and [head:]track.sector labels do.
** <s>Drive leds don't change the pointer, the unit[:drive] and [head:]track.sector labels do.</s> (<b>fixed in trunk</b>)


* hotkeys are broken on macOS.
<s>* hotkeys are broken on macOS.
** the hotkey editor needs to be fixed
** <s>the hotkey editor needs to be fixed
:: The hotkey editor now allows GDK_MOD2_MASK (maps to Command on MacOS) and GDK_META_MASK (no idea what OS uses that), so testing by MacOS users is required to see if the UI now accepts Command as a modifier. Of interest is also whether the UI properly shows "<Command>some-key" or "<Mod2>some-key".
:: The hotkey editor now allows GDK_MOD2_MASK (maps to Command on MacOS) and GDK_META_MASK (no idea what OS uses that), so testing by MacOS users is required to see if the UI now accepts Command as a modifier. Of interest is also whether the UI properly shows "<Command>some-key" or "<Mod2>some-key".</s> (<b>fixed in trunk</b>: modifiers allowed are Control, Command (Mac), Alt/Option and Shift)


** <s>the parser segfaults on '<Meta>', running past the end of the string to parse</s> (fixed in trunk)
** <s>the parser segfaults on '<Meta>', running past the end of the string to parse</s> (<b>fixed in trunk</b>)
** we should provide an alternative hotkey file that has the hotkeys defined for "command+key" instead of "option+key" (which equals alt+key)
** <s>we should provide an alternative hotkey file that has the hotkeys defined for "command+key" instead of "option+key" (which equals alt+key)</s> (<b>fixed in trunk</b>: on MacOS VICE parses the alternative "*-mac.vhk" files which use Command instead of Alt/Option)
** VICE-provided hotkeys are parsed even when using `--help`, so we'll probably need some `help_requested` flag to avoid this and perhaps other stuff that shouldn't run when using `--help`.
** <s>VICE-provided hotkeys are parsed even when using `--help`, so we'll probably need some `help_requested` flag to avoid this and perhaps other stuff that shouldn't run when using `--help`.</s> (<b>fixed in trunk</b>. Include <tt>machine.h</tt> to access the global <tt>int help_requested</tt> (boolean))
** check: https://wiki.gnome.org/Projects/GTK/OSX/Integration
** check: https://wiki.gnome.org/Projects/GTK/OSX/Integration


* <s>joystick default mappings are screwed up at least on windows</s> (should be fixed in trunk)
* <s>joystick default mappings are screwed up at least on windows</s> (should be fixed in trunk)
Line 65: Line 64:
*** check: https://sourceforge.net/p/vice-emu/bugs/1618/
*** check: https://sourceforge.net/p/vice-emu/bugs/1618/
*** check: https://sourceforge.net/p/vice-emu/bugs/1648/
*** check: https://sourceforge.net/p/vice-emu/bugs/1648/


* <s>some macOS specific documentation should be added that explains how to use the binaries from commandline</s> (Moved the relevant readme file into the bindist root)
* <s>some macOS specific documentation should be added that explains how to use the binaries from commandline</s> (Moved the relevant readme file into the bindist root)


 
<s>
* jazzcat reported a crash at startup in windows 10. r41385 apparently still works on his box - better talk to jazzcat directly (ircnet #c-64)
* jazzcat reported a crash at startup in windows 10. r41385 apparently still works on his box - better talk to jazzcat directly (ircnet #c-64)
** looks like it's an msys gtk3 3.24.31 problem. Unseen has the same issue. Builds using old deps on Strobe's machine work
** looks like it's an msys gtk3 3.24.31 problem. Unseen has the same issue. Builds using old deps on Strobe's machine work
*** simple keytest seems to reproduce it: http://hitmen.c02.at/temp/keytest.zip http://paste.debian.net/hidden/f4aa040a/
*** simple keytest seems to reproduce it: http://hitmen.c02.at/temp/keytest.zip http://paste.debian.net/hidden/f4aa040a/</s> (updated gtk works for unseen, and jazzcat also reported this fixed, so: <b>fixed in trunk</b>)
 


== links to threads containing 3.6 feedback ==
== links to threads containing 3.6 feedback ==
Line 81: Line 80:
* https://www.lemon64.com/forum/viewtopic.php?t=79034
* https://www.lemon64.com/forum/viewtopic.php?t=79034
* http://sleepingelephant.com/ipw-web/bulletin/bb/viewtopic.php?f=14&t=10299
* http://sleepingelephant.com/ipw-web/bulletin/bb/viewtopic.php?f=14&t=10299
[[Category:DONE]]

Latest revision as of 18:12, 23 March 2023

We have some regressions and annoying bugs in 3.6 that should be fixed ASAP in a 3.6.1 service release:

  • for making a release, the copyright date must be changed manually in a bunch of files, this should be automatic/scripted: README, index.html, vice.texi, src/sounddrv/soundflac.c, src/arch/gtk3/uiabout.c
  • Saving/restoring window positions with multi-display setups is reportedly broken.
The code in trunk has been altered to allow negative coordinates, using `INT_MIN` as the flag to NOT restore window position, this requires testing on various OSes and window managers.
After testing with two displays set to provide a single desktop (3840x1080 pixels), it appears the code works fine on Debian with Wayland and also works on a Windows 7 VM running on that machine. I (compyx) expected Win7 to use negative coordinates for the secondary (left) display, but coordinates for that display start at 0,0 and the second display starts at 1920,0. So this requires further testing by someone with a bare metal Windows installation.


  • the sound disables itself on buffer underrun. it should not do this - a short hickup is much less annoying. instead it should display a message in the statusbar and leave sound enabled. (fixed in trunk)
    • old behaviour restored in trunk, sound keeps playing - however, now we get underrun warnings at shutdown, we should guard this with a "are we shutting down" flag (fixed in trunk)
  • Related to the above (Gtk3): when a sound output driver fails, sound is disabled and the output driver selection greyed out. This means one cannot re-enable sound by selecting another driver. So the driver selection should never be greyed out. (fixed in trunk)
  • the popups on the statusbar should open also on right-click, not just left-click (fixed in trunk)
  • Status bar drive widgets show "Attach to #8:0" and "Directory of unit 8 drive 0" for single-drive devices, the references to drive 0 should be omitted. (fixed in trunk)
  • The "Maximum Speed" submenu should be added to the regular main menu (where the pause/warp stuff is) (fixed in trunk)
  • The "Control Port" dialog does not immediately update itself when an option was changed. eg change port 1 to "inception" adapter - it should show 8 extra joystick ports without having to go to another tab and back (fixed in trunk)
  • In the Hotkey editor there are weird things going on with ALT-GR (tested on linux)
    • ALT-GR produces a MOD5 modifier (so that probably should not be filtered)
    • ALT-GR produces a GDK_KEY_ISO_Level3_Shift (0xfe03) event, but ONLY on release (wth). This however makes it impossible to actually define a hotkey with ALT-GR
(gpz) i played around with this and came to the conclusion that it is not useful to try to support Alt-Gr for hotkeys. The keyboard handler already does some stunts to support it for mapping regular keys, and that is also what the expected use for this key is.
  • On Windows it behaves differently, but does not need further fixing
    • ALT-GR+key produces CTRL+ALT+MOD2+key
    • strange enough, CTRL+ALT+key also produces CTRL+ALT+MOD2+key
      • so in windows we can filter MOD2 and ignore the existance of ALT-GR (fixed in trunk, we simply ignore MOD2 and Alt-Gr, too much trouble with Alt-Gr)
  • on macOS the emulator seems to not work when the binary (or the data folder?) is in a directory with space in it (fixed in trunk)
  • Monitor window and position can not be saved/restored (fixed in trunk)
  • the hotkeys are at least partially broken in the SDL port. they must be tested and fixed (fixed in trunk)
ideally the hotkey definitions are rewritten to work on named actions instead of menu paths

  • the tarball has a top dir named vice-3.6.0 - this screws up packaging, it shouldnt have this
to rephrase: the top dir should match the package name exactly, so vice-3.6 for 3.6 and vice-3.6.1 for 3.6.1 (fixed in trunk)
  • Joystick/Gamecontroller input is broken on macOS. The generic code (default mapping) now ignores extra axes on macOS like it does on windows, however its still broken. (fixed in trunk)
  • Some clickable widgets on the status bar don't change the mouse pointer to inform the user they can be clicked (mouse pointer doesn't change). (fixed in trunk)
    • Warp and Pause leds don't change the pointer at all. (fixed in trunk)
    • Tape (motor) status indicator doesn't change the pointer, the "Tape:" and counter labels do. (fixed in trunk)
    • Individual joystick status widgets don't change the pointer, the "Joysticks:" label does. (fixed in trunk)
    • Drive leds don't change the pointer, the unit[:drive] and [head:]track.sector labels do. (fixed in trunk)

* hotkeys are broken on macOS.

    • the hotkey editor needs to be fixed
The hotkey editor now allows GDK_MOD2_MASK (maps to Command on MacOS) and GDK_META_MASK (no idea what OS uses that), so testing by MacOS users is required to see if the UI now accepts Command as a modifier. Of interest is also whether the UI properly shows "<Command>some-key" or "<Mod2>some-key". (fixed in trunk: modifiers allowed are Control, Command (Mac), Alt/Option and Shift)
    • the parser segfaults on '<Meta>', running past the end of the string to parse (fixed in trunk)
    • we should provide an alternative hotkey file that has the hotkeys defined for "command+key" instead of "option+key" (which equals alt+key) (fixed in trunk: on MacOS VICE parses the alternative "*-mac.vhk" files which use Command instead of Alt/Option)
    • VICE-provided hotkeys are parsed even when using `--help`, so we'll probably need some `help_requested` flag to avoid this and perhaps other stuff that shouldn't run when using `--help`. (fixed in trunk. Include machine.h to access the global int help_requested (boolean))
    • check: https://wiki.gnome.org/Projects/GTK/OSX/Integration
  • joystick default mappings are screwed up at least on windows (should be fixed in trunk)
    • we should make sure at least buttons 1,2,3 are mapped to fire 1,2,3 (all other buttons to fire 1) (should be fixed in trunk)
    • apparently in windows the "hat" controller (dpad) was mapped to joystick before (now unmapped). this needs to be fixed and made the default again. at this point we also must make sure all default mappings are the same on all OSs (why are they not anyway?) (should be fixed in trunk)
  • some macOS specific documentation should be added that explains how to use the binaries from commandline (Moved the relevant readme file into the bindist root)

  • jazzcat reported a crash at startup in windows 10. r41385 apparently still works on his box - better talk to jazzcat directly (ircnet #c-64)


links to threads containing 3.6 feedback