 GregFreeman
		
			GregFreeman
		
		
		 
		
		
		
		
		
	
			01-17-2017 11:25 AM - edited 01-17-2017 11:26 AM
I have a thread pool that has 'n' workers. Each of these workers, when idle and data is available, calls a perl script using the system exec VI. Is there any way I can get a reference to the particular cmd.exe window it launches? I don't want to arbitrarily get a reference to a window based on cmd.exe name, because there could be 'n' number of them open at any given time.
Solved! Go to Solution.
 aputman
		
			aputman
		
		
		
		
		
		
		
		
	
			01-17-2017 12:13 PM
Have you tried running a cmd from .NET? I think this is possible using System.Diagnostics.Process although I haven't tried it before.
http://stackoverflow.com/questions/691716/running-cmd-commands-via-net
 James@Work
		
			James@Work
		
		
		
		
		
		
		
		
	
			01-17-2017 02:44 PM
I agree with Putnam that .NET may be the best way to go.
I'd been thinking about replacing my use of the System Exec.vi with .NET and your post gave me the incentive to steal a little code from another thread and make my VI. This VI has the handles and title exposed; although unnecessary for my needs. Hope this helps jump start your effort.
James
01-19-2017 11:45 AM - edited 01-19-2017 11:46 AM
Thanks, this is what I ended up doing. I was considering going that route and it seemed that creating the process was slow, but that was only on the first call. All subsequent calls were near the same speed as the system exec VI, even when I created a new process and closed that process with every call, keeping it relatively stateless on my app layer. I didn't want to manage keeping references open for the lifetime of my application and managing the cases where one may go invalid for whatever reason etc.
 Thomas2020
		
			Thomas2020
		
		
		
		
		
		
		
		
	
			07-30-2024 02:33 AM
Your help solved my problem.
Thank you very very much.
🙂