History of Oni modding: Difference between revisions

polishing verbiage, adding subheaders to break up the walls of text
(maybe a bit rough, but here's a general update)
(polishing verbiage, adding subheaders to break up the walls of text)
Line 1: Line 1:
:''This article is a historical perspective on Oni modding; for an introduction to how to actually mod Oni, see [[Modding Oni|here]]. To download mods, you can start [[AE|here]].''
:''This article is a historical perspective on Oni modding; for an introduction to how to actually mod Oni, see [[Modding Oni|here]]. To download mods, you can start [[AE|here]].''


As has been documented on the page about [[Oni]]'s overall development, time ran out for Bungie West to do everything they wanted with this very ambitious game. Just as some features had to be omitted, the promise of modding support
As has been documented on the page about [[Oni]]'s overall development, time ran out for Bungie West to do everything they wanted with this very ambitious game. Just as some features had to be omitted, the promise of modding support
<ref>
<ref>
In [[Harry]]'s [http://oni.bungie.org/special/part1/brent.html interview], Brent Pease, the Project Lead, said: "What we will do is, I'm about 90 percent sure of this, is give away the file format." He also promises with equal certainty that the tools for converting 3D Studio Max models into Oni models will be given away. Pease eventually left the project before its completion. Hardy LeBel, his replacement, would later say that, due to the time crunch, "Our primary focus had to be on completing the content and features of the game rather than building in support for the mod community."
In [[Harry]]'s [http://oni.bungie.org/special/part1/brent.html interview], Brent Pease, the Project Lead, said: "What we will do is, I'm about 90 percent sure of this, is give away the file format." He also promises with equal certainty that the tools for converting 3D Studio Max models into Oni models will be given away. Pease eventually left the project before its completion. Hardy LeBel, his replacement, would later say that, due to the time crunch, "Our primary focus had to be on completing the content and features of the game rather than building in support for the mod community."
Line 8: Line 8:
<ref>Fans wasted no time in dumping the readable text from the executable and trying to figure out how to enable Developer Mode, as [http://carnage.bungie.org/oniresforum/onires.archive.pl?read=35 this thread] from before the game's official release date attests. Little did they know it would take another five years before this particular goal would be reached.
<ref>Fans wasted no time in dumping the readable text from the executable and trying to figure out how to enable Developer Mode, as [http://carnage.bungie.org/oniresforum/onires.archive.pl?read=35 this thread] from before the game's official release date attests. Little did they know it would take another five years before this particular goal would be reached.
</ref>
</ref>
Nevertheless, the lack of any documentation of tools for modding undeniably slowed the development of mods within the community. Only for the last {{age|2010|11|6}}<!--This is the date that geyser posted about new levels having pathfinding grids in the article "New levels".--> years has the community's modding capabilities covered nearly all aspects of the game.
Nevertheless, the lack of any documentation or tools for modding undeniably slowed the development of mods within the community. Only for the last {{age|2010|11|6}}<!--This is the date that geyser posted about OniSplit supporting pathfinding grids for new levels in the article "New levels".--> years has the community's modding capabilities covered nearly all aspects of the game.


There are three basic areas in which the game can be modded. In order of difficulty they are: scripting, binary resources, and the engine code.  Along the way, we'll look at some key discoveries the community made in more detail.
There are three basic areas in which the game can be modded: scripting, binary resources, and the engine itself.  Along the way, we'll look at some key discoveries the community made in more detail.


==BSL scripting==
==BSL scripting==
Line 16: Line 16:
Since the .bsl files were plain-text, and in plain <u>sight</u> within the folders that held Oni's game data, it's not surprising that fans quickly learned some basic commands by seeing what Bungie had written, and making their own scripts. Further commands were discovered by dumping readable text from the engine, although not everything worked as it seemed it should.
Since the .bsl files were plain-text, and in plain <u>sight</u> within the folders that held Oni's game data, it's not surprising that fans quickly learned some basic commands by seeing what Bungie had written, and making their own scripts. Further commands were discovered by dumping readable text from the engine, although not everything worked as it seemed it should.


As scripters were learning BSL, they produced scripts that at first merely modified the original level logic in minor ways. Later, they produced more original, often epic fight scripts (e.g. [[OTA]]); finally, some ambitious modders scripted totally new objectives and mission layouts (e.g., Mariachi Bear's alternate storyline). However, fully original scripts are all the more prone to bugs. The first two are easier to set up, but extreme situations tend to overload the engine (as in [[Blam]]!) in ways that the scripters have trouble preventing.
As scripters were learning [[BSL]], they produced scripts that at first merely modified the original level logic in minor ways. Later, they produced more original, often epic fight scripts (e.g. [[OTA]]); finally, some ambitious modders scripted totally new objectives and mission layouts (e.g., Mariachi Bear's alternate storyline). However, fully original scripts are all the more prone to bugs. The first two are easier to set up, but extreme situations tend to overload the engine (as in [[Blam]]!) in ways that the scripters have trouble preventing.


Testing the scripts required large numbers of attempts in launching Oni and running the scripts to see how they worked.  This process became much faster when the Developer Mode console was unlocked (see below) and individual commands could be tested easily.  While this is the easiest way to mod Oni, it's also the most limited; partly because of the lack of full documentation for BSL (which this wiki hopes to provide at some point), and partly because scripts are limited to the resources that an original level has to offer.
Testing the scripts required large numbers of attempts in launching Oni and running the scripts to see how they worked.  This process became much faster when the Developer Mode console was unlocked (see below) and individual commands could be tested easily.  While this is the easiest way to mod Oni, it's also the most limited; partly because of the lack of full documentation for BSL (which this wiki hopes to provide at some point), and partly because scripts are limited to the resources that an original level has to offer.
Line 22: Line 22:


==Binary resources==
==Binary resources==
===Private knowledge, public results===
[[Image:OniTools.jpg|thumb|225px|right|Ian Patterson was probably the most influential early binary hacker, and his trail-blazing program [[OniTools]] for the Mac was quickly ported to Windows.  It had support for delta patches, and the earliest binary mods were probably based on this method.]]
[[Image:OniTools.jpg|thumb|225px|right|Ian Patterson was probably the most influential early binary hacker, and his trail-blazing program [[OniTools]] for the Mac was quickly ported to Windows.  It had support for delta patches, and the earliest binary mods were probably based on this method.]]
[[Image:OUP_txmpreplace.jpg|thumb|225px|right|OniUnPacker by Alloc, premiering in fall of 2005, provided a simple interface for finding the resource you wanted and displaying it, as well as replacing it.]]
[[Image:OUP_txmpreplace.jpg|thumb|225px|right|OniUnPacker by Alloc, premiering in fall of 2005, provided a simple interface for finding the resource you wanted and displaying it, as well as replacing it.]]
Line 31: Line 32:
This did not stop one intrepid programmer named Pierre Terdiman from deciding to import data from Oni into the game engine that he was writing from scratch. Called [[Konoko Payne]], it is a long-term project which currently takes the form of (1) an underlying engine, and (2) a short scenario for it that resembles a sequel to Oni. In order to extract models and animations from Oni and recreate them precisely in his project, Pierre became one of the early pioneers in "reverse engineering" the game's resources, although his acquired knowledge remained largely private, as his work predated the community's organized public attempts at gathering this information.
This did not stop one intrepid programmer named Pierre Terdiman from deciding to import data from Oni into the game engine that he was writing from scratch. Called [[Konoko Payne]], it is a long-term project which currently takes the form of (1) an underlying engine, and (2) a short scenario for it that resembles a sequel to Oni. In order to extract models and animations from Oni and recreate them precisely in his project, Pierre became one of the early pioneers in "reverse engineering" the game's resources, although his acquired knowledge remained largely private, as his work predated the community's organized public attempts at gathering this information.


Public efforts in "hacking" the binary data began, as far as the modern community is concerned, in the fall of 2004 when [[User_talk:Ssg|Ssg]] started a site on the newly-opened [http://www.oni2.net Oni2.net], a domain run by [[User:Admin|Alloc]], carrying over and translating information that Ssg had originally placed on another site in his native German. A year later, this pool of knowledge was painstakingly moved by [[User:Geyser|geyser]] and Ssg to its [[OBD|current home]] on the wiki to allow collaboration; at this point, [[User_talk:Neo|Neo]] appeared on the scene, adding his own knowledge that he had been acquiring independently until then, and collaborating on further investigations into the resource formats. Today at least 90% of the binary resource formats are documented byte for byte thanks to their hard work.
===Hackers unite===
Public efforts in "hacking" the binary data began, as far as the modern community is concerned, in the fall of 2004 when [[User_talk:Ssg|Ssg]] started a site on the newly-opened [http://www.oni2.net Oni2.net], a domain run by [[User:Admin|Alloc]], carrying over and translating information that Ssg had originally placed on another site in his native German. A year later, this pool of knowledge was painstakingly moved by [[User:Geyser|geyser]] and Ssg to its current home on the wiki, the [[OBD|Oni Binary Database]], to allow collaboration; at this point, [[User_talk:Neo|Neo]] appeared on the scene, adding his own knowledge that he had been acquiring independently until then, and collaborating on further investigations into the resource formats. Today at least 90% of the binary resource formats are documented byte for byte thanks to their hard work.


===Modding by candlelight===
Originally, modders had to alter these binary resources manually with hex editors to adapt them to their scripts. [[User:Loser|Loser]] was the first modder to manually edit the game data to go along with his scripting, with a massively reshuffled Warehouse. Loser's [[AE:Warehouse|Warehouse mod]] included a global component (modified level0_Final), level-specific binary modifications, and a set of customized scripts that took full advantage of the modified binaries.
Originally, modders had to alter these binary resources manually with hex editors to adapt them to their scripts. [[User:Loser|Loser]] was the first modder to manually edit the game data to go along with his scripting, with a massively reshuffled Warehouse. Loser's [[AE:Warehouse|Warehouse mod]] included a global component (modified level0_Final), level-specific binary modifications, and a set of customized scripts that took full advantage of the modified binaries.


Line 39: Line 42:
BIP was hindered by large upload/download sizes as well as by the potential legal issues involved in distributing entire files from the game; in 2006 it was replaced by a smarter alternative to supplying whole levels, in the form of [[OUP|OniUnPacker]]-based patches and was termed [[AE:ONK|Oni ni Kanabô]]. The modder would edit his DAT/RAW files in OUP, and then release a single binary resource patch. This was both bandwidth-efficient and more legal-friendly, but suffered from one major limitation: the indexation of DAT resources and the offsets of RAW data vary a lot across the available versions of Oni. Thus, resources exported with OUP were not truly standalone or portable. Also, OUP still lacked the ability to import new resources alongside existing ones.
BIP was hindered by large upload/download sizes as well as by the potential legal issues involved in distributing entire files from the game; in 2006 it was replaced by a smarter alternative to supplying whole levels, in the form of [[OUP|OniUnPacker]]-based patches and was termed [[AE:ONK|Oni ni Kanabô]]. The modder would edit his DAT/RAW files in OUP, and then release a single binary resource patch. This was both bandwidth-efficient and more legal-friendly, but suffered from one major limitation: the indexation of DAT resources and the offsets of RAW data vary a lot across the available versions of Oni. Thus, resources exported with OUP were not truly standalone or portable. Also, OUP still lacked the ability to import new resources alongside existing ones.


The advent of Neo's [[OniSplit]] in late 2007 marked a radical improvement to our modding methods. A command-line tool for Windows (that can also run on Macs), OniSplit breaks Oni's resources into standalone, truly portable files. These resources can be edited and recombined to create the level data files that Oni reads, but new resources can also be created easily from scratch; image files can be made into texture resources, 3D models into new characters, etc. To take advantage of this, geyser began preparing an OniSplit-based port of some of the work done on BIP and ONK, which he hoped would be ready for the seventh anniversary of Oni's release, January 2008.
===Modular modding===
The advent of Neo's [[OniSplit]] in late 2007 marked a radical improvement to our modding methods. A command-line tool that runs on Windows and Macs, OniSplit breaks Oni's resources into standalone files, making mods truly portable across different retail versions of Oni. These resources can be exported to standard formats as text, images, sounds and 3D models, edited, and recombined into the level data files that Oni expects, and new resources can also be created from scratch. To take advantage of this revolution in modding, geyser began preparing an OniSplit-based port of some of the work done on BIP and ONK, which he hoped would be ready for the seventh anniversary of Oni's release in January 2008.


This Seventh [[Anniversary Edition]] had major releases in January and July 2008. The project then changed hands to [[User:Gumby|Gumby]], who designed a truly modular framework for mods and wrote a GUI-based installer. Since the seventh anniversary had come and gone, the mod collection was simply called the Anniversary Edition, the Edition, or the AE. Released in July 2009, the new AE's framework allowed modders to create their own "[[Making a mod package|packages]]". These could be stored on the {{OMD}}, and if downloaded by the player and placed in a subdirectory of the AE, they would then appear as a choice in the Installer. Another release was made in May 2010 which allowed the AE to install updates smartly rather than requiring manual file replacement by the player, but these updates still needed to be downloaded manually.
This so-called "[[AE|Seventh Anniversary Edition]]" had major releases in January and July 2008. The project then changed hands to [[User:Gumby|Gumby]], who designed a framework and a GUI-based installer that allowed players to selectively install only the modifications that they wanted. Since Oni's seventh anniversary had come and gone, the mod collection was renamed simply the "Anniversary Edition", also known as the "Edition", or the "AE". Released in July 2009, the new AE's framework allowed modders to create their own "[[Making a mod package|packages]]". These could be stored on the {{OMD}}, and if downloaded by the player and placed in a subdirectory of the AE, they would then appear as a choice in the Installer. Another release was made in May 2010 with more bundled mods and an improved framework.


Nothing new took place on this front until 2013, by which time the project had fallen into [[User:Iritscen|Iritscen's]] hands in the absence of geyser and Gumby. At this time, the release of the new AE included a brand-new Installer written by Alloc which could connect to the Mod Depot automatically to offer all mod packages for download and allow the user to download updates to his mods and patches. The AE was stripped down to only non-controversial fixes for the first time since the release of its grandfather, BIP, in 2005, making all notable game modifications into optional third-party mods.
Nothing new took place on this front until 2013, by which time the project had fallen into [[User:Iritscen|Iritscen's]] hands in the absence of geyser and Gumby. At this time, the release of the new AE included a brand-new Installer written by Alloc which could connect to the Mod Depot automatically, offer all mod packages for download, and update the mods and patches already installed. The AE's bundled content was stripped down to only non-controversial fixes for the first time since the release of its grandfather, BIP, in 2005, making all notable game modifications into optional third-party mods.
<br clear="all" />
<br clear="all" />


==Engine patching==
==Engine patching==
[[Image:Sfeli Finds Dev Mode.jpg|thumb|225px|right|[[User_talk:SFeLi|SFeLi]] documents his discovery in 2006; in examining the binary, he noticed that the list of cheat codes had a gap in it where one code had been removed; that code was for Developer Access. For more history, see [[History of Oni modding/The tale of Dev Mode|here]].]]
===Finding Dev Mode===
This ultimate form of modding becomes necessary for modders who want to do things the game's scripts and data do not currently allow for, as well as to fix bugs. Bug fixes were the earliest notable achievement in engine patching, originally performed by a patching application that altered the Windows Oni executable directly, but a revolution in this type of modding occurred in 2006 when Developer Mode was finally discovered in retail Oni's code, and a means for unlocking it was needed. The most foolproof method of altering the engine turned out to be replacing a library that Oni loads at runtime. Now known as the [[Daodan DLL]], this library-as-patch can alter many aspects of Oni's behavior.  This allows the fixing of bugs (some of which result from new computers running a {{age|2001|1|28}} year old game), as well as the adding of new features.
[[Image:Sfeli Finds Dev Mode.jpg|thumb|225px|right|[[User_talk:SFeLi|SFeLi]] documents his discovery in 2006; in examining the binary, he noticed that the list of cheat codes had a gap in it where one code had been removed; that code was for Developer Mode. For more history, see [[History of Oni modding/The tale of Dev Mode|here]].]]
Engine patching is needed when modders want to do things the game's scripts and data do not currently allow for, as well as to fix bugs. Bug fixes were the earliest notable achievement in engine patching, originally performed by a patching application that altered the Windows Oni executable directly, but a revolution in this type of modding occurred in 2006 when [[Developer Mode]] was finally discovered in retail Oni's code, and a means for unlocking it was needed. The most foolproof method of altering the engine turned out to be replacing a library that Oni loads at runtime. Now known as the [[Daodan DLL]], this library-as-patch can alter many aspects of Oni's behavior.  This allows the fixing of bugs (some of which result from new computers running a {{age|2001|1|28}}<!--Give or take a day....--> year old game), as well as the adding of new features.


Not long after the Daodan DLL was released for Windows, it was discovered that the Mac versions of Oni still had Dev Mode in them, too. Unlike Windows, the Omni Group port to OS X did not seem to have any libraries that could be exploited for runtime patching, so the changes were simply made with a hex editor, directly modifying the executable. In the fall of 2008, it was discovered that numerous BSL functions and variables that were thought to be removed from Oni for the Mac [[Mac beta|before release]] were still present in the code, and the ones which allowed Macs to run (almost) all scripts written for Windows Oni were "unlocked" by [[User:EdT|EdT]] using hex edits. Certain changes made by the Daodan DLL for the Windows version were also carried over in [[AE:OMNI|hex-edit form]]. Later, these changes were made in source for Feral Interactive's [[AE:FERAL|Mac Intel port]].
Not long after the Daodan DLL was released for Windows, it was discovered that the Mac versions of Oni still had Dev Mode in them, too. Unlike Windows, the Omni Group port to OS X did not seem to have any libraries that could be exploited for runtime patching, so the changes were simply made with a hex editor, directly modifying the executable. In the fall of 2008, it was discovered that numerous BSL functions and variables that were thought to be removed from Oni for the Mac [[Mac beta|before release]] were still present in the code, and the ones which allowed Macs to run (almost) all scripts written for Windows Oni were "unlocked" by [[User:EdT|EdT]] using hex edits. Certain changes made by the Daodan DLL for the Windows version were also carried over to the Mac's [[AE:OMNI|PPC game application]] in hex-edit form. Later, these changes were made in source for Feral Interactive's [[AE:FERAL|Mac Intel port]].


===Bug fixes and beyond===
One of the most visible changes to the game that the Daodan DLL (and equivalent hex edits on the Mac side) made possible came about in July '07, when an error in Oni's AI routines was corrected, allowing the AI to dodge incoming fire consistently. Fans had originally expected to see at least basic dodging abilities in the AI, so when Oni was released, they were surprised to see the AI usually run blindly at Konoko while being shot at. With the community's patch in place, previously glitched code now works as intended, allowing the AI to [http://www.youtube.com/watch?v=aEuAu7jLQQI intelligently take cover from gunfire].
One of the most visible changes to the game that the Daodan DLL (and equivalent hex edits on the Mac side) made possible came about in July '07, when an error in Oni's AI routines was corrected, allowing the AI to dodge incoming fire consistently. Fans had originally expected to see at least basic dodging abilities in the AI, so when Oni was released, they were surprised to see the AI usually run blindly at Konoko while being shot at. With the community's patch in place, previously glitched code now works as intended, allowing the AI to [http://www.youtube.com/watch?v=aEuAu7jLQQI intelligently take cover from gunfire].