MFC命令行及CCommandLineInfo类

来源:互联网 发布:360网络测速器在线 编辑:程序博客网 时间:2024/04/28 09:46

获取命令行的方法:

1、GetCommandLine() 获取输入的所有信息,包括程序所在路径及参数

2、AfxGetApp()->m_lpCmdLine 只包含参数

一般情况下,获取到命令行后就可以针对命令行中的内容进行相应的处理了

 

CObject
└CCommandLineInfo
类CCommandLineInfo用于分析启动应用时的命令行参数。
MFC应用一般都会在它的应用对象中使用函数InitInstance创建这个类的一个本地实例。然后把该对象传给CWinApp::ParseCommandLine,ParseCommandLine又重复调用ParseParam填充CCommandLineInfo对象。最后,CCommandLineInfo对象被传给CWinApp::ProcessShellCommand来处理命令行参数和选项。

1.BOOL CExampleApp::InitInstance()
2.{
3.    ...
4.    // 分析标准外壳命令、DDE、打开文件操作的命令行 5.    CCommandLineInfo cmdInfo;
6.    ParseCommandLine(cmdInfo);
7.8.9.    // 调度在命令行中指定的命令。如果 10.    // 用 /RegServer、/Register、/Unregserver 或 /Unregister 启动应用程序,则返回 FALSE。 11.    if (!ProcessShellCommand(cmdInfo))
12.        return FALSE;
13.    ...
14.}
15.16.17.void CWinApp::ParseCommandLine(CCommandLineInfo& rCmdInfo)
18.{
19.    for (int i = 1; i < __argc; i++)
20.    {
21.        LPCTSTR pszParam = __targv[i];
22.        BOOL bFlag = FALSE;
23.        BOOL bLast = ((i + 1) == __argc);
24.        if (pszParam[0] == '-' || pszParam[0] == '/')
25.        {
26.            // remove flag specifier 27.            bFlag = TRUE;
28.            ++pszParam;
29.        }
30.        rCmdInfo.ParseParam(pszParam, bFlag, bLast);
31.    }
32.}
这里有个继承CCommandLineInfo类的例子


目标
让应用程序处理这里所见的命令行标志。
>XXX.exe /c /d
策略
一个MFC应用程序可以用CCommandLineInfo类的成员函数ParseParam()处理一些标准标
志。要添加我们自己的标志,而仍然能够支持另外一些标志,我们将从CCommandLineInfo派
生类,然后重载ParseParam()。
步骤
1.创建一个新的CCommandLineInfo类
1)用ClassWizard创建一个派生于CCommandLineInfo的新类。在新类中,为应用程序要
处理的每个新的标志添加一个Boolean或String成员变量。
classCWzdCommandLineInfo:publicCCommandLineInfo
{
public:
BOOLm_bAFlag;
BOOLm_bCFlag;
BOOLm_bDAFlag;
CStringm_sArg;
2)添加一个ParseParam()函数,以重载基类的ParseParam()函数。
//Operations
public:
voidParseParam(constTCHAR*pszParam,BOOLbFlag,BOOLbLast);
};
3)如下实现ParseParam():
voidCWzdCommandLineInfo::ParseParam(constTCHAR*pszParam,
BOOLbFlag,BOOLbLast)
{
CStringsArg(pszParam);
if(bFlag)
{
m_bAFlag=!sArg.CompareNoCase("a");
m_bCFlag=!sArg.CompareNoCase("c");
m_bDAFlag=!sArg.CompareNoCase("da");
}
//m_strFileNamegetsthefirstnonflagname
elseif(m_strFileName.IsEmpty())
{
m_sArg=sArg;
}
88第二部分用户界面实例
下载
CCommandLineInfo::ParseParam(pszParam,bFlag,bLast);
}
注意到变量pszParam包括命令行中的下一项。如果pszParam的后面是一个—(连字符)或
/(正斜杠)字符,则bFlag变量为TRUE,这些字符将被删除;如果pszParam是一行中最后一个
变量,则bLast为TRUE。确信最后调用基类的ParseParam(),否则标准标志不被处理。
4)有关命令行消息类的详细清单,参见本节的“清单—命令行消息类”。
2.把新的命令行消息类插到应用程序类中
1)在应用程序类中找到ParseCommandLine(),并用该新类替换CCommandLineInfo类。
//Parsecommandlineforstandardshellcommands,DDE,fileopen
CWzdCommandLineInfocmdInfo;
ParseCommandLine(cmdInfo);
2)现在,命令行选项不能作为cmdInfo变量的成员变量。
if(cmdInfo.m_bAFlag)
{
:::
}
3)要使这些选项在整个应用程序中可得,则把cmdInfo嵌入应用程序中,并访问它的成员
变量。
(CXXXApp*)AfxGetApp()->m_cmdInfo.m_bAFlag;
注意:CXXXApp类是你自己创建的应用程序类
说明
■标准MFC标志如下,真正处理这些标准命令行发生在ProcessShellCommand(cmdInfo)
中,它正好在应用程序类中ParseCommandLine()之后。
nothing使应用程序试图打开一个新文档
filename使应用程序试图以文档方式打开文件名
/pfilename使应用程序打开并打印给定的文件名到默认的打印机
/ptfilename与上面相同,但输入到指定的打印机
printerdriverport
/dde使应用程序开始运行,并等待DDE命令
/AutomationCOM标志
/Embedding
/Unregister
/Unregserver
■处理非标准标志(如名字)会有点复杂,我们认为出现的第一个非标准标志是文档文件名。
然而,一旦一个文件名被发现,可以根据目的攫取任何非标准标志,这就是说,除非
遇到/pt标志,在这种情况下,下面三个非标准标志变量用来初始化打印。为了简化起
见,也可通过不把/pt标志传递给基类中的ParseParam()来禁用/pt标志。
■当然,如果不需继续支持前面所示的标准MFC标志,则可以更加自由地行动。只要不
用调用基类的ParseParam(),可以使用任何标志或非标准标志选项。但是,不要因为能
用非标准标志,而轻易放弃这些标准标志提供的功能。

 

 

CCommandLineInfo::ParseParam

virtual void ParseParam( LPCTSTR lpszParam, BOOL bFlag, BOOL bLast );

参数: lpszParam 命令行参数或选项。 bFlag 指明lpszParam是参数还是选项。 bLast 是否为命令行中的最后一个参数或选项。
说明:
框架调用此函数来分析解释命令行中的每个输入参数。CWndApp::ParseCommand调用为命令行中的每个参数或选项调用一次ParseParam,然后把它传给lpszParam。如果输入参数的头一个字符为“-”或“/”,则删除它,并把bFlag设置为TRUE。在分析到最后一个输入参数时,把bLast设置为TRUE。
缺省时,本函数可以识别出以下的选项:/p, /pt, /dde/ /Automation和/Embedding。如下表所示: 命令行参数 执行的命令 app 建立新文件 app 文件名 打开文件 app  /p 文件名 在缺省打印机上打印文件 app  /pt 文件名 打印机 驱动程序 打印端口 在指定的打印机上打印文件 app /dde 启动程序并等待DDE命令 app /Automation 启动为一个OLE自动服务器 app /Embedding 启动来编辑嵌入的OLE项 这些信息存放在m_bRunAutomated、m_bRunEmbedded和m_nShellCommand中,选项以“-”或者“/”打头。
缺省时,本函数把不是选项的输入参数放到m_strFileName中。遇到选项/pt时,把第二、三、四个不是选项的参数分别传给m_strPrinterName、m_strDriverName和m_strPortName。
在缺省实现中,仅当新建文件时把m_bShowSplash设置为TRUE。新建一个文件时,用户的动作就包括了应用本身。在其它情况下,例如用外壳(shell)打开一个现存的文件,用户的动作只是直接包括了文件。以一种以文档为中心的观点来看,飞溅型窗口不需要宣布应用的启动。
可以覆盖此函数处理其它的选项和参数值。

原创粉丝点击