Look for 'cython' also as 'cython3'
[jack_mixer.git] / CHANGELOG.md
blob05e2372291fc05fced126ba5260c19834257d05b
1 Change Log
2 ==========
5 ## Version 15 (2021-02-25)
7 **Important change:** `jack_mixer` now uses [meson] for building and
8 installation. See [INSTALL.md] for new build instructions.
11 New:
13 * A global setting for default project file path was added and can be changed
14   in the preference dialog.
16     The default value is `$XDG_DATA_HOME/jack_mixer` (which is normally
17     `~/.local/share/jack_mixer`).
19 * A "Recent projects" menu was added, to allow loading recently used / saved
20   projects more quickly.
22 * Direct channel output ports are now optional and can be enabled/disabled in
23   the channel preferences dialog.
25 * Ctrl+left-click on the mute ("M") or solo ("S") channel buttons now activates
26   exclusive mute resp. solo.
28 * A man page for `jack_mixer` was added.
30 * `jack_mix_box` now supports the `-p|--pickup` command line option to enable
31   MIDI pickup mode, to prevent sudden volume or balance value jumps.
34 Fixed:
36 * Activating the solo function on an input channel could cause its
37   output signal be sent to the monitor outputs instead of the signal
38   from the channel, which had monitoring activated.
40 * Volume and balance level and mute and solo state changes originating from
41   the UI now send the correct assigned MIDI CCs, allowing for MIDI feedback
42   to controllers. Same for changes originating from reception of assigned MIDI
43   CCs.
45 * The handler for right-clicking the input channel mute/solo buttons, was
46   accidentally removed and is now re-instated.
48 * Creating a new output channel assigns it a randomly chosen color,
49   which can be changed in the new channel dialog (used to work
50   some releases ago, but was broken at some point).
52 * The `jack_mix_box` command line options `--help` and `--stereo`
53   erroneously required an argument.
55 * Saving the current project on reception of the `SIGUSR1` signal, which is a
56   requirement for LADISH level L1 support, was broken in version 14.
58 * When re-ordering channels via drag-and-drop, the order of the edit / remove
59   channel menu items were not updated.
61 * When creating an output channel, it could happen that the initial channel
62   volume would randomly be set to -inf or 0 dB, regardless of what was
63   selected in new channel dialog.
66 Changed:
68 * The minimum supported Python version is now 3.6.
70 * The `jack_mix_box` command line usage help message was improved.
72 * The channel strip buttons (solo, mute, etc.) now have more distinctive colors
73   when activated or the mouse hovers over them.
75 * The balance slider step size was increased slightly so right-clicking the
76   slider changes the value more rapidly.
78 * When using the "Save as..." function, `jack_mixer` now sets the default
79   filename and directory for file chooser to the last ones used.
81 * A window title was added to the preferences dialog.
83 * MIDI control for mute and solo now interprets control value 0-63 as off
84   and 64-127 as on, instead of toggling the state on reception of any
85   controller value.
88 Project infrastructure and internals:
90 * The `jack_mixer_c` Python extension module, which was originally implemented
91   in hand-written C code using the PYTHON C API, was replaced with the
92   `_jack_mixer` extension module implemented in [Cython], which generates the C
93   code in `_jack_mixer.c`.
95 * The autotools build toolchain was replaced with a build setup using [meson],
96   which improves build times and maintainability markedly. See the file
97   [INSTALL.md] for updated build and installation instructions.
99 * A build option to allow building only `jack_mix_box` was added (`-Dgui=disabled`).
101 * All Python code was re-formatted with [black].
103 * All errors and warnings reported by [flake8] were fixed or are explicitly and
104   selectively ignored.
106 * The file `version.py` is now generated from the version set in the project
107   definition in the top-level `meson.build` file, leaving this as the only
108   place where the version number needs to be updated before a release.
110 * The `NEWS` file was renamed to `CHANGELOG.md` and converted to Markdown
111   format.
113 This release was created by Christopher Arndt. With a contribution from
114 Athanasios Silis.
117 [INSTALL.md]: ./INSTALL.md
118 [black]: https://pypi.org/project/black/
119 [Cython]: https://cython.org/
120 [meson]: https://mesonbuild.com/
121 [flake8]:  https://pypi.org/project/flake8/
124 ## Version 14 (2020-10-15)
126 * Changes to channel fader/meter layout and features:
127     * Added K20 and K14 scales.
128     * Added tick marks for left/center/right on balance slider and add tooltip
129       displaying left/right value.
130     * Added maximum width for control group labels. Labels are ellipsized if
131       too long and a tooltip with the full name is added.
132 * Channel add/property dialogs usability improvements:
133     * Remember last used settings for new input/outut channel dialogs (MIDI CCs
134       are always initialized with -1 by default, so they can be auto-assigned).
135     * Channel name is pre-filled in with "Input" or "output" and an
136       auto-incremented number suffix.
137     * Add mnemonics for all input/output channel dialog fields.
138 * When running under NSM, closing the main window only hides UI and the "Quit"
139   menu entry is replaced with a "Hide" entry.
140 * Added a global option to always ask for confirmation when quitting
141   jack_mixer.
142 * Allow drag'n'drop to change channel positions.
143 * Added ability to shrink/expand width of input and output channels.
144 * The font color of control group labels automatically adapts to their
145   background color for better contrast and readability.
146 * Fixed: Ctrl-click on volume fader sets it to 0.0 dbFS, not 1.0.
147 * Fixed: some issues with channel monitoring.
148 * Fixed: don't create empty project file on new NSM session.
149 * Fixed: on project load, give input focus to fader of last added channel and
150   deselect volume entry widget so keyboard input doesn't accidentally change
151   the value.
153 With contributions from Christopher Arndt, Daniel Sheeler and Frédéric Péters.
156 ## Version 13 (2020-07-16)
158 * Added NSM support.
159 * Store preferences to per session config file to override global
160   preferences.
161 * Added accelerator shortcuts to menu items.
162 * New ctrl-click, double-click, scroll, and click-drag-anywhere
163   fader behaviors.
164 * Added MIDI 'Pick Up' behavior to avoid discontinuities.
165 * Can choose output channel colors.
166 * Changed to logarithmic ramping on volume changes.
167 * Added a pre/post fader button.
168 * Pick volume for new channels.
169 * Allow manual setting of MIDI control change numbers.
170 * Remove GConf; use plaintext .ini preferences file instead.
171 * Remove remnants of Swig python bindings.
173 With contributions from Daniel Sheeler and Christopher Arndt.
176 ## Version 12 (2020-06-22)
178 * Added reporting of the current volume through SIGUSR1 signal to
179   jack_mix_box.
180 * Reset color of over 0db/NaN peak on click.
181 * Fixed memory leaks.
182 * Fixed some Python 3 compatibility leftovers.
184 With contributions from Daniel Sheeler and Athanasios Silis.
187 ## Version 11 (2020-06-18)
189 * Spread out volume transition over a period of time to reduce
190   discontinuities.
191 * Port to pygobject and GTK3.
192 * Port to Python 3.
194 With contributions from Daniel Sheeler.
197 ## Version 10 (2014-04-27)
199 * Fixed change of channel settings (#18299)
200 * Added a MIDI out port for feeding back volume levels into motorized
201   controllers
202 * Added jack_mix_box, a minimalistic (no UI) jack mixer
203 * Added a trayicon and minimize to tray feature
205 With contributions from John Hedges, Sarah Mischke, and Nedko Arnaudov.
208 ## Version 9 (2010-10-04)
210 * Changed to no longer appends PID to jack client name (#15006)
211 * Added 'Edit .. channel' submenus
212 * Set a default 'apply' button in channel properties
213 * Fixed creation of  mono channels
214 * Removed bad crackling when changing the volume through MIDI
215 * Moved back to polling for MIDI events, to avoid the need for threads
216 * Changed to use backward compatible call to gobject.timeout_add (#14999)
217 * Updated not to fail if we can't get lash server name
218 * Added support for Ladish level 1
219 * Improved SIGUSR1 handling
221 With contributions from Nedko Arnaudov and Arnout Engelen.
224 ## Version 8 (2009-12-16)
226 * Fix private modules lookup
227 * Fix rotation of output channel colours
228 * New menu items to remove output channels
229 * New command line parameter to not connect to LASH
232 ## Version 7 (2009-12-14)
234 * New maintainer, thanks Nedko for everything!
235 * New icon by Lapo Calamandrei
236 * Option to have a gradient in the vumeters
237 * Option to use stock GtkScale widget for volume and balance
238 * Rewrite of the C/Python binding (this removed the dependency on SWIG)
239 * Improve performance when drawing vumeters
240 * New menu items to load/save settings
241 * New "Channel Properties" dialog, allowing to change assigned MIDI CCs
242 * Automatic post fader outputs for input channels
243 * Possibility to add new output channels, besides main mix
244 * New "monitor" output, assignable to any output channel, or input channel
245   (in which case it will take its prefader volume)
246 * Removal of PyXML dependency
248 With contributions from Nedko Arnaudov, Lapo Calamandrei, Arnout Engelen,
249 and Krzysztof Foltman.
252 ## Version 6 (2009-07-25)
254 * Fix building against jack 0.102.20
255 * Handle python prefix different from install prefix
256 * Fix LASH-less operation
257 * Update install instructions after lash-0.5.3 and phat-0.4.1 releases
258 * Apply Markus patch (thanks!) for sr #1698 (can't restore session using LASH)