01-08-2012 10:18 AM
I have written an application that save data into file as labview class. The class consist of array of waveforms and other classes. When I want to read data from the file I get the error 1527 "Attempted to read flattened data of a LabVIEW class that is not currently loaded into LabVIEW".
I tried to remove class from library, because I found on forums that this might be the cause of the problem, but it isn't help. Then I put class back to the library and now I get the error "End of file encountered".
I have no idea what am I doing wrong, because I have used the same approach several times and it worked fine.
Is there any other way to read data from the file? For example, if I would know how the array of waveforms is saved in binary file I could parse data from file.
I have Labview 2011.
Solved! Go to Solution.
01-08-2012 11:07 AM
I'm guessing this happens because the class lost its mutation history, so it doesn't know how to load the old data. Things which could cause this are renaming the class and moving it into or out of a library (as you've found). Moving it back does not bring back the mutation history and the only option is to go back to an old version of the class (if you have source code control).
Here are some relevant links, including descriptions of how flat data is saved, in no particular order:
01-08-2012 11:32 AM
TST, thank you for your effort.
I have source code control, but something must have gone wrong because I am not able to open the file with any revision.
I know the exact format of the file, because it didn't change for a while now.
Is there any possibility to read data from the file if I recreate the class, knowing its exact format? If not, them I'm stuck with reading flat data from the file.
01-08-2012 11:37 AM
One additional question. Does NI provide binary file parser in any form? That would help a lot.
01-09-2012 02:52 AM
A parser for binary data is meaningless unless you either know the format of the data or the file has meta data to desribe that format.
As for whether or not you can recreate the class and have it work, my understanding is that LV uses the fully qualified name of the class (that is its name along with all the libraries which contain it) to determine whether the object is of the correct class and then checks the version of the object and applies the transformation. Presumably, if you manage to recreate all the conditions, loading the object would work, but that's just a guess. You can look at those other links for more details.