Solved

function not working in DLL

Posted on 2002-04-27
12
211 Views
Last Modified: 2013-11-20
The following function works fine when the class "Util" was part of the MFC project I am writing.

void CBBrowserView::DMakeFormPretty()
{
     Util *utilCTRL = new Util;
     if(::IsWindow(m_EnglishCTRL.m_hWnd))
          TRACE("*****DMFP Is Window %d\n",m_EnglishCTRL.m_hWnd);
     else
          TRACE("*****DMFP Not Window %d\n",m_EnglishCTRL.m_hWnd);

     //Init Font Resources for the English Verse
     utilCTRL->ApplyFontToObj(&m_EnglishCTRL,"Courier New",17);

     //Init Font Resources for the Non-English Verse
     utilCTRL->ApplyFontToObj(&m_NonEnglishCTRL,"OLBHEB",17);

     delete utilCTRL;
}

I created an MFC extension DLL and transfered the Util class to it.

The Util class is declared in the "Util.h" class like this:
class AFX_EXT_CLASS Util : public CCmdTarget


I changed the #include statement in the CPP for the "Util.h" to point it to it's new location.
Also, in the Project Settings Link tab, I put the path to the new DLLs .Lib file there.

The function I am calling in the DLL is as follows:
The prototype:

void Util::ApplyFontToObj(CWnd* p_objToApply, CString strFontName, int intFontSize, int intWeight, bool bItalic, bool bUnderline)
{
     CFont     cfFontHolder;  // structure for applying a font to an object
     //Init Font Resources for the search for edit box
     cfFontHolder.CreateFont(intFontSize,0,0,0,intWeight,bItalic,bUnderline,0,
          ANSI_CHARSET,OUT_DEFAULT_PRECIS,
          CLIP_DEFAULT_PRECIS,DEFAULT_QUALITY,
          DEFAULT_PITCH | FF_SWISS, strFontName);

     if(::IsWindow(p_objToApply->m_hWnd))
          TRACE("*****AFTO Is Window %d\n", p_objToApply->m_hWnd);
     else
          TRACE("*****AFTO Not Window %d\n", p_objToApply->m_hWnd);

     p_objToApply->SetFont(&cfFontHolder);
     cfFontHolder.Detach();  //release DC
}

The ::IsWindows function returns true in the EXE but not in the DLL.  In fact the m_hWnd is zero in the DLL.

Like I said, the Util::ApplyFontToObj function worked just fine when is was implemented in the EXE.  When I implemented it into the DLL the CWnd* p_objToApply variable seems to have lost its refenence.

What is that?

Thanx
Dave
0
Comment
Question by:Smave
  • 7
  • 5
12 Comments
 

Author Comment

by:Smave
ID: 6974180
NOTE: m_EnglishCTRL is a control member variable for an Edit box.

CEdit     m_EnglishCTRL;

Thanx
Dave
0
 

Author Comment

by:Smave
ID: 6974212
ALSO: this is the out put from the TRACE macros:
*****DMFP Is Window 1836788
*****AFTO Not Window 0
0
 
LVL 3

Expert Comment

by:GGRUNDY
ID: 6974261
First thoughts...
After checking that the "Structure member alignment", code geration option is the same in you exe & dll, I would do a "Rebuild All" (not batch build) on both the exe & dll, keeping fingers & toes firmly crossed.

0
 
LVL 3

Expert Comment

by:GGRUNDY
ID: 6974268
(not batch build) - I meant (not incremental build)
0
 

Author Comment

by:Smave
ID: 6974947
Tried that.  It didn't work.
0
 
LVL 3

Expert Comment

by:GGRUNDY
ID: 6975706
Hmmmmm...
Maybe you will have to zip up both projects and post a link to them for experts to have a closer look.
0
How your wiki can always stay up-to-date

Quip doubles as a “living” wiki and a project management tool that evolves with your organization. As you finish projects in Quip, the work remains, easily accessible to all team members, new and old.
- Increase transparency
- Onboard new hires faster
- Access from mobile/offline

 

Author Comment

by:Smave
ID: 6975817
OK.  Will do.  Stand by...
0
 

Author Comment

by:Smave
ID: 6975935
Here is the URL to my FTP site.
ftp://24.159.56.211/ProgShare/
Username:IUSER
Password: expert

Download Theo.zip from there.

I am running ZoneAlarmPro, so let me know if you have any problems.

Dave
0
 
LVL 3

Accepted Solution

by:
GGRUNDY earned 100 total points
ID: 6976124
Your dll project has "Use MFC in a shared Dll".
Your exe project has "Use MFC in a static library".

Change your exe project to "shared dll".

Cheers Greg
0
 

Author Comment

by:Smave
ID: 6976147
I feel a little stupid.  But, I figured the solution would probably be that dumb.

Question: Why should that matter?

Thanx again
Dave
0
 

Author Comment

by:Smave
ID: 6976150
Just a thought.  While you have the project there...

If you have any constructive criticism it would be appreciated.

Thanx again
Dave
0
 
LVL 3

Expert Comment

by:GGRUNDY
ID: 6976193
The CWnd structure has different members depending upon whether or not you are linking statically or dynmaically.
The CRuntimeClass::m_pfnGetBaseClass is different.
Makes it difficult when your exe & your dll each have their own opinion of the layout of structures which they pass around.

Cheers
0

Featured Post

What Is Threat Intelligence?

Threat intelligence is often discussed, but rarely understood. Starting with a precise definition, along with clear business goals, is essential.

Join & Write a Comment

Introduction: Displaying information on the statusbar.   Continuing from the third article about sudoku.   Open the project in visual studio. Status bar – let’s display the timestamp there.  We need to get the timestamp from the document s…
Introduction: The undo support, implementing a stack. Continuing from the eigth article about sudoku.   We need a mechanism to keep track of the digits entered so as to implement an undo mechanism.  This should be a ‘Last In First Out’ collec…
This video will show you how to get GIT to work in Eclipse.   It will walk you through how to install the EGit plugin in eclipse and how to checkout an existing repository.
Get a first impression of how PRTG looks and learn how it works.   This video is a short introduction to PRTG, as an initial overview or as a quick start for new PRTG users.

706 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

Need Help in Real-Time?

Connect with top rated Experts

20 Experts available now in Live!

Get 1:1 Help Now