zoukankan      html  css  js  c++  java
  • qmake使用方法(自动生成Makefile文件)

    qmake的使用简介


    下面是qmake的简单介绍和使用要领,更为详细的信息请参阅手册

    qmake的介绍

    手写Makefile是比较困难并且容易出错的,尤其是需要给不同的平台和编译器组合写几个Makefile。使用qmake,开发者创建一个简单的“项目”文件并且运行qmake生成适当的Makefile。qmake会注意所有的编译器和平台的依赖性,可以把开发者解放出来只关心他们的代码。Trolltech公司使用qmake作为Qt库和Qt所提供的工具的主要连编工具。

    qmake也注意了Qt的特殊需求,可以自动的包含moc和uic的连编规则。


    qmake概念

    qmake是用来为不同的平台的开发项目创建makefile的Trolltech开发一个易于使用的工具。qmake简化了makefile的生成,所以为了创建一个makefile只需要一个只有几行信息的文件。qmake可以供任何一个软件项目使用,而不用管它是不是用Qt写的,尽管它包含了为支持Qt开发所拥有的额外的特征。
    debug_and_release_target
    qmake基于一个项目文件这样的信息来生成makefile。项目文件可以由开发者生成。项目文件通常很简单,但是如果需要它是非常完善的。不用修改项目文件,qmake也可以为为Microsoft Visual Studio生成项目。

    QMAKESPEC环境变量

    举例来说,如果你在Windows下使用Microsoft Visual Studio,然后你需要把QMAKESPEC环境变量设置为win32-msvc。如果你在Solaris上使用gcc,你需要把QMAKESPEC环境变量设置为solaris-g++。
    在qt/mkspecs中的每一个目录里面,都有一个包含了平台和编译器特定信息的qmake.conf文件。这些设置适用于你要使用qmake的任何项目,请不要修改它,除非你是一个专家。例如,假如你所有的应用程序都必须和一个特定的库连接,你可以把这个信息添加到相应的qmake.conf文件中。
     
    项目(.pro)文件

    一个项目文件是用来告t诉qmake关于为这个应用程序创建makefile所需要的细节。例如,一个源文件和头文件的列表、任何应用程序特定配置、例如一个必需要连接的额外库、或者一个额外的包含路径,都应该放到项目文件中。

    “#”注释

    你可以为项目文件添加注释。注释由“#”符号开始,一直到这一行的结束。

    模板

    模板变量告诉qmake为这个应用程序生成哪种makefile。下面是可供使用的选择:

    app - 建立一个应用程序的makefile。这是默认值,所以如果模板没有被指定,这个将被使用。
    lib - 建立一个库的makefile。
    vcapp - 建立一个应用程序的Visual Studio项目文件。
    vclib - 建立一个库的Visual Studio项目文件。
    subdirs - 这是一个特殊的模板,它可以创建一个能够进入特定目录并且为一个项目文件生成makefile并且为它调用make的makefile。

    “app”模板

    “app”模板告诉qmake为建立一个应用程序生成一个makefile。当使用这个模板时,下面这些qmake系统变量是被承认的。你应该在你的.pro文件中使用它们来为你的应用程序指定特定信息。

    HEADERS - 应用程序中的所有头文件的列表。
    SOURCES - 应用程序中的所有源文件的列表。
    FORMS - 应用程序中的所有.ui文件(由Qt设计器生成)的列表。
    LEXSOURCES - 应用程序中的所有lex源文件的列表。
    YACCSOURCES - 应用程序中的所有yacc源文件的列表。
    TARGET - 可执行应用程序的名称。默认值为项目文件的名称。(如果需要扩展名,会被自动加上。)
    DESTDIR - 放置可执行程序目标的目录。
    DEFINES - 应用程序所需的额外的预处理程序定义的列表。
    INCLUDEPATH - 应用程序所需的额外的包含路径的列表。
    DEPENDPATH - 应用程序所依赖的搜索路径。
    VPATH - 寻找补充文件的搜索路径。
    DEF_FILE - 只有Windows需要:应用程序所要连接的.def文件。
    RC_FILE - 只有Windows需要:应用程序的资源文件。
    RES_FILE - 只有Windows需要:应用程序所要连接的资源文件。
    LIBS - 包含要链接到项目(project)的库列表文件/ 路径。用-l (library) 和 -L(library path)。

    你只需要使用那些你已经有值的系统变量,例如,如果你不需要任何额外的INCLUDEPATH,那么你就不需要指定它,qmake会为所需的提供默认值。例如,一个实例项目文件也许就像这样:

    TEMPLATE = app
    DESTDIR = c://helloapp
    HEADERS += hello.h
    SOURCES += hello.cpp 
    SOURCES += main.cpp
    DEFINES += QT_DLL
    CONFIG += qt warn_on release

    如果条目是单值的,比如template或者目的目录,我们是用“=”,但如果是多值条目,我们使用“+=”来为这个类型添加现有的条目。使用“=”会用新值替换原有的值,例如,如果我们写了DEFINES=QT_DLL,其它所有的定义都将被删除。

    “lib”模板

    “lib”模板告诉qmake为建立一个库而生成makefile。当使用这个模板时,除了“app”模板中提到系统变量,还有一个VERSION是被支持的。你需要在为库指定特定信息的.pro文件中使用它们。
    VERSION - 目标库的版本号,比如,2.3.1。

    “subdirs”模板

    “subdirs”模板告诉qmake生成一个makefile,它可以进入到特定子目录并为这个目录中的项目文件生成makefile并且为它调用make。

    在这个模板中只有一个系统变量SUBDIRS可以被识别。这个变量中包含了所要处理的含有项目文件的子目录的列表。这个项目文件的名称是和子目录同名的,这样qmake就可以发现它。例如,如果子目里是“myapp”,那么在这个目录中的项目文件应该被叫做myapp.pro。

    CONFIG变量

    配置变量指定了编译器所要使用的选项和所需要被连接的库。配置变量中可以添加任何东西,但只有下面这些选项可以被qmake识别。

    下面这些选项控制着使用哪些编译器标志:

    release - 应用程序将以release模式连编。如果“debug”被指定,它将被忽略。
    debug - 应用程序将以debug模式连编。
    warn_on - 编译器会输出尽可能多的警告信息。如果“warn_off”被指定,它将被忽略。
    warn_off - 编译器会输出尽可能少的警告信息。
    debug_and_release : The project is built in both debug and release modes.
    debug_and_release_target: The project is built in both debug and release modes. TARGET is built into both the debug and release directories.
    build_all : If debug_and_release is specified, the project is built in both debug and release modes by default.

    下面这些选项定义了所要连编的库/应用程序的类型:

    qt - 应用程序是一个Qt应用程序,并且Qt库将会被连接。
    thread - 应用程序是一个多线程应用程序。
    x11 - 应用程序是一个X11应用程序或库。
    windows - 只用于“app”模板:应用程序是一个Windows下的窗口应用程序。
    console - 只用于“app”模板:应用程序是一个Windows下的控制台应用程序。
    dll - 只用于“lib”模板:库是一个共享库(dll)。
    staticlib - 只用于“lib”模板:库是一个静态库。
    plugin - 只用于“lib”模板:库是一个插件,这将会使dll选项生效。

    例如,如果你的应用程序使用Qt库,并且你想把它连编为一个可调试的多线程的应用程序,你的项目文件应该会有下面这行:

    CONFIG += qt thread debug

    注意,你必须使用“+=”,不要使用“=”,否则qmake就不能正确使用连编Qt的设置了,比如没法获得所编译的Qt库的类型了。

    qmake的使用

    编程需要使用makefile,我想大家都应该知道吧。不过在Windows下很多朋友因为长期使用IDE已经不太了解它底层的编译过程了,建议大家稍微看一下有关这方面的资料。有关makefile的写法,建议大家到网上去查找有关资料。Linux相关的工具是autoconf/automake

    这里我们就介绍一下Trolltech提供的qmake。

    Qt中就自带了qmake,一般在$QTDIR/qmake下就是。当然编译好的二进制程序都放在$QTDIR/bin下了。

    有一个比较重要的环境变量QMAKESPEC,是用来表明操作系统和编译器的,一般我们用的都是linux-g++。

    下面就写个简单的例子:

    SOURCES = hello.cpp main.cpp
    HEADERS = hello.h
    CONFIG += qt warn_on release

    我们假设你的应用程序是有main.cpp、hello.h、hello.cpp三个文件构成。上述文件内容就是hello.pro文件的内容。这四个文件在同一目录下。

    生成makefile:

    qmake -o Makefile hello.pro

    这样就会生成这个项目的Makefile了。

    qmake还可以为visual studio生成dsp文件:

    qmake -t vcapp -o hello.dsp hello.pro

    QT编译错误:
    执行qmake-arm时出现错误
    QMAKESPEC has not been set, so configuration cannot be deduced.
    Error processing project file: XXXXX.pro
    处理办法:
    这是因为QMAKESPEC变量没有设置好,在.bash_profile文件里加入一行:
    export QMAKESPEC=/home/satellite/qt-everywhere-opensource-src-4.7.3/mkspecs/linux-g++(即是linux-g++的路径)。
  • 相关阅读:
    【leetcode】Find Minimum in Rotated Sorted Array JAVA实现
    去哪儿2015笔试题JAVA实现
    实现前端table中checkbox全选功能,并将选中的数据发送到后端
    跨站请求伪造CSRF
    XSS危害——session劫持
    跨站脚本攻击XSS
    python异常中的else作用
    Markdown文本编辑
    Gson的简单使用
    【spring in action 学习--springMVC搭建】在不使用web.xml的情况下,配置Srping MVC工程
  • 原文地址:https://www.cnblogs.com/senior-engineer/p/8478877.html
Copyright © 2011-2022 走看看