Jump to content

Variant to Data bug


John Lokanis

Recommended Posts

Just sent this one to NI but thought I would post here to in case anyone had any ideas. See the att zip for a simple example.

It appears that the Variant to Data primitive *or* the Control Value.Get method does not like to work with complex typedef'd data.

This used to work in LV2009SP1 but now give me error 91 in LV2010.

Has anyone else run into this?

-John

Variant to Data bug.zip

Link to comment

I have see somthing with a simular result. Mine was on LabVIEW 8.6.1. Mine seamed to be a block diagram corruption, but would reappear randomly. I think we had to copy the code into new vi to replace the problem vi. Anyways, I just had to try this one out to see if it was the same problem. Although it is not the same problem, it appears that the invoke node is not giving the correct data. The output of a "to variant" node is not the same as the output of the property node. Selecting "Show Type" (right click menu) of a variant control/indicator gives this output:

"invoke node"

'FP References': cluster of 18 elements 	'Run': Boolean Refnum     	'': void 	'Loop': Boolean Refnum     	'': void ...

"to variant"

'Value': cluster of 18 elements 	'Run': Boolean Refnum     	'': boolean (TRUE or FALSE) 	'Loop': Boolean Refnum     	'': boolean (TRUE or FALSE) 	'Abort': Boolean Refnum ...

I am curious if this has anything to do with it.

Edited by SuperS_5
Link to comment

In the process of investigating this, it appears that NI found another bug. If you try this with simple typedef'd datatypes, it also fails if the datatypes are strict. It works if they are not. Unfortunately, making all the datatypes in my example non-strict does not fix this. So, beware of using the Control Value.Get with strictly typedef'd datatypes.

Still no CAR# yet.

Link to comment

If you uncheck "Include Data Type" on the VI server reference classes ( Run, abort. Text display tree etc). It works.

And if you save it to 2009 and add the "include Data Type" it fails. A default setting has changed maybe?.

Ok, so removing the include datatype fixes the issue. And adding back the strict typedef setting has no effect. So my bug is the 'include datatype' problem. FWIW, the original with all the data types included and the strict type defs still works in 2009SP1 (this has been in my code since 8.2 and always worked until upgrading to LV2010)

Here is the LV2009SP1 version where the datatypes are included and the typedefs are strict and it generates no errors.

Variant to Data bug 2009.zip

But NI did find a bug with the strict type defs. Here is the example from NI support where they demonstrate the strict typedef bug using simple datatypes:

7299252 Variant to Data bug.zip

I might get two CARs out of this one. Nice... rolleyes.gif

Link to comment

Ok, so removing the include datatype fixes the issue. And adding back the strict typedef setting has no effect. So my bug is the 'include datatype' problem. FWIW, the original with all the data types included and the strict type defs still works in 2009SP1 (this has been in my code since 8.2 and always worked until upgrading to LV2010)

Here is the LV2009SP1 version where the datatypes are included and the typedefs are strict and it generates no errors.

Variant to Data bug 2009.zip

But NI did find a bug with the strict type defs. Here is the example from NI support where they demonstrate the strict typedef bug using simple datatypes:

7299252 Variant to Data bug.zip

I might get two CARs out of this one. Nice... rolleyes.gif

Your example of the 2009 also fails on my 2009 SP1 (error 91). But if I remove the strict type it works again. I can switch backwards and forwards between it working and not working, so I'm not sure what you mean by "adding back the strict typedef setting has no effect"

Hmmm. 2 cars? I didn't even get a rep-point biggrin.gif

Edited by ShaunR
Link to comment

Your example of the 2009 also fails on my 2009 SP1 (error 91). But if I remove the strict type it works again.

All I can do is show you this. Note the run continuously and that the include data type red stars are present and the version of LV is now displayed. Must be something wrong with your version of LV2009SP1 or mine. Can anyone else confirm this?

post-2411-039504500 1285710462_thumb.png

Link to comment

Nope you are right (only 1/2 a rep point then wink.gif) When I launched your example (dbl clicked) it switched to 2010 instead of my usual 2009. Making sure 2009 was open when I dbl clicked made sure I was using 2009, and it worked ok without moding.

Edited by ShaunR
Link to comment

Nope you are right (only 1/2 a rep point then wink.gif) When I launched your example (dbl clicked) it switched to 2010 instead of my usual 2009.

Doh!

Well, in the end it turns out the bug is only associated with the 'Include Data Type' setting on control references. It has nothing to do with 'Strict Type Defs' afterall. Just confirmed that with the app support people. And the CAR# is 251234 for future reference.

Hope this one does not bite anyone else. Luckily, I was able to find a workaround.

Next time I will write my app in OOP and try to avoid these issues of getting data via VI Server methods. (this app was written a while ago when LVOOP was just a twinkle in AQ's eye...) biggrin.gif

Link to comment

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

×   Pasted as rich text.   Paste as plain text instead

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

By using this site, you agree to our Terms of Use.