本主题解释如何审查和自定义项目级别和文件级别的选项,包括构建设置、自定义编译器和链接器选项、报告中心设置和其它设置。
各节内容包括:
必须配置相应的构建设置,以便 C/C++test 能正确测试您的代码。另外,需要时可以配置高级设置(检测选项)。
要审查和修改设置:
右键单击 C/C++ 项目树 (也称为 " 项目的树状图 ")您想要审查和修改设置的项目或文件的节点,然后选择来自快捷菜单中的属性 。将打开【属性】对话框。
选项来源: 定义如何设置选项。 可以手动设置选项,也可以基于构建系统选项,构建数据文件选项,Visual C++ 6.0 项目选项,Green Hills 项目选项或 Eclipse Managed Make 项目设置进行设置。
如果您使用cpptestscan
来创建一个构建数据文件,推荐使用构建数据文件中的选项。如下描述使用现有构建系统创建项目,如果您希望手动管理再生并更新构建数据文件。
对于最初在 Microsoft Visual C++ 6.0 中开发的项目,建议使用使用 Microsoft Visual C++ 6.0 项目中的选项。
对于最初在 Green Hills IDEs 中开发的项目,建议使用使用 GHS 项目中的选项。
对于最初在 Eclipse 中开发的 Managed Make 项目,建议使用使用该项目中的选项 。
否则,推荐手动指定所有选项。
可用的控件取决于所选的选项源。
构建系统的复杂性和执行完整项目重建所需的时间决定了哪个选项源合适。 如果启用了使用构建系统的选项 :
如果启用了使用构建数据文件中的选项:
|
如果您决定手动管理构建数据文件,则强烈建议将用于创建构建数据文件的机制集成到构建过程中。这样,开发团队的成员就可以访问和使用您的构建数据文件,并帮助您在常规构建活动中无缝地生成或更新它。 |
在 C++test 7.1 及更高版本中, 使用 Makefile-based 项目中的选项 已替换成 使用构建系统中的选项。 要实现与 使用 Makefile-based 项目中的选项,所提供的功能相同的功能,请使用以下设置
|
多个 C/C++test 项目配置可用于管理一系列不同配置的测试。例如,您可以配置一个项目来测试主机编译器、交叉编译器、在 Debug 模式下进行测试、在 Release 模式下进行测试等。
您还可以将当前活动的属性导出到文件,或从文件导入先前保存的属性:
导出属性会创建一个文件,该文件也可以用作cpptestcli -localsettings
参数中的参数。从命令行进行测试时,这使您可以轻松地在不同的项目配置之间切换。
要配置适当的设置:
${resource_loc}
解析到特定项目资源的路径。例如,${resource_loc:/MyProject/linked_src_dir/source.cpp}
会解析到 C:\src\source.cpp
。当指定的构建数据文件中的选项变更时,C/C++test 将自动重新扫描选项并相应地修改项目。如果要 C/C++test 强制立即更新选项(例如,如果外部配置文件已变更),请单击重置缓存按钮。
要配置适当的设置:
${CPPTEST_SCAN}
变量表示。这是一个示例 GNU 构建命令行:make -i -B objects CXX=${CPPTEST_SCAN} CC=${CPPTEST_SCAN}
此命令行将使用带有标志-B
(无条件创建所有目标)和-i
(忽略错误)的目标来构建 对象
。CXX
和 CC
使变量被${CPPTEST_SCAN}
取代。此命令行将允许 C/C++test 为通常编译为构建对象
目标的所有源文件提取选项。
CXX=\${CPPTEST_SCAN}
构建命令行已预设为包括 -B Switch 选项(无条件地构建所有目标)。仅 GNU Make 3.80+ 支持此选项。 如果您使用的是较早的 make,请在创建项目之前清理构建。保持 -k switch。 如果你正在使用的 make 不支持 -B, 则需要进一步修改命令行。项目属性中使用的默认构建命令行没有任何目标。我们建议您使用用于构建您要分析的代码的目标来修改此命令行,例如:
另外,在正常构建目标之前添加一个整洁的步骤。示例:
这将首先构建 clean 目标,然后构建 |
3。在构建工作目录 字段,指定应在其中执行构建过程的目录。
${Project_loc}
解析为绝对路径 Eclipse 项目位置 (包含 .project
文件的位置)。如果您的项目具有 " 链接的 " 源文件夹,也就是源文件并非实际上存在于项目位置,则请勿使用此变量,参见下面的消息框,以了解详细信息。
${Project_loc}
解析为特定项目资源的路径。例如, ${resource_loc:/MyProject/linked_src_dir/source.cpp}
将解析为 C:\src\source.cpp
。
当以链接源文件夹配置基于 Makefile 的项目时,不能将 要正确配置项目,而不使用本地系统上源目录的绝对路径 (这在整个团队中并不方便),—可使用 例如,假定您正在处理 ATM_makefile 项目,该项目包含指向源位置的链接的 ATM 文件夹。实际的项目存储在不同的物理位置(因为您想要将项目设置文件与实际源分离开来)。配置 C/C++test 以找到 make 运行目录、以及与之相关的所有被引用文件,可在项目设置中使用 |
4。在依赖文件 字段,指定要检查更改的 Makefile (s)。如果指定的文件更改,选项将自动更新。
使用绝对路径可能会导致无法移植的项目。我们建议您使用以下 C/C++test 变量来指定路径:
${Project_loc}
解析为路径 Eclipse项目位置 (包含 .project
文件的位置)。如果您的项目具有 " 链接的 " 源文件夹,也就是源文件并非实际上存在于项目位置,则请勿使用此变量,参见下面的消息框,以了解详细信息。
${resource_loc}
解析到特定项目资源的路径。例如, ${resource_loc:/MyProject/linked_src_dir/source.cpp}
将解析为 C:\src\source.cpp
。
5。在编译器设置 区域中,指定编译器可执行文件(用于 C 和 C++ 源代码)、链接器和系列。如果未列出您的编译器,请为其添加一个自定义编译器定义(如使用交叉编译器配置测试中所述)。
6。在 选项 区域中,指定您想要使用但尚未在 Makefile 中指定的指定测试、指定 C/C++test 选项的编译器或链接器选项。有关详细信息,请参见为 指定自定义编译器设置和链接器选项 。
当指定的依赖性文件选项更改时,C/C++test 将自动重新扫描选项,并相应地修改项目。 如果要 C/C++test 强制立即更新选项(例如,如果外部配置文件已变更),请单击重置缓存按钮。
要配置适当的设置:
*.dsp
) 项目文件的位置。${project_loc}
解析为 Eclipse 项目位置的绝对路径(包含 .project 文件的位置)。如果您的项目具有 " 链接的 " 源文件夹,也就是源文件实际上并非存在于项目位置,则请勿使用此变量,参见下面的消息框了解详细信息。${Project_loc}
解析为特定项目资源的路径。例如, ${resource_loc:/MyProject/linked_src_dir/source.cpp}
将解析为 C:\src\source.cpp
。$INCLUDE
、 $LIB
和 $PATH
变量的选项。可用的选项有:当 Visual C++ 项目文件选项变更时,C++test 将自动重新扫描选项并相应地修改项目。如果要 C/C++test 强制立即更新选项(例如,如果外部配置文件已变更),请单击重置缓存按钮。
要配置适当的设置:
*.gpj
) 项目文件的位置。${project_loc}
解析为 Eclipse 项目位置的绝对路径(包含 .project
文件的位置)。如果您的项目具有 " 链接的 " 源文件夹,也就是源文件实际上并非存在于项目位置,则请勿使用此变量,参见下面的消息框了解详细信息。${Project_loc}
解析为特定项目资源的路径。例如, ${resource_loc:/MyProject/linked_src_dir/source.cpp}
将解析为 C:\src\source.cpp
。当 GHS 项目文件选项更改时,C++test 将自动重新扫描选项。如果要 C/C++test 强制立即更新选项(例如,如果外部配置文件已变更),请单击重置缓存按钮。
有关 C/C++test 如何使用 GHS 选项源的其他详细信息
C/C++test 支持以下类型的 GPJ 项目,这意味着它将使用这些项目类型指定的项目节点视为项目来扫描源和构建选项:
C/C++test 将 GPJ 项目分为两组:
根项目是被作为选项扫描开始的顶层项目文件。
对于复杂结构的项目。
可测试的源码是 C 和 C++ 源码。
这里有两种 GPJ 项目提供的选项:
在 C/C++test 中,对于一个指定的源文件的构建选项 (编辑选项和构建属性)包括从所有通向这个源文件的父项目节点收集来的全部选项,连同源文件节点本身的所有选项。此外,对于一个具体的可测试项目连接选项包括从所有通向这个项目的父项目节点收集来的全部选项,连同这个可测试项目节点本身的所有选项。
下面表示构建属性,它们被 MULTI 构建选项编辑器指定:
为了向后兼容 GHS 支持以前 C++test 版本的可用性。目前 C/C++test 的版本有兼容模式,它将总是把根项目当成可测试项目。不考虑它们的类型(只要它的类型被支持)。但是,从 "不可测试" 项目中构建一个测试可执行程序是不可能的;有两个常见的原因是:
兼容模式是主要用于对在完整的项目层级中找到的所有可测试源文件运行静态分析。
要配置适当的设置:
要配置适当的设置:
${project_loc}
解析为 Eclipse 项目位置的绝对路径(包含 .project
文件的位置)。如果您的项目具有 " 链接的 " 源文件夹,也就是源文件实际上并非存在于项目位置,则请勿使用此变量,参见下面的消息框了解详细信息。${Project_loc}
解析为特定项目资源的路径。例如, ${resource_loc:/MyProject/linked_src_dir/source.cpp}
将解析为 C:\src\source.cpp
。确定在测试用例执行期间是否检测到选定的源文件。
为了将这个设置应用到多个文件,请在项目树中选择文件,然后右键该选项并选择 Parasoft> C/C++test> 执行设置。请注意,当前的设置将会被统一应用到所有选中的文件。
C/C++test 临时文件 字段控制 C/C++test 保存临时数据/文件的位置,例如检测源、编译对象、链接的测试可执行文件和自动生成的头文件。 此设置控制 {cpptest:testware_loc}
。
由于 C/C++test 可以在需要时自动重新生成这些文件,因此无需在所有团队成员之间共享它们。因此,这些文件不应保存在项目中或添加到源码控制中。
单击【清除】按钮可以删除临时数据。我们建议您不要在两次测试运行之间删除临时数据;保存这些数据可以显著提高性能。
为获得优化的性能,请使用本地硬盘驱动器上的位置。
此表允许您指定各个低级选项和调试选项;有关可用选项的列表,请参见 高级的仪器配置选项。
当处理源文件时,确定是否多字节编码应该被使用。默认情况下, C/C++test 基于当前系统的编码自动激 活对多字节字符的支持 (自动 模式 )。为了手动地控制多字节支持,设置选项值为On或Off。
请注意,由于启用多字节字符的支持对分析性能可能受到影响。
允许您指定不想测试的项目文件。参见 测试用户定义的资源集了解详细信息。