diff options
Diffstat (limited to 'externals')
-rw-r--r-- | externals/grill/vst/pd/help-vst~.pd | 216 | ||||
-rw-r--r-- | externals/grill/vst/readme.txt | 12 | ||||
-rw-r--r-- | externals/grill/vst/src/VstHost.cpp | 92 | ||||
-rw-r--r-- | externals/grill/vst/src/VstHost.h | 17 | ||||
-rw-r--r-- | externals/grill/vst/src/main.cpp | 204 |
5 files changed, 359 insertions, 182 deletions
diff --git a/externals/grill/vst/pd/help-vst~.pd b/externals/grill/vst/pd/help-vst~.pd index 8aaeb983..f27c9e54 100644 --- a/externals/grill/vst/pd/help-vst~.pd +++ b/externals/grill/vst/pd/help-vst~.pd @@ -1,10 +1,10 @@ -#N canvas 118 11 818 647 12;
+#N canvas 180 14 842 665 12;
#X obj 26 190 dac~;
#X obj 26 94 noise~;
-#X obj 444 172 hsl 128 15 0 1 0 0 empty empty empty -2 -6 0 8 -225271
+#X obj 473 178 hsl 128 15 0 1 0 0 empty empty empty -2 -6 0 8 -225271
-1 -1 0 1;
-#X msg 441 189 param 2 \$1;
-#X obj 133 191 print A;
+#X msg 470 195 param 2 \$1;
+#X obj 140 192 print A;
#X obj 27 451 tgl 15 0 empty empty empty 0 -6 0 8 -225271 -1 -1 0 1
;
#X msg 26 473 vis \$1;
@@ -13,7 +13,7 @@ #X msg 26 389 edit \$1;
#X msg 94 389 getedit;
#X msg 89 473 getvis;
-#N canvas 367 122 548 455 info 0;
+#N canvas 367 122 550 426 info 0;
#X msg 94 130 getversion;
#X msg 94 75 getname;
#X msg 95 153 getvendor;
@@ -38,6 +38,7 @@ #X text 213 38 get all attributes;
#X msg 268 189 geteditor;
#X text 348 189 has editor?;
+#X msg 22 41 help;
#X connect 0 0 7 0;
#X connect 1 0 7 0;
#X connect 2 0 7 0;
@@ -51,85 +52,61 @@ #X connect 11 0 7 0;
#X connect 19 0 7 0;
#X connect 21 0 7 0;
-#X restore 414 561 pd info;
+#X connect 23 0 7 0;
+#X restore 26 616 pd info;
#X obj 96 96 r \$0-vst;
#X obj 25 416 s \$0-vst;
#X obj 25 499 s \$0-vst;
#X text 52 366 display edit window;
#X text 50 449 make edit window (in)visible;
-#X obj 413 353 s \$0-vst;
-#X obj 414 517 s \$0-vst;
-#X msg 443 471 program 2;
-#X msg 529 470 getprogram;
-#X msg 413 109 getparams;
-#X text 498 108 get number of parameters;
-#X text 509 414 get number of programs;
-#X msg 414 417 getprograms;
-#X msg 543 190 getparam 2;
+#X obj 432 360 s \$0-vst;
+#X obj 409 617 s \$0-vst;
+#X msg 532 478 getprogram;
+#X msg 433 96 getparams;
+#X text 511 96 get number of parameters;
+#X text 504 406 get number of programs;
+#X msg 409 409 getprograms;
+#X msg 572 196 getparam 2;
#X msg 105 295 getplug;
#X obj 26 323 s \$0-vst;
#X text 65 249 set/get plugin;
-#X text 480 561 further information;
-#X obj 23 15 cnv 15 700 58 empty empty vst~ 10 32 0 24 -260818 -1 0
+#X text 92 616 further information;
+#X obj 23 15 cnv 15 750 58 empty empty vst~ 10 32 0 24 -260818 -1 0
;
#X text 134 53 http://www.parasitaere-kapazitaeten.net;
-#X text 140 169 attribute outlet;
-#X text 143 140 inlets outlets [plugname];
-#N canvas 367 122 488 343 win 0;
-#X obj 14 187 s \$0-vst;
-#X msg 94 89 getx;
-#X text 186 89 get window coordinates;
-#X msg 139 89 gety;
-#X msg 93 141 gettitle;
-#X text 273 139 get/set window title;
-#X msg 175 141 title hugo;
-#X obj 94 39 nbx 5 14 -1e+037 1e+037 0 0 empty empty empty 0 -6 0 10
+#X text 137 173 attribute outlet;
+#X text 103 137 inlets outlets [plugname];
+#N canvas 367 122 465 214 win 0;
+#X obj 34 160 s \$0-vst;
+#X msg 26 109 getx;
+#X text 155 110 get window coordinates;
+#X msg 71 109 gety;
+#X obj 23 51 nbx 5 14 -1e+037 1e+037 0 0 empty empty empty 0 -6 0 10
-225271 -1 -1 0 256;
-#X msg 95 59 x \$1;
-#X obj 164 39 nbx 5 14 -1e+037 1e+037 0 0 empty empty empty 0 -6 0
-10 -225271 -1 -1 0 256;
-#X msg 165 57 y \$1;
-#X text 229 49 set window coordinates;
-#X msg 90 218 getstyle;
-#X text 278 218 get/set window style;
-#X obj 173 193 vradio 15 1 0 3 empty empty empty 0 -6 0 8 -225271 -1
--1 0;
-#X msg 90 281 getmode;
-#X msg 198 218 style \$1;
-#X msg 168 281 mode 101;
-#X text 253 279 get/set window sys menu;
+#X msg 24 69 x \$1;
+#X obj 93 51 nbx 5 14 -1e+037 1e+037 0 0 empty empty empty 0 -6 0 10
+-225271 -1 -1 0 256;
+#X msg 94 67 y \$1;
+#X text 154 61 set window coordinates;
#X text 10 7 NOT IMPLEMENTED;
#X connect 1 0 0 0;
#X connect 3 0 0 0;
-#X connect 4 0 0 0;
-#X connect 6 0 0 0;
-#X connect 7 0 8 0;
-#X connect 8 0 0 0;
-#X connect 9 0 10 0;
-#X connect 10 0 0 0;
-#X connect 12 0 0 0;
-#X connect 14 0 16 0;
-#X connect 15 0 0 0;
-#X connect 16 0 0 0;
-#X connect 17 0 0 0;
+#X connect 4 0 5 0;
+#X connect 5 0 0 0;
+#X connect 6 0 7 0;
+#X connect 7 0 0 0;
#X restore 26 542 pd win;
#X text 92 542 manipulating the edit window;
-#X msg 412 135 getpname 2;
-#X msg 440 236 param gain 0;
-#X text 503 133 get parameter name;
-#X msg 550 236 getparam gain;
-#X msg 545 283 getptext gain;
-#X text 451 300 get value in textual representation;
-#X msg 440 283 getptext 2;
-#X text 466 211 set/get parameter (0-based);
-#X text 469 496 set/get program (0-based);
-#X text 487 254 NOT IMPLEMENTED;
-#X text 484 315 NOT IMPLEMENTED;
+#X msg 470 242 param gain 0;
+#X text 542 144 get parameter name;
+#X text 484 312 get value in textual representation;
+#X text 495 217 set/get parameter (0-based);
+#X text 463 497 set/get program (0-based);
#X msg 28 296 plug \$1;
#X obj 27 240 bng 25 250 50 0 empty empty empty 0 -6 0 8 -225271 -1
-1;
#X obj 27 271 openpanel;
-#N canvas 461 281 486 331 midi 0;
+#N canvas 461 281 490 335 midi 0;
#X obj 20 279 s \$0-vst;
#X msg 238 147 ctlchg 3 123;
#X text 116 28 note on;
@@ -167,27 +144,49 @@ #X connect 18 0 17 0;
#X restore 25 581 pd midi;
#X text 93 582 midi messages for vst synths;
-#X msg 414 442 getprogcats;
-#X text 509 439 get number of program categories;
+#X msg 409 434 getprogcats;
+#X text 504 431 get number of program categories;
#X text 134 33 based on the work of Jarno Seppanen and Mark Williamson
;
#X text 133 14 VST plugins for PD \, (C)2003-04 Thomas Grill;
-#X obj 26 140 vst~ 1 2;
-#X obj 685 548 loadbang;
-#X msg 685 575 \; pd dsp 1;
-#X obj 233 367 tgl 15 0 empty empty empty 0 -6 0 8 -225271 -1 -1 0
+#X obj 26 140 vst~ 1 2 @pnames 100;
+#X obj 741 569 loadbang;
+#X msg 741 596 \; pd dsp 1;
+#X obj 228 339 tgl 15 0 empty empty empty 0 -6 0 8 -225271 -1 -1 0
1;
-#X obj 231 416 s \$0-vst;
-#X msg 232 389 bypass \$1;
-#X msg 314 389 getbypass;
-#X text 258 366 bypass plugin;
-#X obj 237 264 tgl 15 0 empty empty empty 0 -6 0 8 -225271 -1 -1 1
+#X obj 226 388 s \$0-vst;
+#X msg 227 361 bypass \$1;
+#X msg 309 361 getbypass;
+#X text 253 338 bypass plugin;
+#X obj 228 245 tgl 15 0 empty empty empty 0 -6 0 8 -225271 -1 -1 0
1;
-#X obj 235 313 s \$0-vst;
-#X text 262 263 mute output;
-#X msg 236 286 mute \$1;
-#X msg 318 286 getmute;
-#X connect 1 0 56 0;
+#X obj 226 294 s \$0-vst;
+#X text 253 244 mute output;
+#X msg 227 267 mute \$1;
+#X msg 309 267 getmute;
+#X msg 429 478 program \$1;
+#X obj 430 462 nbx 5 14 0 10000 0 0 empty empty empty 0 -6 0 10 -225271
+-1 -1 0 256;
+#X msg 471 290 getptext \$1;
+#X obj 471 273 nbx 5 14 0 10000 0 0 empty empty empty 0 -6 0 10 -225271
+-1 -1 0 256;
+#X obj 450 128 nbx 5 14 0 10000 0 0 empty empty empty 0 -6 0 10 -225271
+-1 -1 0 256;
+#X msg 450 146 getpname \$1;
+#X msg 576 290 getptext gain;
+#X msg 580 242 getparam gain;
+#X obj 434 516 nbx 5 14 0 10000 0 0 empty empty empty 0 -6 0 10 -225271
+-1 -1 0 256;
+#X msg 432 533 getprogname \$1;
+#X text 552 530 get program name;
+#X obj 433 567 nbx 5 14 0 10000 0 0 empty empty empty 0 -6 0 10 -225271
+-1 -1 0 256;
+#X text 569 582 get program name;
+#X msg 431 584 getprogname 2 \$1;
+#X text 571 596 (with category);
+#X text 480 328 (may be ambigous!);
+#X text 568 544 (no category);
+#X connect 1 0 49 0;
#X connect 2 0 3 0;
#X connect 3 0 17 0;
#X connect 5 0 6 0;
@@ -196,29 +195,36 @@ #X connect 8 0 13 0;
#X connect 9 0 13 0;
#X connect 10 0 14 0;
-#X connect 12 0 56 0;
+#X connect 12 0 49 0;
#X connect 19 0 18 0;
-#X connect 20 0 18 0;
-#X connect 21 0 17 0;
-#X connect 24 0 18 0;
-#X connect 25 0 17 0;
-#X connect 26 0 27 0;
-#X connect 36 0 17 0;
-#X connect 37 0 17 0;
-#X connect 39 0 17 0;
-#X connect 40 0 17 0;
-#X connect 42 0 17 0;
-#X connect 47 0 27 0;
-#X connect 48 0 49 0;
-#X connect 49 0 47 0;
-#X connect 52 0 18 0;
-#X connect 56 0 0 0;
-#X connect 56 1 0 1;
-#X connect 56 2 4 0;
-#X connect 57 0 58 0;
-#X connect 59 0 61 0;
-#X connect 61 0 60 0;
-#X connect 62 0 60 0;
-#X connect 64 0 67 0;
-#X connect 67 0 65 0;
-#X connect 68 0 65 0;
+#X connect 20 0 17 0;
+#X connect 23 0 18 0;
+#X connect 24 0 17 0;
+#X connect 25 0 26 0;
+#X connect 35 0 17 0;
+#X connect 40 0 26 0;
+#X connect 41 0 42 0;
+#X connect 42 0 40 0;
+#X connect 45 0 18 0;
+#X connect 49 0 0 0;
+#X connect 49 1 0 1;
+#X connect 49 2 4 0;
+#X connect 50 0 51 0;
+#X connect 52 0 54 0;
+#X connect 54 0 53 0;
+#X connect 55 0 53 0;
+#X connect 57 0 60 0;
+#X connect 60 0 58 0;
+#X connect 61 0 58 0;
+#X connect 62 0 18 0;
+#X connect 63 0 62 0;
+#X connect 64 0 17 0;
+#X connect 65 0 64 0;
+#X connect 66 0 67 0;
+#X connect 67 0 17 0;
+#X connect 68 0 17 0;
+#X connect 69 0 17 0;
+#X connect 70 0 71 0;
+#X connect 71 0 18 0;
+#X connect 73 0 75 0;
+#X connect 75 0 18 0;
diff --git a/externals/grill/vst/readme.txt b/externals/grill/vst/readme.txt index 9d96e2cb..68917404 100644 --- a/externals/grill/vst/readme.txt +++ b/externals/grill/vst/readme.txt @@ -31,10 +31,6 @@ pd - darwin (MacOSX): --------------------- o GCC: edit "config-pd-darwin.txt" & run "sh build-pd-darwin.sh" -Max/MSP - MacOS9/X: -------------------- -o CodeWarrior: edit "vst.cw" and build - ---------------------------------------------------------------------------- @@ -50,7 +46,8 @@ Version history: - fixed crash on destroying vst~ with open editor window - stripped all MFC code - fixed DSP initialization, zero dangling audio vectors -- added "bypass" and "mute" attributes +- pre12: added "bypass" and "mute" attributes +- pre13: with flext 0.4.7 no more interruptions on window close 0.0.0: - version of mark@junklight.com @@ -62,6 +59,9 @@ features: - include necessary Steinberg license stuff BUGS: -- Quadrafuzz crashes on closing editor window - Waveshell crashes on load +- mouse interaction in editor can cause audio dropouts +TODO: +- do name scanning in the background +- translate special characters in strings (like ° as param_label) into system-digestible form diff --git a/externals/grill/vst/src/VstHost.cpp b/externals/grill/vst/src/VstHost.cpp index 041acb76..bd686716 100644 --- a/externals/grill/vst/src/VstHost.cpp +++ b/externals/grill/vst/src/VstHost.cpp @@ -11,7 +11,7 @@ WARRANTIES, see the file, "license.txt," in this distribution. #include "VstHost.h" #include "AEffectx.h" -using namespace std; +#include <ctype.h> static VstTimeInfo _timeInfo; @@ -21,7 +21,8 @@ typedef AEffect *(VSTCALLBACK *PVSTMAIN)(audioMasterCallback audioMaster); VSTPlugin::VSTPlugin(): h_dll(NULL),hwnd(NULL),_pEffect(NULL), posx(0),posy(0), - _midichannel(0),queue_size(0) + _midichannel(0),queue_size(0), + paramnamecnt(0) {} VSTPlugin::~VSTPlugin() @@ -62,39 +63,36 @@ int VSTPlugin::Instance(const char *dllname) ret = Dispatch( effIdentify); FLEXT_ASSERT(ret == 'NvEf'); - if (!Dispatch( effGetProductString, 0, 0, &_sProductName, 0.0f)) { + *_sProductName = 0; + Dispatch( effGetProductString, 0, 0, &_sProductName, 0.0f); + if(_sProductName) { // no product name given by plugin -> extract it from the filename - string str1(dllname); - string::size_type slpos = str1.rfind('\\'); - if(slpos == string::npos) { + std::string str1(dllname); + std::string::size_type slpos = str1.rfind('\\'); + if(slpos == std::string::npos) { slpos = str1.rfind('/'); - if(slpos == string::npos) + if(slpos == std::string::npos) slpos = 0; else ++slpos; } else ++slpos; - string str2 = str1.substr(slpos); + std::string str2 = str1.substr(slpos); int snip = str2.find('.'); - if( snip != string::npos ) + if( snip != std::string::npos ) str1 = str2.substr(0,snip); else str1 = str2; strcpy(_sProductName,str1.c_str()); } - if(!Dispatch( effGetVendorString, 0, 0, &_sVendorName, 0.0f)) - strcpy(_sVendorName, "Unknown vendor"); + *_sVendorName = 0; + Dispatch( effGetVendorString, 0, 0, &_sVendorName, 0.0f); _sDllName = dllname; -/* - Dispatch( effMainsChanged, 0, 1); - Dispatch( effSetSampleRate, 0, 0,NULL,44100.); - Dispatch( effSetBlockSize, 0, 64); -*/ return VSTINSTANCE_NO_ERROR; } @@ -140,19 +138,30 @@ void VSTPlugin::Free() // Called also in destruction void VSTPlugin::DspInit(float samplerate,int blocksize) { -// sample_rate = samplerate; - - Dispatch(effMainsChanged, 0, 1); + // sample rate and block size must _first_ be set Dispatch(effSetSampleRate, 0, 0,NULL,samplerate); Dispatch(effSetBlockSize, 0, blocksize); + // than signal that mains have changed! + Dispatch(effMainsChanged, 0, 1); +} + +static void striptrail(char *txt) +{ + // strip trailing whitespace + for(int i = strlen(txt)-1; i >= 0; --i) + // cast to unsigned char since isspace functions don't want characters like 0x80 = -128 + if(isspace(((unsigned char *)txt)[i])) txt[i] = 0; } void VSTPlugin::GetParamName(int numparam,char *name) const { - if(numparam < GetNumParams()) + if(numparam < GetNumParams()) { + name[0] = 0; Dispatch(effGetParamName,numparam,0,name,0.0f); + striptrail(name); + } else - strcpy(name,"Index out of Range"); + name[0] = 0; } bool VSTPlugin::SetParamFloat(int parameter,float value) @@ -169,14 +178,17 @@ void VSTPlugin::GetParamValue(int numparam,char *parval) const { if(Is()) { if(numparam < GetNumParams()) { -// char par_name[64]; - char par_display[64]; - char par_label[64]; - -// Dispatch(effGetParamName,parameter,0,par_name,0.0f); + // how many chars needed? + char par_display[64]; par_display[0] = 0; Dispatch(effGetParamDisplay,numparam,0,par_display,0.0f); - Dispatch(effGetParamLabel,numparam,0,par_label,0.0f); -// sprintf(psTxt,"%s:%s%s",par_name,par_display,par_label); +// if(par_display[7]) par_display[8] = 0; // set trailing zero + + // how many chars needed? + char par_label[64]; par_label[0] = 0; + Dispatch(effGetParamLabel,numparam,0,par_label,0.0f); + striptrail(par_label); +// if(par_label[7]) par_label[8] = 0; // set trailing zero + sprintf(parval,"%s%s",par_display,par_label); } else @@ -194,6 +206,26 @@ float VSTPlugin::GetParamValue(int numparam) const return -1.0; } +void VSTPlugin::ScanParams(int cnt) +{ + if(cnt < 0) cnt = GetNumParams(); + if(paramnamecnt >= cnt) return; + if(cnt >= GetNumParams()) cnt = GetNumParams(); + + char name[64]; + for(int i = paramnamecnt; i < cnt; ++i) { + GetParamName(i,name); + if(*name) paramnames[std::string(name)] = i; + } + paramnamecnt = cnt; +} + +int VSTPlugin::GetParamIx(const char *p) const +{ + NameMap::const_iterator it = paramnames.find(std::string(p)); + return it == paramnames.end()?-1:it->second; +} + void VSTPlugin::Edit(bool open) { if(Is()) { @@ -308,9 +340,11 @@ void VSTPlugin::AddControlChange(int control, int value) bool VSTPlugin::GetProgramName( int cat , int p, char *buf) const { + buf[0] = 0; int parameter = p; - if(parameter < GetNumPrograms()) { + if(parameter < GetNumPrograms() && cat < GetNumCategories()) { Dispatch(effGetProgramNameIndexed,parameter,cat,buf,0.0f); + striptrail(buf); return true; } else diff --git a/externals/grill/vst/src/VstHost.h b/externals/grill/vst/src/VstHost.h index bbbebe1f..00b5164f 100644 --- a/externals/grill/vst/src/VstHost.h +++ b/externals/grill/vst/src/VstHost.h @@ -72,6 +72,13 @@ public: void GetParamValue(int numparam,char *parval) const; float GetParamValue(int numparam) const; + // scan plugin names (can take a _long_ time!!) + void ScanParams(int i = -1); + // get number of scanned parameters + int ScannedParams() const { return paramnamecnt; } + // get index of named (scanned) parameter... -1 if not found + int GetParamIx(const char *p) const; + bool SetParamFloat(int parameter, float value); bool SetParamInt(int parameter, int value) { return SetParamFloat(parameter,value/65535.0f); } @@ -143,6 +150,16 @@ protected: char _sVendorName[64]; std::string _sDllName; // Contains dll name + struct NameCmp: + std::less<std::string> + { + bool operator()(const std::string &a,const std::string &b) const { return a.compare(b) < 0; } + }; + + typedef std::map<std::string,int,NameCmp> NameMap; + int paramnamecnt; + NameMap paramnames; + /* float *inputs[MAX_INOUTS]; float *outputs[MAX_INOUTS]; diff --git a/externals/grill/vst/src/main.cpp b/externals/grill/vst/src/main.cpp index 2467e1bd..13205a4d 100644 --- a/externals/grill/vst/src/main.cpp +++ b/externals/grill/vst/src/main.cpp @@ -17,10 +17,9 @@ WARRANTIES, see the file, "license.txt," in this distribution. #include <io.h> #include <string> -using namespace std; -#define VST_VERSION "0.1.0pre12" +#define VST_VERSION "0.1.0pre13" class vst: @@ -67,7 +66,18 @@ protected: V ms_program(I p); V mg_program(I &p) const { p = plug?plug->GetCurrentProgram():0; } + V mg_progname(int argc,const t_atom *argv) const; + V m_pname(I pnum); + V ms_paramnames(int cnt) { paramnames = cnt; if(plug) plug->ScanParams(cnt); } + + V ms_param(I pnum,F val); + V ms_params(int argc,const t_atom *argv); + V mg_param(I pnum); + V mg_params(int argc,const t_atom *argv); + V m_ptext(I pnum); + V m_ptexts(int argc,const t_atom *argv); + // V m_control(const S *ctrl_name,I ctrl_value); V m_pitchbend(I ctrl_value); V m_programchange(I ctrl_value); @@ -76,17 +86,13 @@ protected: V m_note(I note,I vel); inline V m_noteoff(I note) { m_note(note,0); } - V ms_param(I pnum,F val); - V mg_param(I pnum); - V m_pname(I pnum); - V m_ptext(I pnum); - private: V display_parameter(I param,BL showparams); VSTPlugin *plug; - string plugname; - BL echoparam,visible,bypass,mute; + std::string plugname; + bool echoparam,visible,bypass,mute; + int paramnames; I blsz; V (VSTPlugin::*vstfun)(R **insigs,R **outsigs,L n); @@ -119,10 +125,17 @@ private: FLEXT_CALLBACK_II(m_ctrlchange) FLEXT_CALLVAR_I(mg_program,ms_program) + FLEXT_CALLBACK_V(mg_progname) + + FLEXT_CALLBACK_I(m_pname) + FLEXT_ATTRGET_I(paramnames) + FLEXT_CALLSET_I(ms_paramnames) FLEXT_CALLBACK_2(ms_param,int,float) + FLEXT_CALLBACK_V(ms_params) FLEXT_CALLBACK_I(mg_param) - FLEXT_CALLBACK_I(m_pname) + FLEXT_CALLBACK_V(mg_params) FLEXT_CALLBACK_I(m_ptext) + FLEXT_CALLBACK_V(m_ptexts) FLEXT_CALLBACK_II(m_note) FLEXT_CALLBACK_I(m_noteoff) @@ -141,11 +154,15 @@ private: FLEXT_CALLGET_S(mg_plugdll) FLEXT_CALLGET_I(mg_plugversion) FLEXT_CALLGET_B(mg_issynth) + + static const t_symbol *sym_progname,*sym_pname,*sym_param,*sym_ptext; }; FLEXT_NEW_DSP_V("vst~",vst); +const t_symbol *vst::sym_progname,*vst::sym_pname,*vst::sym_param,*vst::sym_ptext; + V vst::Setup(t_classid c) { post(""); @@ -170,11 +187,16 @@ V vst::Setup(t_classid c) FLEXT_CADDMETHOD_(c,0,"progchg",m_programchange); FLEXT_CADDATTR_VAR(c,"program",mg_program,ms_program); + FLEXT_CADDMETHOD_(c,0,"getprogname",mg_progname); + FLEXT_CADDMETHOD_I(c,0,"getpname",m_pname); + FLEXT_CADDATTR_VAR(c,"pnames",paramnames,ms_paramnames); FLEXT_CADDMETHOD_2(c,0,"param",ms_param,int,float); + FLEXT_CADDMETHOD_2(c,0,"param",ms_params,t_symptr,float); FLEXT_CADDMETHOD_(c,0,"getparam",mg_param); - FLEXT_CADDMETHOD_I(c,0,"getpname",m_pname); - FLEXT_CADDMETHOD_I(c,0,"getptext",m_ptext); + FLEXT_CADDMETHOD_(c,0,"getparam",mg_params); + FLEXT_CADDMETHOD_(c,0,"getptext",m_ptext); + FLEXT_CADDMETHOD_(c,0,"getptext",m_ptexts); FLEXT_CADDATTR_VAR1(c,"echo",echoparam); FLEXT_CADDATTR_VAR(c,"x",mg_winx,ms_winx); @@ -191,6 +213,11 @@ V vst::Setup(t_classid c) FLEXT_CADDATTR_GET(c,"version",mg_plugversion); FLEXT_CADDATTR_GET(c,"synth",mg_issynth); + sym_progname = MakeSymbol("progname"); + sym_pname = MakeSymbol("pname"); + sym_param = MakeSymbol("param"); + sym_ptext = MakeSymbol("ptext"); + SetupEditor(); } @@ -199,7 +226,7 @@ vst::vst(I argc,const A *argv): plug(NULL),visible(false), blsz(0), vstfun(NULL),vstin(NULL),vstout(NULL),tmpin(NULL),tmpout(NULL), - echoparam(false),bypass(false),mute(false) + echoparam(false),bypass(false),mute(false),paramnames(0) { if(argc >= 2 && CanbeInt(argv[0]) && CanbeInt(argv[1])) { AddInSignal(GetAInt(argv[0])); @@ -234,6 +261,8 @@ V vst::InitPlug() InitPlugDSP(); InitBuf(); + + plug->ScanParams(paramnames); } V vst::InitPlugDSP() @@ -276,7 +305,7 @@ V vst::InitBuf() for(i = 0; i < outputs; ++i) vstout[i] = new R[Blocksize()]; } -static string findFilePath(const string &path,const string &dllname) +static std::string findFilePath(const std::string &path,const std::string &dllname) { _chdir( path.c_str() ); #if FLEXT_OS == FLEXT_OS_WIN @@ -308,7 +337,7 @@ static string findFilePath(const string &path,const string &dllname) } */ - return string(); + return std::string(); } @@ -322,6 +351,17 @@ BL vst::ms_plug(I argc,const A *argv) if(i > 0) plugname += ' '; GetAString(argv[i],buf,sizeof buf); strlwr(buf); + +#if FLEXT_SYS == FLEXT_SYS_PD + // strip char escapes (only in newer/devel PD version) + char *cs = buf,*cd = cs; + while(*cs) { + if(*cs != '\\') *(cd++) = *cs; + ++cs; + } + *cd = 0; +#endif + plugname += buf; } @@ -353,7 +393,7 @@ BL vst::ms_plug(I argc,const A *argv) // if dir is current working directory... name points to dir if(dir == name) strcpy(dir,"."); - string dllname(dir); + std::string dllname(dir); dllname += "\\"; dllname += name; @@ -362,9 +402,9 @@ BL vst::ms_plug(I argc,const A *argv) } if(!lf) { // try finding it on the VST path - C *vst_path = getenv ("VST_PATH"); + C *vst_path = getenv("VST_PATH"); - string dllname(plugname); + std::string dllname(plugname); if(dllname.find(".dll") == -1) dllname += ".dll"; if(vst_path) { @@ -373,12 +413,12 @@ BL vst::ms_plug(I argc,const A *argv) strcpy( tok_path , vst_path); char *tok = strtok( tok_path , ";" ); while( tok != NULL ) { - string abpath( tok ); + std::string abpath( tok ); if( abpath[abpath.length()-1] != '\\' ) abpath += "\\"; FLEXT_LOG1("trying VST_PATH %s",(const C *)abpath.c_str()); - string realpath = findFilePath( abpath , dllname ); + std::string realpath = findFilePath( abpath , dllname ); //post( "findFilePath( %s , %s ) = %s\n" , abpath , dllname , realpath ); if ( realpath.length() ) { realpath += plugname; @@ -444,13 +484,14 @@ V vst::m_signal(I n,R *const *insigs,R *const *outsigs) if(sigmatch) (plug->*vstfun)(const_cast<R **>(insigs),const_cast<R **>(outsigs),n); else { + const int cntin = CntInSig(),cntout = CntOutSig(); R **inv,**outv; - if(inputs <= CntInSig()) + if(inputs <= cntin) inv = const_cast<R **>(insigs); else { // more plug inputs than inlets I i; - for(i = 0; i < CntInSig(); ++i) tmpin[i] = const_cast<R *>(insigs[i]); + for(i = 0; i < cntin; ++i) tmpin[i] = const_cast<R *>(insigs[i]); // set dangling inputs to zero // according to mode... (e.g. set zero) @@ -459,24 +500,25 @@ V vst::m_signal(I n,R *const *insigs,R *const *outsigs) inv = tmpin; } - const BL more = outputs <= CntOutSig(); + const BL more = outputs <= cntout; if(more) // more outlets than plug outputs outv = const_cast<R **>(outsigs); else { I i; - for(i = 0; i < CntOutSig(); ++i) tmpout[i] = outsigs[i]; + for(i = 0; i < cntout; ++i) tmpout[i] = outsigs[i]; for(; i < outputs; ++i) tmpout[i] = vstout[i]; outv = tmpout; } + // call plugin DSP function (plug->*vstfun)(inv,outv,n); if(more) { // according to mode set dangling output vectors // currently simply clear them.... - for(int i = outputs; i < CntOutSig(); ++i) + for(int i = outputs; i < cntout; ++i) ZeroSamples(outsigs[i],n); } } @@ -531,6 +573,33 @@ V vst::ms_program(I p) if(plug && p >= 0) plug->SetCurrentProgram(p); } +void vst::mg_progname(int argc,const t_atom *argv) const +{ + if(plug) { + int cat,pnum; + if(argc == 1 && CanbeInt(argv[0])) { + cat = -1,pnum = GetAInt(argv[0]); + } + else if(argc == 2 && CanbeInt(argv[0]) && CanbeInt(argv[1])) { + cat = GetAInt(argv[0]),pnum = GetAInt(argv[1]); + } + else pnum = -1; + + if(pnum >= 0) { + char str[256]; + plug->GetProgramName(cat,pnum,str); + + A at[3]; + SetInt(at[0],cat); + SetInt(at[1],pnum); + SetString(at[2],str); + ToOutAnything(GetOutAttr(),sym_progname,3,at); + } + else + post("%s - Syntax: %s [category] program",thisName(),GetString(thisTag())); + } +} + V vst::m_ctrlchange(I control,I ctrl_value) { if(plug) plug->AddControlChange(control,ctrl_value ); @@ -639,7 +708,7 @@ V vst::display_parameter(I param,BL showparams) if(*name) { if (showparams) { -// plug->DescribeValue( j , display ); +// plug->DescribeValue( j , display ); plug->GetParamValue(j,display); val = plug->GetParamValue( j ); post ("parameter[#%d], \"%s\" value=%f (%s) ", j, name, val,display); @@ -651,6 +720,18 @@ V vst::display_parameter(I param,BL showparams) } } +V vst::m_pname(I pnum) +{ + if(!plug || pnum < 0 || pnum >= plug->GetNumParams()) return; + + char name[256]; // how many chars needed? + plug->GetParamName(pnum,name); + + A at[2]; + SetInt(at[0],pnum); + SetString(at[1],name); + ToOutAnything(GetOutAttr(),sym_pname,2,at); +} // set the value of a parameter V vst::ms_param(I pnum,F val) @@ -668,6 +749,25 @@ V vst::ms_param(I pnum,F val) FLEXT_ASSERT(false); } +void vst::ms_params(int argc,const t_atom *argv) +{ + if(plug) { + char str[255]; *str = 0; + if(argc && CanbeFloat(argv[argc-1])) + PrintList(argc-1,argv,str,sizeof str); + + if(*str) { + int ix = plug->GetParamIx(str); + if(ix >= 0) + ms_param(ix,GetAFloat(argv[argc-1])); + else + post("%s %s - Parameter not found",thisName(),GetString(thisTag()),str); + } + else + post("%s - Syntax: %s name value",thisName(),GetString(thisTag())); + } +} + V vst::mg_param(I pnum) { if(!plug || pnum < 0 || pnum >= plug->GetNumParams()) return; @@ -675,37 +775,57 @@ V vst::mg_param(I pnum) A at[2]; SetInt(at[0],pnum); SetFloat(at[1],plug->GetParamValue(pnum)); - ToOutAnything(GetOutAttr(),MakeSymbol("param"),2,at); + ToOutAnything(GetOutAttr(),sym_param,2,at); } -V vst::m_pname(I pnum) +V vst::mg_params(int argc,const t_atom *argv) { - if(!plug || pnum < 0 || pnum >= plug->GetNumParams()) return; - - C name[109]; /* the Steinberg(tm) way... */ - - memset(name,0,sizeof(name)); - plug->GetParamName(pnum,name); - - A at[2]; - SetInt(at[0],pnum); - SetString(at[1],name); - ToOutAnything(GetOutAttr(),MakeSymbol("pname"),2,at); + if(plug) { + char str[255]; + PrintList(argc,argv,str,sizeof str); + + if(*str) { + int ix = plug->GetParamIx(str); + if(ix >= 0) + mg_param(ix); + else + post("%s %s - Parameter not found",thisName(),GetString(thisTag()),str); + } + else + post("%s - Syntax: %s name value",thisName(),GetString(thisTag())); + } } V vst::m_ptext(I pnum) { if(!plug || pnum < 0 || pnum >= plug->GetNumParams()) return; - C display[164]; /* the Steinberg(tm) way... */ - + char display[256]; // how many chars needed? memset(display,0,sizeof(display)); plug->GetParamValue(pnum,display); A at[2]; SetInt(at[0],pnum); SetString(at[1],display); - ToOutAnything(GetOutAttr(),MakeSymbol("ptext"),2,at); + ToOutAnything(GetOutAttr(),sym_ptext,2,at); +} + +V vst::m_ptexts(int argc,const t_atom *argv) +{ + if(plug) { + char str[255]; + PrintList(argc,argv,str,sizeof str); + + if(*str) { + int ix = plug->GetParamIx(str); + if(ix >= 0) + m_ptext(ix); + else + post("%s %s - Parameter not found",thisName(),GetString(thisTag()),str); + } + else + post("%s - Syntax: %s name value",thisName(),GetString(thisTag())); + } } V vst::m_note(I note,I velocity) |