Unofficial patch


An unofficial patch is a non-commercial patch for a piece of software, created by a user community instead of the original developer. Similar to an ordinary patch, it alleviates bugs or shortcomings. Unofficial patches do not usually change the intended usage of the software, in contrast to other third-party software adaptions such as mods or cracks.

Motivation

A common motivation for the creation of unofficial patches is missing technical support by the original software developer or provider. Reasons may include:
Unofficial patches are also sometimes called fan patches or community patches, and are typically intended to repair unresolved bugs and provide technical compatibility fixes, e.g. for newer operating systems, increased display resolutions or new display formats.
While unofficial patches are most common for the PC platform, they can also be found for console games e.g. in context of the emulation community.

Translations

Unofficial patches are not limited to technical fixes; fan translations of software, especially games, are often created if the software has not been released locally. Fan translations are most common for Japanese role-playing games which are often not localized for Western markets.
Another variant of unofficial patches are slipstream like patches which combine official patches together, when individual patches are only available online or as small incremental updates.

Methods

The most common case is that the source code and the original development tools are not available for the software. Therefore, the faulty software's binary must be analyzed at run time by reverse engineering and debugging. If the problem is found, a fix to the program must be applied. Sometimes only small changes in configuration files or the registry are required, sometimes binary hacks on the executable itself are required to fix bugs. If a software development kit is available, fixes to the content can be easily produced, otherwise the community would need to create their own tools. These found fixes are typically packed to user deployable patches.
If the source code is available, support can by provided most effectively. Sometimes the source code is released intentionally, sometimes by leaking or mistake, such as what happened with the game engine of the Thief series. Sometimes fans even completely reverse-engineer source code from the original program binary. With the source code available even the support of completely different but recent platforms with source ports becomes possible.

Law

While no court cases have directly addressed the legal ramifications of unofficial patches, similar cases have been tried on related issues. The case of Galoob v. Nintendo found that it was not copyright infringement by a user to apply an unauthorized patch to a system. On the other hand, the case Micro Star v. FormGen Inc. found that user-generated maps were derivative works of the original game. In Sega v. Accolade, the 9th Circuit held that making copies in the course of reverse engineering is a fair use, when it is the only way to get access to the "ideas and functional elements" in the copyrighted code, and when "there is a legitimate reason for seeking such access". According to Copyright law of the United States 17 U.S. Code § 117, the owner of a copy of a program can modify it as necessary for "Maintenance or Repair", without permission from the copyright holder; an argumentation also raised by Daniel J. Bernstein professor at the University of Illinois at Chicago.
Similar user rights are given also according to European copyright laws. The question of whether unauthorized changes of lawfully obtained copyright-protected software qualify as fair use is an unsettled area of law. An article of Helbraun law firm remarks, in the context of fan translations, that while redistributing complete games with adaptions most likely does not fall under fair use, distributing the modifications as a patch might be legally permissible; however, that conclusion has not been tested in court.

Reception

Reception of unofficial patches is mixed, but by large, copyright holders are ambivalent. When the software is not considered commercially viable unofficial patches are ignored by the copyright holder as it is not seen as a source of lost revenue.
There have been seldom cases of cease and desist letters to unofficial patch and fan translation projects.
Sometimes the copyright holder actively support the patching and fixing efforts of a software community, sometimes even by releasing the source code under a software license which allows the software community the continued software support by themselves. Examples for such software are in the List of commercial video games with later released source code.
The free and open source software movement was founded in the 1980s to solve the underlying problem of unofficial patches, the limited possibility for user self-support in binary only distributed software due to missing source code. Free and open source software demands from distributed software the availability of source code, which prevents the technical problems and legal uncertainties of binary only user patching of proprietary software.

Examples in video games

Examples in general software