-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathINSTALL
230 lines (170 loc) · 7.4 KB
/
INSTALL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
########
# 1oom #
########
1. Options
===========
The configuration options:
--enable-static enable static builds (experimental)
--enable-modebug add debugging options
--without-readline do not try to use the readline library
(used by 1oom_cmdline)
--without-samplerate do not try to use libsamplerate
--disable-tools disables extra tools
(do not build 1oom_pbxmake, 1oom_gfxconv, ...)
--disable-uiclassic disables classic UI
(do not build 1oom_classic_*)
--disable-uicmdline disables cmdline UI
(do not build 1oom_cmdline)
--disable-hwsdl1 disables SDL1 HW
(do not build 1oom_*_sdl1)
--disable-hwsdl1audio disables SDL1 HW audio support
(no audio for 1oom_*_sdl1)
--disable-hwsdl1gl disables SDL1 HW OpenGL support
(no graphics resizing for 1oom_*_sdl1)
--disable-hwsdl2 disables SDL2 HW
(do not build 1oom_*_sdl2)
--disable-hwsdl2audio disables SDL2 HW audio support
(no audio for 1oom_*_sdl2)
--disable-hwalleg4 disables Allegro 4 HW
(do not build 1oom_*_alleg4)
--disable-hwx11 disables X11 HW
(do not build 1oom_classic_x11)
Parameters for configure:
CFLAGS
SDL1_CFLAGS
SDL1_LIBS
SDL1MIXER_LIBS
SDL2_CFLAGS
SDL2_LIBS
SDL2MIXER_LIBS
2. Quick guide
===============
You'll need make and a C99 compiler. You will most likely also want to have
SDL development libraries. Both SDL 1.2.x and SDL2.x are supported.
If you want to use SDL1:
aptitude install libsdl1.2-dev libsdl-mixer1.2-dev
If you prefer SDL2:
aptitude install libsdl2-dev libsdl2-mixer-dev
For better audio quality, also get libsamplerate.
aptitude install libsamplerate-dev
OpenGL libraries are highly recommended.
If you checked this out with git, do this first:
autoreconf -fi
Make a build directory:
mkdir build-native
cd build-native
Then the usual:
../configure && make -j 3
!!! You need the data files from the original Master of Orion to run 1oom. !!!
Actual install step is not needed:
src/1oom_classic_sdl1 -data /path/to/moo
src/1oom_classic_sdl2 -data /path/to/moo
The install step can still be done:
make install
3. Compiling on Windows
========================
To compile 1oom, you need a GNU build environment. This guide uses MinGW to
compile the SDL2 version of 1oom. There are other options you may use, like
Cygwin, MinGW-w64 or MSYS2, but in that case, you're on your own.
Download and install mingw-get-setup.exe from: https://osdn.net/projects/mingw/releases/
This will install a graphical package manager. Ensure that you have the latest autoconf,
automake and make versions available and also MSYS.
Download the SDL2 development libarary for MinGW from:
https://www.libsdl.org/download-2.0.php
Download the SDL2 mixer development library for MinGW from:
https://www.libsdl.org/projects/SDL_mixer/
Then unzip the two archives you downloaded.
Then, open a command prompt and run
C:\MinGW\msys\1.0\bin\sh
which gives you a UNIX-style command prompt. First, add the MinGW binaries to
your PATH:
PATH="/c/MinGW/bin:/c/MinGW/msys/1.0/bin:$PATH"
Then, go to the directory where you extracted SDL2 and enter:
make native
Do the same for SDL2 Mixer.
You are now ready to configure and build 1oom as described in Section 2. When
running configure, pass the following options:
--disable-hwsdl1 --disable-hwalleg4 --disable-hwx11
To run 1oom, place the *32-bit* versions of SDL2.dll and SDL2_mixer.dll in the
same directory as the binary.
4. Cross-compiling
===================
[These instructions were written by KilgoreTroutMaskReplicant for 1oom v1.0. I
have not tested them, but I leave them here in case they turn out to be useful
for somebody -- Max Fillinger]
Something like this may work:
mkdir build-win32d
cd build-win32d
../configure --host=i686-w64-mingw32.shared
If the libraries are not found, try something like:
../configure --host=i686-w64-mingw32.shared
SDL1_CFLAGS="`i686-w64-mingw32.shared-sdl-config --cflags`" \
SDL1_LIBS="`i686-w64-mingw32.shared-sdl-config --libs`" \
SDL1MIXER_LIBS="`i686-w64-mingw32.shared-pkg-config --libs SDL_mixer`" \
SDL2_CFLAGS="`i686-w64-mingw32.shared-sdl2-config --cflags`" \
SDL2_LIBS="`i686-w64-mingw32.shared-sdl2-config --libs`" \
SDL2MIXER_LIBS="`i686-w64-mingw32.shared-pkg-config --libs SDL2_mixer`"
Good luck!
4.1. Unix to win32
===================
This is a quick guide to make a cross compiler based on MXE: http://mxe.cc/
First we build MXE:
git clone https://github.com/mxe/mxe.git
cd mxe
make MXE_TARGETS='i686-w64-mingw32.shared' gcc sdl sdl_mixer sdl2 sdl2_mixer libsamplerate readline
(or i686-w64-mingw32.static if you want static binaries, or maybe both)
Edit your .bashrc, .profile or equivalent and add/edit:
export PATH="/MXE_path/usr/bin:$PATH"
(If you are unsure of the MXE_path, run pwd.)
Run the export line on the current terminal to set the PATH for this session.
Now to cross compile 1oom:
cd ~/path/to/1oom
mkdir build-win32d
cd build-win32d
../configure --host=i686-w64-mingw32.shared && make -j 3
If you want to make distributable packages of .shared compiles:
mkdir extrabindist_win32
cp /MXE_path/usr/i686-w64-mingw32.shared/bin/{SDL*,libgcc_s_sjlj-1.dll,libsamplerate.dll} extrabindist_win32
(the list may be incomplete; run the EXEs in wine and see the error messages)
4.2. Unix to msdos
===================
This is a quick guide to cross compile a MSDOS binary.
First get a cross compiler:
git clone https://github.com/andrewwutw/build-djgpp.git
...
(or just grab a prebuilt one from the GitHub page)
Edit your .bashrc, .profile or equivalent and add/edit:
export PATH="/djgpp_path/bin:$PATH"
Run the export line on the current terminal to set the PATH for this session.
Get allegro-4.2.3.1.tar.gz from http://liballeg.org/
tar xaf allegro-4.2.3.1.tar.gz
cd allegro-4.2.3.1
"Fix" it for djgpp:
./fix.sh djgpp
Apply patches:
patch -p1 < /path/to/1oom/doc/ext/allegro-4.2.3.1-p1-modern-xmake.patch
patch -p1 < /path/to/1oom/doc/ext/allegro-4.2.3.1-p2-remove-mouse-cursor.patch
patch -p1 < /path/to/1oom/doc/ext/allegro-4.2.3.1-p3-disable-unused.patch
Edit xmake.sh and check that the paths and compiler name are correct.
./xmake.sh
Copy the header files to the cross compiler:
cp -r include/* /opt/djgpp/i586-pc-msdosdjgpp/include
Copy the library file to the cross compiler:
cp lib/djgpp/lib*a /opt/djgpp/i586-pc-msdosdjgpp/lib
Now to cross compile 1oom:
cd ~/path/to/1oom
mkdir build-msdos
cd build-msdos
../configure --host=i586-pc-msdosdjgpp && make -j 3
5. Building distributable packages
===================================
Build a tarball requiring no Autotools:
make dist
Some OS targets support building binary distributions. The bindist scripts
use git for version information if .git/ exists, otherwise the version is
"vUnknown". Files from extrabindist_common/ and extrabindist_$OS/ are copied
to the distribution.
Build a binary distribution:
make -j 3 && make bindist
Build a binary distribution zip:
make -j 3 && make bindistzip