7418c12a5b
override -fvisibility=hidden for the LV2plugin descriptor
2014-01-17 16:10:03 +01:00
0506f85e9d
remove cruft
2014-01-17 16:00:17 +01:00
3ebd42b873
override visibility default for Apple's "appleutility" library, which was written without symbol export control
2014-01-17 09:52:13 -05:00
c0e6f8e4c3
Merge branch 'master' into cairocanvas
2014-01-17 09:13:44 -05:00
0479405e2f
fix typo in auditioner-seek
2014-01-17 00:25:32 +01:00
b4462b3d22
add seeking to sfdb auditioner
2014-01-17 00:20:58 +01:00
2e27e21d3a
Merge branch 'master' into cairocanvas
2014-01-16 17:26:50 -05:00
10933e2003
allow auditioning via the monitor section to work.
...
Ideally, we would feed the monitor section via an internal (aux) send/return, but this is an improvement over what we had before
2014-01-16 17:22:19 -05:00
620e1e6677
add event type string function to canvas (since it does not use gtkmm2ext)
2014-01-16 10:52:34 -05:00
016a9cc533
add Gtkmm2ext::event_type_string()
2014-01-16 10:14:42 -05:00
e279b9892b
Merge branch 'master' into cairocanvas
2014-01-15 22:28:34 -05:00
0b9199163d
continue with tweaks to VST timeinfo, such that the again demo plugin appears to work exactly as expected
2014-01-15 22:28:01 -05:00
1745340c67
Merge branch 'master' into cairocanvas
2014-01-15 20:40:11 -05:00
1c01ac5bc8
minor tweak to layout of vestige aeffectx.h
2014-01-15 20:37:26 -05:00
c3984f35ac
more work on debugging VST timeinfo issues
2014-01-15 16:48:22 -05:00
3eadbaaf58
debug VST timeinfo callback, pt3
2014-01-15 16:31:10 -05:00
4365ea06e3
debug VST timeinfo callback, pt2
2014-01-15 16:26:21 -05:00
0265f3f1e2
debug VST timeinfo callback
2014-01-15 16:24:03 -05:00
40e7379569
don't require VST plugins to actually ask for time info fields
2014-01-15 16:19:04 -05:00
a882e96db1
Merge branch 'master' into cairocanvas
2014-01-15 16:10:09 -05:00
af3481fb78
add lots more BBT-based time info for VST plugins (see 5737)
2014-01-15 16:08:27 -05:00
a454bedc1d
update VstTimeInfo structure, from Qtractor's version of vestige, which has all fields thanks to some steinberg online docs
2014-01-15 16:07:47 -05:00
00f145dbdf
Revert "update VstTimeInfo structure, from Qtractor's version of vestige, which has all fields thanks to some steinberg online docs"
...
This reverts commit febc6b957e
.
2014-01-15 16:06:57 -05:00
febc6b957e
update VstTimeInfo structure, from Qtractor's version of vestige, which has all fields thanks to some steinberg online docs
2014-01-15 16:06:35 -05:00
ca621b3fbf
improve comment explaining the use of alloca()
2014-01-15 15:00:07 -05:00
e8202dded8
add back comment explaining the use of alloca()
2014-01-15 14:58:59 -05:00
9aacefc170
merge with master
2014-01-15 14:29:32 -05:00
f9a5f87003
don't pan send/return inserts
2014-01-15 17:59:16 +01:00
b06fa27ccb
rework LXVST port assignments - fixes #5827
2014-01-15 14:55:26 +01:00
c8f9405386
stereo-panner: clamp width during processing to valid range
2014-01-15 14:07:02 +01:00
abb75d4a2e
prevent stackoverflow when pannable changes to fewer params
...
endless loop: e.g. 2in2out -> balance (or 1in1out)
#23 0xb7ab5c17 in ARDOUR::Pannable::value_as_string
#24 0xb2ebb206 in ARDOUR::Pannerbalance::value_as_string
#25 0xb7ab5c17 in ARDOUR::Pannable::value_as_string
#26 0xb2ebb206 in ARDOUR::Pannerbalance::value_as_string
ad infinitum
2014-01-15 10:38:32 +01:00
d27d6e673f
re-allow panners for monitoring-section (for now)
2014-01-15 10:37:25 +01:00
a4dc05f603
fix invalid width when swiching to 2in2out
2014-01-15 09:45:02 +01:00
58def58bf5
VBAP GUI convention: top == front ^= azimuth == .5
...
This allows to move from stereo,mono panners to VBAP and back
and also facilitates sharing pannables of all currently
existing panners with semantically similar results.
(somewhat dirty solution, this retains PBD::spherical_to_cartesian
and maps angles pretty much everywhere else)
2014-01-15 09:37:20 +01:00
96586e81f4
the vampplugins lib that we build needs to use VAMPSDK
2014-01-14 21:46:41 -05:00
37b1f5017e
merge with master
2014-01-14 21:13:21 -05:00
35c170937d
NOOP, semantic update, don't pannable's panner for direct access.
2014-01-15 02:51:53 +01:00
813ead6d8b
cont'd backend work on panner-linking
2014-01-15 02:51:52 +01:00
218cf268b9
remove debug code
2014-01-15 02:51:52 +01:00
d434287811
fix compilation problem on OS X caused by a missing implementation of a virtual method
2014-01-14 17:27:21 -05:00
adc2edc05c
add back required extern
2014-01-14 15:11:32 -05:00
e332900055
revert incorrect include path changes and removal of export macros for two libardour symbols (revision and ardour_config_info)
2014-01-14 12:22:18 -05:00
b3526d855e
'libs/ardour' - Non-visibility stuff changed for MSVC (mostly alterations to #include paths)
2014-01-14 16:47:29 +00:00
b9390869ea
'libs/ardour' - Remove the old 'visibility.h' (so as not to merge it into cairocanvas)
2014-01-14 16:47:28 +00:00
10a4b2d3ed
'libs/ardour' - DLL visibility stuff and associated changes needed for building with MSVC. Currently includes debugging information and things that are just commented out until we have known compatibility with the other platforms (i.e. contains stuff to be removed at a later date)
2014-01-14 16:47:27 +00:00
cf806123ca
merge (with conflict fixes) with master (even against rgareus' recommendation)
2014-01-14 10:56:17 -05:00
cfc9a1f22e
fix broken build after addition of normalizer.cc
2014-01-14 09:33:02 -05:00
eb023b7496
'libs/ardour' - DLL visibility stuff and associated changes needed for building with MSVC. Currently includes debugging information and things that are just commented out until we have known compatibility with the other platforms (i.e. contains stuff to be removed at a later date)
2014-01-14 10:13:12 +00:00
e45151b89c
first stab at send+route panner link
2014-01-13 23:21:30 +01:00
a1a3f6c826
Merge branch 'windows+cc' into cairocanvas
2014-01-13 15:05:30 +00:00
5f0492deae
'libs/audiographer' - Add a new source file (to accommodate the stuff removed from 'normalizer.h')
2014-01-13 15:01:14 +00:00
5fc1cbb65c
'libs/audiographer' - DLL visibility stuff and associated changes needed for building with MSVC. Currently includes debugging information and things that are just commented out until we have known compatibility with the other platforms (i.e. contains stuff to be removed at a later date)
2014-01-13 14:58:04 +00:00
b9c389eac5
fix botched merge of vbap changes
2014-01-13 09:47:20 -05:00
e10bfb8054
VBAP backend re-work (part one):
...
* fix azimuth, don't clamp but map to [0,1]
* prepare elevation (10+ speakers)
2014-01-13 09:40:41 -05:00
fbe94f4470
pixel-align canvas PolyItems with single-pixel outlines, for crispness
2014-01-13 09:39:50 -05:00
2f3830eddb
fix delivery: check if panshell exists on session-load
2014-01-13 09:39:50 -05:00
113f28b6fe
independent panning for external sends
2014-01-13 09:39:50 -05:00
533e0091b7
fix output metering for Sends (Aux and External)
2014-01-13 09:39:50 -05:00
7e1e7e7629
add independent panner for internal (Aux) sends
2014-01-13 09:39:50 -05:00
0da58eeebf
update internal-send port-count when target port-count changes
2014-01-13 09:39:50 -05:00
b4dea5309d
ignore additional channels for AFL, PFL:
...
If the monitor-section has fewer-channels than the solo-listen point:
ignore additional channels.
2014-01-13 09:39:50 -05:00
1e4e6499e3
fix deadlock when removing monitoring-section
2014-01-13 09:39:50 -05:00
1b24aad933
fix processor -> reconfigure I/O || process concurrency
...
Add a ReaderLock to Route::process_output_buffers().
But process_output_buffers() is always called with processor-lock
held. To avoid deadlocks, a processor WriterLock must always imply
a process-lock (IFF reconfigure-I/O is called with _processor_lock).
Otherwise: e.g.
* add_processor() -> takes processor-lock. set up and activate processor.
* simult. audio-engine process, process-lock -> call process_output_buffers() -> wait for processor-lock
* add_processor() continues -> calls reconfigure-io -> take process-lock -> deadlock.
2014-01-13 09:39:50 -05:00
ac8eb0581d
take process lock when adding processors:
...
fixes possible crash if a processor modifies port-count
1. a processor is inserted and activated with processor-lock held
2. only after that the process_lock() is taken, configure_processors() is called which reconfigures-IO
BUT if the processor that is inserted changes the channel count AND audio is processed before IOs are reconfigured
-> possible crash (invalid port-buffers)
To reproduce: Bus1 (2in, 3out), Bus2 (2in, 3out)
- add a send from Bus1 to Bus2,
- then add a processor to Bus1, just before the send which
increases the channel-count to 4 -> occasional crash or assert.
2014-01-13 09:39:18 -05:00
a919ac8a86
aubio 3+4 compat
2014-01-13 09:38:24 -05:00
75e21d3ab4
cosmetic change - properly use lilv API
2014-01-13 09:38:24 -05:00
28470af5f7
swap channel VBAP channel
2014-01-13 09:38:24 -05:00
dd4c0e040f
VBAP rework (part III): fix position computation backend & GUI
2014-01-13 09:37:35 -05:00
431babc272
update default speaker position list
2014-01-13 09:37:35 -05:00
60fe9606f4
VBAP GUI depends on signal-position (not parameter changes)
2014-01-13 09:37:35 -05:00
1bf9c4c990
VBAP backend re-work (part two): speaker positioning
...
* clean up source (whitespace)
* fix speaker 3x3 matrix iteration
* update math to go along with Ardour Cartesian -- fixes rounding errors
* fix division by zero in cross_prod()
* disable old debug output
(NB PBD::spherical_to_cartesian() returns
3.7494e-33, 6.12323e-17, 1 for azimuth 90 elevation 90 distance 1
while it should return
0.000000, 0.000000, 1 for azimuth 90 elevation 90 distance 1
IOW cos(90.0 * 2.0 * M_PI / 360.0) != 0
Cause unknown. This is currently worked around check in vec_length()
)
2014-01-13 09:37:34 -05:00
112de00841
VBAP backend re-work (part one):
...
* fix azimuth, don't clamp but map to [0,1]
* prepare elevation (10+ speakers)
2014-01-13 09:35:57 -05:00
1fb9437e26
'libs/timecode' - Change some instances of 'rint' to be 'lrint' (better compatibility with MSVC)
2014-01-13 14:26:19 +00:00
291618fe71
allow to custom select panner-type for each delivery.
2014-01-13 15:13:37 +01:00
5da8c2b476
'libs/evoral' - and add 'Note.impl' to the project
2014-01-13 12:47:21 +00:00
1d69f31266
'libs/evoral' - #include 'Note.impl' when building with MSVC (this is necessary to ensure that Evoral::Note gets exported from the evoral DLL)
2014-01-13 12:16:02 +00:00
346310c60b
fix delivery: check if panshell exists on session-load
2014-01-13 11:49:09 +01:00
bc88203ef5
independent panning for external sends
2014-01-13 10:50:49 +01:00
d9cf6880b6
fix output metering for Sends (Aux and External)
2014-01-13 10:50:22 +01:00
0559c1babb
add independent panner for internal (Aux) sends
2014-01-13 10:48:37 +01:00
0c384b7c21
update internal-send port-count when target port-count changes
2014-01-13 10:48:23 +01:00
5e2a145cdd
ignore additional channels for AFL, PFL:
...
If the monitor-section has fewer-channels than the solo-listen point:
ignore additional channels.
2014-01-13 10:47:17 +01:00
35ab234e5e
fix deadlock when removing monitoring-section
2014-01-13 10:46:11 +01:00
9c753dbaec
use LIBEVORAL_TEMPLATE_API with Evoral::Note
2014-01-12 20:23:45 -05:00
2fc2df8c5d
fix 64 bit template types
2014-01-12 20:01:12 -05:00
cdfc094b9f
add new file (required by MSVC) to sources list
2014-01-12 20:00:55 -05:00
491bc4e865
use LIBEVORAL_TEMPLATE_API
...
Also clean up unnecessary comments - git blame provides complete per-line history, no need to leave comments behind
2014-01-12 20:00:26 -05:00
a94dadc759
add LIBEVORAL_TEMPLATE_API to deal with gcc/msvc difference of opinion
2014-01-12 19:59:40 -05:00
a08e7c0016
fix processor -> reconfigure I/O || process concurrency
...
Add a ReaderLock to Route::process_output_buffers().
But process_output_buffers() is always called with processor-lock
held. To avoid deadlocks, a processor WriterLock must always imply
a process-lock (IFF reconfigure-I/O is called with _processor_lock).
Otherwise: e.g.
* add_processor() -> takes processor-lock. set up and activate processor.
* simult. audio-engine process, process-lock -> call process_output_buffers() -> wait for processor-lock
* add_processor() continues -> calls reconfigure-io -> take process-lock -> deadlock.
2014-01-12 23:13:35 +01:00
7e3282486d
take process lock when adding processors:
...
fixes possible crash if a processor modifies port-count
1. a processor is inserted and activated with processor-lock held
2. only after that the process_lock() is taken, configure_processors() is called which reconfigures-IO
BUT if the processor that is inserted changes the channel count AND audio is processed before IOs are reconfigured
-> possible crash (invalid port-buffers)
To reproduce: Bus1 (2in, 3out), Bus2 (2in, 3out)
- add a send from Bus1 to Bus2,
- then add a processor to Bus1, just before the send which
increases the channel-count to 4 -> occasional crash or assert.
2014-01-12 21:47:15 +01:00
83c0720645
remove VAMP and Rubberband from source tree
2014-01-12 15:40:48 -05:00
4b3feefa55
add -fvisibility=default back to cxx/cflags when building QM DSP and VAMP plugins libs, because ... ugh
2014-01-12 15:40:48 -05:00
26a9e28922
add export visibility macro
2014-01-12 15:40:48 -05:00
87009afff2
add new file
2014-01-12 15:40:48 -05:00
c3a00990b3
add missing export/visibility macro
2014-01-12 15:40:48 -05:00
0a2a6aaabb
remove taglib from source tree (require external provision)
2014-01-12 15:40:48 -05:00
5062a00c7d
move -fvisibility=hidden to the top of the source tree, and remove its internal use; use libtimecode as a shared lib again
2014-01-12 15:40:47 -05:00
2c21cbb044
add export/visibility macros to libtimecode and build as a shared library again
2014-01-12 15:40:47 -05:00
b7bc2dd2c6
build libsmf as a static library, since it is private to evoral and would otherwise require export visibility control
...
This also removes -fvisibility=hidden, a change that is taking place across the source tree and will show up in a later commit elsewhere
2014-01-12 15:40:47 -05:00
6fc1f27013
Merge branch 'windows+cc' into cairocanvas
2014-01-12 17:45:28 +00:00