-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathREADME
135 lines (107 loc) · 5.16 KB
/
README
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
OpenBOR (anallyst edition)
--------------------------
ABOUT THIS GIT REPO
===================
this git-repository has both the anallyst version of
OpenBOR (branch master) and the "official" version
from Chronocrash (former Lavalit) from SVN in branch svn.
The anallyst edition was forked off from SVN revision
3233 and was kept in sync with lavalit until rev 3318.
Differences:
the anallyst version is heavily optimized, debloated and
debugged and runs much faster than the lavalit version.
it has also a lot of platform-specific junk stripped off.
unlike the official version, this version is able to play
extracted mods directly from a directory.
this makes it much easier to debug and improve them.
the lavalit version has more bugs and some new features
which are not in mainstream usage.
some of the new features that were encountered in real-world
mods were backported to the anallyst version.
the anallyst edition should be able to play 99% of available
mods, after unpacking and repacking them with borpak from this
repo (see below).
the history of this git repo lasts back until SVN REV 3020,
at which point the repo was split into 2 parts.
the official svn repo is broken and it is not possible to
retrieve earlier commits.
the history was slightly edited with automatic tools to
remove all embedded binaries
(except of the required resources like .png's).
the original had a lot of cruft in the tools directory
(entire tarballs of toolchains, svn-setup.exe, etc.)
adding these to this git repo would make it about 100x bigger
and thus slower to use, so they were omitted.
also automatically generated changes to version.h, meta.xml
and Info.plist were removed from the commits (version numbers
generated by make), as those just make it harder to see the
relevant information.
BUILD
=====
just run:
make
an executable of the name "OpenBOR" will be created.
possible flags to make:
NO_GL=1 BUILD_DEBUG=1 make #will build without opengl but with debugging support
OpenBOR directory layout:
-> OpenBOR (executable)
-> Paks/ (put paks or directories with extracted paks)
-> ScreenShots/
-> Logs/
-> Saves/
ABOUT
=====
OpenBOR is a continuation of the Beats Of Rage 2D game engine, which was originally
created by http://www.senileteam.com.
this is a fork of "official OpenBOR" (i.e. from lavalit forums)
by rofl0r aka anallyst, former "OpenBOR team" member.
his work on OpenBOR started back with SVN rev ~2900.
he left the lavalit team due to internal differences after SVN rev 3318 and
started his own fork.
instead of adding features over features, it is the intent to strip off
unnecesary stuff and simplify things,
while staying compatible to the existing mods and POSIX.
a possible idea is to add lua scripting support at some point in the future,
and the ugly and slow "C script" interpreter code can be removed and the
good mods be converted to lua.
Current Situation/Comparison with "official" OpenBOR
====================================================
PAKS:
since the commit tagged "pak-change" the internal layout of
.pak files has changed to simplify things.
filenames are stored in unix fashion (/) and lowercase only.
to make old pak files compatible, they have to be "converted":
extract them using the borpak tool in tools/borpak,
then repack them using the same tool.
this results in a fresh pak in the required format.
this change made it possible to use extracted paks in a directory.
you can simply create a directory in the Paks dir for each game
(i.e. Paks/MyGame/data/)
BLOAT:
OpenBOR (anallyst edition) x64 binary : 750 KB
OpenBOR (lavalit edition, rev 3320) x64 binary : 1250 KB
OpenBOR (lavalit edition, rev 3600+) x64 binary : probably 1.5 MB+
SPEED:
anallysts work on OpenBOR made for huge speed improvements in loading times.
most mods now load in an instant and took several seconds (up to minutes (!))
formerly.
this improvements have gone into the lavalit version as well, but some team
members there prefer seeing a moving loading bar between levels over instant
loading, so some of the optimisations has been removed by them.
it's likely that the lavalit version will get slower and slower over time.
this fork is currently the fastest openbor version available.
MOD COMPATIBILITY:
some upstream features have been ported so mods relying on OpenBOR 36xx features
should work exactly as intended.
compatibility to older mods should be even better as the lavalit version
as some bugs have been fixed that prevented some mods to work with anything
newer than rev 28xx.
PLATFORMS:
support for any non-posix compatible game console has been removed.
this fork builds well on any posix compatible platform that has ports
of libogg/vorbis and SDL.
this means it should build on any linux based device, *BSD, etc.
possibly even mingw.
we're taking the stance that instead of buying a commercial game console to
crack it for homebrew usage, you should rather buy products that are intended
for homebrewers and thus support the companies producing them.