If you have a problem or need to report a bug please email : support@dsprobotics.com
There are 3 sections to this support area:
DOWNLOADS: access to product manuals, support files and drivers
HELP & INFORMATION: tutorials and example files for learning or finding pre-made modules for your projects
USER FORUMS: meet with other users and exchange ideas, you can also get help and assistance here
NEW REGISTRATIONS - please contact us if you wish to register on the forum
Users are reminded of the forum rules they sign up to which prohibits any activity that violates any laws including posting material covered by copyright
[SOLVED]✔ VST: Win32API not work?
8 posts
• Page 1 of 1
[SOLVED]✔ VST: Win32API not work?
as the title says, does not work when exported as a vst.
I run the example in the manual, to capture the movement of the mouse cursor.
But it works fine when run in Flowstone.
I run the example in the manual, to capture the movement of the mouse cursor.
But it works fine when run in Flowstone.
Last edited by Tronic on Tue Nov 20, 2012 11:06 am, edited 2 times in total.
- Tronic
- Posts: 539
- Joined: Wed Dec 21, 2011 12:59 pm
Re: VST: Win32API not work
Probably the plugin cannot find the Win32API library - it is an extension to Ruby that is stored in a separate file, so if the plugin cannot find that file, the .dll call will not work.
The files are in the Ruby folder of the FowStone install, and a copy of that folder will be needed whenever you use the plugin in a different environment.
The easiest way to do this woud be to copy the folder into the same location as the plugin .dll, and then you'll need to add a little bit of stuff to the plugin to make the file visible.
- Add an extra string input to the Ruby primitive, and call it something like "my_path"
- Connect a "start folder" primitive to this input
- inside the code, add the following code...
That will point the library loader at the files inside the "Ruby" folder that you copied into the plugin directory.
NB - from memory, haven't tested yet. The principle is right, but I may not have typed the paths exactly right - if you type $LOAD_PATH into a blank Ruby primitive, you'll be able to see the correct names of the sub-folders.
The files are in the Ruby folder of the FowStone install, and a copy of that folder will be needed whenever you use the plugin in a different environment.
The easiest way to do this woud be to copy the folder into the same location as the plugin .dll, and then you'll need to add a little bit of stuff to the plugin to make the file visible.
- Add an extra string input to the Ruby primitive, and call it something like "my_path"
- Connect a "start folder" primitive to this input
- inside the code, add the following code...
- Code: Select all
$LOAD_PATH << (@my_path + '/Ruby/libraries/win32/i386')
$LOAD_PATH << (@my_path + '/Ruby/libraries/win32/common)
That will point the library loader at the files inside the "Ruby" folder that you copied into the plugin directory.
NB - from memory, haven't tested yet. The principle is right, but I may not have typed the paths exactly right - if you type $LOAD_PATH into a blank Ruby primitive, you'll be able to see the correct names of the sub-folders.
All schematics/modules I post are free for all to use - but a credit is always polite!
Don't stagnate, mutate to create!
Don't stagnate, mutate to create!
-
trogluddite - Posts: 1730
- Joined: Fri Oct 22, 2010 12:46 am
- Location: Yorkshire, UK
Re: [SOLVED]✔ VST: Win32API not work?
Quick correction.
After re-reading the User Guide, it seems that if you put the entire Ruby folder in the same location as the export, the $LOAD_PATH code should not be required - it looks like the export 'home' folder is automatically added to the default search locations.
After re-reading the User Guide, it seems that if you put the entire Ruby folder in the same location as the export, the $LOAD_PATH code should not be required - it looks like the export 'home' folder is automatically added to the default search locations.
All schematics/modules I post are free for all to use - but a credit is always polite!
Don't stagnate, mutate to create!
Don't stagnate, mutate to create!
-
trogluddite - Posts: 1730
- Joined: Fri Oct 22, 2010 12:46 am
- Location: Yorkshire, UK
Re: [SOLVED]✔ VST: Win32API not work?
trogluddite wrote:Quick correction.
After re-reading the User Guide, it seems that if you put the entire Ruby folder in the same location as the export, the $LOAD_PATH code should not be required - it looks like the export 'home' folder is automatically added to the default search locations.
i tried not work in vst mode, the load path in vst work different.
$LOAD_PATH point to a virtual path like this:
C:/Users/<username>/AppData/Roaming/lib/ruby/......
but it not realy exist.
i have found $EXE_PATH and $INSTALL_PATH
but it point to CWD directory, ie, the last or current working directory used in your Host.
so I think for now it is mandatory to define the load path of the vst.
I defined it as a class variable @ @ Path_MyVST, taking the value as you suggested from the primitive Start folder.
I have not declared as gloabl variable to avoid future clash with other plugins.
- Tronic
- Posts: 539
- Joined: Wed Dec 21, 2011 12:59 pm
Re: [SOLVED]✔ VST: Win32API not work?
Ah thanks - I hadn't tried it yet, so that is good to know.
BTW) A class variable will work the same as a global variable for FS plugins - because all Ruby primitives are instances of the same class, RubyEdit. I've even done a couple of experiments deliberately passing values between two plugins using class variables, and it works very well (or badly, depending whether you want them to or not!)
This is going to be something that we'll all have to learn to deal with.
Best not to use RubyEdit class variables at all - even if you are very careful with naming, this will not help if two instances of the same plugin are loaded at once.
Modules and classes are simlarly visible across plugins, but that is slightly less of a problem, as the actual objects made from those classes will be local. The common practice in other Ruby enabled app's is to always wrap cutsom class definitions inside a Module named after the developer etc. - just in case two people use a common name for a new class and overwrite each other's methods. And NEVER redefine one of the built in Ruby methods - sounds obvious, hut I have had my CAD software brought to its knees by a plugin that did this!
In the case of 'require', appending the paths to $LOAD_PATH from an instance variable is probably safest. Require only ever loads the same library once anyway (so custom libraries must have unique names!) - plugins loaded later will know that "win32api" is already available and not bother loading it again. (there's a different method 'load' that does re-load the file every single time).
BTW) A class variable will work the same as a global variable for FS plugins - because all Ruby primitives are instances of the same class, RubyEdit. I've even done a couple of experiments deliberately passing values between two plugins using class variables, and it works very well (or badly, depending whether you want them to or not!)
This is going to be something that we'll all have to learn to deal with.
Best not to use RubyEdit class variables at all - even if you are very careful with naming, this will not help if two instances of the same plugin are loaded at once.
Modules and classes are simlarly visible across plugins, but that is slightly less of a problem, as the actual objects made from those classes will be local. The common practice in other Ruby enabled app's is to always wrap cutsom class definitions inside a Module named after the developer etc. - just in case two people use a common name for a new class and overwrite each other's methods. And NEVER redefine one of the built in Ruby methods - sounds obvious, hut I have had my CAD software brought to its knees by a plugin that did this!
In the case of 'require', appending the paths to $LOAD_PATH from an instance variable is probably safest. Require only ever loads the same library once anyway (so custom libraries must have unique names!) - plugins loaded later will know that "win32api" is already available and not bother loading it again. (there's a different method 'load' that does re-load the file every single time).
All schematics/modules I post are free for all to use - but a credit is always polite!
Don't stagnate, mutate to create!
Don't stagnate, mutate to create!
-
trogluddite - Posts: 1730
- Joined: Fri Oct 22, 2010 12:46 am
- Location: Yorkshire, UK
Re: [SOLVED]✔ VST: Win32API not work?
This does not sound good; will this be fixed soon?trogluddite wrote:BTW) A class variable will work the same as a global variable for FS plugins - because all Ruby primitives are instances of the same class, RubyEdit. I've even done a couple of experiments deliberately passing values between two plugins using class variables, and it works very well (or badly, depending whether you want them to or not!)
This is going to be something that we'll all have to learn to deal with.
Best not to use RubyEdit class variables at all - even if you are very careful with naming, this will not help if two instances of the same plugin are loaded at once.
Modules and classes are simlarly visible across plugins, but that is slightly less of a problem, as the actual objects made from those classes will be local. The common practice in other Ruby enabled app's is to always wrap cutsom class definitions inside a Module named after the developer etc. - just in case two people use a common name for a new class and overwrite each other's methods..
I think we could use clearer workarounds for this please...
- infuzion
- Posts: 109
- Joined: Tue Jul 13, 2010 11:55 am
- Location: Kansas City, USA, Earth, Sol
Re: [SOLVED]✔ VST: Win32API not work?
Yes, I'd like to see something done about this too - it will potentially lead to a lot of confusion.
Prior to FS going VST, it was probably not such an issue - but multiple instances are par for the course for us.
Not sure how you'd deal with it though - firing up a separate instance of the Ruby interpreter for each plugin would be very wasteful of resources.
Prior to FS going VST, it was probably not such an issue - but multiple instances are par for the course for us.
Not sure how you'd deal with it though - firing up a separate instance of the Ruby interpreter for each plugin would be very wasteful of resources.
All schematics/modules I post are free for all to use - but a credit is always polite!
Don't stagnate, mutate to create!
Don't stagnate, mutate to create!
-
trogluddite - Posts: 1730
- Joined: Fri Oct 22, 2010 12:46 am
- Location: Yorkshire, UK
8 posts
• Page 1 of 1
Who is online
Users browsing this forum: No registered users and 105 guests