Search code examples
c#shellexecute

Calling another EXE with C# on Windows fails on target machine


I have created a Windows shell extension that provides a menu to users when they right-click in File Explorer. This then invokes a small dialogue App.

I'm a novice at software development so there is probably some schoolboy error I'm making but I just can't see it.

For testing purposes I am hard-coding the path to the EXE and ensuring it's present on the VM.

 private void CallExteralAddLocation(string sFullPath)
        {
            string sEXE = Path.Combine(Application.StartupPath, "AddLocation.exe");
            WriteLog(sEXE);
            // during testing, hard-code this path
            sEXE = "C:\\temp\\AddLocation.exe";

            System.Diagnostics.Process.Start(sEXE, sFullPath);
        }

       
        private void WriteLog(string sText)
        {
            using (StreamWriter sr = new StreamWriter("C:\\Temp\\ShellExtLog.txt"))
            {
                sr.WriteLine(sText);
                
            }
        }

It works fine on my host machine but when running on a VM running Windows 10, which is where I am testing it, the dialogue App does not get invoked.

I have checked that I can invoke the AddLocation.exe from a command window on the VM and that works as expected. So it looks like it's just not getting called.

As it's a shell extension it's very difficult to debug. I tried using MessageBoxes and writing to the console but those wouldn't work, so I have added the WriteLog so that I have some idea of what it's doing.

This works on the host machine i.e. a log file is created and it shows the path to the EXE, but no log file is created on the VM.

NOTE: When testing on either machine, I'm installing afresh from the application's MSI. Also note that the host is running Windows 11 and the VM is running Windows 10.

So, why does the same code fail to either run the EXE or create a log file on the VM?


Solution

  • I eventually worked out that the problem was how C# handles strings.

    If you read through my problem above you will see that, weirdly the same code worked fine on Windows 11 but not on Windows 10.

    The problem was that I was letting the compiler interpret the path string. I had 'escaped' the slashes as shown here and it should have worked fine:

    sEXE = "C:\\temp\\AddLocation.exe";
    

    Changing it to the following resolved the problem so that it works on both now:

    sEXE = @"C:\temp\AddLocation.exe";
    

    Similarly, whereas it wouldn't create a log file on Win10, changing the path to the log file to the following fixed it:

        using (StreamWriter sr = new StreamWriter(@"C:\Temp\ShellExtLog.txt"))