Ubuntu install
Contents |
[edit]
Ubuntu
We now have a maintained and up to date APT repository for Ubuntu 7.10 (Gutsy) and 8.04 (Hardy). If you have some older version of ubuntu, you can easily upgrade with these instructions: http://www.ubuntu.com/getubuntu/upgrading.
The components necessary for a fully playable spring game are the spring engine, a lobby client (already installed in Ubuntu), a mod and at least one map. Currently the repository contains everything except mods.
[edit] Installation
To install the engine, lobby client and maps follow the instructions for either the GUI or CLI installation method below.
[edit] Graphical Interface
Go to System → Administration → Software Sources, and click on the Third-Party Software tab. Then, click the ﹢Add button, and paste one of the two lines corresponding to your Ubuntu release (7.10 or 8.04). Finally click the +Add button again and add the second line:
Ubuntu 7.10 "Gutsy Gibbon":
deb http://ppa.launchpad.net/spring/ubuntu gutsy main
deb-src http://ppa.launchpad.net/spring/ubuntu gutsy main
Ubuntu 8.04 "Hardy Heron":
deb http://ppa.launchpad.net/spring/ubuntu hardy main
deb-src http://ppa.launchpad.net/spring/ubuntu hardy main
Then click Close, and Reload. After that's done, head to System → Administration → Synaptic Package Manager, and search for spring. For the bare essentials, you'll need to install the spring and spring-maps-default packages. Other maps are available there, so check them off if you'd like to get them. After you're done, click on Apply, and Spring will be downloaded & installed.
Spring lobby can be found in Applications → Games. (Please note that you also need mods to play, and they aren't yet available in the repository. Scroll down to the Mods section of this page on how to get those).
[edit] Or in the terminal CLI
Press alt-F2 to run a command. Enter:
gksudo gedit /etc/apt/sources.list.d/springproject.list
Copy and paste the following into the file:
Ubuntu 7.10:
deb http://ppa.launchpad.net/spring/ubuntu gutsy main
deb-src http://ppa.launchpad.net/spring/ubuntu gutsy main
Ubuntu 8.04:
deb http://ppa.launchpad.net/spring/ubuntu hardy main
deb-src http://ppa.launchpad.net/spring/ubuntu hardy main
Save the file. You can then either use the graphical package manager Synaptic (System->Administration->Synaptic Package Manager) and search for spring related packages, or just install spring from a terminal using:
sudo apt-get update
sudo apt-get install spring spring-maps-default
Many other map packages are also available in the repository. To add them in a terminal enter.
sudo apt-get install spring-maps-1v1 spring-maps-deltasiege spring-maps-hunterw
spring-maps-kernelpanic spring-maps-smallsupreme and spring-maps-teamplay
[edit] Other information
The webpage for the repository is here - you can browse other spring packages there as well: https://edge.launchpad.net/~spring/+archive
For configuring the lobbies, you can note that the package installs the Spring executable at /usr/games/spring and
read-only data in /usr/share/games/spring.
[edit] Finalizing installation
Now you have Spring installed along with SpringLobby. You are now ready to start springlobby for the first time.
[edit] Mods
Since Spring itself is only an engine, you need to download mods for it. Springlobby will do this for you using bittorrent once you joined a game with a mod you don't have. If you want to download it manually, [1] has almost all mods ever created for spring. Once you downloaded them to ~/.spring/mods, they are ready to use.
[edit] BA (Balanced Annihilation)
A popular mod to get started with is Balanced Annihilation (BA) 6.21. Please note that before you can run it though, you'll need to download the OTA content - read the section below on how to get that.
[edit] CA (Complete Annihilation)
A new mod with better models, graphical effects, and a different take on gameplay is the CA mod - get it here.
[edit] OTA Content
If you want to play mods based on Total Annihilation, for example XTA, AA, BA, or CA then you have to do the following:
If you are on Gentoo:
emerge spring-ota-content
Other distributions:
wget http://ipxserver.dyndns.org/games/spring/mods/xta/base-ota-content.zip -P ~/.spring/base
unzip ~/.spring/base/base-ota-content.zip -d ~/.spring/base/
Note that you need to own a copy of Total Annihilation, to download this file legally. Mods that do not require this file are at least NanoBlobs, Kernel Panic and Expand & Exterminate
[edit] Maps
When joining a game with a map you don't have, springlobby will start downloading it using bittorrent.
If you want to browse existing maps, there are several easy to use websites - here are some:
Pick any of those sites, download a map, and save it under ~/.spring/maps/ (if the folder doesn't exist - create it). Don't unpack the file in any way though, just download and save it.
Hint: If you know the map name you want, there is a Search function provided in those websites. Just write a part of the name, like one word, and you'll easily find the map you were looking for - this is helpful later on.
[edit] Tips
- If spring hangs/crashes while in full screen mode, you can press ctrl+alt+backspace to restart X, so no need for a reboot.
- Spring uses OpenAL for sound, Config your sound output i.e esd / arts / oss / alsa by editing /etc/openalrc or ~/.openalrc, example: ("'(" is not a typo)
(define devices '(alsa))
(define speaker-num 2)
(define alsa-out-device "hw:0,0")
(define alsa-in-device "hw:0,0")
Adventurous people with an emu10k1 based card (sblive) can try the accelerated openal version. http://www.lost.org.uk/openal.html , don't submit audiobugs if you do.
- If you really can't figure out how to get spring compiled, or you think there's a bug in the code or the buildsystem...
- Just poke any developer on IRC:
- Post it on the forum
- or file a bug in our bug tracking system.
[edit] Troubleshooting
[edit] Ingame
[edit] LuaUI Crash Ingame
This issue is caused by a memory corruption bug in spring. It will be fixed in version after 0.76b1. Ubuntu packages include the fix. Workaround: disable ground decals.
LuaUI can crash during game, because some lua script you use has a bug. 0.75 should be resistant to this problem, but 0.74b3 is not. After crash, you won't see the bottom left tooltip box and top right resource bar anymore. Fear not, help is near:
/resbar 1
/tooltip 1
These might not be necessary in 0.75 anymore at all.
Also, you won't be able to change the build menu page with mouse anymore, but keys , and . do the trick.
LuaUI can also be restarted after it crashed. Often this does the trick and it works fine the rest of the game:
/luaui reload
[edit] Mouse is slow in fullscreen mode
Run:
echo 'export SDL_MOUSE_RELATIVE=0' >> ~/.bash_profile
And log out and log in again.
The mouse should now be as fast as in windowed mode.
[edit] Rotating Buildings Ingame
You can rotate a building before you give the build order, but the keys that do this don't work in linux by default for some users. Issue the following commands in the beginning of the game:
/bind keycodex buildfacing inc
/bind keycodey buildfacing dec
Keycodex and keycodey above are just placeholders. What you want to write depends on which key you want to use. To see what keycodes any keys have, do:
/keydebug yes
And then hit the keys you want to use, and spring prints the keycodes in the message buffer.
TODO: add information on how to save the settings so that they work the next time you start spring.
[edit] Map is White
If the whole map is only shades of white and grey, there is a problem with your display driver. Maybe your gpu is very old and does not support some needed opengl feature. For example I had this problem with matrox g550 but not with some very old geforce.
[edit] Sound is Choppy
If the engine sound is very broken or choppy sounding, and you hear some noise or crackling, you need to tell OpenAL to try to use a different sound backend. If you don't have an ~/.openalrc file, create it with these contents, or modify your current one to look like this:
(define devices '(native alsa sdl arts esd null))
(define alsa-device "dsp0")
(define speaker-num 2)
- (define sampling-rate 22050)
The important line here is the "define devices" line, OpenAL attempts to use each of those sound output methods in order. It uses the first one that works; in some cases native will work best, in other cases perhaps alsa. If Gnome is running its sound daemon, esd would be the best choice, while KDE usually uses artsd.
[edit] Startup
[edit] Missing Default Cursor
This or any similar error of not being able to find a specific file are usually because the mod you are using needs ota content, download & install as explained earlier in this document.
[edit] could not open file: gamedata/defs.lua
Make sure your ~/.spring does not contain an outdated version of base/springcontent.sdz because a new version of this file is distributed with spring. If you do, just remove it.
[edit] sounds/button9.wav "cant find wav file"
Same problem as above.
[edit] Couldnt find matching GLX visual
Reduce anti aliasing.
[edit] GL_ARB_texture_compression not found
This can be an issue with your gpu drivers. The drivers you are using do not support a feature that is required to run spring. You might have better luck with the closed source official drivers of nvidia or amd cards. If your gpu itself is really old, this might not help.
If you use the fglrx ati-graphics driver and you are getting this error there might be a chance that still spring work (I use this with ubuntu gusty). At first we must check that fglrx is installed correctly:
~$ fglrxinfo
display: :0.0 screen: 0
OpenGL vendor string: ATI Technologies Inc.
OpenGL renderer string: ATI Mobility Radeon X1400
OpenGL version string: 2.0.6747 (8.40.4)
Then lets check the glx-extention.
~$ glxinfo | grep direct
Xlib: extension "XFree86-DRI" missing on display ":1.0".
direct rendering: No
If you get this message, notice that glxinfo releates to display ':1' and fglrxinfo to display ':0'!! Lets check the glx-extention on display :0 now.
~$ DISPLAY=:0 glxinfo | grep direct
direct rendering: Yes
This message mean that you can start spring by typing (in a terminal)
~$ DISPLAY=:0 spring
If you use the TASclient with wine and the native linux spring. Start the whole TASclient-start-script by typing.
DISPLAY=:0 TASCLIENT-start-script
But Notice under circumstances is no windowmanager running on screen :0! This means there are NO windowframes at the TASClient window! You can't move it or close it by clicking the closebutton (unless you click at the close button on the terminal-window in witch you startet TAS). You can although close TAS with the keys ALT-F4
[edit] OpenAL Segfault
If spring crashes with this output:
OpenAL: ALC_EXT_capture AL_EXT_capture AL_EXT_vorbis AL_EXT_MP3
AL_LOKI_quadriphonic AL_LOKI_play_position AL_LOKI_WAVE_format
AL_LOKI_IMA_ADPCM_format AL_LOKI_buffer_data_callback ALC_LOKI_audio_channel
Segmentation fault (core dumped)
Look into this thread on the forums for a fix: http://spring.clan-sy.com/phpbb/viewtopic.php?f=20&t=12568
Then bug nemo in #taspring to finish this troubleshooting entry. He knows how to fix it.
This is mod-related, ie. it only happens on some mods. Please list here the mod versions that give this error for you.
- Star Wars mod, unknown version, by user report
The problematic mod contains a sound file that crashes openal. You can try to unzip the mod file that crashed for you, and play each sound file. Please report any sound files that fail to play right, just list them here.
- unknown file
[edit] Desync in game
If you start a network game with other players, and you get sync error messages in game, your lobby version may be too old. It does not support the new protocol so it does not set the options on spring correctly, and desyncs at game start.
[edit] Compiletime
[edit] invalid use of ILvoid / ALCvoid
During compiling, if you get a lot of the following errors:
/usr/include/IL/il.h:497: error: '<anonymous>' has incomplete type
/usr/include/IL/il.h:497: error: invalid use of 'ILvoid'
This happens because the version of libdevil-dev you have installed is not compatible with gcc version 4.2 and newer.
You should upgrade your libdevil-dev to fix this issue. However, in some distributions (at least gentoo), the fixed package has the SAME version number as the older unfixed package, so you might actually need to remove your current libdevil-dev package completely and reinstall it.
this is an issue that can be better hacked there. while the packages aren't fixed for their maintainers, you will need to do nasty things, like that:
//typedef void ALCvoid;
#define ALCvoid void
[edit] Network Setup
Usually you don't need to do any network setup whatsoever, because the lobbies take care of nat traversal with firewall hole punching, but if you need to know the topology, it goes like this:
Host needs to enable incoming udp to port 8452, and outgoing replies to those. Non-host players need to enable outgoing udp, and incoming replies to those. So basically only non-host players initiate "connections", and only the server listens on a well-known port.
[edit] If You Still Have Problems
Join to #taspring on Freenode or #sy on QuakeNet and try your luck.
However, generic linux problems not really related to installing this should be asked elsewhere.
Prepare to list your distribution, which installation method you used, and what exactly is the error. Don't ask if people are around or not, just go straight to business and tell all details, for maximizing your chances of getting help.
[edit] IRC
- #taspring @ FreeNode
- #sy @ QuakeNet
[edit] Asking For Help
Ok so you need human help. This is how NOT to do it:
15:54 -!- **** [n=****@*] has joined #taspring
15:54 < ****> Hi, i have a problem with compiling spring on debian
15:54 < ****> can anyone help me?
15:57 -!- **** [n=****@*] has quit [Client Quit]
Don't ask to ask, instead go straight to business by stating the exact problem you have, and giving all necessary information. What you were trying to achieve, how did you try to do it, what happened and what did you expect to happen.
Then WAIT for someone to notice you.
