 Charles_CLA
		
			Charles_CLA
		
		
		
		
		
		
		
		
	
			11-17-2014 11:09 PM
This is a utility that I wrote over a year ago to reference wrap my Dynamic Dispatch VIs. Here are the (known) caveats:
Other comments:
Finally a note to NI, I've spent roughly a man week on this (partially due to lack of scripting documentation). This utility should not be necessary as there should be a native way for a class to accept either a ByVal or ByRef class. Please don't use this as an excuse to not create an easy way to have ByRef Dynamic Dispatch.
 smithd
		
			smithd
		
		
		
		
		
		
		
		
	
			11-19-2014 01:27 PM
OK, so I made a quick drop shortcut with the help of that code as an excellent example. The shortcut still needs work, but basically it takes this:

And makes this:

Which, cleaned up, looks like this:

code is here:
https://github.com/dsmithni/LVTools-Palettes/tree/dvrqds/Trunk/quick%20drop%20shortcuts/DVR%20Wrap
And you can download that whole repo as a zip here if you don't have any git clients on your machine:
https://github.com/dsmithni/LVTools-Palettes/archive/dvrqds.zip
When I feel more comfortable with it I'll post to the QD shortcut group.
 Jim_Kring
		
			Jim_Kring
		
		
		 
		
		
		
		
		
	
			11-19-2014 01:52 PM
I love everything about this! 
11-20-2014 02:58 PM
One change you might consider: If your VI has "automatic error handling" turned off, you don't have to bother with the second "Merge Error" node. Don't wire the "error out" on the right-hand side at all. The error out on the left-hand side of the IPE and on the left-hand side both output the same value. If you are using automatic error handling, you can wire the right side error out to the border of an empty sequence structure and LV will compile that code away (unwired terminals on structures do not trigger automatic error handling. You might choose to always wire to the sequence structure anyway just in case someone toggles automatic error handling on your VI later.
 Nate_Moehring
		
			Nate_Moehring
		
		
		 
		
		
		
		
		
	
			11-20-2014 03:08 PM
So the error out on the right border of a dereferencing IPE can always be ignored? Why is it there?
This is a direct quote from MattP on this subject:
There are some additional error types that can come from the right border node, but this is mostly there (I believe) to allow for more types of errors to be generated in the future if needed. ... It is technically correct, and yes quite clunky, to be merging errors from both nodes on structure exit.
 smithd
		
			smithd
		
		
		
		
		
		
		
		
	
			11-20-2014 03:49 PM
Yeah, matt and I have talked about that. He misread a line in the original spec document, if I remember correctly--there is only one runtime error right now, and it happens on both error outputs. I'm guessing at this point that more errors are unlikely to be added, making both merge errors kind of useless.
That having been said, I tend to think that having both merges there is the right thing to do, in case the user clears the initial one in their code. For example I've recently seen some vi server calls which don't have standard error in functionality and it would be nice to be sure that the true error (ref==bad) is the one being sent downstream (just noticed my qd shortcut actually misorders them, but ^^this was my intent). Another reasonable option would be to put a case structure inside of the IPE structure and just don't call the code if an error occurs, but I don't know if I'm a huge fan of that either.
11-20-2014 04:20 PM
smithd wrote:
Another reasonable option would be to put a case structure inside of the IPE structure and just don't call the code if an error occurs, but I don't know if I'm a huge fan of that either.
This would far and away be my preferred -- why spend a bunch of time continually checking that error and doing other computation work? I don't tend to add such case structures all over my code because they require me to drop them manually and it is easier to just let each individual node check the error and skip, but if something is autoscripting, I think it makes things easier. There's another reason to do the case structure... consider this case:
You have an array of integers wired through a tunnel into the IPE. You have a DVR of an integer. You unlock the DVR and multiply the value in the DVR times your array and then pass the array out.
If you got an error, what should be the value of the output array? Do you really want an array of all zeros? I can think of two common values I would want -- the array unmodified or an empty array. Both of those are easy to achieve with a case structure (one has "use default if unwired" and the other has the array wired across the False case).
Basically, any output tunnels of the IPE whose value is determined by the value of the DVR seem to make the case for checking the case structure once and skipping all work because not every node checks the error cluster at all.
 smithd
		
			smithd
		
		
		
		
		
		
		
		
	
			11-21-2014 10:47 AM
Fair enough, makes sense. Should be easy to add that, I'll just wrap the initial node selection with a case structure after I've already wired up the IPE.