Example #1
0
 private static string lvPathFinder(CliOptions options)
 {
     if (options.lvExe != null)
     {
         if (!File.Exists(options.lvExe))
         {
             throw new FileNotFoundException("specified executable not found", options.lvExe);
         }
         return(options.lvExe);
     }
     if (options.lvVer != null)
     {
         try
         {
             return(LvVersions.ResolveVersionString(options.lvVer, options.x64).ExePath);
         }
         catch (KeyNotFoundException ex)
         {
             throw; // So the exception makes it to the handler above.
         }
     }
     if (LvVersions.CurrentVersion != null)
     {
         return(LvVersions.CurrentVersion.ExePath);
     }
     else
     {
         throw new FileNotFoundException("No LabVIEW.exe found...", "LabVIEW.exe");
     }
 }
Example #2
0
 private static lvVersion lvPathFinder(CliOptions options)
 {
     if (options.lvVer != null)
     {
         try
         {
             return(LvVersions.ResolveVersionString(options.lvVer, options.x64));
         }
         catch (KeyNotFoundException ex)
         {
             throw; // So the exception makes it to the handler above.
         }
     }
     if (LvVersions.CurrentVersion != null)
     {
         return(LvVersions.CurrentVersion);
     }
     else
     {
         return(new lvVersion());
     }
 }
Example #3
0
        static int Main(string[] args)
        {
            int    exitCode = 0;
            Output output   = Output.Instance;

            string[]   cliArgs, lvArgs;
            lvComms    lvInterface   = new lvComms();
            lvMsg      latestMessage = new lvMsg("NOOP", "");
            LvLauncher launcher      = null;
            CliOptions options       = new CliOptions();

            lvVersion current = LvVersions.CurrentVersion;

            splitArguments(args, out cliArgs, out lvArgs);
            //CommandLine.Parser.Default.ParseArguments(cliArgs, options);
            if (!CommandLine.Parser.Default.ParseArguments(cliArgs, options))
            {
                Environment.Exit(CommandLine.Parser.DefaultExitCodeFail);
            }
            if (options.Version)
            {
                output.writeMessage(Assembly.GetExecutingAssembly().GetName().Version.ToString());
                Environment.Exit(0);
            }

            output.setVerbose(options.Verbose);
            output.writeInfo("LabVIEW CLI Started - Verbose Mode");
            output.writeInfo("Version " + Assembly.GetExecutingAssembly().GetName().Version);
            output.writeInfo("LabVIEW CLI Arguments: " + String.Join(" ", cliArgs));
            output.writeInfo("Arguments passed to LabVIEW: " + String.Join(" ", lvArgs));

            //Force a rescan at this point to get an output - the constructor scan does not seem to write to output, possibly due to happening before we set verbose flag.
            LvVersions.Scan();

            if (options.noLaunch)
            {
                output.writeMessage("Auto Launch Disabled");
                // disable timeout if noLaunch is specified
                options.timeout = -1;
            }
            else
            {
                // check launch vi
                if (options.LaunchVI == null)
                {
                    output.writeError("No launch VI supplied!");
                    return(1);
                }
                if (!File.Exists(options.LaunchVI))
                {
                    output.writeError("File \"" + options.LaunchVI + "\" does not exist!");
                    return(1);
                }

                List <string> permittedExtensions = new List <string> {
                    ".vi", ".lvproj", ".exe"
                };
                string ext = Path.GetExtension(options.LaunchVI).ToLower();
                if (!permittedExtensions.Contains(ext))
                {
                    output.writeError("Cannot handle *" + ext + " files");
                    return(1);
                }

                try
                {
                    launcher         = new LvLauncher(options.LaunchVI, lvPathFinder(options), lvInterface.port, lvArgs);
                    launcher.Exited += Launcher_Exited;
                    launcher.Start();
                }
                catch (KeyNotFoundException ex)
                {
                    // Fail gracefully if lv-ver option cannot be resolved
                    string bitness = options.x64 ? " 64bit" : string.Empty;
                    output.writeError("LabVIEW version \"" + options.lvVer + bitness + "\" not found!");
                    output.writeMessage("Available LabVIEW versions are:");
                    foreach (var ver in LvVersions.Versions)
                    {
                        output.writeMessage(ver.ToString());
                    }
                    return(1);
                }
                catch (FileNotFoundException ex)
                {
                    output.writeError(ex.Message);
                    return(1);
                }
            }

            //At this point LV should have launched so now we need to handle Ctrl+C to ensure LV is killed as well.
            Console.CancelKeyPress += delegate(object sender, ConsoleCancelEventArgs e)
            {
                output.writeMessage("Cancel key recieved, closing LabVIEW.");
                launcher.Kill();
            };

            // wait for the LabVIEW application to connect to the cli
            connected = lvInterface.waitOnConnection(options.timeout);

            // if timed out, kill LabVIEW and exit with error code
            if (!connected && launcher != null)
            {
                output.writeError("Connection to LabVIEW timed out!");
                launcher.Kill();
                launcher.Exited -= Launcher_Exited;
                return(1);
            }

            do
            {
                latestMessage = lvInterface.readMessage();

                switch (latestMessage.messageType)
                {
                case "OUTP":
                    Console.Write(latestMessage.messageData);
                    break;

                case "EXIT":
                    exitCode = lvInterface.extractExitCode(latestMessage.messageData);
                    output.writeMessage("Received Exit Code " + exitCode);
                    stop = true;
                    break;

                case "RDER":
                    exitCode = 1;
                    output.writeError("Read Error");
                    if (latestMessage.messageData != "")
                    {
                        output.writeError(": " + latestMessage.messageData);
                    }
                    output.writeError("Since the network stream will be out of sync the application will now exit.");
                    stop = true;
                    break;

                default:
                    output.writeError("Unknown Message Type Received:" + latestMessage.messageType);
                    break;
                }
            } while (!stop);

            // close tcp listener
            lvInterface.Close();

            // if killswitch is set, force LabVIEW to exit if it has not closed by itself after a 10s timeout (or the period specified in --timeout)
            if (options.kill)
            {
                int timeout = options.timeout == -1 ? 10000 : options.timeout;
                if (!launcher.lvExited.Wait(timeout))
                {
                    output.writeMessage("Forcing LabVIEW to terminate...");
                    launcher.Kill();
                }
            }

            launcher.Close();

            return(exitCode);
        }