Floating IPS is a patcher for IPS and BPS files.
Go to file
2019-01-08 22:00:51 +01:00
.vscode Implement #5 2018-04-02 14:21:40 +02:00
libdivsufsort-2.0.1 Include this one. 2016-01-17 18:17:20 +01:00
profile Various doc and profile downloader updates 2019-01-08 22:00:51 +01:00
.gitignore (GTK) Fix some improper nulls, and let's save the rom database to config 2019-01-05 21:49:44 +01:00
bps.ico Initial commit - version 1.31 2016-01-17 18:14:53 +01:00
COPYING Let's make use of this new config. 2016-05-03 21:04:25 +02:00
COPYING.gpl3 Rename those to something more normal. 2016-05-01 17:43:43 +02:00
crc32.cpp Clean up formatting a bit. 2016-01-19 09:43:19 +01:00
crc32.h Clean up formatting a bit. 2016-01-19 09:43:19 +01:00
divsufsort.c and of course I forgot adding the new files. 2016-01-17 18:16:54 +01:00
divsufsort.h and of course I forgot adding the new files. 2016-01-17 18:16:54 +01:00
flips-cli.cpp Use more mmap, per #10 2018-04-21 11:20:12 +02:00
flips-gtk.cpp (GTK) Fix some improper nulls, and let's save the rom database to config 2019-01-05 21:49:44 +01:00
flips-w32.cpp Alternative solution to #14 2018-09-17 04:22:11 +02:00
flips.cpp Various doc and profile downloader updates 2019-01-08 22:00:51 +01:00
flips.h (GTK) Fix some improper nulls, and let's save the rom database to config 2019-01-05 21:49:44 +01:00
flips.ico Initial commit - version 1.31 2016-01-17 18:14:53 +01:00
flips.Manifest Initial commit - version 1.31 2016-01-17 18:14:53 +01:00
flips.rc Add bps-in-memory creator, also update version 2018-04-25 18:45:30 +02:00
global.h Implement the rest of #14; close #14 2018-09-17 12:27:04 +02:00
ips.ico Initial commit - version 1.31 2016-01-17 18:14:53 +01:00
libbps-suf.cpp Random minor cleanups 2016-05-11 15:58:56 +02:00
libbps.cpp Switch to smaller profiling data - seems to give better results, anyways 2018-12-30 19:15:29 +01:00
libbps.h Add bps-in-memory creator, also update version 2018-04-25 18:45:30 +02:00
libips.cpp This warning isn't needed 2018-09-17 04:18:22 +02:00
libips.h Whatever changes I made since 1.31 2016-01-17 18:15:18 +01:00
libups.cpp Fix #1 2017-01-13 16:36:25 +01:00
libups.h Fix UPS header a little. Also add non-plans. 2016-01-19 01:59:09 +01:00
make.bat Implement the rest of #14; close #14 2018-09-17 12:27:04 +02:00
make.sh Various doc and profile downloader updates 2019-01-08 22:00:51 +01:00
Makefile Various doc and profile downloader updates 2019-01-08 22:00:51 +01:00
README.md Various doc and profile downloader updates 2019-01-08 22:00:51 +01:00
special.sh Initial commit - version 1.31 2016-01-17 18:14:53 +01:00

Floating IPS is a patcher for IPS and BPS files, aiming for a simple interface yet plenty of power under the hood.

Features:

  • Creates the smallest BPS patches of any known tool in existence, and is faster than any other comparable creator
  • Creates the smallest IPS patches of any known tool in existence, too (but only a little smaller, Lunar IPS is quite good)
  • Fully-featured GUIs under Windows and GTK+, including command line support; can also be a pure command line program
  • Can apply multiple patches to the same ROM, creating a huge pile of ROMs (GUI only)
  • Can remembers which ROMs you've used, and use them again if it thinks it's correct (BPS only, GUI only)
  • Can launch other programs after patching the ROMs; together with the above, this allows you to double click a BPS to launch an emulator (GUI only)

Planned features:

  • Better autodetection for CLI apply/create; if the first one is a patch, apply, else create
  • Better support for ROM database in CLI; the -d flag, or DB enabling from the GUI (for pure-CLI, existence of flipsdb.bin file beside Flips), will store ROMs in the database; the filename "." will read from it, and "wrong ROM" will look for the right one (but not automatically use it)
  • Use path of patch as output filename, not the ROM path
  • Replace Settings button with Advanced, which switches to a different UI
  • Remove emulator chooser, use OS file associations instead
  • Automatic source ROM chooser for creation

Not planned (if your plans are different, send a PR):

  • OSX GUI support; there's a third-party fork here, and MultiPatch exists and the Windows version works in Wine. I can't test OSX stuff well enough to merge that fork, so pick your favorite.
  • Qt GUI support; my distro prefers GTK+, and all distros I've seen can run both GTK+ and Qt, not worth the effort (and QString's UTF-16 irritates me)

Compilation - Linux (Debian/Ubuntu):

  • sudo apt-get install g++ build-essential; for GUI support, also sudo apt-get install libgtk-3-dev pkg-config
  • ./make.sh to build an optimized binary; for development, use make CFLAGS=-g

Compilation - other Linux:

  • Install make and g++; for GUI support, also install pkg-config and GTK+ 3 headers; for profiling support, also install curl or wget
  • ./make.sh to build an optimized binary; for development, use make CFLAGS=-g

Compilation - OSX and other Unix:

  • Install a C++ compiler
  • clang++ *.c *.cpp -O3 -o flips (with changes as appropriate)
  • For GTK GUI support, use some suitable variant of clang++ *.c *.cpp -O3 -o flips -DFLIPS_GTK -lgtk3
  • For better optimizations (profiling/etc), extract the appropriate commands from Makefile and make.sh

Compilation - Windows:

  • Install mingw-w64
  • mingw32-make CFLAGS=-O3 (GUI is automatically enabled), or extract the appropriate optimization commands from make.sh
  • Alternatively, here's a binary.

Usage:

  • If GUI is enabled, just run the program. File pickers' window titles tell what they want; Enable automatic ROM picker and Run in Emulator can cause file pickers to appear and disappear depending on the chosen patch, making usage less predictable, so it's disabled by default.
  • For CLI use, see ./flips --help. Available both with or without GUI support (though Windows CLI use from interactive prompts is slightly screwy, due to OS limitations).