2022-01-28 06:26:40 +00:00
# Furnace Tracker
2021-05-11 20:08:08 +00:00
2022-06-29 09:57:05 +00:00
![screenshot ](papers/screenshot2.png )
2021-12-19 08:36:42 +00:00
2022-06-29 09:57:05 +00:00
the biggest multi-system chiptune tracker ever made!
2021-05-28 19:15:27 +00:00
2022-04-06 19:57:05 +00:00
[downloads ](#downloads ) | [discussion/help ](#quick-references ) | [developer info ](#developer-info ) | [unofficial packages ](#unofficial-packages ) | [FAQ ](#frequently-asked-questions )
2022-01-28 07:52:48 +00:00
2022-03-22 02:34:50 +00:00
***
2022-03-22 02:58:07 +00:00
## downloads
2022-04-06 19:56:11 +00:00
2022-03-22 02:58:07 +00:00
check out the [Releases ](https://github.com/tildearrow/furnace/releases ) page. available for Windows, macOS and Linux (AppImage).
2022-04-16 19:12:55 +00:00
[see here ](https://nightly.link/tildearrow/furnace/workflows/build/master ) for unstable developer builds.
2021-05-28 19:15:27 +00:00
## features
2022-06-29 09:57:05 +00:00
- over 50 sound chips - and counting:
- Yamaha FM chips:
- YM2151 (OPM)
- YM2203 (OPN)
- YM2413 (OPLL)
- YM2414 (OPZ) used in Yamaha TX81Z
- YM2608 (OPNA) used in PC-98
- YM2610 (OPNB) used in Neo Geo
- YM2610B (OPNB2)
- YM2612 (OPN2) used in Sega Genesis and FM Towns
- YM3526 (OPL) used in C64 Sound Expander
- YM3812 (OPL2)
- YMF262 (OPL3) with full 4-op support!
- Y8950 (OPL with ADPCM)
- square wave chips:
- AY-3-8910/YM2149(F) used in several computers and game consoles
- Commodore VIC used in the VIC-20
- Microchip AY8930
- TI SN76489 used in Sega Master System and BBC Micro
- PC Speaker
- Philips SAA1099 used in SAM Coupé
- sample chips:
- Amiga
- SegaPCM - all 16 channels
- Capcom QSound
- Yamaha YMZ280B (PCMD8)
- Ricoh RF5C68 used in Sega CD and FM Towns
- OKI MSM6258 and MSM6295
- wavetable chips:
- HuC6280 used in PC Engine
- Konami Bubble System WSG
- Konami SCC/SCC+
- Namco arcade chips (WSG/C15/C30)
- WonderSwan
- Seta/Allumer X1-010
- NES (Ricoh 2A03/2A07), with additional expansion sound support:
- Konami VRC6
- Konami VRC7
- MMC5
- Famicom Disk System
- Sunsoft 5B
- Namco 163
- Family Noraebang (OPLL)
- SID (6581/8580) used in Commodore 64
- Mikey used in Atari Lynx
- ZX Spectrum beeper (SFX-like engine)
2022-07-21 20:28:24 +00:00
- Commodore PET
2022-06-29 09:57:05 +00:00
- TIA used in Atari 2600
2022-01-13 08:05:41 +00:00
- Game Boy
2022-06-29 09:57:05 +00:00
- modern/fantasy:
- Commander X16 VERA
- tildearrow Sound Unit
- mix and match sound chips!
- over 200 ready to use presets from computers, game consoles and arcade boards...
- ...or create your own - up to 32 of them or a total of 128 channels!
- DefleMask compatibility
- loads .dmf modules from all versions (beta 1 to 1.1.3)
- saves .dmf modules - both modern and legacy
- Furnace doubles as a module downgrader
- loads .dmp instruments and .dmw wavetables as well
- clean-room design (guesswork and ABX tests only, no decompilation involved)
- bug/quirk implementation for increased playback accuracy through compatibility flags
- VGM export
- modular layout that you may adapt to your needs
- audio file export - entire song, per system or per channel
- quality emulation cores (Nuked, MAME, SameBoy, Mednafen PCE, NSFplay, puNES, reSID, Stella, SAASound, vgsound_emu and ymfm)
- wavetable synthesizer
- available on wavetable chips
- create complex sounds with ease - provide up to two wavetables, select and effect and let go!
- MIDI input support
- [Fractal Sound ](https://gitlab.com/Natsumi/Fractal-Sound ) support!
- the game-ready Sega Genesis/Mega Drive sound driver!
- compose your songs in Furnace using the Fractal Sound presets and then use them in your games with Fractal!
- additional features:
2022-01-28 06:26:40 +00:00
- FM macros!
2022-03-05 08:37:56 +00:00
- negative octaves
2022-01-28 06:26:40 +00:00
- arbitrary pitch samples
- sample loop points
2022-06-29 09:57:05 +00:00
- SSG envelopes and ADPCM-B in Neo Geo
2022-01-11 08:52:26 +00:00
- full duty/cutoff range in C64
2022-06-29 09:57:05 +00:00
- ability to change tempo mid-song
- multiple sub-songs in a module
- per-channel oscilloscope with waveform centering
- built-in sample editor
- chip mixing settings
- built-in visualizer in pattern view
2022-02-15 02:59:26 +00:00
- open-source under GPLv2 or later.
2021-05-28 19:15:27 +00:00
2022-03-22 02:34:50 +00:00
***
# quick references
2022-04-06 19:56:11 +00:00
2022-03-22 02:34:50 +00:00
- **discussion**: see the [Discussions ](https://github.com/tildearrow/furnace/discussions ) section, or (preferably) the [official Discord server ](https://discord.gg/EfrwT2wq7z ).
- **help**: check out the [documentation ](papers/doc/README.md ). it's mostly incomplete, but has details on effects.
2022-04-06 19:56:11 +00:00
2022-03-22 02:34:50 +00:00
## unofficial packages
2022-04-06 19:56:11 +00:00
2022-03-04 09:09:16 +00:00
[![Packaging status ](https://repology.org/badge/tiny-repos/furnace.svg )](https://repology.org/project/furnace/versions)
2022-03-04 07:46:35 +00:00
some people have provided packages for Unix/Unix-like distributions. here's a list.
2022-03-22 02:34:50 +00:00
- **Arch Linux**: [furnace-git is in the AUR. ](https://aur.archlinux.org/packages/furnace-git ) thank you Essem!
- **FreeBSD**: [a package in ports ](https://www.freshports.org/audio/furnace/ ) is available courtesy of ehaupt.
- **Nix**: [package ](https://search.nixos.org/packages?channel=unstable&show=furnace&from=0&size=50&sort=relevance&type=packages&query=furnace ) thanks to OPNA2608.
2022-06-29 09:57:05 +00:00
- **openSUSE**: [a package ](https://software.opensuse.org/package/furnace ) is available, courtesy of fpesari.
2022-03-04 07:46:35 +00:00
2022-03-22 02:34:50 +00:00
***
2021-12-19 18:05:09 +00:00
# developer info
2022-03-14 04:10:52 +00:00
[![Build furnace ](https://github.com/tildearrow/furnace/actions/workflows/build.yml/badge.svg )](https://github.com/tildearrow/furnace/actions/workflows/build.yml)
2022-04-16 19:12:55 +00:00
if you can't download these artifacts (because GitHub requires you to be logged in), [go here ](https://nightly.link/tildearrow/furnace/workflows/build/master ) instead.
2022-03-22 02:34:50 +00:00
**NOTE: do not download the project's source as a .zip or .tar.gz as these do not include the project's submodules which are necessary to proceed with building. please instead use Git as shown below.**
2022-01-29 03:23:08 +00:00
2021-05-28 19:15:27 +00:00
## dependencies
2021-05-28 20:31:35 +00:00
- CMake
2022-06-29 09:57:05 +00:00
- JACK (optional, macOS/Linux only)
2021-05-28 20:31:35 +00:00
2022-06-29 09:57:05 +00:00
if building under Windows or macOS, no additional dependencies are required.
otherwise, you may also need the following:
- libpulse
- libx11
- libasound
- libGL
some Linux distributions (e.g. Ubuntu or openSUSE) will require you to install the `-dev` versions of these.
2021-05-28 19:15:27 +00:00
2022-01-29 03:23:08 +00:00
## getting the source
type the following on a terminal/console: (make sure Git is installed)
```
git clone --recursive https://github.com/tildearrow/furnace.git
cd furnace
```
(the `--recursive` parameter ensures submodules are fetched as well)
2021-05-28 19:15:27 +00:00
## compilation
2022-01-29 03:23:08 +00:00
your typical CMake project.
2021-05-28 19:15:27 +00:00
2021-05-28 20:31:35 +00:00
### Windows using MSVC
2022-01-28 07:52:48 +00:00
as of now tildearrow uses MinGW for Windows builds, but thanks to OPNA2608 this works again!
2021-12-19 08:37:42 +00:00
2021-05-28 20:31:35 +00:00
from the developer tools command prompt:
```
mkdir build
cd build
cmake ..
msbuild ALL_BUILD.vcxproj
```
### macOS and Linux
2021-05-28 19:15:27 +00:00
```
mkdir build
cd build
cmake ..
make
```
2022-03-22 02:34:50 +00:00
Alternatively, build scripts are provided in the `scripts/` folder in the root of the repository.
2021-05-28 19:15:27 +00:00
2022-02-01 20:50:25 +00:00
### CMake options
To add an option from the command-line: `-D<NAME>=<VALUE>`
Example: `cmake -DBUILD_GUI=OFF -DWARNINGS_ARE_ERRORS=ON ..`
Available options:
| Name | Default | Description |
| :--: | :-----: | ----------- |
2022-05-11 00:40:35 +00:00
| `BUILD_GUI` | `ON` | Build the tracker (disable to build only a headless player) |
2022-06-29 09:57:05 +00:00
| `USE_RTMIDI` | `ON` | Build with MIDI support using RtMidi |
| `USE_SDL2` | `ON` | Build with SDL2 (required to build with GUI) |
| `USE_SNDFILE` | `ON` | Build with libsndfile (required in order to work with audio files) |
| `USE_BACKWARD` | `ON` | Use backward-cpp to print a backtrace on crash/abort |
2022-02-01 20:50:25 +00:00
| `WITH_JACK` | `ON` if system-installed JACK detected, otherwise `OFF` | Whether to build with JACK support. Auto-detects if JACK is available |
2022-06-29 09:57:05 +00:00
| `SYSTEM_FFTW` | `OFF` | Use a system-installed version of FFTW instead of the vendored one |
2022-02-01 20:50:25 +00:00
| `SYSTEM_FMT` | `OFF` | Use a system-installed version of fmt instead of the vendored one |
| `SYSTEM_LIBSNDFILE` | `OFF` | Use a system-installed version of libsndfile instead of the vendored one |
2022-06-29 09:57:05 +00:00
| `SYSTEM_RTMIDI` | `OFF` | Use a system-installed version of RtMidi instead of the vendored one |
2022-02-01 20:50:25 +00:00
| `SYSTEM_ZLIB` | `OFF` | Use a system-installed version of zlib instead of the vendored one |
| `SYSTEM_SDL2` | `OFF` | Use a system-installed version of SDL2 instead of the vendored one |
| `WARNINGS_ARE_ERRORS` | `OFF` (but consider enabling this & reporting any errors that arise from it!) | Whether warnings in furnace's C++ code should be treated as errors |
2022-08-04 22:48:10 +00:00
| `WITH_DEMOS` | `ON` | Install demo songs on `make install` |
| `WITH_INSTRUMENTS` | `ON` | Install demo instruments on `make install` |
2022-02-01 20:50:25 +00:00
2022-06-29 09:57:05 +00:00
## console usage
2021-05-28 19:15:27 +00:00
```
2021-12-19 18:05:09 +00:00
./furnace
2021-05-28 19:15:27 +00:00
```
2021-12-19 18:05:09 +00:00
this opens the program.
2021-12-07 18:08:48 +00:00
```
2021-12-19 18:05:09 +00:00
./furnace -console < file >
2021-12-07 18:08:48 +00:00
```
2022-01-16 09:43:54 +00:00
this will play a compatible file.
2021-12-07 18:08:48 +00:00
```
2021-12-19 18:05:09 +00:00
./furnace -console -view commands < file >
2021-12-07 18:08:48 +00:00
```
2022-01-16 09:43:54 +00:00
this will play a compatible file and enable the commands view.
2021-12-07 18:08:48 +00:00
2022-03-22 02:34:50 +00:00
**note that these commands only actually work in Linux environments. on other command lines, such as Windows' Command Prompt, or MacOS Terminal, it may not work correctly.**
***
2022-04-06 19:56:11 +00:00
# frequently asked questions
2022-03-22 02:34:50 +00:00
2022-06-29 09:57:05 +00:00
> woah! 50 sound chips?! I can't believe it!
yup, it's real.
> where's the manual?
2022-06-29 16:09:15 +00:00
see [papers/ ](papers/doc/README.md ). it's kind of incomplete, but at least the systems (sound chips) section is there.
2022-06-29 09:57:05 +00:00
> it doesn't open under macOS!
this is due to Apple's application signing policy. a workaround is to right click on the Furnace app icon and select Open.
2022-01-11 23:57:26 +00:00
> how do I use C64 absolute filter/duty?
on Instrument Editor in the C64 tab there are two options to toggle these.
also provided are two effects:
- `3xxx` : set fine duty.
- `4xxx` : set fine cutoff. `xxx` range is 000-7ff.
2022-03-22 02:34:50 +00:00
additionally, you can change the cutoff and/or duty as a macro inside an instrument by clicking the `absolute cutoff macro` and/or `absolute duty macro` checkbox at the bottom of the instrument. (for the filter, you also need to click the checkbox that says `volume macro is cutoff macro` .)
2022-01-11 23:57:26 +00:00
2022-06-29 09:57:05 +00:00
> how do I use PCM on a PCM-capable system?
2022-03-05 08:37:56 +00:00
2022-06-29 09:57:05 +00:00
two possibilities:
- the recommended way is by creating the "Sample" type instrument and assigning a sample to it.
- otherwise you may employ the DefleMask-compatible method, using `17xx` effect.
2021-12-11 18:30:06 +00:00
2022-06-29 09:57:05 +00:00
> my .dmf song sounds very odd at a certain point
2021-12-11 18:30:06 +00:00
2022-06-29 09:57:05 +00:00
file a bug report. use the Issues page. it's probably another playback inaccuracy.
2021-12-11 18:41:37 +00:00
2022-06-29 09:57:05 +00:00
> my .dmf song sounds correct, but it doesn't in DefleMask
2021-12-11 18:41:37 +00:00
2022-06-29 09:57:05 +00:00
file a bug report **here** . it still is a playback inaccuracy.
2022-01-11 08:52:26 +00:00
2022-06-29 09:57:05 +00:00
> my song sounds terrible after saving as .dmf!
2022-01-11 08:52:26 +00:00
2022-06-29 09:57:05 +00:00
the DefleMask format has several limitations. save in Furnace song format instead (.fur).
2022-01-19 22:10:21 +00:00
2022-06-29 09:57:05 +00:00
> how do I solo channels?
2022-01-19 22:10:21 +00:00
2022-06-29 09:57:05 +00:00
right click on the channel name.
2022-02-15 02:59:26 +00:00
2022-03-22 02:34:50 +00:00
***
2022-02-15 02:59:26 +00:00
# footnotes
copyright (C) 2021-2022 tildearrow and contributors.
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
2022-02-15 03:01:11 +00:00
despite the fact this program works with the .dmf file format, it is NOT affiliated with Delek or DefleMask in any way, nor it is a replacement for the original program.