5

MFC と COM を使用する巨大なレガシー プロジェクトがあります。これを Linux に移行するというアイデア (winelib はこれには機能しません) では、MFC を使用するコードの部分を特定する必要があります。奇妙なことに、CWinApp から継承してインスタンス化する 2 つの DLL プロジェクトがソリューションに含まれています。さらに、実際の G​​UI コードは別の非 DLL プロジェクトにあるため、これらの DLL に CWinApp の目的がわかりません。

2 つの質問:
1. MFC 固有のコードを見つけて削除するのに役立つツールはありますか? すでにQt オプションを見ました。
2. GUI 作業をまったく実行していない DLL プロジェクトで (以下のように) CWinApp がインスタンス化されるのはなぜですか? メッセージパッシングに使用されますか?しかし、そのような構文は見当たりません。CWinApp のインスタンス化を削除すると、初期化されていない別のプロジェクトのポインターが発生します。変!

DLL プロジェクトのコードの 1 つは次のようになります。

#include "stdafx.h"
#include "resource.h"
#include <initguid.h>
#include "dlldatax.h"
//removed some project-specific includes for posting on SO

#ifdef _MERGE_PROXYSTUB
extern "C" HINSTANCE hProxyDll;
#endif

CComModule _Module;

BEGIN_OBJECT_MAP(ObjectMap)
OBJECT_ENTRY(CLSID_MyManager, CMyManager)
//removed some other similar lines as the line above
END_OBJECT_MAP()

// Component Category Helper Functions
static HRESULT CreateComponentCategory( CATID catid, WCHAR* catDescription );
static HRESULT UnRegisterCategory( CATID catid );

class CMyClassWrapperApp : public CWinApp
{
public:
    public:
    virtual BOOL InitInstance();
    virtual int ExitInstance();
    DECLARE_MESSAGE_MAP()
};

BEGIN_MESSAGE_MAP(CMyClassWrapperApp, CWinApp)
END_MESSAGE_MAP()

CMyClassWrapperApp theApp;

BOOL CMyClassWrapperApp::InitInstance()
{
#ifdef _MERGE_PROXYSTUB
    hProxyDll = m_hInstance;
#endif
    _Module.Init(ObjectMap, m_hInstance, &LIBID_MyClassWrapperLib);
    return CWinApp::InitInstance();
}

int CMyClassWrapperApp::ExitInstance()
{
    _Module.Term();
    return CWinApp::ExitInstance();
}
4

1 に答える 1

5
  1. MFC プロジェクト設定で、Use Standard Windows LibrariesUse of MFCに変更します。次に、 から「afx」で始まるすべてのインクルードを削除します。コンパイル エラーは、すべての MFC 固有の部分を示します。StdAfx.h
  2. CWinAppMFC 実行可能ファイルが DLL 内の MFC コードを正しく使用できるようにするためのものです。フレームワークは、このオブジェクトを通じて DLL を初期化します。MFC 以外の DLL の場合は、DllMain.

MFCCOMがない場合は、これをグーグルで検索することから始めます。atl com codeproject

于 2012-09-17T10:50:02.017 に答える