Solved running exe without dll files in folder

Posted on 2006-06-08
Last Modified: 2008-02-01
I'm converting a vb6 app to 2003 and have it working the only problem is that if I try running the .exe file without all the "Interop.whatever.dll" files in the same folder, I get an error "An unhandled exception of type 'System.IO.FileNotFoundException' occurred in myprogram.exe . The vb6 program runs fine without any other supporting files needed. I've tried using regasm on the files but it doesn't seem to change anything. How can I get this to run without needing the dll files in the same folder as the exe?
Question by:alterami
  • 3
  • 2
  • 2
  • +1
LVL 25

Expert Comment

ID: 16865152
Well... If you just ran a converter, it probably made an interop dll to help you call things that the vb6 app used which aren't in or are done differently. If you find the offending location, you can look for a DotNet equivalent and replace it.  

If the code has to do with files/folders, look for objects in namespace
Without knowing what code you have in the interop file or anything about where it is blowing up it would be hard to solve from here.  

The exception you are getting is pretty obvious.. The program can't find a file and your are not catching that error.
Is this the dll that it can't find or some other file that you are trying to open.

If you want to catch the error, surround the code block where it occurs with


'your code here

Catch ex as
      'handle it or show a message about it
end try

Hope this helps some. Please provide more info for more help.


Author Comment

ID: 16865307
I know which files it can't find, the problem is I don't want to have the 8 dll files in the same folder as the exe. I want to be able to put the exe in any folder and have it work the same, without requiring any dll files in the same folder. I want to be able to put the dll files in the system or common files folder and the exe would know where to look for them.

Expert Comment

ID: 16866009
Check if the .NET framework is up and running properly. If you VB.Net was installed properly you should not get this error.
Free Tool: Port Scanner

Check which ports are open to the outside world. Helps make sure that your firewall rules are working as intended.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.


Expert Comment

ID: 16867173
the interop is created because your application is calling some com component. The interop file must be in the same folder as your app, this is a .net limitation, i cont seem to remember where i found this on msdn.

as i found in another post, you can use IlMerge to merge all your interop files and distribute only one file with your app.

or you can remove any reference to unmanage components in the application aswell...

hope that help.

here is the post i referenced above :
LVL 25

Expert Comment

ID: 16869755
Well, as mentioned you  have dependencies to com and if you don't want these DLL's you must rewrite that part of the application to use  .NET components instead of com objects.  This would solve your hole problem--but it is more work.

There is no "convert from vb6 to .NET" without any work.  That would be rare.  At least not to get the type of solution many people want.

Not knowing what your app does sort of limits my suggestions, but I can't imagine why it need be in whatever directory.
Why not just hide the dlls on install, then make shortcuts to anywhere you want, would this not do the same thing?

Author Comment

ID: 16906862
I don't mind if its dependant on dll files, I just don't want to have to have them in the same folder as the .exe file for it to function. I want to be able to move the .exe file around and put it into several different locations and be able to run it. Is there a way I can register the interop files and just put them into a common files folder somewhere, so that anytime I run the .exe file no matter which folder its in on my pc, that it would know where to look for them, and doesn't need them in the same folder?

Accepted Solution

MySt1k earned 250 total points
ID: 16908641
as i said earlier, i don't think it is possible.

you can try to add the interop into the gac, but it is a bit complicated and i dont guarantee it'll work because i couldn't get it to work.
here is what i tried,
generate a new key pair with : sn.exe -k keyfile.snk

create a new interop file from the type lib you are using. it must be signed to add to the gac.
tlbimp.exe yourTlbPath /out:CurrentInteropPathAndName /keyfile:keyfile.snk

Install the file to the gac.
gacutil.exe /i CurrentInteropPathAndName

hope this works for you ... waiting for your feedback.
LVL 25

Assisted Solution

SStory earned 250 total points
ID: 16912931
GAC is the only thing I can think of also.  Not sure if that would work either.
You know you can, as I said, hide them on install.

Sorry I can't think of any other way.

Featured Post

Free Tool: Site Down Detector

Helpful to verify reports of your own downtime, or to double check a downed website you are trying to access.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Go is an acronym of golang, is a programming language developed Google in 2007. Go is a new language that is mostly in the C family, with significant input from Pascal/Modula/Oberon family. Hence Go arisen as low-level language with fast compilation…
Computer science students often experience many of the same frustrations when going through their engineering courses. This article presents seven tips I found useful when completing a bachelors and masters degree in computing which I believe may he…
In this fourth video of the Xpdf series, we discuss and demonstrate the PDFinfo utility, which retrieves the contents of a PDF's Info Dictionary, as well as some other information, including the page count. We show how to isolate the page count in a…

828 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question