InstallShield LE (with Visual Studio 2012) completely fails to detect dependencies

不想你离开。 提交于 2019-12-02 17:03:04

Old post so perhaps this can help you or others going through this infuriating issue (assuming you're going through errors like -6225).

Symptoms:

  • you can (re)build each project without a hitch, including the Install Shield project
  • however, if you build the Solution (of multiple projects) errors just seem to pop up

Try:

  • in VS 2012, right click your Solution and select Project Build Order
  • even if the order "looks" right, continue to set dependencies
    • e.g. your install project depends on the source project (obviously, but since this tool doesn't "know" it needs some help).

I'm not sure if this solves the "wrong dlls" issue (I haven't gone through that pain...) but the suggestion to check on the project outputs could help....the above did fix my issues.

Yes, I agree, if it can't even do parity with VS2010 and below setup and deployment projects ease of use, then its one of those yet-another-learning-curve that devs have to deal with (waste of time). Not prepared to call it shoddy though, it does have some nice(r) candy - even the "limited" version.....

Anyway I hope this helps....

Update 1

Yes, I can officially call ISLE shoddy indeed. I am now horribly experiencing the "missing dlls" (forget wrong dlls, they're not even in the intall folder, excuse the colorful langauge but WTF??!!) issue. ISLE cannot identify the proper dependencies - and I don't agree with the previous answer. This issue DID NOT exist with the built-in Setup and Deployment Project we've had since VS 2005.

Agreed on comment regarding bonehead MS move.

Once I fix this issue, I'll update.

Update 2

My fix (if there is a better way, please provide answer).. All this is done in the ISLE UI:

  1. Scan for dependencies - right click project primary output, select Dependencies from scan at build

  2. You will see the dependencies you will have to manually add, indicated by a red icon


    I unchecked them so I could get rid of the -6248 warning which is really odd because IMHO it should be a fatal error in the build - How can this install/setup possibly work if it's missing dependencies?? A warning continues the build, yet it will never work!
  3. Then (yes) manually add the dependencies you identified above...

BTW, unsure if this matters - I started the whole process by importing a VS 2010 install project using ISLE (ISLE menu -> Visual Studio Deployment Project Import Wizard). I'm not sure if this actually matters - re: would it still be able to Dependencies from scan at build if you started from scratch (instead of importing)?

So much for "progress" in Setup and Deployment for VS2012...

Hope this helps!

I have recently been experiencing the problem you describe: a console application builds correctly, with up to date versions of dependencies in the bin directory, but when packaged with InstallShield LE, uses old versions of the dependency DLLs.

As you say:

Doing a "Clean Solution" didn't even fix the problem with the DLLs that are in my solution. It was finding a random version somewhere on my machine (in some sort compiler temp directory), and insisting on including that.

In my case, the offending files were located in the ASP.NET dynamic compilation cache at C:\Windows\Microsoft.NET\Framework\v4.0.30319\Temporary ASP.NET Files\root and C:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporary ASP.NET Files\root

Clearing the contents of these directories resolved the problem.

As an aside, I thought about adding a build action to empty these directories automatically, but I couldn't do this automatically without falling fowl of ownership permissions.

Each setup tool has its problems. Please note that there are no tools which can accurately detect your application dependencies. The best a tool can do is make suggestions. This is why most setup developers determine the dependencies themselves and manually include them in the installer.

If you're not happy with InstallShield, you can try a different setup tool: http://en.wikipedia.org/wiki/List_of_installation_software

The free version of Advanced Installer includes a Visual Studio setup project which may help.

Instead of using installation shield you can publish your project by just doing right click on project and Publish wizard create exe as Single Image or whatever your selection And finally It take care of all dependency..So when install exe created by Publish Wizard than it automatically install all dependency such .net framework and If some runtime framework required by your application than it will alert you to install that one.

You can have look at this

http://msdn.microsoft.com/en-IN/library/31kztyey.aspx

I was having a problem with my DLL. It was grabbing a much older one from somewhere. Nothing was in the GAC for this DLL. I tried everything. Finally, I just added the darn thing manually (ISLE) in the Files section by right clicking and selecting add. I found the DLL in my \obj\Release folder. Then I just built the Release again (SingleImage) and everything worked correctly.

You can fix build order problems (like when you try to rebuild the solution) by right clicking on the solution -> Project dependencies -> Select your setup project and check the projects it uses. (Tested in VS2013)

I expected the InstallShield project to set those dependencies automatically when you select its source files, but apparently it does not.

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!