/dunelegacy

Primary LanguageC++GNU General Public License v2.0GPL-2.0

Dune Legacy

This project

Build Status

Workflow Status
Windows Windows
Ubuntu Ubuntu

Binaries

Binaries are built automatically from the latest source and can be found here:

Windows arm64
Windows x86
Windows x64
Windows x64/avx2

Summary

The goals of this effort are to modernize the codebase, simplify the build system, and to improve performance. The game engine itself will eventually be moved off of the rendering thread, which will provide for a much more responsive user interface, particularly when many units are on the map.

All builds are now being done through CMake with regular testing on Windows with Visual Studio 2019 and Ubuntu with g++. Windows development is being done with VS2019's native CMake support, which uses Ninja for the actual build. (It is unknown if the CMake Visual Studio generators produce usable vcxproj files.)

Notable Changes

  • Builds are done with CMake (and only CMake).
  • ENet and libfmt have been updated are are no longer a normal part of the tree but are included as Git submodules instead.
  • vcpkg is used to provide SDL2, gtest, fmt, and ms-gsl.
  • Pausing after the mission has completed but before the statistic page is displayed will let the user explore the map for as long as they like.
  • On Windows, DirectX 11 is now the preferred renderer. An option has been added to the INI file to configure the preferred renderer. Add Renderer = direct3d or Renderer = software under the [Video] section to request SDL2's DX9 or software renderer, respectively.
  • A texture atlas (sprite-sheet) is created during startup that drastically reduces the number of texture switches during rendering. Some more work needs to be done for it to not fail when faced with an older GPU. To improve startup times, these texture atlases should probably be cached on disk.
  • Screen/windows managment has been changed to allow a window to be used over a Remote Desktop (RDP) session. Disconnecting and reconnecting RDP should no longer cause a hang.

At some point, some of these change might be incorporated into the upstream repository.

Known Issues

  • The random number generator is different than the one in the official release.
  • Systems with older GPUs may need to use the software renderer (add Renderer = software under the [Video] section in the INI file).
  • With all the rendering changes, there are now some glitches that need to be tracked down.

Building

Windows

Install Visual Studio 2019 including the "Desktop development with C++" workload. Go to the "Individual Components" of the installer to make sure "C++ CMake tools for Windows" is enabled (enable clang as well to enable builds with "clang-cl").

To build from inside Visual Studio, open the "dunelegacy" folder, go to the menu to select "Project" -> "CMake Settings for dunelegacy", and create a release configuration, set it as the current configuration, then select "Build" -> "Build All". It should be possible to open the repository directly by going to "File" -> "Clone Repository..." on the menu.

From the command line (a bit faster, but requries more typing):

First open a command prompt with access to CMake (for example, "Developer Command Prompt for Visual Studio 2019"). Get a copy of the code repository, along with the submodules:

git clone https://github.com/henricj/dunelegacy.git
cd dunelegacy
git submodule update --init --recursive -j 8

Build the vcpkg packages,

IDE\VC\vcpkg\build_vcpkg.bat

Configure CMake's build folder, compile the source, and run the tests (alas, there are far too few tests):

mkdir out\build\x64-avx2-Release
cd out\build\x64-avx2-Release
cmake -G Ninja -DCMAKE_BUILD_TYPE:STRING=Release -DDUNE_TARGET_ARCHITECTURE:STRING=x64 -DDUNE_TARGET_ARCHITECTURE_EXTENSION=avx2 -DVCPKG_TARGET_TRIPLET:STRING=x64-avx2-windows-ltcg ../../..
cmake --build .
ctest

There should now be a working dunelegacy executable in out\build\x64-avx2-Release\src.

Linux

The build-essential, git, ninja-build, and cmake packages are needed. Either g++ or clang can be used for the build (tested with g++-10 and clang-10).

git clone https://github.com/henricj/dunelegacy.git
cd dunelegacy
git submodule update --init --recursive -j 8

Build the vcpkg packages,

IDE/VC/vcpkg/build_vcpkg.sh

(At some point, the vcpkg folder will move to the externals folder where it belongs.)

Configure CMake's build folder, compile the source, and run the tests (alas, there are far too few tests):

mkdir -p out/build/x64-Release
cd out/build/x64-Release
cmake -G Ninja -DCMAKE_BUILD_TYPE:STRING=Release -DVCPKG_TARGET_TRIPLET:STRING=x64-linux ../../..
cmake --build .
ctest

There should now be a working dunelegacy executable in out/build/x64-Release\src.

Notes

Builds for macOS have not been tested, but should be similar to the Linux instructions.


Original README

              /-------------------------------\
              |                               |
              |    Dune Legacy 0.96 readme    |
              |    -----------------------    |
              |                               |
              \-------------------------------/

IMPORTANT: This software is provided as is, and you are running it at your own risk. I'm not responsible if any harm results from you aquiring, or running this software. If you distribute this software, make sure this readme file is included. The program Dune Legacy is an modernized clone of the excellent Westwood Studios game "Dune 2". It is ridiculusly easy to find Dune2 on the net anyways, but I won't provide it. I think you can still even buy it from Westwood studios, so do that. There exists a mod called Superdune 2. The PAK-Files Superdune 2 provides are nearly the same except SCENARIO.PAK.

This program would not have been created without the use of the excellent SDL library and its extensions. Thanks guys :).

Getting Started

The following PAK-files from the original Dune 2 are needed to play Dune Legacy:

  • HARK.PAK
  • ATRE.PAK
  • ORDOS.PAK
  • ENGLISH.PAK
  • DUNE.PAK
  • SCENARIO.PAK
  • MENTAT.PAK
  • VOC.PAK
  • MERC.PAK
  • FINALE.PAK
  • INTRO.PAK
  • INTROVOC.PAK
  • SOUND.PAK
  • GERMAN.PAK (for playing in German)
  • FRENCH.PAK (for playing in French)

It depends on your system and installation where to put these files. LEGACY.PAK is supplied with Dune Legacy and is already in the data directory. All the other files should be copied there too. If you are not allowed to copy files there you may copy these files inside the dunelegacy configuration directory (e.g. ~/.config/dunelegacy/data/ on unix).

Linux

It depends on how the game was compiled. Normally you should put these files under /usr/share/dunelegacy/ or /usr/local/share/dunelegacy/ . Just look for LEGACY.PAK. If you do not have root access to your system you should put them in your home directory under ~/.config/dunelegacy/data/ .

Windows

The installer has already asked for the files and put them in the installation directory. If not put the PAK-files inside your installation folder or if you do not have administrator privileges you should put them to C:\Documents and Settings<YourName>\Application Data\dunelegacy\data\ .

MAC OS X

The PAK-files have to be copied inside the application bundle. If you have followed the steps in the supplied dmg you have already copied them there. Otherwise just right-click on the bundle and select "Show Bundle Content". Then navigate into "Contents" and then into "Resources". There you will find LEGACY.PAK. Put the other PAK-files there too. Alternativly you can put them in your home directory under ~/.config/dunelegacy/data/ but putting them inside the application bundle is the preferred way.

Keyboard Shortcuts

General Keyboard Shortcuts:

Key Effect
Escape Go to menu
Space Pause game
Alt + Enter Toggle fullscreen
Alt + Tab Switch to other application
Print Key or Ctrl + P Save screenshot as ScreenshotX.bmp with increasing numbers for X
Enter Start/Stop chatting
Key F1 Zoomlevel x1
Key F2 Zoomlevel x2
Key F3 Zoomlevel x3
Key T Toggle display of current game time
Key F10 Toggle sound effects and voice
Key F11 Toggle music
Key F12 Toggle display of FPS
Key Up, Down, Left or Right Move on the map
Key G Cycle through construction yards
Key F Cycle through factories/other builders
Key F4 Skip 10 seconds (only in singleplayer)
Key F5 Skip 30 seconds (only in singleplayer)
Key F6 Skip 2 minutes (only in singleplayer)
Key - Decrease gamespeed (only in singleplayer)
Key + Increase gamespeed (only in singleplayer)
Ctrl + (Key 1 to Key 9) Save the list of selected units as unit group 1 to 9
Key 1 to Key 9 Select units from unit group 1 to 9
Shift + (Key 1 to Key 9) Add all units from unit group 1 to 9 to the list of currently selected units
Key 0 Deselect all currently selected units
Ctrl + Key 0 Remove currently selected units form all unit groups (group 1-9)
Key M Order unit to move to some position
Key A Order selected units to attack some unit, structure or position
Key C Order selected infantry units to capture some structure
Key R Repair selected structure or send selected units to repair yard
Key H Return selected harvester
Key D Request a carryall drop (only if this game option is enabled)
Key U Upgrade selected structure
Key P Place a structure (if a construction yard is selected)

Map Editor:

Key Effect
Print Key or Ctrl + P Save a picture of the whole map as .bmp
Ctrl + Z Undo last edit
Ctrl + Y Redo last edit

Configuration file

If you want to fine tune the configuration of Dune Legacy you might want to take a look at the configuration file "Dune Legacy.ini". Depending on your system it is either placed in ~/.config/dunelegacy (on Linux), ~/Library/Application Support/Dune Legacy (on Mac OS X) or in C:\Documents and Settings<YourName>\Application Data\dunelegacy\ (on Windows).

Internet Game

To play online via Internet you have to manually enable port forwarding if you use a NAT Router. Forward the Dune Legacy Server Port (Default is 28747) from your NAT Router to your computer. Use the same port on your router as configured in Dune Legacy. Example: If your machine has IP 192.168.123.1 and your using the default Dune Legacy Port, than forward port 28747 from your router to 192.168.123.1:28747.


IRC: #dunelegacy @ irc.freenode.net
Web: http://sourceforge.net/projects/dunelegacy