BletchMAME
BletchMAME is a new experimental front end for MAME. Unlike existing front ends (which function as launchers, keeping MAME's internal UI), BletchMAME replaces the internal MAME UI with a more conventional point and click GUI to provide a friendlier experience in a number of areas (such as profiles, input configuration and a number of others). While BletchMAME is intended to support all machines supported by MAME, it should be particularly suitable to computer emulation.
Running BletchMAME
To run BletchMAME, run the installer (BletchMAME.msi on Windows) and BletchMAME will install, or install manually from the ZIP file. The first thing you must do is point BletchMAME at a locally installed version of MAME 0.213 or later. BletchMAME will take some time to read info from MAME, and when this is complete you can run the emulation.
Version History
-
2.17 (2023-Jul-13)
- Fixing BletchMAME's LUA code to be compatible with MAME 0.253 and after
- Now using default MSYS2 Qt static build (6.2.1 as of November 2022)
-
2.16 (2022-Aug-14)
- Added support for viewing history.xml files (for both machines and software list items)
- Added support for 7-zip
-
2.15 (2022-May-22)
- Fixed a bug that could cause image dropdowns to not properly display software list part names
- Stopped displaying <> for device slots that do not have any options
- Turning off the MAME intrinsic cassette animation as BletchMAME has its own UX (MAME 0.243 and later)
- Added an option to disable the warning displayed when stopping an emulation
- Improvements to the various table views
- Added columns to the machine and software list views to identify source files
- Added the ability to customize the field list and show/hide specific fields
- Added a right click context menu to control sort order
- When invoking software from software lists, now specifying the full name
- Failing to do so could cause problems when mulitple lists have the same name (e.g. - msx1_cart:hero vs msx1_cass:hero)
- Fixed a bug that could cause software lists with hex values (e.g. - size="0x2000") to not parse
- Fixed a bug that could cause crashes when parsing MAME -listxml output
- In practice this only happened with variant MAME builds with more machines than off the shelf MAME
- Updated Qt to 6.2.0
-
2.14 (2022-Mar-26)
- In addition to the menu bar, ScrLk will now also toggle the visibility of the status bar
- Created a nicer status bar display for cassette status
- When the user chooses a MAME executable accompanied by a MAME.ini, BletchMAME will now prompt the user to import these settings
- On MAME.ini importing, now tracking preferred actions for subsequent imports
- Fixed a bug that caused BletchMAME to not prompt the user to find MAME when no MAME is known
- Fixed a bug that could cause duplication of items on the "recent images list" list
- Fixed a CMake build issue when performing out-of-tree builds [Davide Cavalca]
-
2.13 (2022-Feb-26)
- Fixed a serious issue that could cause an emulation to stop handling input (#295)
- Fixed an issue that caused resets to incorrectly pause the emulation (#294)
- Changing screenshots to default to the snapshot directory, and prompting with the machine name (#297)
- Now clearing out the right of the status bar when running an emulation
- Implemented support for environment variable substitution when importing MAME.ini [Davide Cavalca]
- Changed path list handling to tolerate both ';' and ':' as path list separators on non-Windows platforms
- Fixed a bug in the paths dialog that caused a user to see slashes as path separators when editing paths directly
- Fixed a flickering problem in running emulations when resizing the BletchMAME window
- Fixed a bug that could cause the machine count to not properly update in response to searches
-
2.12 (2022-Feb-17)
- Added a capability to import subsets of MAME.ini settings
- Placing the BletchMAME version and (when running) the MAME version on the title bar
- Cosmetic changes to the "About..." dialog to make it appear cleaner
- Fixed a thread safety problem that could cause random crashes when communicating with MAME
- Lowering the priority of background audit tasks
- Fixed a bug that caused auditing to not respect "romof" when identifying paths
- Preventing Info DB refreshes when emulations are running
-
2.11 (2021-Dec-27)
- Enabled Link Time Optimization for Release builds
- Made BletchMAME aware of the CHD Diff path (-diff_directory)
- Fixed an issue that could cause the UI to hang whenever MAME was invoked
- Fixed an issue that could cause the MAME window to not be properly attached to BletchMAME's window when starting an emulation session
- Fixed a bug that caused LUA errors when using fixed slot devices in MAME versions 0.227 and after
- Various Auditing improvements
- The auditing dialog will now show a progress bar
- Optimized dispatch of auditing tasks
- Increased the amount of simultaneous auditing tasks
- Changed maximum of audits per audit task to 20 (was 3)
- Any audit task will max out at 50 MB
- Now properly identifying proper file extensions for disks and samples (CHD and WAV)
- Now properly extracting SHA-1 hashes from CHD files
- Fixed a bug that could cause hangs on exit
- Fixed a bug that caused all samples to be incorrectly reported as having no good dumps
- Various build improvements [Davide Cavalca]
- CI builds against Qt6.2
- No longer hardcoding a particular version of QuaZip
-
2.10 (2021-Dec-4)
- Added an "Available" folder to the machine tree view (like MAMEUI)
- Added the ability to reset settings to default
- Current selections and auditing results will be described in the status bar
- Various improvements to auditing
- Media auditing will now proceed even when visible items have been audited
- Changing ROMs and Samples paths will only force reaudits of items that use the relevant media
- Fixed some bugs that could cause audit icons to not be properly painted
- Hash paths will now default to 'hash' in the MAME directory
- Fixed a bug that could cause switching between paths in the paths dialog to not persist changes
- Various improvements to the CI/CD pipeline [Davide Cavalca]
-
2.9 (2021-Oct-23)
- Added experimental MAMEUI-style media auditing capabilities
- ROMs, Samples, Disks and Software Lists are supported
- When refreshing the MAME Info Database (-listxml handling), names and descriptions of machines will be displayed
- No longer waiting for the MAME version check to complete on startup
- Various enhancements to the Paths Dialog
- Highlighting file paths for snapshots and icons that are not valid archives in red
- Multi selection of paths is now supported
- Minor bug fixes to the logic that updates the status of the Browse/Insert/Delete buttons
- Improving display of icon on the machine list on high resolution displays
- Now remembering the maximized/full screen and size state of the main window
- Fixed a bug that caused column sorts to not be honored on startup
- Fixed a bug that caused newly created profiles to not get selected when created
- Fixed a bug that caused the software list tab to not be populated is selected on startup
- Small optimizations to the building of MAME Info Database and general XML parsing
-
2.8 (2021-Aug-29)
- Added support for snapshots in ZIP files instead of in directories (#128)
- Fixed an issue in Info XML parsing caused by inappropriately relying on the current locale's rules (#143) [Julian Sikorski]
- This rendered BletchMAME unusable in some locales
- Fixed a bug where updates to the snapshot path failed to trigger an update of the info panel
- Removed accidentally introduced dependency on libwinpthread-1.dll
-
2.7 (2021-Aug-27)
- Updated to Qt 6.1
- On Windows, Qt is now built statically and optimized for size
- Fixed a minor bug that caused garbage icons to be displayed for systems without icons
- Supporting -attach_window on SDLMAME 0.232 and higher
- Omitting -attach_window when MAME identified as lacking support
- Various changes for running under Linux [Davide Cavalca]
- CMake and build tweaks to link with dependencies non-statically
- Created basic desktop and metadata files for GNOME
- Small optimizations to the building of MAME Info Database (-listxml handling)
-
2.6 (2021-Mar-6)
- Added a number of MAMEUI-style builtin folders
- BIOS, CHD, CPU, Dumping, Mechanical, Non Mechanical, Raster, Samples, Save State, Sound, Unofficial, Vector
- Added support for custom folders
- Added a "Show Folders" contextual menu to the folder tree
- Fixed a unicode issue in preferences handling
- Updated to C++20
-
2.5 (2021-Jan-31)
- Beginings of a MAMEUI-style machine folder and snapshot view
-
2.4 (2021-Jan-3)
- Updated various parts of the worker_ui plugin in response to breaking LUA changes in MAME 0.227
- An implication is that previous versions of BletchMAME will not work with MAME 0.227 or greater
- Because MAME 0.227 doesn't support hot changes to mouse capture, the mouse may not be usable
- BletchMAME will warn the user in this scenario
- Changed the Images Dialog to a Configurable Devices dialog, combining image and slot selection
- Slot modification requires MAME 0.227, and will not function in previouew versions
- Resurrected the "Quick Load/Save State" feature, which has been broken since 2.0
- Fixed profile renaming, which also has been broken since 2.0
- Fixed a bug in the profiles view that could cause a crash if one right clicks empty space
-
2.3 (2020-Dec-13)
- Added a warning to the Images Dialog if no hash paths were set up
- Fixed a bug that could cause image widgets to not be properly cleaned up if they got removed by a slot change
- Fixed a bug that prevented the "Unload Image" menu item from working
- Fixed a bug in the console window that could cause text to be appended in the wrong location
- Fixed a cosmetic bug in the "About BletchMAME" dialog
- No longer passing -nodtd when invoking -listxml on MAME
- Changed worker_ui plugin to tolerate changes in machine().images expected with MAME 0.227
-
2.2 (2020-Oct-3)
- Support for cheats (requires MAME 0.225)
- The worker_ui plugin is now tested automatically as a part of the CI/CD pipeline
-
2.1 (2020-Aug-29)
- Better handling of scenarios when the preferences directory does not exist
- Various changes to build on Linux [Davide Cavalca]
-
2.0 (2020-Aug-23)
- Overhaul of BletchMAME application
- Transitioned from wxWidgets to Qt
- Adopted CMake
- Unit tests now executed as part of build pipeline
-
1.9 (2020-May-20)
- Added the ability to record AVI/MNG movies (requires MAME 0.221)
- Fixed a bug that would choose odd default file name when saving screenshots
- Ensuring that directory paths always have trailing path separators
-
1.8 (2020-Feb-16)
- Added command to drop into debugger
- Fixed menu bar toggling bug
-
1.7 (2019-Dec-28)
- We have a real domain name (https://www.bletchmame.org/); added a menu item to go directly there
- If we fail to start MAME, we will now crudely present MAME's error message to the user
- When supported by MAME (0.217 dirty or greater), we will attach to a child window rather than the BletchMAME root window. This fixes a bug where the status bar could obscure part of the running emulation
-
1.6 (2019-Nov-24)
- Upgraded to wxWidgets 3.1.3
- Fixed a bug that could cause paths with parentheses to be incorrectly recognized (#1)
-
1.5 (2019-Nov-10)
- Support for MAMEUI-style icon packs
-
1.4 (2019-Nov-3):
- Full software list support
- Fixed recently introduced bugs in the profiles view that could caused actions to be made against an incorrect profile
-
1.3 (2019-Oct-9):
- Support for loading software list parts individually (but not yet full softlist software entries)
- List views can now be sorted by column
-
1.2 (2019-Sep-18):
- Improvements to the error reporting in the LUA plugin
- Distributing BletchMAME as a ZIP file in addition to MSI
- Fixed issues surrounding the "Mouse Inputs" button when changing inputs, including potential crashes
- Fixed a bug that could cause the mouse to be captured at the start of an emulation session, even if the menu bar was showing
-
1.1 (2019-Sep-8):
- Fixed bugs related to starting with a fresh configuration directory
- Added basic "preflight checks" prior to starting MAME emulation sessions, to better catch obvious problems
-
1.0 (2019-Sep-7):
Support for BletchMAME
Visit the BletchMAME website at https://www.bletchmame.org/ or the IRC FreeNode channels #mame and #bletchmame