翻译qmake文档(三) Creating Project Files

翻译qmake文档 目录

 

原英文文档:http://qt-project.org/doc/qt-5/qmake-project-files.html

 

创建项目文件
     项目文件包含qmake构建你的应用程序,库文件,或插件需要的所有信息。通常,你会在项目文件里使用一系列的声明指定资源,但是对简单程序构造的支持,允许你为不同的平台或环境描述不同的构建过程。

项目文件元素

     qmake使用的项目文件格式可以支持简单和复杂的构建系统使用。简的项目文件使用简单的声明样式,定义标准的变量,用于指出项目中使用的头文件和源文件。复杂的项目可以使用控制流程结构来调整构建过程。

 

     下面的章节描述了在项目文件里使用不同类型的元素。

变量

     在项目文件里,变量是用于保存字符串的列表。在简单的项目里,这些变量通知qmake使用相关的配置信息,或者提供文件名和路径在构建过程使用。

     qmake在每个项目文件中查找某些变量,并使用这些内容用于确定什么要写到 makefile里。举例,在HEADERSSOURCES里的变量列表用于告诉qmake在相同目录里的头文件和源文件做为项目文件。

     变量也可以在内部保存临时变量列表,现有变量列表可以被新值覆盖或扩展。

     下面的代码片段说明了值列表是如何赋值给变量的:

 

HEADERS = mainwindow.h paintwidget.h

 

 

在变量里的值列表是通过下边的方式进行扩展的:

 

SOURCES = main.cpp mainwindow.cpp \
          paintwidget.cpp
CONFIG += console

 

 

注意:第一个赋值语句只包含指定在同一行里的值是HEADERS变量。第二个赋值语句把SOURCES里不同行的值用反斜杠(\)分开。

     CONFIG变量是另一个当生成Makefile时qmake用来使用的特殊变量 。这里讨论了它General Configuration .在上面的代码片段,console被添加到CONFIG已经存在的值列表里。

      下边的表格列了了常用的变量并描述了他们的内容。完整的变量列表及它们的描述,请查看Variables

 

变量 描述
CONFIG 通用的项目配置选项。
DESTDIR 将要存放可执行文件和二进制文件的目录。
FORMS user interface compiler(uic)处理过的UI文件列表。
HEADERS 当构建项目时被使用的头文件(.h)名称列表。
QT 在项目中使用的Qt模块列表
RESOURCES 在最终项目中包含的资源文件(.qrc)列表。更多资源文件的详细信息查看   The Qt Resource System 。
SOURCES 在构建项目时使用的源文件(.cpp)列表。
TEMPLATE 项目使用的模板。这个决定构建过程输出的是否是一个应用程序、库、或者生成一个插件

 

     可以通过在变量名前附加$$读取变量的内容。这样可以把一个变量的内容赋值给另一个变量。

 

TEMP_SOURCES = $$SOURCES

 

 

     $$操作符被广泛的应用于内置函数,用于操作字符串和值的列表。更多详细信息,请查看,qmake Language

 

空格

 

通常,在变量赋值中用空格分隔值。指定变量中包含空格,你必需用双引号包围变量

DEST = "Program Files"

 

引号文本被视为一个单独的值保存在变量里。类似的方法用来处理包含空格的路径,特别是在windows平台定义INCLUDEPATHLIBS变量时:

 

win32:INCLUDEPATH += "C:/mylibs/extra headers"
unix:INCLUDEPATH += "/home/user/extra headers"

 

注释

可以在项目文件里添加注释。注释以#字符开始持续到这一行的结尾。例如:

 

# 注释通常开始于一行的头部,但它
# 也可以在这同行内容的后边

 

要在赋值变量时包含#字符,必需使用内置的LITERAL_HASH变量的内容

 

内置函数和控件流

 

qmake 提供了大量的内置函数允处理变量内容。在简单的项目文件里最常用的是include()函数,这个函数用一个文件名做为参数。 给定的文件的内容包含在在项目文件的地方使用include函数。include()函数经常用于包含其它项目文件

include(other.pro)

 

可以通过作用域(scopes)支持条件结构语句。这种行为和编程语言里的if一样

win32 {
    SOURCES += paintwidget_win.cpp
}

 

 

     只有条件为true的时候花括号里的任务才会被执行。在这个例子里,必须设置CONFIG的Win32选项。只有在windows系统上才会自动处理,左边的大括号必须和条件在同一行

     变量上更复杂的操作通常封面要循环提供的内置函数比如find()unique()和 count()。提供的这些功能,和其它操作字符串和路径,提供用户输入,以及调用扩展工具。使用这些函数更详细的内容,请查看 qmake Language 。所有函数和它们的描述列表,请查看 Replace Functions 和 Test Functions.

 

项目模板

     TEMPLATE变量,是用来定义项目将要构建的类型。如果它没有在项目文件里声明,qmake会假定构建应用程序,并且将为此生成一个适当的Makefile(或者等价的文件)。

     

     下表简要说明了项目类型变量和成描述qmake生成的每一个文件:

模板 qmake输出
app (default) makefile生成一个应用程序
lib makefile生成一个库
aux makefile什么也不生成。如果没有编辑器需要调用创建目标。例如你的项目是用解释型语言编写的。
注意:这个模板类型只适用于基于Makefile的生成器。特别是,它不会与vcxproj和Xcode生成器一起工作。
subdirs Makefile规则包含使用SUBDIRS变量指定的子文件。每一个子目录必须包含它自己的项目文件。
vcapp Visual Studio项目文件 生成一个应用程序
vclib
Visual Studio项目文件生成一个库

vcsubdirs
Visual Studio解决方案文件要在子目录生成项目

 

查看 Building Common Project Types 在编写使用项目模板和库模板项目的项目文件时的建议。

     当使用subdirs模板时,qmake生成一个makefile用来检查每一个子目录,处理在子目录里找到的工程文件,并执行平台的make 工具生成新的Makefile。SUBDIRS变量被用于包含所有要被处理的子目录的列表。

 

 

常规配置

     CONFIG变量指定项目应该配置的选项和功能。

     可以在release模式或debug模式或两种模式一起构建项目。如果debug和release一同指定,最后一个指定的生效。如果你指定 debug_and_release 选项用来构建项目的debug和release两个版本,qmake会生成包含构建两个版本规则的Makefile。可以通过以下方式调用:

 

make all

 

 

添加 build_all选项到 CONFIG变量,在规则构建项目时使用这个默认值。

 

     注意:每一个在CONFIG里指定的变量都可以用做条件作用域。你可以使用内置的CONFIG()方法测试某个配置选项是否存在。例如,下边的代码展示使用这个方法做为域的条件测试是否只有opengl选项被使用

 

CONFIG(opengl) {
    message(Building with OpenGL support.)
} else {
    message(OpenGL support is not available.)
}

 

这允许为release和debug 定义不同的配置 构建。更详细的信息,请查看Using Scopes

 

下边的选项定义要构建的项目类型。

注意:一些选项只有在相关平台上使用时才会生效。

 

选项 描述
qt 这个项目是Qt应用程序需要连接Qt库。你可以为用QT变量控制应用程序所需的所有额外的Qt模块。这个值是默认添加的,但是你可为非qt项目用qmake删除它。
x11 项目是一个X11应用程序或库。如果目标使用Qt那么这个值是不需要的。

 

     应用程序和库项目模板为你提供了更专业的配置选项用来调整生成过程。选项更详细的解释在Building Common Project Types

 

     例如,如果你的应用程序使用Qt库并且你想在debug模式下构建项目。你的项目文件将包含下边的代码:

 

CONFIG += qt debug

 

 

     注意:你必需使用"+=",不能使用"=",不然qmake将不能为使用Qt的配置确定哪些设置是你的应用程序需要的。

 

声明Qt库

 

     如果CONFIG变量包含qt值,开启qmake对Qt应用程序的支持。这样就可以微调你的应用程序使用的Qt模块。通过QT的变量可以用于声明需要的额外的模块。例如我们可以也下面的方式启用 XML和network模块:

 

QT += network xml

注意:QT默认包含core和gui模块,所以上边的声明把network和XML模块添加到了默认列表。下边的赋值删除了默认模块,这将导致应用程序的源码在编译的时候出现错误:

 

QT = network xml # This will omit the core and gui modules.

如果你想构建没有gui模块的项目,你需要用 "-=" 操作删除它。默认情况下,QT包含core和gui。下面的代码将导致最小的Qt项目构建:

 

QT -= gui # Only the core module is used.

 

你可以添加到QT变量的Qt模块列表,请查看QT

 

配置功能

 

     qmake可以提供在功能文件(.prf)里指定的额外的配置功能。这些额外的功能经常为在构建过程使用的自定义工具提供支持。为了能将功能添加到构建过程,把功能的名字(功能文件名的词干)追加到CONFIG变量后边

     例如,用下边的代码qmake可以配置构建过程利用pkg-config提供的外部库。如D-Bus和ogg库。

 

 

CONFIG += link_pkgconfig

PKGCONFIG += ogg dbus-1

 

 

关于添加新特性更详细的信息,请查看 Adding New Configuration Features.

声明其它库

 

     除了Qt支持的库,你可以把其它的库添加到工程里,你必需在工程文件里指定它们。

     qmake可以查找库所在的路径,及特定库链接可以被添加到LIBS变量的值列表。你可以指定库的路径或者,或者使用UNIX样式符号指定库和路径。

     例如,下边的代码显示如何指定库:

 

LIBS += -L/user/local/lib -lmath

 

包含头文件的路径也可以使用相同的方式添加到 INCLUDEPATH 变量

 

例如,添加几个用于查找头文件的路径

 

INCLUDEPATH = c:/msdev/include d:/stl/include

 


 

 

 

 

时间: 2024-11-03 20:13:44

翻译qmake文档(三) Creating Project Files的相关文章

翻译qmake文档 目录

利用空闲时间把qmke的文档翻译出来,翻译水平有限,有些地方翻译的不好,请谅解, 如果您能指出来,我会很感激并在第一时候做出修改.   翻译qmake文档(一) qmake指南和概述 翻译qmake文档(二) Getting Started 翻译qmake文档(三) Creating Project Files 翻译qmake文档(四) Building Common Project Types  

翻译qmake文档(四) Building Common Project Types

翻译qmake文档 目录   本章原英文文档:http://qt-project.org/doc/qt-5/qmake-common-projects.html   构建常见的项目类型        本章描述如何设置基于Qt的应用程序.库和插件的三种常见项目类型的qmake项目项目文件.虽然所有的项目类型使用大量相同的变量,但是它们中的每一个都使用项目特定的变量来自定义输出文件.      这里不会描述特定于平台的变量.更多详细修改请查看  Qt for Windows - Deployment

翻译qmake文档(一) qmake指南和概述

  翻译qmake文档 目录 英文文档连接: http://qt-project.org/doc/qt-5/qmake-manual.html http://qt-project.org/doc/qt-5/qmake-overview.html  由于qmake manual和overview  两章的内容都不多就把它们放在一起翻译了出来 qmake 指南  qmake 是帮助简化跨平台项目开发的构建过程的工具,qmake能自动生成Makefile,以至于只需要几行代码就可以创建相应的Makef

翻译qmake文档(二) Getting Started

翻译qmake文档 目录   原英文文档: http://qt-project.org/doc/qt-5/qmake-tutorial.html         本教程教讲授qmake基础知识.这个手册里的其它专题包含更详细的使用qmke信息. 从简单开始      假设你已经完成了应用程序的基本实现,并且你创建了下边的文件: hello.cpp hello.h main.cpp   qt分布的目录 examples/qmake/tutorial 中,你可以找到这些文件.你只需要知道的另一件事是

C# 写入XML文档三种方法详细介绍_C#教程

我在以前的博客中介绍了如何使用XmlDocument类对XML进行操作,以及如何使用LINQ to XML对XML进行操作.它们分别使用了XmlDocument类和XDocument类.在本文中,我再介绍一个类,XmlTextWriter.我们分别用这三个类将同样的xml内容写入文档,看一看哪种写法最直观.简便. 我们要写入的XML文档内容为 复制代码 代码如下: <?xml version="1.0" encoding="UTF-8"?> <Co

word2013中翻译文档方法

  在word2013中翻译文档方法一: 步骤一:首先用word 2013打开需要翻译的文档,本教程就以中文翻译成英语为例吧."审阅"--"语言"--"翻译"--"选择转换语言".如图1 ( 图 1 ) 步骤二:弹出的对话框中"选择文档翻译语言"--"翻译为"的选项框中下拉选择"英语(美国)",然后点"确定",如图 2.图 3 ( 图 2 ) (

PHPExcel开发者文档[中文版]

1. 写在前面的话 首先,第一次翻译该文档,漏洞百出,希望大家给点意见和指导. phpExcel官网指出:PHPExcel是基于OPENXML标准,使用PHP读写并创建Excel文件电子表格的引擎. 该项目为php编程语言提供了一系列允许你读写不同文件格式的电子表格的类,像Excel(BIFF).xls.Excel 2007 (Office OpenXML).xlsx.CSV.Libre/OpenOffice Cacl .ods.Gnumeric.PDF.HTML等等.该项目围绕微软的OpenX

软件开发的过程中,这些文档你都用到了吗(转)

导读:做软件的目的就是要满足客户的需求,这个需求包括功能.外观.操作.时间及性能等各方面.那么,在软件开发过程中那部分最重要呢,程序员说"毋庸置疑,我编写的程序实现了客户提出的功能以及业务流程,..... 众所周知,做软件的目的就是要满足客户的需求,这个需求包括功能.外观.操作.时间及性能等各方面.那么,在软件开发过程中那部分最重要呢,程序员说"毋庸置疑,我编写的程序实现了客户提出的功能以及业务流程,肯定我是最重要的",美工说"你开发的功能如果没有我的页面美化,是无

Redis集群明细文档(转)

相信很多用过Redis的同学都知道,Redis目前版本是没有提供集群功能的,只能单打独斗.如果要实现多台Redis同时提供服务只能通过客户端自身去实现.目前根据文档已经看到Redis正在开发集群功能,其中一部分已经开发完成,但是具体什么时候可以用上,还不得而知.本文是对其集群文档的翻译,文档来源:http://redis.io/topics/cluster-spec 总体来说,其集群没有存在代理节点或者控制器的东西,所有节点功能一样,并且所有节点通过一个叫做连接总线的东西上发送消息包.每个节点会