Difference between revisions of "Building LÖVE"
m (adding a library to Ubuntu/Debian) |
(Update branch and add note about SDL3) |
||
Line 23: | Line 23: | ||
git checkout 0.8.0 # any (released) version from 0.6.0 onwards. | git checkout 0.8.0 # any (released) version from 0.6.0 onwards. | ||
git checkout 0.7.2 | git checkout 0.7.2 | ||
− | git checkout | + | git checkout 11.x # to the latest commit at stable branch (currently 11.x) |
− | git checkout | + | git checkout main # to the latest commit at upcoming version 12.0 |
</source> | </source> | ||
Line 38: | Line 38: | ||
=== Linux === | === Linux === | ||
Download the development packages of the dependencies from the repository of your distribution. | Download the development packages of the dependencies from the repository of your distribution. | ||
+ | |||
+ | ==== Note on LÖVE 12.0 ==== | ||
+ | LÖVE 12 requires '''recent commit of SDL3''' instead of SDL2, which may not packaged by your distro. We recommend using | ||
+ | [https://github.com/love2d/love-appimage-source love-appimage-source] to compile LÖVE 12. If for any reason you cannot use it, you must have SDL3 development files installed. | ||
+ | |||
+ | LÖVE 12 no longer uses mpg123. It is safe to compile LÖVE 12 without it present. | ||
==== Ubuntu and Debian Jessie onwards ==== | ==== Ubuntu and Debian Jessie onwards ==== | ||
<source lang="bash"> | <source lang="bash"> | ||
sudo apt-get install build-essential autotools-dev automake libtool pkg-config \ | sudo apt-get install build-essential autotools-dev automake libtool pkg-config \ | ||
− | libfreetype6-dev libluajit-5.1-dev | + | libfreetype6-dev libluajit-5.1-dev libsdl3-dev libopenal-dev libogg-dev \ |
− | libvorbis-dev libmodplug | + | libvorbis-dev libmodplug-dev libtheora-dev libharfbuzz-dev |
</source> | </source> | ||
These are taken from the <code>platform/unix/debian/control.in</code> file in the repository. | These are taken from the <code>platform/unix/debian/control.in</code> file in the repository. | ||
Line 54: | Line 60: | ||
</source> | </source> | ||
− | Notes: Prior to [[11.0]], <code>libphysfs-dev</code> is also needed. | + | Notes: |
+ | * Prior to [[11.0]], <code>libphysfs-dev</code> is also needed. | ||
+ | * Prior to [[12.0]], <code>libmpg123-dev</code> is also needed. | ||
+ | * Starting on 12.0, <code>libsdl3-dev</code> is required, which is currently in experimental. 11.x requires <code>libsdl2-dev</code> instead. | ||
==== Arch Linux ==== | ==== Arch Linux ==== | ||
Line 62: | Line 71: | ||
pacman -S luajit physfs freetype2 devil mpg123 openal libvorbis libmodplug sdl2 shared-mime-info hicolor-icon-theme desktop-file-utils # for 0.9.x (taken from package in repository) | pacman -S luajit physfs freetype2 devil mpg123 openal libvorbis libmodplug sdl2 shared-mime-info hicolor-icon-theme desktop-file-utils # for 0.9.x (taken from package in repository) | ||
pacman -S luajit freetype2 mpg123 openal libvorbis libtheora libmodplug sdl2 shared-mime-info hicolor-icon-theme desktop-file-utils # for 11.x | pacman -S luajit freetype2 mpg123 openal libvorbis libtheora libmodplug sdl2 shared-mime-info hicolor-icon-theme desktop-file-utils # for 11.x | ||
− | pacman -S luajit freetype2 openal libvorbis libtheora libmodplug | + | pacman -S luajit freetype2 openal libvorbis libtheora libmodplug sdl3 shared-mime-info hicolor-icon-theme desktop-file-utils # for 12.x, see note below |
</source> | </source> | ||
+ | |||
+ | Please note that ArchLinux currently needs to install [https://aur.archlinux.org/packages/sdl3 SDL3 AUR] when compiling LÖVE 12. | ||
==== Fedora ==== | ==== Fedora ==== | ||
Line 71: | Line 82: | ||
Please note that libmpg123-devel is in the rpmfusion-free repository. | Please note that libmpg123-devel is in the rpmfusion-free repository. | ||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
==== Mageia 2 ==== | ==== Mageia 2 ==== |
Latest revision as of 05:31, 2 January 2025
This page is still incomplete, you are likely to be eaten by a grue. |
This page has information on compiling the LÖVE source code. This is only necessary if you want to make modifications or additions to the framework itself, or if a binary is not provided for your platform (for example, GNU/Linux distributions other than Ubuntu or 32-bit GNU/Linux). If you just want to code a game in Lua, go back to Getting Started. |
LÖVE for Android has its own build instructions which deviates entirely from this page. See the repository for more information! |
Still interested? Okay. Follow these three steps and you'll have your very own LÖVE binary:
Contents
1. Getting the source
The official repository of LÖVE is hosted on GitHub.
You can download the source code either by downloading an archive from one of the tags on the download page or by installing Git and cloning the repository. Almost every Linux distributions have Git in their repositories, some even have it installed by default. Windows and OS X users can get the official binary of Git from here.
To create a clone with Git, open a terminal or command prompt, go to the directory that you want to download the source code folder to and use the following commands:
git clone https://github.com/love2d/love
This will create a love folder and download the latest source code into it.
If you want to use the source code of a specific version, go into the love directory and issue one of the following commands:
git checkout 0.8.0 # any (released) version from 0.6.0 onwards.
git checkout 0.7.2
git checkout 11.x # to the latest commit at stable branch (currently 11.x)
git checkout main # to the latest commit at upcoming version 12.0
2. Dependencies
LÖVE uses several open source libraries such as Lua, libvorbis, etc. Some are shipped alongside LÖVE source code but some must be installed manually. Those libraries and their development files are required to successfully build LÖVE. It's possible to build every dependency yourself, but this is out of the scope of this page. The following explains how you can get prebuilt binaries instead.
Windows
The dependencies and instructions for LÖVE 0.9.0+ can be found here.
Mac OS X
The required pre-built frameworks are available here. Place the frameworks in /Library/Frameworks/
in order for LÖVE's Xcode project to recognize them.
Linux
Download the development packages of the dependencies from the repository of your distribution.
Note on LÖVE 12.0
LÖVE 12 requires recent commit of SDL3 instead of SDL2, which may not packaged by your distro. We recommend using love-appimage-source to compile LÖVE 12. If for any reason you cannot use it, you must have SDL3 development files installed.
LÖVE 12 no longer uses mpg123. It is safe to compile LÖVE 12 without it present.
Ubuntu and Debian Jessie onwards
sudo apt-get install build-essential autotools-dev automake libtool pkg-config \
libfreetype6-dev libluajit-5.1-dev libsdl3-dev libopenal-dev libogg-dev \
libvorbis-dev libmodplug-dev libtheora-dev libharfbuzz-dev
These are taken from the platform/unix/debian/control.in
file in the repository.
For the 0.9.0 branch, older versions of Ubuntu need the latest libsdl2-dev packages, which can be found via this ppa: https://launchpad.net/~bartbes/+archive/love-stable
If you get an error during the build complaining about libturbojpeg, you must first fix a bug in Ubuntu, then run `configure` again:
ln -s /usr/lib/x86_64-linux-gnu/libturbojpeg.so.0 /usr/lib/x86_64-linux-gnu/libturbojpeg.so
Notes:
- Prior to 11.0,
libphysfs-dev
is also needed. - Prior to 12.0,
libmpg123-dev
is also needed. - Starting on 12.0,
libsdl3-dev
is required, which is currently in experimental. 11.x requireslibsdl2-dev
instead.
Arch Linux
pacman -S devil flac freetype2 glibc libmodplug libvorbis lua51 mesa mpg123 openal physfs sdl # 0.6.x
pacman -S devil freetype2 libmodplug libvorbis lua51 mpg123 openal physfs sdl # 0.7.x
pacman -S luajit physfs freetype2 devil mpg123 openal libvorbis libmodplug sdl2 shared-mime-info hicolor-icon-theme desktop-file-utils # for 0.9.x (taken from package in repository)
pacman -S luajit freetype2 mpg123 openal libvorbis libtheora libmodplug sdl2 shared-mime-info hicolor-icon-theme desktop-file-utils # for 11.x
pacman -S luajit freetype2 openal libvorbis libtheora libmodplug sdl3 shared-mime-info hicolor-icon-theme desktop-file-utils # for 12.x, see note below
Please note that ArchLinux currently needs to install SDL3 AUR when compiling LÖVE 12.
Fedora
dnf install freetype-devel glibc-devel libmpg123-devel libmodplug-devel physfs-devel mesa-libGL-devel openal-soft-devel DevIL-devel libvorbis-devel SDL-devel libmng-devel libtiff-devel lua-devel gcc-c++ libtool luajit luajit-devel libtheora-devel SDL2-devel
Please note that libmpg123-devel is in the rpmfusion-free repository.
Mageia 2
urpmi make automake autoconf libopenal-devel libtool libtool-base libphysfs-devel libSDL-devel lua liblua-devel libdevil-devel libmodplug-devel libfreetype6-devel libmpg123-devel libvorbis-devel libmng-devel libxpm-devel libxcursor-devel libxxf86vm-devel
Gentoo
emerge -va lua physfs libsdl opengl devil freetype openal libvorbis mpg123 libmodplug
Make sure you have autotools installed (which should normally be the case):
emerge -va automake autoconf libtool
Other distributions
Any other distribution will most likely have the dependencies in their repositories too, possibly with slightly different package names.
3. Building
Windows
Follow the instructions at the megasource repository page to build LÖVE 0.9.0+.
Be sure to keep the required DLLs in the same folder as love.exe when running the executable.
Mac OS X
Open the love.xcodeproj
file with Xcode and press 'build', or use the xcodebuild
command-line utility.
Linux
Use the automagic script to generate the configure file and then run configure and make as usual.
Be aware that if you got your source from the LÖVE homepage your configure script has been pre-generated. This means that the ./platform/unix/automagic step should be skipped.
./platform/unix/automagic
./configure
make
Your LÖVE binary will end up in the src directory.
Note: If you need to build an AppImage, check love-appimage-source repository instead.
Other Languages
Dansk –
Deutsch –
English –
Español –
Français –
Indonesia –
Italiano –
Lietuviškai –
Magyar –
Nederlands –
Polski –
Português –
Română –
Slovenský –
Suomi –
Svenska –
Türkçe –
Česky –
Ελληνικά –
Български –
Русский –
Српски –
Українська –
עברית –
ไทย –
日本語 –
正體中文 –
简体中文 –
Tiếng Việt –
한국어
More info