LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Deprecated Nodes

How do I add property/invoke nodes that are deprecated by NI and where can I find help documentation for these nodes? Like the OPEN:VI FROM BUFFER in the attachment, I googled a lot of keywords, but have no clue. Or is there a VI that includes all nodes deprecated by NI, this problem has troubled me for a long time, please help me

0 Kudos
Message 1 of 12
(1,661 Views)

Deprecated nodes are not supposed to be used for new designs and are also a sign that the support for them will be removed in near future.

 

Any reason you would want to use something that is not supported?

Santhosh
Soliton Technologies

New to the forum? Please read community guidelines and how to ask smart questions

Only two ways to appreciate someone who spent their free time to reply/answer your question - give them Kudos or mark their reply as the answer/solution.

Finding it hard to source NI hardware? Try NI Trading Post
0 Kudos
Message 2 of 12
(1,654 Views)

Because there is an old program that has nodes in the attachment, it works fine in some specific cases, and it doesn't work in most cases. Because there is no relevant help documentation, I don't know how it works (what does buffer represent), and I haven't found an alternative in the new version of labview (2019), so I ask this question

0 Kudos
Message 3 of 12
(1,648 Views)

I would assume it does the same job as Open VI ref.

G# - Award winning reference based OOP for LV, for free! - Qestit VIPM GitHub

Qestit Systems
Certified-LabVIEW-Developer
0 Kudos
Message 4 of 12
(1,610 Views)

I'm not aware of any way of accessing deprecated items in the editor, although there might be an INI key for it. You could possibly use some scripting tricks to get to them, but I haven't tried.

 

Presumably, you don't actually need that, since you already have the VI which calls the deprecated method, so you could just copy that code if you want. I'm not entirely sure about this, but I believe that at least for deprecated features which were official, their context help should include a section about what they were replace with. I doubt this particular method was ever made public, but you should still try looking at its context help.

 

As for what it does, it takes a binary string representing a VI and then loads that VI without going through the disk, returning a reference you can use. You could probably do this by writing that binary data to a file and then using Open VI Reference with that file path.


___________________
Try to take over the world!
Message 5 of 12
(1,590 Views)

@tst wrote:

As for what it does, it takes a binary string representing a VI and then loads that VI without going through the disk, returning a reference you can use. You could probably do this by writing that binary data to a file and then using Open VI Reference with that file path.


It sounds similar to Open VI with just a name? Those VIs should already be in memory i.e. in a buffer?

G# - Award winning reference based OOP for LV, for free! - Qestit VIPM GitHub

Qestit Systems
Certified-LabVIEW-Developer
0 Kudos
Message 6 of 12
(1,584 Views)

@Yamaeda wrote:


It sounds similar to Open VI with just a name? Those VIs should already be in memory i.e. in a buffer?


No no! It takes the binary data of a VI as it is saved in a file on disk but from a byte array buffer in memory. So basically VI Open Reference with a path parameter is more or less equal to: 

 

- Read file from path into a memory buffer

- Call VI Open from Buffer with this memory buffer

 

It's the memory buffer streaming version of VI Open.

 

In reality it is more complex to make it more performant but still the principle is like that.

 

Rolf Kalbermatter
My Blog
0 Kudos
Message 7 of 12
(1,576 Views)

@rolfk wrote:

@Yamaeda wrote:


It sounds similar to Open VI with just a name? Those VIs should already be in memory i.e. in a buffer?


No no! It takes the binary data of a VI as it is saved in a file on disk but from a byte array buffer in memory. So basically VI Open Reference with a path parameter is more or less equal to: 

 

- Read file from path into a memory buffer

- Call VI Open from Buffer with this memory buffer

 

It's the memory buffer streaming version of VI Open.

 

In reality it is more complex to make it more performant but still the principle is like that.

 


That's why i specified the String version with only a Name, there should be no file read on that one, right? Or am i missing something?

G# - Award winning reference based OOP for LV, for free! - Qestit VIPM GitHub

Qestit Systems
Certified-LabVIEW-Developer
0 Kudos
Message 8 of 12
(1,568 Views)

@Yamaeda wrote:


That's why i specified the String version with only a Name, there should be no file read on that one, right? Or am i missing something?


Well no of course not. It only works on VIs already in memory. But it references them by their name. This one is very different. The buffer contains the binary data of the VI. And the VI does not have to be already loaded. Basically think of it like a method to open a VI that you for instance received over some network communication as binary stream. Instead of having to write it onto disk and then open it from there, you can directly open it from the data in memory.

Rolf Kalbermatter
My Blog
Message 9 of 12
(1,560 Views)

"Open VI From Buffer.vi" provides equivalent functionality.

 

"Open VI From Buffer.vi (deprecated)" contains the deprecated node.

 

To be able to set any node yourself:

Place "Set Property or Method.vi" in C:\ ... \LabVIEW 200x\project\ ...", then restart LabVIEW.

Select (click on or lasso) a property or invoke node, then Menu → Tools → Set Property or Method

 

"If you weren't supposed to push it, it wouldn't be a button."
0 Kudos
Message 10 of 12
(1,532 Views)