LabVIEW

cancel
Showing results for 
Search instead for 
Did you mean: 

Best practice for backward compatibility of reuse libraries?

Solved!
Go to solution

At work we pick a version of LabVIEW and use it across the board until we eventually upgrade everything.

 

Now I'm hoping to develop some open source hobby libraries to share with the community. I plan to distribute a VIPM package. I want to use the freshest version of LabVIEW (23Q1) because I have the Community Edition so why not see the improvements from a few years of NI's effort.

 

Is there any simple or at least standard process for developing in the latest LabVIEW version but allowing folks on older versions to still run the code? I don't want to lock out most other users who aren't on the "bleeding edge".

0 Kudos
Message 1 of 9
(1,941 Views)

I'd recommend the opposite.  Use the oldest version you can that will support your functionality.   Even if all you have is 2023, when ready to put together a VIPM package, first do a "Save for Previous Version..." back several years into a new folder.   If you used a feature or function not available in that version, you'll get a warning.  Then you can decide whether to recode to avoid the incompatibility or whether to be a little less retro in your back-save.

 

Then make your VIPM package out of the code in the back-saved folder to minimize the # of users you lock out.

 

 

-Kevin P

ALERT! LabVIEW's subscription-only policy came to an end (finally!). Unfortunately, pricing favors the captured and committed over new adopters -- so tread carefully.
Message 2 of 9
(1,935 Views)

Thanks, I was hoping that wasn't the case. We use LV20SP1 at work so I was looking forward to trying something newer at home.

 

For the back-saving option, do I need the earlier LabVIEW version installed to Save As? Or for VIPM to package it?

0 Kudos
Message 3 of 9
(1,920 Views)
Solution
Accepted by OneOfTheDans

You'll need the version you want to save packages for. 2020 is the base year I've been using for packages. Interfaces & the new collection types from 2019. There aren't any significant language features new in 21-23 and in fact you might find some of the changes annoying if you've been using LabVIEW for any amount of time (they changed the wire routing algorithms and some other stuff) though of course some stuff got fixed too. VIPM needs the version of the package build since it does some relinking and dependency management for VIs and controls since they'll be in a different location after install.

 

2020 CE is available for download. If you want to do development in 23 you would need to do the save for previous from 23 (don't need 20 for that) but then to build the 2020 VIP you'd need a 20 environment. And then if you have other packages that depend on that package... make sure you have that package installed for both versions of LabVIEW, back save again, and make sure everything links properly in 20... Which is why you'll just want to work in 20. It's not really feasible to continually be back-saving for package building and maintaining package installs and updates in multiple versions.

~ Self-professed LabVIEW wizard ~
Helping pave the path to long-term living and thriving in space.
Message 4 of 9
(1,908 Views)

Thanks guys, 2020 it is then!

 

I'm glad I setup everything in a virtual machine, it should be pretty quick to clone and setup a fresh OS. I don't like mixing LabVIEW versions on one "machine" - I have enough troubles in life ready 😄

 


@IlluminatedG wrote:

There aren't any significant language features new in 21-23


lol I didn't want to be the one to say it!

0 Kudos
Message 5 of 9
(1,899 Views)

FWIW I just got done installing 2020 after installing 2022 myself (both Community Editions) and there haven't been any issues I've run into yet that weren't of my own doing 🙂 Though there's been a couple of times I've thought I was in 2020 and was working on something in 2022 instead, that's the main issue I see. I do need 2022 for some stuff for a specific bugfix so I do want them side by side.

~ Self-professed LabVIEW wizard ~
Helping pave the path to long-term living and thriving in space.
0 Kudos
Message 6 of 9
(1,873 Views)

I have a taskbar icon for each explicit version of LabVIEW, and I always open up the version of LabVIEW that I want from there.  That's the only way I can see to keep them separate.

Bill
CLD
(Mid-Level minion.)
My support system ensures that I don't look totally incompetent.
Proud to say that I've progressed beyond knowing just enough to be dangerous. I now know enough to know that I have no clue about anything at all.
Humble author of the CLAD Nugget.
0 Kudos
Message 7 of 9
(1,802 Views)

lv taskbar.png

 

Ditto. But the numbers are practically illegible, at least on Win 11, and aren't otherwise differentiated anymore. I'm so used to working from file explorer with tortoisegit and all though that I'm continually opening in the wrong version.

 

Is there a way to force LV to a specific version when double-clicking from explorer? Can't say I'm a fan of the smart behavior now that I finally have a system with multiple versions at once. I'd like to be able to set 2020 to the always opened with default and I can manually open in 22/23 when needed. Worst case with that I get told file version is too new. Worst case with the current smartness is I accidentally version bump everything and hope I didn't have any changes not in SCC yet and have to do some save for previous juggling.

~ Self-professed LabVIEW wizard ~
Helping pave the path to long-term living and thriving in space.
0 Kudos
Message 8 of 9
(1,774 Views)

I recollect someone on the forum developed a launcher app that allows you to select the LV version to launch.

 

I guess @paul_cardinale developed it.

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 9 of 9
(1,767 Views)