/[svn]/linuxsampler/trunk/ChangeLog
ViewVC logotype

Diff of /linuxsampler/trunk/ChangeLog

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1897 by persson, Sun May 10 09:31:51 2009 UTC revision 3765 by schoenebeck, Mon Apr 6 09:46:52 2020 UTC
# Line 1  Line 1 
1  Version CVS HEAD (?)  Version SVN trunk (?)
2    
3      * general changes:
4        - Fixed compiler error in Pool.h.
5        - Require C++14 compiler support.
6        - Autoconf: Added m4/ax_cxx_compile_stdcxx.m4 macro which is used
7          for checking in configure for C++14 support (as mandatory
8          requirement) and automatically adds compiler argument if required
9          (e.g. -std=C++14).
10        - RTMath: Implemented floating point comparison methods
11          fEqual32(float,float) and fEqual64(double,double) which take the
12          expected floating point tolerances into account.
13        - Added public API C++ class "LFO", which is a cluster class encapsulating
14          all the sampler's LFO implementations to be used by 3rd party applications
15          (e.g. by Gigedit).
16        - Added int math square LFO implementation.
17        - Added int math saw LFO implementation.
18        - Added numeric complex nr sine LFO implementation.
19        - Marked class LFOTriangleDiHarmonic as deprecated
20          (will be removed in future).
21        - Added LFOAll.h which includes all LFO implementation's header files.
22        - Refactored LFO class names and their file names (PulseLFO -> LFOPulse,
23          LFOSawIntMath -> LFOSawIntMathNew, SawLFO -> LFOSawIntMathOld,
24          SineLFO -> LFOSineBuiltinFn, LFOSine -> LFOSineNumericComplexNr,
25          SquareLFO -> LFOSquarePulse and separated the latter to its own header
26          file).
27        - Renamed type LFOSigned -> LFOTriangleSigned.
28        - Renamed type LFOUnsigned -> LFOTriangleUnsigned.
29        - Using now cubic interpolation as resampling algorithm by default; and
30          linear interpolation is deprecated now.
31        - Event:Init(): memset() entire Event::Param union to zero instead of trying
32          to do that for its individual members; the latter became error prone due
33          to the union's growing complexity meanwhile.
34        - EngineChannel: Overhaul of RPN/NRPN related methods: Added new
35          *Rpn*Parameter*() methods as replacement for previous *Rpn*Controller*()
36          methods and marked the old ones as deprecated; and likewise added new
37          *Nrpn*Parameter*() methods as replacement for previous *Nrpn*Controller*()
38          methods and marked those old ones deprecated as well.
39        - Added support for MIDI CC #38 (data entry LSB): this allows higher value
40          resolution for certain (e.g. hard coded) RPN and NRPN parameters.
41        - Implemented support for compressed RPN/NRPN message sequences (that is to
42          allow processing MIDI data entry messages without always having to be
43          preceded strictly by RPN/NRPN parameter selection messages on each value
44          change).
45        - Added support for MIDI CC #96 (data increment) and MIDI CC #97 (data
46          decrement).
47        - Added support for 'null function RPN/NRPN' (which is RPN/NRPN parameter
48          MSB=127 and LSB=127) and which is disabling subsequent data
49          entry/increment/decrement CC messages.
50        - Fixed crash when editing key groups (a.k.a. exclusive groups) with an
51          instrument editor.
52        - Fixed playing noise at the end of a disk stream under certain conditions.
53        - Fixed potential crash with high pitch at end of RAM playback.
54        - Added configure checks whether C++ compiler supports so called
55          'designated initializers'.
56        - Added global backtraceAsString() function for debugging purposes
57          (POSIX systems only, no Windows implementation yet).
58        - Thread class: Added new methods pushCancelable(), popCancelable(), name(),
59          nameOfCaller() and setNameOfCaller().
60        - configure: Always check for availability of pthread_testcancel() and use
61          it if so (previously it was only used if explicitly enabled by configure
62          option).
63        - Thread class: raise compiler warning if pthread_testcancel() is not
64          available, because it can lead to deadlocks.
65        - Mutex class: Implemented optional bug detection and deadlock debugging
66          features.
67    
68      * Real-time instrument scripts:
69        - Added method ScriptVM::setExitResultEnabled() which allows to
70          explicitly enable the built-in exit() function to optionally accept
71          one function argument; the value of the passed exit() function
72          argument will then become available by calling
73          VMExecContext::exitResult() after script execution.
74        - 64 bit support for NKSP integer scripts variables (declare $foo).
75        - Variable names, function names and preprocessor condition names must start
76          with a regular character (a-z or A-Z); starting them with a digit or
77          underscore is not allowed.
78        - NKSP parser fix: equal comparison operator "=" and not equal comparison
79          operator "#" must only accept integer operands.
80        - NKSP language: Implemented support for standard units like Hertz, seconds,
81          Bel including support for metric unit prefixes; so one can now e.g.
82          conveniently use numbers in scripts like "5us" meaning "5 microseconds",
83          or e.g. "12kHz" meaning "12 kilo Hertz", or e.g. "-14mdB" meaning
84          "minus 14 Millidecibel", or e.g. "28c" meaning "28 cents" (for tuning).
85        - NKSP language: Introduced "final" operator "!" which is specifically
86          intended for synthesis parameter values to denote that the synthesis
87          parameter value is intended to be the "final" value for that synthesis
88          parameter that should explicitly be used by the engine and thus causing
89          the sampler engine to ignore all other modulation sources for the same
90          synthesis parameter (like e.g. LFO, EG); by simply prefixing a value,
91          variable or formula with this new "!" operator the expression is marked as
92          being "final".
93        - NKSP script editor API: Added support for detecting standard unit tokens
94          and their potential metric prefix token.
95        - NKSP language: Added support for NKSP real number literals and
96          arithmetic operations on them (e.g. "(3.9 + 2.9) / 12.3 - 42.0").
97        - NKSP language: Added support for NKSP real number (floating point) script
98          variables (declare ~foo).
99        - NKSP language: Added support for NKSP real number (floating point) array
100          script variables (declare ?foo[]).
101        - Built-in script function "message()" accepts now real number argument as
102          well.
103        - Added built-in script function "real_to_int()" and its short hand form
104          "int()" for casting from real number to integer in NKSP scripts.
105        - Added built-in script function "int_to_real()" and its short hand form
106          "real()" for casting from integer to real number in NKSP scripts.
107        - Allow built-in exit() function to potentially accept real number type
108          argument as well.
109        - Built-in script functions may have a different return type depending on
110          the arguments passed to the function.
111        - Built-in script function "abs()" optionally accepts and returns real
112          number.
113        - Built-in script functions "min()" and "max()" optionally accept real
114          number arguments and return real number as result in that case.
115        - NKSP VM API: Allow units and 'final'ness to be returned as result from
116          built-in functions (added methods VMFunction::returnUnitType() and
117          VMFunction::returnsFinal() for that purpose which must be implemented by
118          built-in function implementations).
119        - NKSP language: Allow metric unit prefixes of numeric scalar and array
120          variables to be changed freely at runtime (unlike unit types like Hz etc.
121          which are still sticky, parse-time features of variables which cannot be
122          changed at runtime for the intentional sake of determinism).
123        - NKSP language: 'final' values are prohibited for array variables for now
124          (attempt causes a parsers error).
125        - NKSP language: expressions with unit types (e.g. Hz) are prohibited for
126          conditions of runtime control structures like if(), while(), select()
127          (attempt causes a parser error).
128        - NKSP VM API: Allow built-in functions to perform their own, individual
129          parse time checks of arguments going to be passed to the function at
130          runtime (added method VMFunction::checkArgs() for that purpose).
131        - NKSP language: raise parser warning if only one operand of binary
132          operators (like logical 'or' comparison) contain a 'final' value (because
133          it would always yield in a 'final' result in such cases).
134        - NKSP language: Allow comparison (=, #, <, >, <=, >=) of values with
135          different metric unit prefixes, which will behave as expected (e.g.
136          result of expression '1000us < 2ms' is true).
137        - NKSP language: Allow adding values with different metric unit prefixes
138          (e.g. result of expression '100Hz + 5kHz' is '5100Hz').
139        - NKSP language: Allow subtracting values with different metric unit
140          prefixes (e.g. result of expression '1ms - 20us' is '980us').
141        - NKSP language: Allow multiplying with any metric unit prefixes
142          (e.g. result of expression '2k * 3ms' is '6s'), however multiplications
143          with unit types on both sides (e.g. '2s * 2s') is still prohibited since
144          we don't have any considerable practical use for a term like '4s^2'
145          (hence any attempt multiplying two unit types still causes parser error).
146        - NKSP language: Allow dividing by any metric unit prefixes and allow
147          division of same unit type on both sides (e.g. expression '8kHz / 1000Hz'
148          yields in unit free result '8'). So this is now a way to cast units away
149          e.g. for passing the result to other expressions, certain function calls
150          or variables which are not accepting any units (or that specific unit).
151        - NKSP language: integer arrays and real number arrays can now be converted
152          to strings (e.g. for dumping their content with message() calls for
153          script debugging purposes).
154        - NKSP language: expressions and variables with units are now correctly
155          casted to strings (e.g. with message() calls).
156        - NKSP language: comparing real numbers for equalness (e.g. '~foo = 3.1') or
157          unequalness (e.g. '~foo # 3.1') is now less strict and takes the expected
158          floating point tolerances into account.
159        - NKSP VM API: Added methods VMScalarNumberExpr::evalCastInt() and
160          VMScalarNumberExpr::evalCastReal().
161        - NKSP VM API: Added base class 'VMNumberArrayExpr' for classes
162          'VMIntArrayExpr' and 'VMRealArrayExpr'.
163        - NKSP VM API: replaced all unitPrefix() (parse time) methods by
164          unitFactor() (runtime) methods.
165        - Built-in function "exit()" supports now returning units and 'final'ness
166          for test cases.
167        - The following built-in functions support now units as well: "abs()",
168          "random()", "inc()", "dec()", "in_range()", "min()", "max()",
169          "real_to_int()", "int()", "int_to_real()" and "real()".
170        - Built-in functions "array_equal()", "search()" and "sort()" support now
171          real number arrays (correctly) as well.
172        - Added individual parse time checks of arguments to be passed to built-in
173          functions "random()", "inc()", "dec()", "in_range()", "min()", "max()",
174          "array_equal()" and "search()" specific for their individual purposes.
175        - NKSP VM refactoring: Renamed all methods, functions and classes matching
176          pattern *ScalarNumber* to simply *Number* (that is i.e. classes
177          VMScalarNumberExpr -> VMNumberExpr, ScalarNumberExpr -> NumberExpr,
178          ScalarNumberVariable -> NumberVariable, ScalarNumberBinaryOp ->
179          NumberBinaryOp, VMScalarNumberResultFunction -> VMNumberResultFunction,
180          method VMExpr::asScalarNumberExpr() -> VMExpr::asNumber(), function
181          isScalarNumber() -> isNumber()).
182        - NKSP VM API: Added 4 overridden methods to class VMNumberExpr:
183          evalCastInt(MetricPrefix_t), evalCastInt(MetricPrefix_t,MetricPrefix_t),
184          evalCastReal(MetricPrefix_t), evalCastReal(MetricPrefix_t,MetricPrefix_t)
185          as convenient methods for automatically converting values to expected
186          metric value basis.
187        - Built-in function "wait()" accepts now both integers and real numbers as
188          argument.
189        - NKSP VM API cleanup: Get rid of legacy method
190          VMFunction::argType(vmint iArg) which was already superseded by its new
191          replacement VMFunction::acceptsArgType(vmint iArg, ExprType_t type).
192        - NKSP parser: if wrong argument type was passed to a built-in function and
193          that built-in function accepts more than one data type for the argument,
194          then show all supported data types as parser error message.
195        - Built-in function "play_note()" accepts now real numbers and seconds as
196          unit type as well for its 3rd and 4th function arguments.
197        - The following built-in functions accept now real numbers as well for their
198          2nd function argument: "change_vol()", "change_tune()", "change_cutoff()",
199          "change_attack()", "change_decay()", "change_release()",
200          "change_sustain()", "change_cutoff_attack()", "change_cutoff_decay()",
201          "change_cutoff_sustain()", "change_cutoff_release()",
202          "change_amp_lfo_freq()", "change_cutoff_lfo_freq()",
203          "change_pitch_lfo_freq()", "change_vol_time()", "change_tune_time()",
204          "change_pan_time()", "fade_in()", "fade_out()", "change_play_pos()".
205        - Fixed built-in function "change_play_pos()" not having accepted metric
206          prefixes at all.
207        - Fixed the following built-in functions having misinterpreted values given
208          with unit type (for their 2nd argument) as if they were relative values
209          (that is as if they were passed without a unit type): "change_attack()",
210          "change_decay()", "change_release()", "change_cutoff_attack()",
211          "change_cutoff_decay()", "change_cutoff_release()".
212        - Fixed the following built-in functions having applied completely wrong
213          'final' values: "change_sustain()", "change_cutoff_sustain()" (since the
214          respective EGs being their modulation sink assume uint data type with
215          value range 0..1000 instead of 0.0..1.0.
216        - Added individual parse-time checks of function arguments for the following
217          built-in functions: "play_note()", "note_off()", "set_event_mark()",
218          "delete_event_mark()", "by_marks()", "change_cutoff()", "change_attack()",
219          "change_decay()", "change_release()", "change_cutoff_attack()",
220          "change_cutoff_decay()", "change_cutoff_release()",
221          "change_amp_lfo_freq()", "change_cutoff_lfo_freq()",
222          "change_pitch_lfo_freq()", "change_vol_time()", "change_tune_time()" and
223          "change_pan_time()".
224        - Don't abort function call if unit type was used and at the same time
225          'final' operator was omitted for the primary value argument of the
226          following built-in functions: "change_cutoff()", "change_attack()",
227          "change_decay()", "change_release()", "change_cutoff_attack()",
228          "change_cutoff_decay()", "change_cutoff_release()",
229          "change_amp_lfo_freq()", "change_cutoff_lfo_freq()",
230          "change_pitch_lfo_freq()", "change_vol_time()", "change_tune_time()",
231          "change_pan_time()", instead imply 'final'ness at runtime and raise an
232          appropriate parser warning at parse time.
233        - Added built-in real number functions "round()", "ceil()", "floor()",
234          "sqrt()", "log()", "log2()", "log10()", "exp()", "pow()", "sin()",
235          "cos()", "tan()", "asin()", "acos()", "atan()".
236        - Added built-in script real number constant "~NI_MATH_PI".
237        - Added built-in script real number constant "~NI_MATH_E".
238        - NKSP language: Allow unary '+' operator.
239        - Added built-in script functions "msb()" and "lsb()".
240        - NKSP language: Added support for RPN event handler
241          ("on rpn ... end on" in instrument scripts).
242        - NKSP language: Added support for NRPN event handler
243          ("on nrpn ... end on" in instrument scripts).
244        - Added built-in read-only variables "$RPN_ADDRESS" and "$RPN_VALUE" which
245          may be read from the new RPN/NRPN script handlers to get the (N)RPN
246          parameter that had been changed and its new value.
247        - Added built-in const variables "$NI_CB_TYPE_RPN" and "$NI_CB_TYPE_NRPN"
248          which are identifying the new (N)RPN handlers as such at script runtime.
249        - Implemented built-in script function "set_rpn()".
250        - Implemented built-in script function "set_nrpn()".
251        - Fix: built-in functions returning an array type were broken and caused a
252          crash when the built-in function's (supposed to be array) result value was
253          used by the script VM.
254        - Removed upper value constraint for 2nd argument of built-in functions
255          "change_amp_lfo_freq()", "change_cutoff_lfo_freq()",
256          "change_pitch_lfo_freq()","change_reso()", "change_cutoff()",
257          "change_amp_lfo_depth()", "change_cutoff_lfo_depth()" and
258          "change_pitch_lfo_depth()", to allow e.g. passing value 2000000 to double
259          the LFO frequency / resonance / cutoff frequency.
260        - Reduced code involved for parsing NKSP variable declarations by using 2
261          generalized grammar rules with optional components (i.e. optional value
262          assignment and optional variable qualifiers) instead of previous linear
263          combinations of grammar rules, which also fixes some edge case.
264        - NKSP language parser: track code block locations also by a) raw byte
265          position in NKSP source code string and b) length of that code block in
266          bytes (along to the already existing code block tracking by line/column);
267          and added appropriate new members to public C++ API classes like
268          'firstByte' and 'lengthBytes' to class VMSourceToken and struct CodeBlock.
269        - NKSP language: Added support for 'patch' variable qualifier (capture their
270          locations and allow replacement of their assignment expression via VM C++
271          API).
272        - Fixed incorrect EG times if standard measuring unit was passed to built-in
273          functions "change_attack()", "change_decay()" or "change_release()".
274        - Fixed intermediate function result values never having reflected any
275          standard measuring unit type.
276        - Fixed re-entrant issue with function calls which caused wrong result
277          values if the same function was called multiple times in a term
278          (specifically if metric prefixes were used).
279    
280      * test cases:
281        - Fixed compiler errors in test cases.
282        - Updated README for how to compile & run test cases.
283        - Updated test case
284          MutexTest::testDoubleLockStillBlocksConcurrentThread() to latest
285          expected behaviour of the Mutex class implementation (recursive
286          mutex type).
287        - Added test cases for NKSP core language aspects and core built-in
288          functions.
289        - Fixed thread tests segfaulting on Linux.
290        - NKSP: Added real number test cases for built-in functions exit(),
291          int_to_real(), real(), real_to_int() and int(), as well as for the
292          plus, minus and negate language operators.
293        - Added massive amount of NKSP test cases for standard measuring units and
294          'final' operator usage cases.
295        - Added NKSP test cases for (floating point tolerance aware) real number
296          equalness / unequalness comparison.
297        - Added NKSP int array and real array tests for value assignment and
298          initialization of arrays.
299        - Added NKSP test cases for built-in functions "round()", "ceil()",
300          "floor()", "sqrt()", "log()", "log2()", "log10()", "exp()", "pow()",
301          "sin()", "cos()", "tan()", "asin()", "acos()", "atan()".
302        - Added NKSP test cases for unary '+' operator.
303        - Added NKSP test cases for core built-in variables.
304        - Added thorough NKSP test cases for variable declarations.
305    
306      * GigaStudio/Gigasampler format engine:
307        - LFOTriangleIntMath and LFOTriangleIntAbsMath: Fixed FlipPhase=true
308          behaviour for start_level_mid.
309        - Changed LFO start levels: LFO1 and LFO2 both to mid, LFO3 to max. start
310          level (see discussion "GigaStudio LFO compatibility" on mailing list
311          from 2019-09-26 for details).
312        - Changed default wave form for all 3 LFOs to sine (instead of triangle;
313          see discussion "GigaStudio LFO compatibility" on mailing list from
314          2019-09-26 for details).
315        - Format extension: Added support for different LFO wave forms (currently
316          either sine [default], triangle, saw or square).
317        - Format extension: Added support for LFO phase displacement (0°..360°).
318        - Format extension: Added support for flipping LFO polarity on LFO 3
319          (in the original gig format this was only available for LFO 1 and LFO 2).
320        - Format extension: Support for additional filter types:
321          lowpass 1/2/4/6-pole, highpass 1/2/4/6-pole, bandpass 2-pole,
322          bandreject 2-pole.
323        - Fixd potential crash with polynomial interpolator and max. pitch.
324        - If minimum cutoff is defined, remap cutoff controller CC values to really
325          span the entire possible cutoff range (and avoiding a dead controller
326          zone).
327        - Implemented support for loading instrument scripts with 'patch' variables
328          (by patching these script variables with potentially overridden ones by
329          gig Instrument).
330    
331      * SFZ format engine:
332        - Fixed support for regions with loccN/hiccN conditions on more than one
333          MIDI controller.
334    
335      * Benchmarks:
336        - Fixed benchmarks/triang.cpp falsely having favoured "int math abs"
337          algorithm (since result of 2nd run was not accumulated).
338        - Added benchmark for saw wave (benchmarks/saw.cpp).
339        - Added benchmark for sine wave (benchmarks/sine.cpp).
340        - Added benchmark for square wave (benchmarks/square.cpp).
341        - Increased amount of benchmarks runs by factor 6 to achieve benchmark times
342          which are large enough on modern systems.
343    
344    Version 2.1.1 (27 Jul 2019)
345    
346      * Real-time instrument scripts:
347        - Fixed behavior of built-in NKSP functions change_sustain(),
348          change_cutoff_attack(), change_cutoff_decay(), change_cutoff_sustain()
349          and change_cutoff_release().
350    
351      * general changes:
352        - Only play release trigger samples on sustain pedal up if this behaviour
353          was explicitly requested by the instrument (otherwise only on note-off).
354        - Fixed compiler warnings.
355        - Fixed compilation error when cross-compiling to Mac.
356        - FX Sends: Provide more useful error messages on routing problems
357          (see bug #169).
358        - LSCP doc: Be more clear describing the two distinct approaches
359          of using external vs. internal effects (see bug #169).
360        - "optional" class: Fixed comparison operators.
361    
362      * Gigasampler/GigaStudio format engine:
363        - Format extension: If requested by instrument then don't play release
364          trigger sample on note-off events.
365    
366      * SFZ format engine:
367        - Fixed memory leak when releasing samples
368          (fixes bug #307, patch by Jacek Roszkowski)
369        - Fixed potential crash when a sample is shared by more than one region
370          (fixes bug #308, patch by Jacek Roszkowski).
371        - Opcode 'sample': Added support for built-in sample '*silence'
372          (fixes bug #310, patch by Jacek Roszkowski).
373    
374    Version 2.1.0 (25 Nov 2017)
375    
376      * SFZ format engine:
377        - added support for <global>, <master> and #define (patch by Alby M)
378        - Removed code duplication in SFZ file loading code.
379        - Added support for sfz extension opcode 'script' which may be used to
380          load real-time instrument script file (NKSP script language).
381        - Implemented opcode set_ccN (initial patch by Giovanni Senatore).
382        - Fixed unintended volume fade-in of voices under certain conditions.
383        - sfz parser: allow missing space between header and opcode
384    
385      * Gigasampler/GigaStudio format engine:
386        - Fixed clicks and pumping noise with Lowpass Turbo filter on very low
387          cutoff settings.
388        - Got rid of resembling an ancient GSt misbehavior which did not pitch at
389          all if an up-pitch of more than 40 semi tones was requested (I don't
390          think there is any stock gig sound that requires this behavior to
391          resemble its original sound).
392        - Added support for controlling whether the individual EGADSR stages may
393          be aborted (as LinuxSampler extension to the original GigaStudio 4
394          format).
395    
396      * general changes:
397        - fixed printf type errors (mostly in debug messages)
398        - use unique_ptr instead of auto_ptr when building with C++11
399        - Added RTAVLTree class which is a real-time safe ordered multi-map, thus
400          allowing to sort data efficiently in real-time safe manner.
401        - RTList class: added methods for moving/inserting elements to arbitrary
402          position within a list.
403        - RTList class: added method fromPtr() for creating an Iterator object from
404          a raw element pointer.
405        - Attempt to partly fix resetting engine channels vs. resetting engine, an
406          overall cleanup of the Reset*(), ConnectAudioDevice(),
407          DisconnectAudioDevice() API methods would still be desirable though,
408          because the current situation is still inconsistent and error prone.
409        - Active voices are now internally grouped to "Note" objects, instead of
410          being directly assigned to a keyboard key. This allows more fine graded
411          processing of voices, which is i.e. required for certain instrument
412          script features.
413        - Fix: Release trigger voices were not spawned on sustain pedal up
414          (CC #64) events.
415        - Fix: Release trigger voices can now also distinguish correctly between
416          note-off and sustain pedal up events.
417        - All engines: Increased ramp speed of volume smoother and pan smoother
418          (while slow rate of crossfade smoother is preserved) to allow quick
419          volume and pan changes by instrument scripts for instance.
420        - gig/sf2/sfz: Fixed aftertouch channel pressure events being processed
421          properly and thus were ignored for certain uses.
422        - Added new C++ API method
423          VirtualMidiDevice::SendChannelPressureToSampler().
424        - windows, 32-bit: fixed potential crashes by making sure the stack in
425          sub threads is 16-byte aligned
426        - fixed numerous compiler warnings
427        - Fixed invalid (note-on) event ID being assigned to new Note objects.
428        - Revised fundamental C++ classes "Thread", "Mutex" and "Condition" which
429          fixes potential undefined behavior.
430        - Fixed Note object leak when triggering notes on keys which did not
431          have a valid sample mapped (fixes bug #252).
432        - Fixed compilation errors when compiling with CONFIG_DEVMODE enabled.
433        - linuxsampler binary fix: option --create-instruments-db ignored
434          subsequent optional argument due to glibc's implementation oddity
435          which expects a "=" sign, but no space between them.
436    
437      * packaging changes:
438        - removed unnecessary dependency to libuuid
439          (originated by libgig's usage of it)
440        - Automake: set environment variable GCC_COLORS=auto to allow GCC to
441          auto detect whether it (sh/c)ould output its messages in color.
442        - Debian: Fixed packaging error about invalid "Source-Version"
443          substitution variable.
444        - Debian: Raised Debian compatibility level to Debian 9 "Stretch".
445        - Debian: Added build dependency to libsqlite3-dev for building
446          linuxsampler with instruments DB support.
447    
448      * Real-time instrument scripts:
449        - Implemented scheduler for delayed MIDI events and for suspended scripts.
450        - Built-in script function "wait()": implemented support for function's
451          "duration-us" argument, thus scripts using this function are now
452          correctly resumed after the requested amount of microseconds.
453        - Built-in script function "play_note()": implemented support for
454          function's "duration-us" argument, thus notes triggered with this
455          argument are now correctly released after the requested amount of
456          microseconds.
457        - Fix: script events were not cleared when engine channel was reset,
458          potentially causing undefined behavior.
459        - Fixed crash which happened when trying to reference an undeclared
460          variable.
461        - Built-in script function "play_note()": Added support for passing
462          special value -1 for "duration-us" argument, which will cause the
463          triggered note to be released once the original note was released.
464        - Instrument script classes now exported with the liblinuxsampler C++ API.
465        - Added new API method ScriptVM::syntaxHighlighting() which provides
466          a convenient syntax highlighting backend for external instrument
467          script editor applications.
468        - Added new C++ API class "ScriptVMFactory".
469        - Extended parser issues to provide not only first line and first
470          column, but also last line and last column of issue (thus marking
471          the precise span of the issue within the source code).
472        - Reload script automatically after being modified by an instrument
473          editor.
474        - NKSP language grammar correction: allow empty event handler bodies
475          like "on note end on".
476        - Implemented built-in script function "change_vol()".
477        - Implemented built-in script function "change_tune()".
478        - Implemented built-in script function "change_pan()".
479        - Implemented built-in script function "change_cutoff()".
480        - Implemented built-in script function "change_reso()".
481        - Implemented built-in script function "event_status()".
482        - Added built-in script constants "$EVENT_STATUS_INACTIVE" and
483          "$EVENT_STATUS_NOTE_QUEUE" both for being used as flags for
484          "event_status()" function.
485        - NKSP language: Added support for bitwise operators ".or.", ".and."
486          and ".not.".
487        - NKSP language scanner: Fixed IDs matching to require at least one
488          character (i.e. when matching function names or variable names).
489        - NKSP language scanner: disabled unusued rules.
490        - Fixed behavior of play_note() and note_off() functions which must
491          be distinguished engine internally from "real" MIDI note on/off
492          events in order to avoid misbehaviors like hanging notes.
493        - Implemented built-in script variable "$KSP_TIMER".
494        - Implemented built-in script variable "$NKSP_REAL_TIMER".
495        - Implemented built-in script variable "$NKSP_PERF_TIMER".
496        - Implemented built-in script variable "$ENGINE_UPTIME".
497        - Implemented built-in script function "inc()".
498        - Implemented built-in script function "dec()".
499        - NKSP language fix: division expressions were evaluated too often.
500        - NKSP language fix: string concatenation operator was right
501          associative instead of left (to right).
502        - NKSP language correction: allow empty statements in entire language
503          (i.e. "if end if").
504        - Implemented built-in script function "stop_wait()".
505        - Implemented built-in script variable "$NI_CALLBACK_ID".
506        - Implemented built-in script variable "$NI_CALLBACK_TYPE".
507        - Implemented built-in script variable "$NKSP_IGNORE_WAIT".
508        - Added support for read-only built-in variables (respectively
509          handled by the script parser).
510        - Added built-in script constant "$NI_CB_TYPE_INIT".
511        - Added built-in script constant "$NI_CB_TYPE_NOTE".
512        - Added built-in script constant "$NI_CB_TYPE_RELEASE".
513        - Added built-in script constant "$NI_CB_TYPE_CONTROLLER".
514        - NKSP Language: Added support for user defined script functions.
515        - Implemented built-in script function "change_attack()".
516        - Implemented built-in script function "change_decay()".
517        - Implemented built-in script function "change_release()".
518        - Fixed all change_*() built-in script functions to apply their
519          synthesis parameter changes immediately in case the respective note
520          was triggered at the same time, instead of scheduling the parameter
521          change, especially because it would cause some parameter types's
522          changes either to be ramped (i.e. change_vol()) or other types even
523          to have not effect at all (i.e. change_attack()).
524        - Implemented built-in script function "sh_left()".
525        - Implemented built-in script function "sh_right()".
526        - Implemented built-in script function "min()".
527        - Implemented built-in script function "max()".
528        - NKSP Fix: "init" event handler was not always executed when a script
529          was loaded.
530        - NKSP built-in wait() script function: abort script execution if
531          a negative or zero wait time was passed as argument (since this is
532          a common indication of a bug either of the script or even of the
533          engine, which could lead to RT instability or even worse).
534        - ScriptVM: Implemented automatic suspension of RT safety
535          threatening scripts.
536        - Provide more user friendly error messages on syntax errors.
537        - Fixed NKSP parser warning "Not a statement" when assigning an
538          initializer list to an array variable.
539        - Implemented built-in script array variable "%ALL_EVENTS".
540        - Implemented built-in script function "in_range()".
541        - Implemented built-in script function "change_amp_lfo_depth()".
542        - Implemented built-in script function "change_amp_lfo_freq()".
543        - Implemented built-in script function "change_pitch_lfo_depth()".
544        - Implemented built-in script function "change_pitch_lfo_freq()".
545        - Implemented built-in script function "change_vol_time()".
546        - Implemented built-in script function "change_tune_time()".
547        - Implemented built-in script function "fade_in()".
548        - Implemented built-in script function "fade_out()".
549        - Fixed acceptance of wrong data type of parameters passed to built-in
550          script functions "change_vol()", "change_tune()", "change_pan()",
551          "change_cutoff()", "change_reso()", "change_attack()", "change_decay()",
552          "change_release()", "change_amp_lfo_depth()", "change_amp_lfo_freq()",
553          "change_pitch_lfo_depth()" and "change_pitch_lfo_freq()".
554        - Added built-in script function "get_event_par()" and implemented some
555          of its possible parameter selections.
556        - Added built-in script function "set_event_par()" and implemented some
557          of its possible parameter selections.
558        - Fixed a bunch of scheduler time related bugs.
559        - Fixed polyphonic variables not being reset to zero after usage.
560        - Built-in "ignore_event()" function: argument is now optional, like with
561          built-in function "ignore_controller()".
562        - Implemented built-in script function "change_velo()".
563        - Implemented built-in script function "change_note()".
564        - Adjusted behavior of "change_vol()" and "change_tune()" to a more
565          intuitive behavior if used in combination with "change_vol_time()" or
566          "change_tune_time()" respectively: now tuning/volume changes are only
567          assigned (without delay) immediately to a new note if the respective
568          timing function has not been called before, otherwise the volume/tuning
569          changes are automatically faded (before, only the event's time stamp was
570          relevant).
571         - Implemented built-in script function "array_equal()".
572         - Implemented built-in script function "search()".
573         - Implemented built-in script function "sort()".
574         - NKSP Fix: Never suspend "init" event handlers.
575         - Implemented built-in script function "same_region()" (currently only
576           available for gig format engine).
577         - Added built-in script constant "$NKSP_LINEAR".
578         - Added built-in script constant "$NKSP_EASE_IN_EASE_OUT".
579         - Implemented built-in script function "change_vol_curve()".
580         - Implemented built-in script function "change_tune_curve()".
581         - built-in "play_note()" function now supports a sample playback start
582           offset with argument 3, where special value -1 means to use the regular
583           sample offset as defined by the instrument file.
584         - Built-in array variable %KEY_DOWN[] is now a read-only variable.
585         - Built-in variable $EVENT_NOTE is now a read-only variable.
586         - Built-in variable $EVENT_VELOCITY is now a read-only variable.
587         - built-in "play_note()" function now accepts -2 for its fourth argument
588           (note duration) which means the life time of the note shall be sticked
589           to the requested note number of argument 1.
590         - Fix: built-in "play_note()" function now returns 0 as result value if
591           -1 was passed for its fourth argument (note duration) and the respective
592           parent note is already gone.
593        - Implemented built-in script function "change_play_pos()".
594        - NKSP language: Added support for user declared const array variables.
595        - NKSP language: Raise parser warning if array variable is accessed with
596          an index that exceeds the array's size.
597        - NKSP language fix: Unknown characters were not handled correctly.
598        - NKSP language: Added support for "synchronized .. end synchronized"
599          code blocks.
600        - Implemented built-in script function "abort()" which allows to abort
601          another script handler by passing its callback ID.
602        - Fixed potential memory access bug and potential undefined behavior of
603          "init" event handlers.
604        - Print a time stamp along to each call of built-in function "message()".
605        - ScriptVM API: Added VMParserContext::preprocessorComments() which allows
606          to retrieve all code blocks filtered out by the preprocessor.
607        - Added built-in script function "fork()".
608        - Added built-in array variable %NKSP_CALLBACK_CHILD_ID[].
609        - Added built-in variable $NKSP_CALLBACK_PARENT_ID.
610        - Fixed potential crash when accessing dynamic built-in array variables.
611        - Added built-in script function "callback_status()".
612        - Added built-in constant $CALLBACK_STATUS_TERMINATED.
613        - Added built-in constant $CALLBACK_STATUS_QUEUE.
614        - Added built-in constant $CALLBACK_STATUS_RUNNING.
615        - Removed max. value limitation of built-in functions "change_attack()",
616          "change_decay()" and "change_release()" to i.e. allow passing 2000000
617          for doubling the respective time.
618        - NKSP script editor syntax highlighting API: Fixed app termination due
619          to a lexer start condition stack underrun.
620        - NKSP preprocessor: Fixed wrong behavior on nested USE_CODE_IF() and
621          USE_CODE_IF_NOT() preprocessor statements.
622        - NKSP: Added built-in preprocessor condition NKSP_NO_MESSAGE, which
623          can be set to disable all subsequent built-in "message()" function calls
624          on preprocessor level.
625        - Implemented built-in script function "change_sustain()".
626        - NKSP script editor syntax highlighting API: catch all fatal lexer errors,
627          to avoid the editor app to crash on ill-formed text input.
628        - Added built-in script function "change_pan_time()".
629        - Added built-in script function "change_pan_curve()".
630        - Added built-in script function "change_cutoff_attack()".
631        - Added built-in script function "change_cutoff_decay()".
632        - Added built-in script function "change_cutoff_sustain()".
633        - Added built-in script function "change_cutoff_release()".
634        - Added built-in script function "change_cutoff_lfo_depth()".
635        - Added built-in script function "change_cutoff_lfo_freq()".
636    
637      * Instruments DB:
638        - Fixed memory access bug of general DB access code which lead to
639          undefined behavior.
640        - Cleanup of instruments DB file creation and opening code.
641        - The instrument DB path of linuxsampler's --create-instruments-db argument
642          is now optional, if it is missing, then a default location is used.
643        - Added support for scanning SFZ (.sfz) files.
644        - Added support for scanning Sound Font (.sf2) files.
645        - Fixed undefined DB transaction behavior.
646    
647    Version 2.0.0 (15 July 2015)
648    
649      * packaging changes:
650        - fixed building with newer MinGW-w64
651        - Mac OS X: support the new dir for Core Audio SDK
652        - Mac OS X: fixed building outside source directory
653        - made sure all source files for hostplugins are included when
654          doing "make dist"
655        - removed empty directories left from the cvs to svn migration
656        - fixed compilation with gcc 4.6.1
657        - another "make dist" fix, for the LV2 plugin
658        - made --enable-pthread-testcancel default on Mac OS X
659        - minor Makefile fix for building lscpparser when build and source
660          directories are separate
661        - Mac OS X: made it possible to specify plugin installation dir to
662          configure
663        - Mac OS X: Makefile fix for the install-strip target
664        - fixed compilation with gcc 4.7
665        - fixed configure script error with old autoconf versions
666        - lsatomic.h: use gcc provided atomic functions if building with
667          gcc 4.7 and C++11
668        - modernized configure script
669        - fixed linkage error when building with
670          LDFLAGS="-Wl,--no-undefined" (#190)
671        - fixed compilation with Clang 3.2
672        - removed usage of deprecated Automake variable INCLUDES
673        - fixed building with C++11
674        - build fix: ChangeFlagRelaxed.h was missing in makefile
675        - build fix: libsndfile compiler flags were missing in some
676          makefiles
677        - fix for building with bison 3.0 (#202)
678        - Mac OS X: added temporary hack allowing to spawn gigedit as callback
679          on the process's main thread
680        - fixed build error on newer MinGW
681        - support building with older jack versions
682        - support building with spaces in vst sdk path
683        - enabled automake 'subdir-objects' option and moved external
684          source references (vst, au, asio) from makefiles to cpp files,
685          in order to get rid of warnings from automake 1.14
686    
687      * general changes:
688        - Refactoring: moved the independent code from
689          the Gigasampler format engine to base classes
690        - command line option '--profile' is currently disabled, since the
691          respective profiling code is currently broken
692        - Introduced support for optional environment variable
693          "LINUXSAMPLER_PLUGIN_DIR" which allows to override the directory
694          where the sampler shall look for instrument editor plugins
695          (patch by Luis Garrido, slightly modified).
696        - implemented Roland GS NRPN 1ArrH which allows to set volume per note
697        - implemented Roland GS NRPN 1CrrH which allows to set pan per note
698        - implemented Roland GS NRPN 1DrrH which allows to set reverb send per
699          note (in this implementation of the sampler its simply hard routed to
700          the 1st effect send of the sampler channel, no matter what the actual
701          effect type is)
702        - implemented Roland GS NRPN 1ErrH which allows to set chorus send per
703          note (in this implementation of the sampler its simply hard routed to
704          the 2nd effect send of the sampler channel, no matter what the actual
705          effect type is)
706        - implemented support for internal LADSPA effects
707        - raised limit of program change queue from 100 to 512
708          (as suggested by Alex Stone)
709        - implemented sine LFO, pulse LFO and saw LFO
710        - experimental support for per voice equalization
711        - added command line option --exec-after-init
712        - Introduced new C++ API method:
713          EngineChannel::InstrumentFileName(int index)
714          allowing to retrieve the whole list of files used for the loaded
715          instrument on an engine channel (a.k.a. part). Some GigaStudio
716          instruments for example are splitted over several files like
717          "Foo.gig", "Foo.gx01", "Foo.gx02", ...
718        - Added new C++ API method Sampler::GetGlobalMaxVoices().
719        - Added new C++ API method Sampler::GetGlobalMaxStreams().
720        - Added new C++ API method Sampler::SetGlobalMaxVoices().
721        - Added new C++ API method Sampler::SetGlobalMaxStreams().
722        - Various "const" and "restrict" optimizations.
723        - all engines: add pan CC value to instrument pan parameter before
724          applying panning, instead of using two separate pan functions in
725          series (#182)
726        - added a lock guard class for exception safe mutex handling and
727          used it everywhere appropriate
728        - Immediately apply scale tuning changes to active voices.
729        - Exposed scale tuning to C++ API (along to the already existing standard
730          SysEx way).
731        - lsatomic.h fixes: seq_cst load and store were suboptimal for x86
732          and broken for ppc64. (Seq_cst loads and stores are actually not
733          used in LS, so the bug wasn't noticable.)
734        - lsatomic.h: added ARMv7 support
735        - Added support for multiple MIDI input ports per sampler channel (and
736          added various new C++ methods for this new feature / design change, old
737          C++ API methods for managing SamplerChannel's MIDI inputs are now marked
738          as deprecated but are still there and should provide full behavior
739          backward compatibility).
740        - AbstractEngine::GSChecksum(): don't allocate memory on the stack (was
741          unsafe and caused compilation error with clang 2.x).
742        - Bugfix: only process the latest MIDI program change event.
743        - Introducing the LSCP shell, which provides convenient control of the
744          sampler from the command line by providing LSCP aware features.
745        - VirtualMidiDevice: Added support for program change.
746        - VirtualMidiDevice: Added support for bank select (MSB & LSB).
747        - VirtualMidiDevice: Added support for pitch bend.
748        - Aftertouch: extended API to explicitly handle channel pressure and
749          polyphonic key pressure events (so far polyphonic pressure was not
750          supported at all, and channel pressure was rerouted as CC128 but not
751          used so far).
752        - Added initial support for real-time instrument scripts. The script VM
753          code is shared by all sampler engine implemementations, however only the
754          gig file format currently provides support for storing instrument scripts
755          (as LinuxSampler extension to the original GigaStudio 4 format).
756    
757      * Gigasampler format engine:
758        - implemented the "round robin keyboard" dimension
759        - fixed round robin and random dimensions for cases when number of
760          dimension zones is not a power of two
761        - made round robin use a counter for each region instead of each
762          key
763        - bugfix: pitch LFO controller "internal+aftertouch" was broken
764        - bugfix: filter keyboard tracking was broken
765        - filter performance fix (an unnecessary copy was made of the
766          filter parameters in each sub fragment)
767        - handle special case when pan parameter in gig file has max or
768          min value
769        - Exclusive Groups: don't ever stop voices of the same note,
770          doesn't sound naturally with a drumkit
771        - fixed EG1 modulation when attack or release is zero
772        - Fixed support for 'aftertouch' attenuation controller.
773        - Fixed crash that happened with velocity split sounds under certain
774          conditions (see also previous commit on libgig).
775        - fixed behaviour of filter LFO
776    
777      * SFZ format engine:
778        - Initial implementation (not usable yet)
779        - added support for v2 multiple stage envelope generators
780        - added a fine-tuned v1 envelope generator instead of using the
781          one from the gig engine
782        - fixed memory leak and memory handling errors
783        - added support for trigger=first, trigger=legato and sw_previous
784        - allow non-numerical key values ("C#4" for example)
785        - "key" opcode now sets pitch_keycenter too
786        - fixed error when unloading instrument with same sample used by
787          multiple regions
788        - added some opcode aliases, like loopmode for loop_mode, to be
789          more compatible
790        - added support for trigger=release and rt_decay
791        - added support for off_mode=normal
792        - added support for random, seq_position, seq_length and volume
793        - added v1 LFO opcodes to parser (no support in engine yet)
794        - added support for amp_veltrack and amp_velcurve_N
795        - fine-tuned the default velocity curve
796        - added support for transpose
797        - fixed crash when using sw_down/up
798        - improved logic for sw_lokey/hikey/up/down/last
799        - added more v1 aliases to parser
800        - reduced memory usage for sfz data
801        - RT-safeness: avoid malloc in audio thread
802        - fixed a bug that could cause voice stealing to fail
803        - optimized sample lookup
804        - improved support for exclusive groups (group, off_by and
805          off_mode)
806        - added support for controller triggered regions (on_locc/on_hicc)
807        - added support for loop_mode=one_shot
808        - fixed playback of 16 bit wav files on big endian CPUs
809        - added support for Ogg Vorbis sample files
810        - use loop markers from sample file if loop_start and loop_end are
811          not set in sfz file
812        - implemeted filters. Filter types: lowpass, bandpass, bandreject
813          and highpass. 1, 2, 4 and 6 pole filters. Opcodes: fil_type,
814          cutoff, resonance, fil_veltrack, fil_keytrack, fil_keycenter,
815          cutoff_cc, cutoff_chanaft.
816        - bugfix: zero ampeg_sustain didn't work
817        - added support for velocity effect on amplifier envelope time
818          (ampeg_vel2attack, ampeg_vel2decay, ampeg_vel2sustain and
819          ampeg_vel2release)
820        - added support for EG hold (ampeg_hold)
821        - added support for sample offset (offset)
822        - use the newly introduced signal units model
823        - implemented opcodes lfoN_delay,
824          lfoN_freq, lfoN_pan, lfoN_cutoff, lfoN_resonance
825        - implemented opcodes ampeg_delay, ampeg_vel2delay
826          pitcheg_delay, pitcheg_start, pitcheg_attack, pitcheg_hold,
827          pitcheg_decay, pitcheg_sustain, pitcheg_release, pitcheg_vel2delay,
828          pitcheg_vel2attack, pitcheg_vel2hold, pitcheg_vel2decay,
829          pitcheg_vel2sustain, pitcheg_vel2release, pitcheg_depth
830        - implemented opcodes pitchlfo_delay, pitchlfo_freq,
831          pitchlfo_depth, fillfo_delay, fillfo_freq, fillfo_depth,
832          amplfo_delay, amplfo_freq, amplfo_depth
833        - implemented opcodes fileg_delay, fileg_start, fileg_attack,
834          fileg_hold, fileg_decay, fileg_sustain, fileg_release, fileg_vel2delay,
835          fileg_vel2attack, fileg_vel2hold, fileg_vel2decay, fileg_vel2sustain,
836          fileg_vel2release
837        - implemented opcode lfoN_wave
838        - implemented opcode pitchlfo_depthccN
839        - implemented opcodes lfoN_phase, lfoN_phase_onccX,
840          lfoN_pitch, lfoN_pitch_onccX
841        - implemented opcodes pitchlfo_fade,
842          fillfo_fade, amplfo_fade, lfoN_fade, lfoN_fade_onccX
843        - implemented opcodes fillfo_freqccN,
844          pitchlfo_freqccN, amplfo_freqccN, lfoN_freq_onccX
845        - implemented opcodes ampeg_delayccN, ampeg_startccN,
846          ampeg_attackccN, ampeg_holdccN, ampeg_decayccN, ampeg_sustainccN,
847          ampeg_releaseccN, egN_timeX_onccY, egN_levelX_onccY
848        - lfoN_* and egN_* opcodes defined in group sections
849          are now taken into account
850        - implemented curves
851        - implemented opcodes volume_onccN, volume_curveccN
852        - implemented opcode volume_smoothccN
853        - implemented opcodes fillfo_depthccN, amplfo_depthccN,
854          lfoN_volume, lfoN_volume_onccX, lfoN_volume_smoothccX,
855          lfoN_freq_smoothccX, lfoN_pitch_smoothccX, lfoN_pan_onccX,
856          lfoN_pan_smoothccX, lfoN_cutoff_onccX, lfoN_cutoff_smoothccX,
857          lfoN_resonance_onccX, lfoN_resonance_smoothccX, lfoN_delay_onccX
858        - implemented opcode end
859        - implemented opcodes egN_amplitude_onccX,
860          egN_volume, egN_volume_onccX, egN_cutoff, egN_cutoff_onccX,
861          egN_pitch, egN_pitch_onccX, egN_resonance, egN_resonance_onccX
862        - implemented opcodes xfin_lokey, xfin_hikey,
863          xfout_lokey, xfout_hikey, xf_keycurve, xfin_lovel, xfin_hivel,
864          xfout_lovel, xfout_hivel, xf_velcurve, xfin_loccN, xfin_hiccN,
865          xfout_loccN, xfout_hiccN, xf_cccurve
866        - implemented opcodes pan_onccN, pan_smoothccN,
867          pan_curveccN, egN_pan, egN_pan_curve, egN_pan_onccX,
868          egN_pan_curveccX, pitch_veltrack
869        - when failed to parse a sfz file
870          print the line number on which the error occurs
871        - use common pool of CC objects to minimize RAM usage
872        - implemented opcodes amplfo_delay_onccN,
873          amplfo_fade_onccN, fillfo_delay_onccN, fillfo_fade_onccN,
874          pitchlfo_delay_onccN, pitchlfo_fade_onccN
875        - implemented opcodes fileg_delay_onccN,
876          fileg_start_onccN, fileg_attack_onccN, fileg_hold_onccN,
877          fileg_decay_onccN, fileg_sustain_onccN, fileg_release_onccN,
878          fileg_depth_onccN, pitcheg_delay_onccN, pitcheg_start_onccN,
879          pitcheg_attack_onccN, pitcheg_hold_onccN, pitcheg_decay_onccN,
880          pitcheg_sustain_onccN, pitcheg_release_onccN, pitcheg_depth_onccN
881        - implemented automatic aliasing *ccN <-> *_onccN
882        - *lfo_freqccN wasn't working when the respective *lfo_freq
883          was not set or was set to zero
884        - lfoN_freq_onccX wasn't working when lfoN_freq
885          was not set or was set to zero
886        - implemented opcodes resonance_onccN, resonance_smoothccN,
887          resonance_curveccN, cutoff_smoothccN, cutoff_curveccN
888        - implemented opcodes fillfo_depthchanaft,
889          fillfo_freqchanaft, amplfo_depthchanaft, amplfo_freqchanaft,
890          pitchlfo_depthchanaft, pitchlfo_freqchanaft
891        - implemented opcodes pitch_onccN,
892          pitch_curveccN, pitch_smoothccN, pitch_stepccN
893        - implemented opcodes volume_stepccN, pan_stepccN,
894          cutoff_stepccN, resonance_stepccN, lfoN_freq_stepccX,
895          lfoN_volume_stepccX, lfoN_pitch_stepccX, lfoN_pan_stepccX,
896          lfoN_cutoff_stepccX, lfoN_resonance_stepccX
897        - implemented opcodes eq1_freq, eq2_freq, eq3_freq,
898          eq1_freqccN, eq2_freqccN, eq3_freqccN, eq1_bw, eq2_bw, eq3_bw,
899          eq1_bwccN, eq2_bwccN, eq3_bwccN, eq1_gain, eq2_gain, eq3_gain,
900          eq1_gainccN, eq2_gainccN, eq3_gainccN
901        - implemented opcodes delay, delay_onccN, delay_random,
902          delay_samples, delay_samples_onccN
903        - implemented opcodes egN_eq1gain, egN_eq2gain, egN_eq3gain,
904          egN_eq1gain_onccX, egN_eq2gain_onccX, egN_eq3gain_onccX, egN_eq1freq,
905          egN_eq2freq, egN_eq3freq, egN_eq1freq_onccX, egN_eq2freq_onccX,
906          egN_eq3freq_onccX, egN_eq1bw, egN_eq2bw, egN_eq3bw, egN_eq1bw_onccX,
907          egN_eq2bw_onccX, egN_eq3bw_onccX, lfoN_eq1gain, lfoN_eq2gain,
908          lfoN_eq3gain, lfoN_eq1gain_onccX, lfoN_eq2gain_onccX, lfoN_eq3gain_onccX,
909          lfoN_eq1gain_smoothccX, lfoN_eq2gain_smoothccX, lfoN_eq3gain_smoothccX,
910          lfoN_eq1gain_stepccX, lfoN_eq2gain_stepccX, lfoN_eq3gain_stepccX,
911          lfoN_eq1freq, lfoN_eq2freq, lfoN_eq3freq, lfoN_eq1freq_onccX,
912          lfoN_eq2freq_onccX, lfoN_eq3freq_onccX, lfoN_eq1freq_smoothccX,
913          lfoN_eq2freq_smoothccX, lfoN_eq3freq_smoothccX, lfoN_eq1freq_stepccX,
914          lfoN_eq2freq_stepccX, lfoN_eq3freq_stepccX, lfoN_eq1bw, lfoN_eq2bw,
915          lfoN_eq3bw, lfoN_eq1bw_onccX, lfoN_eq2bw_onccX, lfoN_eq3bw_onccX,
916          lfoN_eq1bw_smoothccX, lfoN_eq2bw_smoothccX, lfoN_eq3bw_smoothccX,
917          lfoN_eq1bw_stepccX, lfoN_eq2bw_stepccX, lfoN_eq3bw_stepccX
918        - implemented opcodes eq1_vel2freq, eq2_vel2freq,
919          eq3_vel2freq, eq1_vel2gain, eq2_vel2gain, eq3_vel2gain
920        - sfz parser: allow double spaces in sample filenames
921        - sfz parser: allow absolute paths for sample filenames
922        - use linear decay and release for filter and pitch EG
923        - bugfix: only the first amp_veltrack definition in a file was
924          used
925        - bugfix: looping was disabled if loop_start was set to 0
926        - allow regions with end=-1 to turn off other regions using the
927          group and off_by opcodes (#168)
928        - made end=0 play the whole sample
929        - fixed support for lochan and hichan opcodes (#155)
930        - fixed crash when using lochan/hichan opcodes (#187)
931        - sfz parser: allow -200 to 200 for pan_oncc opcode (#182)
932        - added FLAC support (#191)
933        - sfz parser bugfix: lines starting with whitespace were ignored
934        - added amplitude opcode
935        - added support for "#include" instruction
936          (modified patch which was originally posted by Sergey on LS mailing list)
937        - bugfix: generation of velocity curves etc should not be done
938          after each "#include", only after the main file is parsed
939        - bugfix: line numbers in error messages were wrong after "#include"
940        - added support for float and 32 bit sample files
941    
942      * SoundFont format engine:
943        - Initial implementation (not usable yet)
944        - RT-safeness: avoid malloc in audio thread
945        - fixed a bug that could cause voice stealing to fail
946        - fine-tuned amplitude EG (by switching from gig to sfz EG)
947        - initial implementation of Vibrato LFO and Modulation LFO
948        - initial implementation of cutoff filter
949        - use linear decay and release for filter and pitch EG
950    
951      * Host plugins (VST, AU, LV2, DSSI):
952        - AU bugfix: failed to destroy its audio/MIDI devices
953        - Listen to all interfaces on Mac OS X (INADDR_ANY)
954        - VST bugfix: If the host called resume() before and after
955          changing sample rate or block size, the number of channels was
956          incorrectly set to two. This caused silence in Cubase 5.
957        - save engine type (gig, sfz or sf2) in plugin state
958        - VST: when opening Fantasia, look for both 32 and 64 bit Java on
959          64 bit Windows
960        - AU: changed number of output channels from one stereo to 16
961          stereo
962        - VST: made it possible to build the VST plugin for Mac
963        - AU: link AU plugin dynamically if --disable-shared isn't
964          specified
965        - LV2 "state" extension support (patch by David Robillard)
966        - VST bugfix: instrument loading hang and crashed the host when
967          the plugin was loaded a second time (#174)
968        - plugin bugfix: instrument loading hang when the plugin was
969          loaded a second time (this time it's for Linux and Mac, previous
970          similar fix was for Windows)
971        - thread safety fixes for the instrument loading thread
972        - LV2: use the new lv2 package if present
973        - VST: try to open Fantasia automatically on Linux and Mac too (on
974          Linux, the Fantasia jar should be placed in <prefix>/share/java)
975        - VST: fixed crashes on Linux Ardour and EnergyXT
976        - DSSI bugfix: it wasn't possible to change engine type. The MIDI
977          port and audio channel routing for DSSI plugins are now visible.
978        - LV2: use urid and atom extensions instead of deprecated uri-map
979          and event
980        - LV2: lv2 package 1.0 is now required to build the LV2 plugin
981        - LV2: changed number of output channels to 16 stereo, just like
982          the VST and AU plugins
983        - LV2: fixed save/restore of SFZ state (patch by David Robillard)
984        - LV2: made LV2 plugin buildable on Windows and Mac
985        - VST: implemented retrieval and switching of programs using the
986          sampler's internal MIDI instrument mapping system
987    
988      * Instrument editor interface:
989        - Changed instrument editor plugin interface, providing additional
990          informations like the EngineChannel for which the instrument editor was
991          spawned for. This allows the instrument editors to interact more actively
992          with the sampler.
993    
994      * MIDI driver:
995        - ALSA MIDI driver supports now "NAME" device parameter, for overriding
996          the ALSA sequencer client name
997        - removed limit of maximum amount of MIDI ports per MIDI device, since
998          there is no reason for this limit
999        - MME: fixed memory handling bug found with cppcheck
1000        - MME: removed compiler warning
1001        - CoreMIDI: implemented driver specific port parameter "CORE_MIDI_BINDINGS",
1002          which allows to retrieve the list of CoreMIDI clients / ports and to connect
1003          to them a la JACK, via the usual sampler APIs
1004        - CoreMIDI: added driver specific port parameter "AUTO_BIND", if enabled
1005          the driver will automatically connect to other CoreMIDI clients' ports
1006          (e.g. external MIDI devices being attached to the Mac)
1007        - added support for MIDI note on velocity filter
1008        - CoreMIDI: fixed memory deallocation error
1009        - Fixed variable underflow in VirtualMidiDevice, which caused graphical
1010          virtual keyboards in frontends / instrument editors being stuck.
1011        - Bugfix in VirtualMidiDevice: process note on with velocity 0 as note off.
1012        - Implemented missing handling of MIDI "running status".
1013        - CoreMIDI fix: a MIDIPacket can contain more than one event per packet.
1014        - MME bugfix: driver wasn't closed properly
1015        - CoreMIDI: automatically connect to all input sources by default (driver
1016          parameter "AUTO_BIND").
1017        - CoreMIDI: fixed auto bind feature to CoreMIDI ports that go online
1018        - CoreMIDI: fixed minor memory leak
1019    
1020      * audio driver:
1021        - ASIO driver fixes for newer gcc versions (fix from PortAudio)
1022        - JACK audio: react on sample rate changes.
1023        - JACK audio: react on buffer size changes.
1024        - JACK audio: jack_port_get_buffer() was cached and called outside
1025          RT context.
1026        - ASIO driver: removed compiler warnings
1027        - CoreAudio: fixed minor error handling bug
1028        - ASIO driver: be more verbose when no ASIO card could be found (fixes #203)
1029        - JACK audio: return the JACK server's current sample rate as default value
1030          for audio device parameter "SAMPLERATE" (fixes #166).
1031    
1032      * LSCP server:
1033        - added support for sending MIDI CC messages via LSCP command
1034          "SEND CHANNEL MIDI_DATA CC <sampler-chan> <ctrl> <val>"
1035        - added LSCP command "GET AVAILABLE_EFFECTS"
1036        - added LSCP command "LIST AVAILABLE_EFFECTS"
1037        - added LSCP command "GET EFFECT INFO <effect-index>"
1038        - added LSCP command "CREATE EFFECT_INSTANCE <effect-index>"
1039        - added LSCP command
1040          "CREATE EFFECT_INSTANCE <effect-system> <module> <effect-name>"
1041        - added LSCP command "DESTROY EFFECT_INSTANCE <effect-instance>"
1042        - added LSCP command "GET EFFECT_INSTANCES"
1043        - added LSCP command "LIST EFFECT_INSTANCES"
1044        - added LSCP command "GET EFFECT_INSTANCE INFO <effect-instance>"
1045        - added LSCP command
1046          "GET EFFECT_INSTANCE_INPUT_CONTROL INFO <effect-instance> <input-control>"
1047        - added LSCP command "SET EFFECT_INSTANCE_INPUT_CONTROL VALUE
1048          <effect-instance> <input-control> <value>"
1049        - added LSCP command "GET SEND_EFFECT_CHAINS <audio-device>"
1050        - added LSCP command "LIST SEND_EFFECT_CHAINS <audio-device>"
1051        - added LSCP command "ADD SEND_EFFECT_CHAIN <audio-device>"
1052        - added LSCP command
1053          "REMOVE SEND_EFFECT_CHAIN <audio-device> <effect-chain>"
1054        - added LSCP command
1055          "GET SEND_EFFECT_CHAIN INFO <audio-device> <effect-chain>"
1056        - added LSCP command "APPEND SEND_EFFECT_CHAIN EFFECT <audio-device>
1057          <effect-chain> <effect-instance>"
1058        - added LSCP command "INSERT SEND_EFFECT_CHAIN EFFECT <audio-device>
1059          <effect-chain> <effect-chain-pos> <effect-instance>"
1060        - added LSCP command "REMOVE SEND_EFFECT_CHAIN EFFECT <audio-device>
1061          <effect-chain> <chain-pos>"
1062        - added LSCP command "SET FX_SEND EFFECT <sampler_channel>
1063          <fx_send_id> <effect_chain> <chain_pos>"
1064        - added LSCP command "REMOVE FX_SEND EFFECT <sampler_channel> <fx_send_id>"
1065        - added LSCP commands "SUBSCRIBE EFFECT_INSTANCE_COUNT",
1066          "SUBSCRIBE EFFECT_INSTANCE_INFO", "SUBSCRIBE SEND_EFFECT_CHAIN_COUNT",
1067          "SUBSCRIBE SEND_EFFECT_CHAIN_INFO"
1068        - provide comprehensive error messages on LSCP syntax errors
1069          (suggesting expected next non-terminal symbols)
1070        - Fixed client connection not being closed after network errors.
1071    
1072      * LSCP shell:
1073        - Added support for auto correction of obvious and trivial syntax mistakes.
1074        - Added support for auto completion by tab key.
1075        - Show currently available auto completion while typing.
1076        - Added support for browsing command history with up / down keys.
1077        - Show all possible next symbols immediately right to the current command
1078          line while typing (no double tab required for this feature, as it would
1079          be the case in other shells).
1080        - Added support for moving cursor left/right with arrow keys.
1081        - Added support for built-in LSCP reference documentation, which will
1082          automatically show the relevant LSCP reference section on screen as soon
1083          as one specific LSCP command was detected while typing on the command
1084          line.
1085    
1086      * Real-time instrument scripts:
1087        - Implemented built-in script array variable %CC.
1088        - Implemented built-in script int variable $CC_NUM.
1089        - Implemented built-in script int variable $EVENT_NOTE.
1090        - Implemented built-in script int variable $EVENT_VELOCITY.
1091        - Implemented built-in script constant variable $VCC_MONO_AT.
1092        - Implemented built-in script constant variable $VCC_PITCH_BEND.
1093        - Implemented execution of script event handler "init".
1094        - Implemented execution of script event handler "controller".
1095        - Implemented execution of script event handler "note".
1096        - Implemented execution of script event handler "release".
1097        - Implemented built-in script function "play_note()" (only two of the
1098          max. four function arguments are currently implemented yet though).
1099        - Implemented built-in script int variable $EVENT_ID.
1100        - Implemented built-in script function "ignore_event()"
1101        - Implemented built-in script function "ignore_controller()" (may have one
1102          or no argument).
1103        - Implemented built-in script function "set_controller()".
1104        - Added extended script VM for the Gigasampler/GigaStudio format sampler
1105          engine, which extends the general instrument script VM with Giga format
1106          specific variables and functions.
1107        - Giga format scripts: added built-in script int constant variables
1108          $GIG_DIM_CHANNEL, $GIG_DIM_LAYER, $GIG_DIM_VELOCITY, $GIG_DIM_AFTERTOUCH,
1109          $GIG_DIM_RELEASE, $GIG_DIM_KEYBOARD, $GIG_DIM_ROUNDROBIN, $GIG_DIM_RANDOM,
1110          $GIG_DIM_SMARTMIDI, $GIG_DIM_ROUNDROBINKEY, $GIG_DIM_MODWHEEL,
1111          $GIG_DIM_BREATH, $GIG_DIM_FOOT, $GIG_DIM_PORTAMENTOTIME, $GIG_DIM_EFFECT1,
1112          $GIG_DIM_EFFECT2, $GIG_DIM_GENPURPOSE1, $GIG_DIM_GENPURPOSE2,
1113          $GIG_DIM_GENPURPOSE3, $GIG_DIM_GENPURPOSE4, $GIG_DIM_SUSTAIN,
1114          $GIG_DIM_PORTAMENTO, $GIG_DIM_SOSTENUTO, $GIG_DIM_SOFT,
1115          $GIG_DIM_GENPURPOSE5, $GIG_DIM_GENPURPOSE6, $GIG_DIM_GENPURPOSE7,
1116          $GIG_DIM_GENPURPOSE8, $GIG_DIM_EFFECT1DEPTH, $GIG_DIM_EFFECT2DEPTH,
1117          $GIG_DIM_EFFECT3DEPTH, $GIG_DIM_EFFECT4DEPTH, $GIG_DIM_EFFECT5DEPTH.
1118        - Giga format scripts: Implemented built-in script function
1119          "gig_set_dim_zone(event_id, dimension, zone)".
1120        - Implemented built-in script int array variable %KEY_DOWN.
1121        - Implemented built-in script function "abs()".
1122        - Implemented built-in script function "random()".
1123        - Implemented built-in script function "num_elements()".
1124        - Implemented built-in script function "note_off()".
1125        - Implemented built-in script function "set_event_mark()".
1126        - Implemented built-in script function "delete_event_mark()".
1127        - Implemented built-in script function "by_marks()".
1128        - Added built-in script int const variables $MARK_1 to $MARK_28.
1129        - Built-in script functions "ignore_event()", "note_off()" and
1130          "gig_set_dim_zone()" now also accept an array of event IDs as argument
1131          (i.e. return value of new script function "by_marks()").
1132        - Pass/preserve polyphonic variable data from respective "note" event
1133          handler to "release" event handler.
1134        - Fixed crash when using built-in script function "by_marks()".
1135    
1136      * Bug fixes:
1137        - Fixed crash which may occur when MIDI key + transpose is out of range
1138        - minor valgrind fixes
1139        - fixed crash which occurred when changing an already deployed sampler
1140          channel to a different engine type
1141        - fixed crash when deleting a sampler channel or changing engine
1142          type while an instrument load was in progress
1143        - bugfix: playing a note while changing the instrument could cause
1144          a crash, or give "Handing back unknown region" error messages
1145        - bugfix: calling SET VOICES (which Fantasia does on start and
1146          refresh) could cause instruments to be unloaded
1147        - Mac OS X: fixed name collision of enum in EffectControl and
1148          wrong name of destructor in AudioOutputDeviceCoreAudio.cpp
1149        - Mac OS X: fixed hanging threads
1150        - Windows: disabled the previous thread fix on non-Mac systems, as
1151          it caused hanging threads on Windows
1152        - Fixed possible crashes due to corrupted MIDI/audio device list
1153          after MIDI/audio device creation failure
1154        - When creating MIDI instrument map entries with "PERSISTENT" type, the
1155          instruments were uselessly precached with zero samples, however it still
1156          took the full preloading time and on 1st program change the respective
1157          instrument was completely reloaded again.
1158        - fixed handling of rapid bank select and program change messages
1159          sent to the same sampler channel (patch from the Open Octave
1160          project, slightly adjusted)
1161        - fixed crash when trying to create an effect instance with controls
1162          which min and/or max values depend on the sample rate
1163        - fixed bug #162
1164        - bugfix: LADSPA_PATH was not evaluated correctly when containing
1165          multiple paths (#165)
1166        - thread safety fixes for the instrument loading thread
1167        - bugfix: instrument loading crashed for sfz and sf2 in Ardour
1168          (#176)
1169        - more thread safety fixes for the instrument loading thread
1170        - sfz/sf2 engine: fixed crash when using small audio fragment size
1171        - Mac OS X: fixed crash when unloading plugin on 10.7 and later
1172        - Mac OS X: fixed process hang when unloading 32-bit plugin (bug
1173          introduced in previous fix)
1174        - fixed crash when a channel received a program change while
1175          playing a note in a key group
1176        - fixed erroneous error message piping in VoiceBase.h
1177          (labelled "Disk stream not available in time")
1178        - Update effects on sample rate & period size changes (to avoid
1179          crashes and noise on such transitions).
1180        - ignore missing LADSPA paths without ignoring valid LADSPA paths
1181          (fixes #208)
1182        - Fixed bug in LSCP grammar definition which caused a statement like
1183          "GET SERVER INFOasdf\n" to be accepted as valid statement (was so far
1184          practically irrelevant, however it caused problems with the new LSCP
1185          shell's auto completion feature).
1186        - Fixed MIDI program change messages being ignored if quickly executed
1187          after each other (fixes #231).
1188    
1189    Version 1.0.0 (31 July 2009)
1190    
1191    * packaging changes:    * packaging changes:
1192      - autoconf bugfix: the PKG_CONFIG variable wasn't initialized properly,      - autoconf bugfix: the PKG_CONFIG variable wasn't initialized properly,
# Line 13  Version CVS HEAD (?) Line 1201  Version CVS HEAD (?)
1201      - fixed building with libgig installed in a non-standard directory      - fixed building with libgig installed in a non-standard directory
1202      - minor fix in configure for mmsystem.h detection on MinGW      - minor fix in configure for mmsystem.h detection on MinGW
1203      - Windows: look for editor plugins and Fantasia using base      - Windows: look for editor plugins and Fantasia using base
1204        directory of liblinuxsampler dll        directory of liblinuxsampler dll (look in the same directory and one
1205          directory above)
1206        - configure script fix: removed unconditional use of SSE
1207        - fixed building with sqlite installed in a non-standard directory
1208        - when cross-compiling, don't try to create instruments.db
1209        - fix for new mingw-w64 version, which has usleep
1210    
1211    * general changes:    * general changes:
1212      - bugfix: on some POSIX systems instrument editor plugins refused to      - bugfix: on some POSIX systems instrument editor plugins refused to
# Line 53  Version CVS HEAD (?) Line 1246  Version CVS HEAD (?)
1246      - theoretical fix: made SynchronizedConfig follow C++0x memory      - theoretical fix: made SynchronizedConfig follow C++0x memory
1247        model more strictly        model more strictly
1248      - fixes for using large audio device buffers      - fixes for using large audio device buffers
1249        - Windows: add the installation directory to the DLL search path
1250          when loading an editor plugin (solves problems with VST and
1251          gigedit on systems with other GTK versions installed)
1252        - updated linuxsampler man page
1253    
1254    * audio driver:    * audio driver:
1255      - removed the nonsense audio channel constraint (which was hard coded to      - removed the nonsense audio channel constraint (which was hard coded to
# Line 73  Version CVS HEAD (?) Line 1270  Version CVS HEAD (?)
1270        win64)        win64)
1271      - VST: added support for sample rate and buffer size changes      - VST: added support for sample rate and buffer size changes
1272      - VST: close editor (Fantasia) when the VST is removed      - VST: close editor (Fantasia) when the VST is removed
1273        - VST: avoid opening Fantasia more than once for each VST instance
1274        - VST: export main function as "main" on Linux too (fix for
1275          energyXT)
1276        - VST: changed number of output channels from one stereo to 16
1277          stereo
1278        - added channel routing, fxsends and midi maps to the settings
1279          stored in the plugin state
1280        - performance optimization of AudioChannel::MixTo() and
1281          AudioChannel::CopyTo() methods using GCC vector exensions
1282          (if available)
1283        - ASIO fixes: avoid initializing the device twice, avoid throwing
1284          exception when getting parameters from a disconnected device
1285    
1286    * MIDI driver:    * MIDI driver:
1287      - added JACK MIDI driver      - added JACK MIDI driver
# Line 82  Version CVS HEAD (?) Line 1291  Version CVS HEAD (?)
1291      - bugfix: pitch bend wasn't working with JackMidi, VST, LV2, MME,      - bugfix: pitch bend wasn't working with JackMidi, VST, LV2, MME,
1292        CoreMidi or AU        CoreMidi or AU
1293      - fixed mingw-w64 compilation error in MME driver      - fixed mingw-w64 compilation error in MME driver
1294        - made program change handling in MIDI thread real-time safe by
1295          moving the logic to a non-RT thread
1296        - fixed minor memory leak in ALSA driver
1297    
1298    * instruments database:    * instruments database:
1299      - avoid time consuming samples scanning when adding instruments      - avoid time consuming samples scanning when adding instruments
# Line 90  Version CVS HEAD (?) Line 1302  Version CVS HEAD (?)
1302      - Implemented option for adding instruments in separate directories      - Implemented option for adding instruments in separate directories
1303        in the instruments database        in the instruments database
1304        (patch by Chris Cherrett & Andrew Williams, a bit adjusted)        (patch by Chris Cherrett & Andrew Williams, a bit adjusted)
1305        - work-around for missing fnmatch function on Windows to make
1306          instrument database compilable
1307        - added instrument database support on Windows
1308          works with both standalone mode and VST plugin.
1309          the instruments DB file is located in
1310          %USERPROFILE%\.linuxsampler\instruments.db which allows different
1311          databases for each windows user
1312          if no DB is present it automatically creates the .linuxsampler subdir
1313          and then creates an empty DB
1314        - fixed recursive import, which was broken on Windows
1315    
1316    * Gigasampler format engine:    * Gigasampler format engine:
1317      - fixed a memory leak that could happen when a channel was deleted      - fixed a memory leak that could happen when a channel was deleted
# Line 131  Version CVS HEAD (?) Line 1353  Version CVS HEAD (?)
1353      - added support for GS Reset SysEx message      - added support for GS Reset SysEx message
1354      - allow gig files to use unlimited downward pitch shifting      - allow gig files to use unlimited downward pitch shifting
1355      - added a limit check for upward pitch shifting      - added a limit check for upward pitch shifting
1356        - bugfix: sometimes, when playing a note twice fast, the second
1357          note was silent
1358        - fixed crash happening when a pitch bend event arrived at the
1359          same time a new instrument was loading
1360    
1361    * LSCP server:    * LSCP server:
1362      - added new LSCP event "CHANNEL_MIDI" which can be used by frontends to      - added new LSCP event "CHANNEL_MIDI" which can be used by frontends to
# Line 185  Version CVS HEAD (?) Line 1411  Version CVS HEAD (?)
1411        plugin was unloaded        plugin was unloaded
1412      - bugfix: two private structs had the same name, which could cause      - bugfix: two private structs had the same name, which could cause
1413        problems if the linker chose the wrong constructor        problems if the linker chose the wrong constructor
1414        - fixed low-level ConditionServer usage bug that caused lockups on
1415          Windows
1416    
1417    
1418  Version 0.5.1 (6 December 2007)  Version 0.5.1 (6 December 2007)

Legend:
Removed from v.1897  
changed lines
  Added in v.3765

  ViewVC Help
Powered by ViewVC