Solved

Registering a .NET dll to use from VFP exe on WS 2012

Posted on 2015-01-28
10
400 Views
Last Modified: 2015-01-28
I am using VS 2008 to create a DLL which is then called by a VFP Executable.
When I compile the DLL on the Development Machine (Windows 7 64 bit) it automatically registers the dll and everything runs exactly as expected.

When I copy the DLL to the Windows Server machine, I assume I need to register it.  I follow this procedure:
Open Powershell (run as administrator)
cd \windows\syswow64
regsvr32 "path to dll here\mydll.dll"
I get the following error:
The Module "path to dll here\mydll.dll" was loaded but the entry-point DLLRegisterServer was not found.
Make sure that "path to dll here\mydll.dll" is a valid DLL or OCX file and then try again.

On the Dev machine - the dll is actually in the bin\release folder where it is put during the compile.  On the WS 2012 machine, I dropped it in the same folder with the installed VFP EXE.

So - what is VS 2008 doing to correctly load this dll on my Development machine that I am not doing manually on the WS 2012 machine.
It is built with Register for Com Interop checked.  I have built it with Target CPU is x86  and dot net framework 2.0 is targeted (advanced compile options).  I have also tried with Any CPU - they both work on the dev machine, but nothing will register on the WS 2012 machine.  I have checked the registry on the WS machine and there are no references to the DLL.  
I have run Process Monitor and find the following:
regsvr32.exe      4176      CreateFileMapping      C:\Program Files (x86)\Software Plus\PMImport.dll      FILE LOCKED WITH ONLY READERS      SyncType: SyncTypeCreateSection, PageProtection:

I am lost as to why this won't register.  This is a dll I created and it doesn't have the DLLRegisterServer in it, but it is not required on the dev machine which is W7.

Thanks
0
Comment
Question by:DonnaOsburn
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 4
  • 2
10 Comments
 
LVL 34

Expert Comment

by:it_saige
ID: 40575792
The simplistic explanation.  Registration is needed for COM.  COM objects (DLL's and EXE's primarily, and are normally comprised of unmanaged code) that are registered have entries created in the registry.  These entries are used by calling assemblies in order to locate and use the COM objects.

In .NET you do not normally need to register your assemblies because .NET uses a different mechanism (probing) to locate dependencies.

https://msdn.microsoft.com/en-us/library/yx7xezcf.aspx

-saige-
0
 

Author Comment

by:DonnaOsburn
ID: 40575815
Okay, but there is nothing in your answer that has anything to do with my question.

It IS compiled as COM object so i need to register it. If I my EXE were created in .NET I would not need to register it, however, I explained my EXE was created with VFP.
0
 
LVL 34

Expert Comment

by:it_saige
ID: 40575905
In order to register your Managed COM object, you need to use REGASM.EXE.
The Assembly Registration tool reads the metadata within an assembly and adds the necessary entries to the registry, which allows COM clients to create .NET Framework classes transparently. Once a class is registered, any COM client can use it as though the class were a COM class. The class is registered only once, when the assembly is installed. Instances of classes within the assembly cannot be created from COM until they are actually registered.
Source

https://msdn.microsoft.com/en-us/library/aa645736(v=vs.71).aspx
http://www.codeproject.com/Articles/12673/Calling-Managed-NET-C-COM-Objects-from-Unmanaged-C
http://www.codeproject.com/Articles/990/Understanding-Classic-COM-Interoperability-With-NE

-saige-
0
Transaction Monitoring Vs. Real User Monitoring

Synthetic Transaction Monitoring Vs. Real User Monitoring: When To Use Each Approach? In this article, we will discuss two major monitoring approaches: Synthetic Transaction and Real User Monitoring.

 
LVL 40

Assisted Solution

by:Vadim Rapp
Vadim Rapp earned 250 total points
ID: 40575972
Either you need to run regasm with parameter /codebase on the target workstation, or build the setup and deployment project, which will extract all registry information and will have it registered by Installer.

> So - what is VS 2008 doing to correctly load this dll on my Development machine that I am not doing manually on the WS 2012 machine.

It's running the same regasm, which you request by checking the checkbox "Register for COM interop" in project properties/Compile. You can unregister it using action "Clean" on the project.
0
 

Author Comment

by:DonnaOsburn
ID: 40576028
I found 12 copies of RegAsm.exe on the WS 2012 Box. These were the ones I felt were most likely.
c:\Windows\Microsoft.Net\Framework\v2.0.50727
c:\Windows\Microsoft.Net\Framework64\v2.0.50727
c:\Windows\Microsoft.Net\Framework\v4.0.30319
c:\Windows\Microsoft.Net\Framework64\v4.0.30319
I figured it would be the first one since the dll is compiled for Framework 2.0.
I ran it and it gave me no error, no feedback, nothing. It changes the prompt from PS to >> and i can type in whatever i want and nothing happens.  like stop, exit, go away... and it just goes to the next line.  So apparently, i am not doing something correctly.
0
 
LVL 40

Expert Comment

by:Vadim Rapp
ID: 40576048
run

regasm <path>\mydll.dll /codebase
0
 
LVL 34

Accepted Solution

by:
it_saige earned 250 total points
ID: 40576055
Sounds like you are in a PowerShell console and not a Command Prompt console.Running regasm with no parameters produces a help list.
To run a command prompt (you will most likely need to be in an Administrative Command prompt to make changes to the registry):

1. Go to the Start Menu and type in cmd.

Capture.JPG[step="2" title="Right-click on 'Command Prompt' and choose 'Run as administrator']Capture.JPG[/step]
[step="3" title="Once open use the cd command to change to the 'C:\Windows\Micorosoft.Net\Framework\v2.0.50727' directory]Tip: As you are typing in the command, if you hit tab, the command processor will attempt to automatically resolve a portion of the path.Capture.JPG[/step]
-saige-
0
 

Author Comment

by:DonnaOsburn
ID: 40576088
Success!
saige - you were correct, I was in PowerShell not Command prompt.  I truly dislike the whole Windows 8/WS2012 visual experience.
Vadim Rapp - the /codebase did not work. I had to use the /tlb option and it registered and ran.

Interestingly enough, where it ran flawlessly on the Win 7 machine, the code had errors that were caught by the WS 2012 box (I had set a date to DBNull instead of Nothing and it barfed.  

thank you both for the quick response and getting me going.  Now I need to figure out how to get inno install to do regasm.
0
 

Author Comment

by:DonnaOsburn
ID: 40576097
I've requested that this question be closed as follows:

Accepted answer: 0 points for DonnaOsburn's comment #a40576088
Assisted answer: 250 points for Vadim Rapp's comment #a40575972
Assisted answer: 250 points for it_saige's comment #a40576055

for the following reason:

I did not accept my own solution however there is some bug forcing me to put a comment in explaining it. So here is my comment!
0
 
LVL 34

Expert Comment

by:it_saige
ID: 40576112
Glad you got it sorted out Donna.

-saige-
0

Featured Post

Enroll in June's Course of the Month

June’s Course of the Month is now available! Experts Exchange’s Premium Members, Team Accounts, and Qualified Experts have access to a complimentary course each month as part of their membership—an extra way to sharpen your skills and increase training.

Question has a verified solution.

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

A short article about problems I had with the new location API and permissions in Marshmallow
Today, still in the boom of Apple, PC's and products, nearly 50% of the computer users use Windows as graphical operating systems. If you are among those users who love windows, but are grappling to keep the system's hard drive optimized, then you s…
Simple Linear Regression
Finding and deleting duplicate (picture) files can be a time consuming task. My wife and I, our three kids and their families all share one dilemma: Managing our pictures. Between desktops, laptops, phones, tablets, and cameras; over the last decade…

690 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