]> git.xonotic.org Git - xonotic/xonotic.wiki.git/blobdiff - Shared-libraries-(buildfiles).md
Update Mapping packaging, also tell to save lightmaps
[xonotic/xonotic.wiki.git] / Shared-libraries-(buildfiles).md
index abd9c9b1f4bc4577f4e00997f89e73bcfb2ad174..73577fd9f9275932b156dd07f94e39bfc87670ab 100644 (file)
@@ -1,8 +1,12 @@
-Xonotic on Linux uses system libraries. For Windows and macOS external dlls and dylibs are needed. Those reside in xonotic/misc/buildfiles
+darkplaces/Xonotic on Linux uses system libraries. For Windows and macOS external dlls and dylibs are needed. Those reside in xonotic/misc/buildfiles
 
 Because at the time of writing there is no automatism to build or update the games dependencies for those 2 platforms and the current dlls/dylibs are VERY outdated and thus also contain vulnerabilities, this page should document on where to obtain or how to build them, retaining API compatibility to darkplaces and also older OS platform versions like Windows XP.
 
-For Windows, all libraries can/should be obtained from https://packages.msys2.org/search [1] with the exception of an official DLL release from the upstream being available (this is the case for libjpeg-turbo) or if it has to be compiled on under Windows for some reason (eg. libcurl for Schannel (Windows crypto for HTTPS) support).
+For Windows, all libraries can/should be obtained from https://packages.msys2.org/ [1] with the exception of an official DLL release from the upstream being available (this is the case for jpeg-turbo and freetype) or if it has to be compiled on under Windows for some reason (eg. libcurl for Schannel (Windows crypto for HTTPS) support).
+
+A handy tool to check dll deps on Windows is https://github.com/lucasg/Dependencies
+
+TODO: macOS
 
 # libcurl
 libcurl is used for downloading *.pk3 files from servers
@@ -25,7 +29,7 @@ libjpeg-turbo is needed to display jpeg images/textures
 Darkplaces loads `libjpeg.dll`
 
 Obtainment instructions:
-* download libjpeg-turbo-VERSION-vc.exe & libjpeg-turbo-VERSION-vc64.exe from https://sourceforge.net/projects/libjpeg-turbo/files/
+* download `libjpeg-turbo-VERSION-vc.exe` & `libjpeg-turbo-VERSION-vc64.exe` from https://sourceforge.net/projects/libjpeg-turbo/files/
 * extract the *.exe files and use `bin/jpeg62.dll`
 * rename the dlls (x64 & x86) to `libjpeg.dll`
 
@@ -38,6 +42,11 @@ libpng is needed to display png images/textures
 ### Windows
 Darkplaces loads `libpng16.dll` or `libpng16-16.dll` or `libpng15-15.dll` or `libpng15.dll` or `libpng14-14.dll` or `libpng14.dll` or `libpng12.dll`
 
+Obtainment instructions:
+* be sure to use a 1.16.X release
+* download MSYS2 Package [1] in x86 and x64 versions: https://packages.msys2.org/base/mingw-w64-libpng
+* use dll from `bin` folder
+
 ### macOS
 Darkplaces loads `libpng16.16.dylib` or `libpng15.15.dylib` or `libpng14.14.dylib` or `libpng12.0.dylib`
 
@@ -48,28 +57,88 @@ zlib is required to read *.pk3 files. Also it is a dependency of libpng and prob
 Darkplaces loads: ifdef ZLIB_USES_WINAPI `zlibwapi.dll` or `zlib.dll` else `zlib1.dll`. We use `zlib1.dll`!
 
 Obtainment instructions:
-* Download as MSYS2 Package [1] in x86 and x64 versions
+* download as MSYS2 Package [1] in x86 and x64 versions: https://packages.msys2.org/base/mingw-w64-zlib
+* use dll from `bin` folder
 
 ### macOS
 Darkplaces loads `libz.dylib`
 
 # libfreetype
+Required for the Xolonium font
 
-# libogg
+### Windows
+Darkplaces loads: `libfreetype-6.dll` or `freetype6.dll`
 
-# libvorbis
+Obtainment instructions:
+* Download x86 and x64 dlls from: https://github.com/ubawurinna/freetype-windows-binaries
 
-# libvorbisfile
+### macOS
+Darkplaces loads: `libfreetype.6.dylib` or `libfreetype.dylib`
 
-# libvorbisenc
+# libvorbis + libvorbisfile + libvorbisenc
+libvorbis + libvorbisfile are used to play .ogg audio files while libvorbis + libvorbisenc is used for the audio in video capturing (cl_capturevideo)
+
+### Windows
+Darkplaces loads `libvorbis-0.dll` or `libvorbis.dll` or `vorbis.dll` and `libvorbisfile-3.dll` or `libvorbisfile.dll` or `vorbisfile.dll` and `libvorbisenc-2.dll` or `vorbisenc-2.dll` or `vorbisenc.dll`
+
+Obtainment instructions:
+* download MSYS2 Package [1] in x86 and x64 versions: https://packages.msys2.org/base/mingw-w64-libvorbis
+* use dll from `bin` folder
+
+### macOS
+Darkplaces loads `libvorbis.dylib` and `libvorbisfile.dylib`
 
 # libtheora
+libtheora is used for the video in cl_capturevideo
+libtheoraenc/libtheoradec are not needed, they are the newer API; darkplaces uses the legacy pre 1.0 API (libtheora).
+
+### Windows
+Darkplaces loads `libtheora-0.dll` or `theora-0.dll` or `theora.dll`
+
+Obtainment instructions:
+* download MSYS2 Package [1] in x86 and x64 versions: https://packages.msys2.org/base/mingw-w64-libtheora
+* use dll from `bin` folder
+
+### macOS
+Darkplaces loads `libtheora.dylib`
+
+# libogg
+libogg is used for the container in cl_capturevideo
+
+### Windows
+Darkplaces loads `libogg-0.dll` or `libogg.dll` or `ogg.dll`
 
-# libstdc++-6 & libgcc_s_sjlj-1
-libgcc_s_sjlj-1 is a dependency of libstdc++-6
+Obtainment instructions:
+* download MSYS2 Package [1] in x86 and x64 versions: https://packages.msys2.org/base/mingw-w64-libogg
+* use dll from `bin` folder
+
+### macOS
+Darkplaces loads `libogg.dylib`
 
 # libd0_blind_id-0 & libd0_rijndael-0
-See https://gitlab.com/xonotic/d0_blind_id
+Internal project, see https://gitlab.com/xonotic/d0_blind_id
 
 # libgmp
-A dependency of libd0_blind_id-0
\ No newline at end of file
+A dependency of libd0_blind_id-0
+
+### Windows
+libd0_blind_id-0 loads `libgmp-10.dll`
+
+Obtainment instructions:
+* download as MSYS2 Package [1] in x86 and x64 versions: https://packages.msys2.org/base/mingw-w64-gmp
+* use dll from `bin` folder
+
+# libode
+Is not loaded under Windows and crashes the game if it is and a map is loaded up.
+Also it is not statically linked and thus requires libstdc++-6.dll and libgcc_s_sjlj-1.dll.
+
+# libavw
+*Note:* Old and not used in Xonotic but also not disabled :) Adding this for the sake of completeness.
+
+### Windows
+Darkplaces loads: `libavw.dll`
+
+Source code: https://github.com/paulvortex/DpLibAVW
+
+### macOS
+Darkplaces loads: `libavw.dylib`
\ No newline at end of file