ScummVM main repository
Go to file
Lionel Ulmer aa09cbf8fe Fixed a 'file descriptor' leak in the MP3 tracks caching
system. Rewrote a bit the call to the MAD timer API.

svn-id: r4185
2002-05-03 21:11:16 +00:00
dc Use Makefile.common like the rest. 2002-05-03 17:49:03 +00:00
debian Fix debian 'rules' tabbing by braindead editor. 2002-05-03 17:14:52 +00:00
mac Return of the MP3 CD patch ... use CBR 22 kHz 2002-04-17 20:23:45 +00:00
macosclassic Added parameters specifications 2002-03-09 13:42:22 +00:00
morphos Sped-up version of AdvMame2x scaler for MorphOS-native interface integrated 2002-04-29 13:12:45 +00:00
simon Fixed packing for non GCC compilers - Loom & Zak work on WinCE now 2002-05-01 00:13:03 +00:00
sound Remove floating point in the MP3 volume control (baaaaaaaad on PDAs 2002-05-03 19:47:51 +00:00
v3 Removed ScummVM's private alloc / free / realloc functions. If I break 2002-05-01 17:16:47 +00:00
v4 Remove \M's, add IRIX support. 2002-04-20 04:09:02 +00:00
wince Update to new configuration system, fixed right click, fixed landscape mode display bug 2002-05-01 22:24:30 +00:00
2xsai.cpp MP3 CD tracks should now be working properly. 2002-04-27 07:42:14 +00:00
actor.cpp Another fix for LoomCD. Now Valgrind does not reports any error 2002-05-01 10:48:09 +00:00
akos.cpp Fix Indy4/MI2 crash due to VirtScroll code. 2002-04-24 04:26:09 +00:00
akos.h Fix PocketSCUMM. Palette is wrong tho. BBrox is a genius. 2002-04-19 15:02:16 +00:00
boxes.cpp Implemented a few new functions. Now you can control the crane in Full Throttle 2002-04-25 08:53:10 +00:00
boxes.h Fixed packing for non GCC compilers - Loom & Zak work on WinCE now 2002-05-01 00:13:03 +00:00
config-file.cpp My code really need that free(NULL) is valid BBrox... =) 2002-05-02 00:46:12 +00:00
config-file.h moved scummfg to config-file.h - seems more logical. Also added a legal header 2002-04-28 00:56:52 +00:00
copying.txt
costume.cpp Fix actor masking crash. 2002-05-01 19:03:54 +00:00
debug.cpp Use relative include paths to easy some ports. 2002-04-19 11:12:27 +00:00
debugrl.cpp Large pointless reindentation of all the code. Also fixed a few mistakes 2002-04-11 17:19:16 +00:00
debugrl.h Merged Tom Dunstan's debugger readline patch. Define 2001-11-19 00:04:34 +00:00
gameDetector.cpp SFX and Music volumes are now game-specific. 2002-05-03 19:17:15 +00:00
gameDetector.h Add config file support. Thanks |Pixel| :) 2002-04-27 16:58:29 +00:00
gapi_keys.h New key page in GUI 2002-04-21 21:54:08 +00:00
gfx.cpp MP3 CD tracks should now be working properly. 2002-04-27 07:42:14 +00:00
gfx.h Fixed packing for non GCC compilers - Loom & Zak work on WinCE now 2002-05-01 00:13:03 +00:00
gui.cpp Fixed second key page for WinCE, start of volume support 2002-05-01 22:16:17 +00:00
gui.h New key page in GUI 2002-04-21 21:54:08 +00:00
guimaps.h Move stringmaps to own file to prevent warnings. 2002-04-13 04:44:59 +00:00
init.cpp Large pointless reindentation of all the code. Also fixed a few mistakes 2002-04-11 17:19:16 +00:00
insane.cpp Well, one small commit before going to bed to regain the commit king 2002-05-01 23:03:38 +00:00
main.cpp Add a quick dynamic test to see if the memory options (endianness and 2002-05-03 18:24:16 +00:00
Makefile Add config file support. Thanks |Pixel| :) 2002-04-27 16:58:29 +00:00
Makefile.common Add config file support. Thanks |Pixel| :) 2002-04-27 16:58:29 +00:00
Makefile.irix Makefile.mingw now uses Makefile.common, too 2002-04-27 11:06:27 +00:00
Makefile.macosx Makefile.mingw now uses Makefile.common, too 2002-04-27 11:06:27 +00:00
Makefile.mingw Fix cross compile 2002-04-30 15:08:59 +00:00
Makefile.x11 Makefile.mingw now uses Makefile.common, too 2002-04-27 11:06:27 +00:00
object.cpp Fix Indy4/MI2 crash due to VirtScroll code. 2002-04-24 04:26:09 +00:00
readme.txt Update default tempo readme/help text. 2002-05-03 17:42:34 +00:00
resource.cpp Removed ScummVM's private alloc / free / realloc functions. If I break 2002-05-01 17:16:47 +00:00
saveload.cpp Major V7 update with vertical scrolling. Added a few scumm vars related to scrolling. Dig inventory isn't displayed where it should. I hope it doesn't break anything else in other game... 2002-04-23 23:58:31 +00:00
script_v1.cpp Moved loom music synch to the playing function 2002-05-01 22:31:29 +00:00
script_v2.cpp Implemented a few new functions. Now you can control the crane in Full Throttle 2002-04-25 08:53:10 +00:00
script.cpp Add enhanced debugging patch. 2002-04-26 14:13:39 +00:00
scumm.h Removed ScummVM's private alloc / free / realloc functions. If I break 2002-05-01 17:16:47 +00:00
scummsys.h Remove unused library and native Cygwin support 2002-04-30 09:26:31 +00:00
scummvm.6 Update manpage slightly. 2002-04-24 09:59:42 +00:00
scummvm.cpp REALLY fix -m. For sure. Trust me. :) 2002-05-03 18:05:33 +00:00
scummvm.dsp Added icon and version resource to Visual C project. 2002-04-30 13:57:11 +00:00
scummvm.dsw
scummvm.ico Added icon and version resource to Visual C project. 2002-04-30 13:57:11 +00:00
scummvm.proj Update BeOS project file 2002-04-26 12:37:20 +00:00
scummvm.rc Fix MingW compilation. 2002-04-30 14:16:47 +00:00
scummvm.spec updated %changelog with the same text as changelog.txt 2002-04-30 18:01:28 +00:00
scummvm.xpm Fixed properly the transparency problem. I would like people on BE 2002-04-29 19:57:03 +00:00
sdl.cpp Add hotkey for advmame2x 2002-05-02 15:01:38 +00:00
smush.h Add boilerplate license to some files, to satisfy Debian types :) 2002-04-21 17:46:42 +00:00
sound.cpp Fixed a 'file descriptor' leak in the MP3 tracks caching 2002-05-03 21:11:16 +00:00
stdafx.cpp I know it probably doesn't look like much, but this is a start to the reorg - basically I've shuffled the Scumm struct around, and turned it into a Class - labeling and grouping functions that are related. 2002-03-20 17:51:07 +00:00
stdafx.h Reenable MorphOS Midi driver, small updates to CD open code (only when CD audio is requested) and start options 2002-04-18 21:40:24 +00:00
string.cpp Fix Indy4/MI2 crash due to VirtScroll code. 2002-04-24 04:26:09 +00:00
sys.cpp Removed ScummVM's private alloc / free / realloc functions. If I break 2002-05-01 17:16:47 +00:00
system.h Made compiler happy about newline at file end 2002-04-26 13:39:01 +00:00
vars.cpp Fix Indy4/MI2 crash due to VirtScroll code. 2002-04-24 04:26:09 +00:00
verbs.cpp Large pointless reindentation of all the code. Also fixed a few mistakes 2002-04-11 17:19:16 +00:00
whatsnew.txt Readme update, and WhatsNew tidy up. 2002-04-30 17:20:54 +00:00
x11.cpp Zero-initialize the palette and the frame buffer. 2002-05-01 09:41:54 +00:00

ScummVM README
Last updated:    2002-05-01
Release version: 0.2.0 [CVS Build]
------------------------------------------------------------------------

For more information, compatibility lists, details on donating, the latest
release, progress reports and more, please visit the ScummVM home page
at: http://scummvm.sourceforge.net/


About:
------

ScummVM is an implementation of the SCUMM (Script Creation Utility for
Maniac Mansion) engine used in various Lucas Arts games such as Monkey
Island and Day of the Tentacle. At this time ScummVM should be considered
ALPHA software, as it's still under heavy development. Be aware that while
many games will work with few major bugs, crashes can happen. Also note
that saved games can, and probably will, be incompatible between releases.

Also ScummVM is capable of playing several non-SCUMM games, at the moment
this includes Simon The Sorcerer.

If you enjoy ScummVM feel free to donate using the PayPal button on the
ScummVM homepage. This will help us buy utilities needed to develop ScummVM
easier and quicker. If you cannot donate, help and contribute a patch!

Contacting:
-----------
The easiest way to contact the ScummVM team is by subitting bug reports or
commenting in our forums. You can also join and e-mail the scummvm-devel
mailing list, or chat with us on irc (#scummvm, irc.openprojects.net)

Supported Games:
----------------

At the moment the following games have been reported to work, and should
be playable to the end:

        Loom (256 color CD version)            [Game: loomcd]
        Monkey Island 1 (CD version)           [Game: monkey1]
        Monkey Island 2                        [Game: monkey2]
        Indiana Jones And The Fate Of Atlantis [Game: atlantis]
        Day Of The Tentacle                    [Game: tentacle]
        Sam & Max                              [Game: samnmax]
        Simon The Sorcerer                     [Game: simon1dos or simon1win]


The following games should load, but are not yet fully playable. Play these at
your own risk, and please do not file bug reports about them. If you want
the latest updates on game compatibility, visit our web site and view the
compatibility chart.

        Monkey Island 1 (VGA floppy)                   [Game: monkeyvga]
        Zak McKraken (256 color FM Towns version)      [Game: zak256]
        Indiana Jones and the Last Crusade (256 color) [Game: indy3]
        Full Throttle                                  [Game: ft]
        The Dig                                        [Game: dig]

The following games are SCUMM engine, but NOT supported by ScummVM (yet).

        Maniac Mansion
        Zak McKraken (16 color floppy version)
        Monkey Island 1 (EGA, 16 color floppy version)
        Loom (16 color floppy version)
        Curse of Monkey Island

Please be aware that the engine may contains bugs and non-implemented-
features that sometimes make it impossible to finish the game. Save often,
and please file a bug report (details on submitted bug reports are below)
if you discover such a bug.


Supported Platforms:
-------------------

ScummVM has been ported to run on many platforms and operating systems.
Links to these ports can be found either on the ScummVM web page or by a
Google search. Many thanks to the effort of porters. If you have a port of
ScummVM and wish to commit it into the main CVS, feel free to contact us!

        Windows         - SDL
        Windows CE      - SDL           (iPaq and other handheld devices)
        Linux           - SDL/X11       (includes iPaq devices running Linux)
        Macintosh       - SDL/CUSTOM    (Including Classic and Mac OS X)
        AmigaOS         - SDL/AGA
        MorphOS         - SDL
        BeOS            - SDL
        Acorn (RiscOS)  - ???
        Dreamcast       - ???


Known Bugs:
-----------

This release has the following known bugs. There is no need to report them,
although patches to fix them are welcome. If you discover a bug that is not
listed here, nor in the compatibility table on the web site, please see below.

       Indy 4 (Fate Of Atlantis):
                - Keyboard fighting does not work. ScummVM now defaults to
                  using mouse fighting.



       Sam and Max:
                - Subgames are not fully functional.

                - The Wak-A-Rat game will appear to freeze at the end.
                  However, it hasn't really. Just hit Escape and wait.

                - The intro credits will not play correctly if you let the
                  previous cutscene run (the Mad Doctor scene).

                - The Mystery Vortex may hang the game if you hang around in
                  the main room for too long. This is caused by a script race



       Loom (256 Talkie):
                - If you are having random crashes, this is a Windows bug.
                  Try copying the data files from CD to your hard disk.

                - Bobbin may rarely appear to walk backwards.


Reporting Bugs:
---------------
To report a bug, please create a SourceForge account and follow the bugs
link from our homepage. Please make sure the bug is reproducible, and 
still exists in the latest daily build/current CVS version. Also check the
compatibility listing for that game to ensure the issue is not already known.

Please include the following information:
        - Game version (PLEASE test the latest CVS/Daily build)
        - Bug details, including instructions on reproducing
        - Language of game (English, German, etc)
        - Version of game (Talkie, Floppy...)
        - Platform and Compiler (Win32, Linux, etc)
        - Attach a save game if possible
        - If this bug only occurred recently, please note the last
          version without the bug, and the first version including
          the bug. That way we can fix it quicker by looking at the
          changes made.


Compiling:
----------

You need SDL-1.2.2 or newer (older versions may work, but are unsupported), and
a supported compiler. Several compilers, including GCC, mingw and Microsoft
Visual C++ are supported. If you wish to use MP3-compressed CD tracks or
.SOU files, you will need to install the MAD library and define
COMPRESSED_SOUND_FILE. Tools for compressing .SOU files to .SO3 files can be
found in the 'tools' CVS module, or in the 'scummvm-tools' package.

On Win9x/NT/XP you can define WIN_DBG and attach WinDbg to browse the debug 
messages (see http://www.sysinternals.com/ntw2k/freeware/debugview.shtml).

        GCC:
        * Type make (or gmake if that's what GNU make is called on your
          system) and hopefully ScummVM will compile for you.

        Microsoft Visual C++:
        * Open the workspace, scummwm.dsw
        * Enter the path to the SDL include files in Tools|Options|Directories
        * Now it should compile successfully.

        BeOS:
        * Open the 'scummvm.proj' file in BeIDE. Compile as normal.

        PocketPC - Windows CE:
        * Download the SDLAudio library:
          http://arisme.free.fr/PocketScumm/sources/SDLAudio-1.2.3-src.zip
        * Open and compile the SDLAudio WCEBuild/WCEBuild workspace in EVC++
        * Open the ScummVM wince/PocketScumm workspace
        * Enter the SDLAudio directory to your includes path
        * Enter the compiled SDLAudio.lib to your link libraries list
        * Now it should compile successfully


Running:
--------

Before you run the engine, you need to put the game's datafiles in a
directory. The filenames must be in lowercase on *nix systems
(monkey2.000 and monkey2.001). If you use a game with speech, the file
monster.sou must reside in the same directory as the datafiles.

For example, to run a copy of Monkey Island installed in C:\Games\LucasArts
under Windows, you would make a shortcut calling this command:

  C:\Games\LucasArts\scummvm.exe -f -pC:\Games\LucasArts\monkey\ monkey

Or, if you have, for example, Full Throttle on CD, and your CD drive is D:,
and you wish to disable subtitles and run in fullscreen:

  C:\Games\LucasArts\scummvm.exe -f -n -pD:\resource\ ft

Note that if you run the game once this way, and specify the -w commandline
parameter (or edit scummvm.ini manually), ScummVM will remember the path,
and other settings for this game.

The short game name you see at the end of the command line is very
important. A short list is contained at the top of this file. You can also
get the current list of games and game names at:
        http://scummvm.sourceforge.net/compatibility.php

For the adventurous, who like to live on the edge... you can download daily
builds of Win32, Redhat, Debian and other packages here:
        Daily builds - http://scummvm.sourceforge.net/daily/


Command Line Options:
---------------------

        scummvm [OPTIONS] [GAME]

        [GAME]     - Short name of game to load. E.g. monkey for Monkey Island.
        
        -p<path>   - Path to where the game is installed. Default is Cwd.
        -b<num>    - Start in room <num>.
        -c<num>    - Drive to play cd audio from.  E.g., 0 is first drive.
        -s<num>    - Set the sfx volume, 0-255.    Default is '100'
        -m<num>    - Set the music volume, 0-100.  Default is '60'
        -t<num>    - Set music tempo. Defaults: Adlib: 0x1F0000, Midi: 0x460000
        -e<mode>   - Select sound engine. See below.
        -g<mode>   - Select graphics scaler. See below.
        -f         - Full-screen mode.
        -n         - Disable subtitles. Use with games that have voice.
        -r         - Enable Roland conversion. Try if music sounds incorrect.
        -a         - Enable amiga pal conversion, for playing Amiga versions
        -d[<num>]  - Set debug verbosity to <num>
        -w[<file>] - Write configuration file
        -l<file>   - Load alternate configration file (default: scummvm.ini)

In game Hot Keys:
-----------------
        Ctrl 0-9 and Shift 0-9   - load and save states.
        Ctrl-Alt 0-4             - cycles between filter modes
        Ctrl-z                   - quits
        Ctrl-f                   - runs in fast mode.
        Ctrl-d                   - starts the debugger.
        Ctrl-s                   - shows memory consumption.
        F5                       - displays a save/load box.
        Space                    - pauses.
        Alt-Enter                - toggles full screen/windowed


Graphics filters:
-----------------
ScummVM offers several anti-aliasing filters to attempt to improve visual
quality. These are the same filters used in many other emulators, such as
MAME.

They are:
        -gnormal     - No filtering, original 320x200 resolution. Fastest.
        -g2x         - No filtering, double screen/window size to 640x480 (default)
        -g3x         - No filtering, triple screen/window size to 800x600
        -g2xsai      - 2xsai filtering, double screen/window size to 640x480
        -gsuper2xsai - Enhanced 2xsai filtering. 640x480 screen/window size
        -gsupereagle - Less blurry than 2xsai, but slower. Also 640x480
        -gadvmame2x  - 640x480 scaling. Doesn't rely on blurring like 2xSAI.

Note that filters are very slow when ScummVM is compiled in a debug
configuration without optimizations. And there is always a speed impact when
using any form of anti-aliasing/linear filtering.


Autosaves:
----------

Because ScummVM is still a beta product, it -can- crash and/or hang
occasionally. As such, every five minutes it will save a game in Slot 0.


Savegames:
----------

Savegames are by default put in the current directory. You can use the
environment variable SCUMMVM_SAVEPATH to specify where to put save games.
Don't forget the trailing directory separator. Also be aware that saved games
can, and probably WILL, break between ScummVM releases.

Bash Example:
        export SCUMMVM_SAVEPATH=/tmp/scummvm_savegames/

Windows example:
        set SCUMMVM_SAVEPATH=C:\saved_games\


Music and Sound: 
----------------
By default, on most operating systems, ScummVM will automatically use ADLIB
emulation. However, some games do not include Adlib music - such as Sam and
Max. Note: MIDI may not be available on all operating systems or may need
manual configuration.

If you ARE using MIDI, you have several different choices of output, 
depending on your operating system and configuration.
        
        -eadlib     - Uses internal Adlib Emulation (default) 
        -ewindows   - Windows MIDI. Uses built-in sequencer, for Windows users
        -eseq       - Uses /dev/sequencer for MIDI, *nix users. See below.
        -eqt        - Quicktime sound, for Macintosh users.
        -ecore      - CoreAudio sound, for MacOS X users.
        -eamidi     - Uses the MorphOS MIDI system, for MorphOS users
        -enull      - Null output. Don't play any music.
        

Playing sound with Adlib emulation:
-----------------------------------
By default an Adlib card will be emulated and ScummVM will output the music
as sampled waves. This offers far superior performance to Timidity, however
does not work with some games such as Sam and Max.


Playing sound with MIDI:
------------------------
Use the appropriate -e<mode> command line option from the list above to
select your preferred MIDI device. For example, if you wish to use Windows
MIDI over the default Adlib Emulation, use the -ewindows option.


Playing sound with Sequencer:
-----------------------------
If your soundcard driver supports a sequencer, you may set the environment
variable "SCUMMVM_MIDI" to your sequencer device - eg, /dev/sequencer

Then start ScummVM with the parameter '-eseq'. This should work on several
cards, and may offer better performance and quality than Adlib emulation.

Using MP3 files for CD audio:
-----------------------------
Use LAME or some other mp3 encoder to rip the cd audio tracks to files. Name
the files track1.mp3 track2.mp3 etc. ScummVM must be compiled with MAD support
to use this option. You'll need to rip the file from the CD as a WAV file,
then encode the MP3 files in Constant Bit Rate sampled at 22 kHz. This can
be done with the following LAME command line:

lame -t -q 0 -b 96 --resample 22.05 track1.wav track1.mp3


Compressing MONSTER.SOU with MP3:.
---------------------------------
You need LAME, and our extract util from the tools dir to perform this task,
and ScummVM must be compiled with MAD support.

Make a backup file of your MONSTER.SOU before attempting this. Copy your
MONSTER.SOU file to a temporary folder. Then run:
  extract monster.sou
In about 30 minutes or so, you will have a much smaller monster.so3 file, copy
this file to your game dir. You can safely remove the monter.sou file.


Coding style:
------------
For ScummVM coding, we use hugging braces, and two-space tab indents.
We occasionally run the following 'indent' parameters to ensure everything
is kept standard:

-br -bap -nbc -lp -ce -cdw -brs -nbad -nbc -npsl -nip -ts2 -ncs -nbs
-npcs -nbap -Tbyte -Tvoid -Tuint32 -Tuint8 -Tuint16 -Tint -Tint8
-Tint16 -Tint32 -TArrayHeader -TMemBlkHeader -TVerbSlot -TObjectData
-TImageHeader -TRoomHeader -TCodeHeader -TResHdr -TBompHeader
-TMidiChannelAdl -TGui -TScumm -TSoundEngine -TPart -TPlayer


Credits:
--------
  The core ScummVM team:
        Ludvig Strigeus    - Original developer, lead developer 'simon' module
        Vincent Hamm       - Current lead developer, ScummVM
        James Brown        - Co-lead developer, ScummVM
        Jeremy Newman      - Webmaster

 Porters:
        Lionel Ulmer       - X11/Linux port
        Nicolas Bacca      - PocketPC/WinCE port
        Mutwin Kraus       - Macintosh port
        Max Horn           - Macintosh port
        Marcus Comstedt    - DreamCast port
        Ruediger Hanke     - MorphOS port

 Contributors:
        Claudio Matsuoka   - Daily builds (http://scummvm.sf.net/daily/)
        Janne Huttunen     - Zak256/Indy256/LoomCD actor mask support
        Jeroen Janssen     - Numerous readability and bugfix patches
        Gregory Montoir    - AdvanceMAME Scale-2X implementation
        Mikesch Nepomuk    - MI1 VGA Floppy patches.
        Edward Rudd        - Fixes for playing MP3 versions of MI1/Loom Audio
        Daniel Schepler    - Final MI1 CD music support
        Tim 'realmz'       - Initial MI1 CD music support
        Jonathan 'khalek'  - Expert weaver in the Loom
        Nicolas Noble      - Config file support
        Pawel Kolodziejski - Added missing Dig SMUSH codecs

        And to all the contributors, users, and beta testers we've missed.
        Thanks!

 Special thanks to:
        Jimmi Thogersen - For ScummRev, and much obscure code/documentation
        Kevin Carnes    - For Scumm16, the basis of ScummVM older gfx codecs

        Aric Wilmunder, Ron Gilbert, David Fox, Vince Lee, and all those at
        LucasFilm/LucasArts who made SCUMM the insane mess to reimplement
        that it is today. Feel free to drop us a line and tell us what you
        think, guys!




------------------------------------------------------------------------
Good Luck and Happy Adventuring!
The ScummVM team.
http://scummvm.sourceforge.net/
------------------------------------------------------------------------