ScummVM main repository
Go to file
sluicebox 58bb4f81e4 SCUMM: Remove unused dummyArgs. PVS-Studio V597
The intent was to pass zero arguments using dummyArgs, but that would
have caused out of bounds reads because runScript expects an array of
size NUM_SCRIPT_LOCAL (25). Passing `args` worked because it was
already zeroed out, but runScript also accepts null for this purpose.

See: 19b45e2a50
2023-10-31 14:20:25 -07:00
.github CI: Disable artifacts behind a flag 2023-07-27 00:13:08 +01:00
audio COMMON: Fix memory leak in MidiDriver. PVS-Studio V773 2023-10-30 11:22:10 -07:00
backends BACKENDS: CLOUD: Remove last pass-by value arguments 2023-10-30 10:49:36 +01:00
base BASE: Add commented out dumping of all GUI dialogs 2023-10-10 23:23:35 +02:00
common COMMON: FORMATS: Pass image extensions to the user callbacks in Markdown 2023-10-31 01:58:55 +01:00
devtools DUMPER-COMPANION: JANITORIAL: Remove unneeded indent 2023-10-27 01:19:43 +02:00
dists DISTS: IOS7: Add ios-help.zip 2023-10-11 23:14:37 +02:00
doc DOC: Fix warning in android.rst 2023-10-27 01:17:11 +02:00
engines SCUMM: Remove unused dummyArgs. PVS-Studio V597 2023-10-31 14:20:25 -07:00
graphics COMMON: FORMATS: Pass image extensions to the user callbacks in Markdown 2023-10-31 01:58:55 +01:00
gui GUI: Fix memory leak in DownloadPacksDialog. PVS-Studio V773 2023-10-30 11:28:13 -07:00
icons
image IMAGE: Fix memory leak in Cel3DODecoder on error. PVS-Studio V773 2023-10-30 11:28:13 -07:00
LICENSES DISTS: Keep Catharon license original naming 2023-09-03 22:27:43 +02:00
math MATH: added function to obtain size of AABBs 2023-05-17 10:11:20 +02:00
po I18N: Update translation (Portuguese (Brazil)) 2023-10-31 08:41:30 +00:00
test TESTS: Remove tests for transparent_surface.h 2023-10-29 01:41:29 +02:00
video ALL: Unify zlib and gzio API 2023-08-28 21:49:03 +02:00
.clang-format
.clang-tidy
.editorconfig
.gitattributes
.gitignore DEVTOOLS: Add Missing Git Ignore for Nancy Engine Datafile Tool Binary 2023-10-22 18:51:30 +01:00
.gitlab-ci.yml
.gitmodules
.readthedocs.yaml DOCS: fixes readthedocs config file paths 2023-10-06 22:24:55 +02:00
AUTHORS CREDITS: Sync SCUMM, SWORD1 and CRAB 2023-10-13 00:43:36 +02:00
config.guess
config.sub
configure CONFIGURE: Update DWARF version comment after Discord feedback 2023-10-15 07:39:34 +02:00
CONTRIBUTING.md
COPYING
COPYRIGHT
engines.awk
Makefile
Makefile.common DISTS: Keep Catharon license original naming 2023-09-03 22:27:43 +02:00
NEWS.md NEWS: Mention Loom drafts dialog enhancement 2023-10-29 20:25:29 +01:00
plugin.exp
ports.mk DISTS: IOS7: Add ios-help.zip 2023-10-11 23:14:37 +02:00
README.md
rules.mk
TODO
vcpkg.json CI: Update to use latest vcpkg version and integration 2023-04-29 13:16:08 +02:00

ScummVM README · CI Translation status PRs Welcome Codacy Badge

About ScummVM

ScummVM allows you to play classic graphic point-and-click adventure games, text adventure games, and RPGs, as long as you already have the game data files. ScummVM replaces the executable files shipped with the games, which means you can now play your favorite games on all your favorite devices.

So how did ScummVM get its name? Many of the famous LucasArts adventure games, such as Maniac Mansion and the Monkey Island series, were created using a utility called SCUMM (Script Creation Utility for Maniac Mansion). The VM in ScummVM stands for Virtual Machine.

While ScummVM was originally designed to run LucasArts SCUMM games, over time support has been added for many other games: see the full list on our wiki. Noteworthy titles include Broken Sword, Myst and Blade Runner, although there are countless other hidden gems to explore.

For more information, compatibility lists, details on donating, the latest release, progress reports and more, please visit the ScummVM home page.

Quickstart

For the impatient among you, here is how to get ScummVM running in five simple steps.

  1. Download ScummVM from our website and install it.

  2. Create a directory on your hard drive and copy the game datafiles from the original media to this directory. Repeat this for every game you want to play.

  3. Start ScummVM, choose 'Add game', select the directory containing the game datafiles (do not try to select the datafiles themselves!) and press Choose.

  4. The Game Options dialog opens to allow configuration of various settings for the game. These can be reconfigured at any time, but for now everything should be OK at the default settings.

  5. Select the game you want to play in the list, and press Start. To play a game next time, skip to step 5, unless you want to add more games.

Hint:

To add multiple games in one go, press and hold the shift key, then click 'Add game' -- the label will change to 'Mass Add' and if you press it, you are again asked to select a directory, only this time ScummVM will search through all subdirectories for supported games.

Reporting a bug

To report a bug, go to the ScummVM Issue Tracker and log in with your GitHub account.

Please make sure the bug is reproducible, and still occurs in the latest git/Daily build version. Also check the compatibility list for that game, to ensure the issue is not already known. Please do not report bugs for games that are not listed as completable on the Supported Games wiki page, or on the compatibility list. We already know those games have bugs!

Please include the following information in the bug report:

  • ScummVM version (test the latest git/Daily build)
  • Bug details, including instructions for how to reproduce the bug. If possible, include log files, screenshots, and any other relevant information.
  • Game language
  • Game version (for example, talkie or floppy)
  • Platform and Compiler (for example, Win32, Linux or FreeBSD)
  • An attached saved game, if possible.
  • If this bug only occurred recently, include the last version without the bug, and the first version with the bug. That way we can fix it quicker by looking at the changes made.

Finally, please report each issue separately; do not file multiple issues on the same ticket. It is difficult to track the status of each individual bug when they aren't on their own tickets.

Documentation

User documentation

For everything you need to know about how to use ScummVM, see our user documentation.

The ScummVM Wiki

The wiki is the place to go for information about every game supported by ScummVM. If you're a developer, there's also some very handy information in the Developer section.

Changelog

Our extensive change log is available here.

SAST Tools

PVS-Studio - static analyzer for C, C++, C#, and Java code.

Credits

A massive thank you to the entire team for making the ScummVM project possible. See the credits here!


Good Luck and Happy Adventuring! The ScummVM team. https://www.scummvm.org/