Solved

FYI: MFC BUG with Win2000 and Platform SDK

Posted on 2000-02-23
1
595 Views
Last Modified: 2013-11-20
[Any comments on this from other Experts]

In order to access Win2000 specific APIs etc, one needs the following #define in the application's stdafx.h (before any other #includes)

     #define _WIN32_WINNT 0x0500

With the latest platform SDK, this also has the side effect of changing the definition for the OPENFILENAME struct; in particular it makes it larger.  This is because of the following lines in the "CommDlg.h"

     typedef struct tagOFNA {
        DWORD        lStructSize;
...
...
        LPCSTR       lpTemplateName;
     #ifdef _MAC
        LPEDITMENU   lpEditInfo;
        LPCSTR       lpstrPrompt;
     #endif
>>>  #if (_WIN32_WINNT >= 0x0500)
>>>     void *       pvReserved;
>>>     DWORD        dwReserved;
>>>     DWORD        FlagsEx;
>>>  #endif // (_WIN32_WINNT >= 0x0500)
     } OPENFILENAMEA, *LPOPENFILENAMEA;

This means when the definition of class CFileDialog is compiled, it's m_ofn member will have a different size than in the MFC dlls.  This is because CFileDialog is defined as:

     class CFileDialog : public CCommonDialog
     {
          DECLARE_DYNAMIC(CFileDialog)
     public:
     // Attributes
>>>       OPENFILENAME m_ofn; // open file parameter block
...
...
     };

When a CFileDialog is used in your code and is destructed, the wrong offsets into memory for member varialbes will be unsed, and in particular, the m_strFilter will not destruct properly.

The work-around for this is to #undef _WIN32_WINNT before the #include <afxext.h> in the application's stdafx.h:

>>>  #define _WIN32_WINNT 0x0500   /* allow Win2000 specific calls */
     #define VC_EXTRALEAN          // Exclude rarely-used stuff from Windows
headers
     #include <afxwin.h>         // MFC core and standard components
>>>  #undef _WIN32_WINNT           /* allow CFileDialog to build with the
correct size */
     #include <afxext.h>         // MFC extensions
     #include <afxdtctl.h>         // MFC support for Internet Explorer 4 Common
Controls
     #ifndef _AFX_NO_AFXCMN_SUPPORT
     #include <afxcmn.h>           // MFC support for Windows Common Controls
     #endif // _AFX_NO_AFXCMN_SUPPORT

Now, <afxext.h> will (indrectly) #include <CommDlg.h> and define CFileDIalog all without the offending _WIN32_WINNT.

NOTE: This only works because the VC_EXTRALEAN stops <afxwin.h> from including CommDlg.h earlier.

0
Comment
Question by:RONSLOW
1 Comment
 
LVL 3

Accepted Solution

by:
darinw earned 0 total points
ID: 2610632
Posting answer to save information to PAQ.

darinw
Customer Service
0

Featured Post

Gigs: Get Your Project Delivered by an Expert

Select from freelancers specializing in everything from database administration to programming, who have proven themselves as experts in their field. Hire the best, collaborate easily, pay securely and get projects done right.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
repeateFront java challenge 31 92
no14 challenge 14 66
Sed question 2 84
Remove Password Protection from pdf (with password) using an command line executable 5 49
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: Hints for the grid button.  Nested classes, templated collections.  Squash that darned bug! Continuing from the sixth article about sudoku.   Open the project in visual studio. First we will finish with the SUD_SETVALUE messa…
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.
Although Jacob Bernoulli (1654-1705) has been credited as the creator of "Binomial Distribution Table", Gottfried Leibniz (1646-1716) did his dissertation on the subject in 1666; Leibniz you may recall is the co-inventor of "Calculus" and beat Isaac…

776 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