QT中PRO文件寫法的詳細介紹

在QT中,有一個工具qmake能夠生成一個makefile文件,它是由.pro文件生成而來的,.pro文件的寫法以下:程序員


1. 註釋
從「#」開始,到這一行結束。
windows

2.模板變量告訴qmake爲這個應用程序生成哪一種makefile。下面是可供使用的選擇:
TEMPLATE = app
A> app -創建一個應用程序的makefile。這是默認值,因此若是模板沒有被指定,這個將被使用。
B> lib - 創建一個庫的makefile。
C> vcapp - 創建一個應用程序的VisualStudio項目文件。
D> vclib - 創建一個庫的VisualStudio項目文件。
E> subdirs -這是一個特殊的模板,它能夠建立一個可以進入特定目錄而且爲一個項目文件生成makefile而且爲它調用make的makefile。
api


#指定生成的應用程序放置的目錄
DESTDIR += ../bin
安全

#指定生成的應用程序名
TARGET = pksystem
多線程

#配置信息
CONFIG用來告訴qmake關於應用程序的配置信息。
app

    CONFIG+= qt warn_on releaseide

在這裏使用「+=」,是由於咱們添加咱們的配置選項到任何一個已經存在中。這樣作比使用「=」那樣替換已經指定的全部選項是更安全的。
A> qt部分告訴qmake這個應用程序是使用Qt來連編的。這也就是說qmake在鏈接和爲編譯添加所需的包含路徑的時候會考慮到Qt庫的。
B> warn_on部分告訴qmake要把編譯器設置爲輸出警告信息的。
C> release部分告訴qmake應用程序必須被連編爲一個發佈的應用程序。在開發過程當中,程序員也可使用debug來替換release函數


#指定uic命令將.ui文件轉化成ui_*.h文件的存放的目錄
UI_DIR += forms
工具

#指定rcc命令將.qrc文件轉換成qrc_*.h文件的存放目錄
RCC_DIR += ../tmp
學習

#指定moc命令將含Q_OBJECT的頭文件轉換成標準.h文件的存放目錄
MOC_DIR += ../tmp

#指定目標文件(obj)的存放目錄
OBJECTS_DIR += ../tmp

#程序編譯時依賴的相關路徑
DEPENDPATH += . forms include qrc sources

#頭文件包含路徑
INCLUDEPATH += .

#qmake時產生的信息,【

a讀取變量a的字符串】,【

(PATH)讀取環境變量PATH】
#message($$(PATH))

#源文件編碼方式
CODECFORSRC = GBK

#工程中包含的頭文件
HEADERS += include/painter.h
#工程中包含的.ui設計文件
FORMS += forms/painter.ui
#工程中包含的源文件
SOURCES += sources/main.cpp sources/painter.cpp
#工程中包含的資源文件
RESOURCES += qrc/painter.qrc

LIBS += -L folderPath  //引入的lib文件的路徑  -L:引入路徑

Release:LIBS += -L folderPath // release 版引入的lib文件路徑

Debug:LIBS += -L folderPath // Debug 版引入的lib 文件路徑

DEFINES += XX_XX_XXX  //定義編譯選項,在.h文件中就可使用:#ifdefine xx_xx_xxx

RC_FILE = xxx.icns

7. 平臺相關性處理
咱們在這裏須要作的是根據qmake所運行的平臺來使用相應的做用域來進行處理。爲Windows平臺添加的依賴平臺的文件的簡單的做用域看起來就像這樣:

win32 {
SOURCES += hello_win.cpp
}
====================================================================================================================
當你已經建立好你的項目文件,生成Makefile就很容易了,你所要作的就是先到你所生成的項目文件那裏而後輸入:

Makefile能夠像這樣由「.pro」文件生成:

    qmake -oMakefile hello.pro

對於VisualStudio的用戶,qmake也能夠生成「.dsp」文件,例如:

    qmake -tvcapp -o hello.dsp hello.pro

++++++++++++++++++++++++一個PRO文件實例++++++++++++++++++++++++++++++++++++++++

TEMPLATE = app     #模塊配置
LANGUAGE = C++   #C++語言

CONFIG += qt warn_on debug release

#引入的lib文件,用於引入動態連接庫
LIBS += qaxcontainer.lib

#頭文件包含路徑
INCLUDEPATH += ..\..\qtcompnent\qtchklisten\inc ..\..\qtcompnent\qtclearfile\inc ../../validator\inc\validerrcode ../../qtcompnent/qtdir/inc ../inc ../../utillib/inc/xmlapi ../../utillib/inc/util ../../xercesc ../../qtcompnent/qteditor/inc ../../qtcompnent/qtfunreview/inc ../../qtcompnent/qttable/inc ../../qtcompnent/qtversion/inc ../../qtcompnent/qtini/inc ../../icdtool/icdservices/inc ../../icdtool/dataset/inc ../../icdtool/doi/inc ../../icdtool/reportcontrol/inc ../../icdtool/GSEconctrol/inc ../../icdtool/inputs/inc ../../icdtool/SMVconctrol/inc ../../icdtool/logcontrol/inc ../../scdpreview/inc/scdpreviewtoollib ../../scdpreview/form ../../icdtool/sclcontrol/inc ../../icdtool/log/inc ../../icdtool/settingcontrol/inc ../../qtcompnent\qteditor\inc ../../qtcompnent\qttreeview\inc ../../qtcompnent\qttabwidget\inc ../../communication/inc ../../qtcompnent/qtabout/inc ../iedmanage/inc ../ldmanage/inc ../foriecrun/inc ../../qtcompnent\validset\inc

#工程中包含的頭文件
HEADERS += ../inc/exportstable.h \
 ../inc/maintabwidget.h \
 ../inc/outputtab.h \
 ../inc/strutil.h \
 ../inc/treeeditview.h \
 ../inc/MainForm.h \
 ../inc/recenfileini.h \
 ../inc/ExportCIDFunction.h

#工程中包含的源文件
SOURCES += ../src/main.cpp \
 ../src/exportstable.cpp \
 ../src/maintabwidget.cpp \
 ../src/outputtab.cpp \
 ../src/treeeditview.cpp \
 ../src/MainForm.cpp \
 ../src/recenfileini.cpp \
 ../src/ExportCIDFunction.cpp

#工程中包含的.ui設計文件
FORMS = ../form/scdmainform.ui \
 ../form/exportiedform.ui \
 ../form/Exportsedform.ui \
 ../form/Importsedform.ui \
 ../form/formiminputs.ui

#圖像文件

IMAGES = images/substation.png \
 images/communication.png \
 images/autocom.png \
 images/reportcfg.png \
 images/comcfg.png \
 images/filetrans.png \
 images/review.png \
 images/setting.png

#工程中包含的資源文件
RESOURCES   = Scintilla.qrc

#CONFIG -= release
CONFIG -= debug


RC_FILE = scdtool.rc

 
BINLIB = ../../bin ../../xercesc/lib

UI_HEADERS_DIR = ../inc  # .ui文件轉會爲**.h   存放的目錄
UI_SOURCES_DIR = ../src  # .ui文件轉會爲**.cpp 存放的目錄
QMAKE_LIBDIR = $${BINLIB}

release {
TARGET = scdtool       #指定生成的應用程序名
OBJECTS_DIR = ../../obj/scdtool/release #指定目標文件(obj)的存放目錄
}
debug {
TARGET = scdtool_d     #指定生成的應用程序名
OBJECTS_DIR = ../../obj/scdtool/debug #指定目標文件(obj)的存放目錄
}

MOC_DIR = $${OBJECTS_DIR}
DESTDIR = ../../bin    #指定生成的應用程序放置的目錄

 ==============================================================================

1.簡介:
  qmake是Trolltech公司建立的用來爲不一樣的平臺和編譯器書寫Makefile的工具。是qt工具包的一部分.在Unixstdio.h>
  int main(int argc, char** argv)
  {
  printf("Hello, world!\n");
  return 0;
  }
  建立qmake須要的項目文件(hello.pro),
  SOURCES = hello.cpp
  CONFIG += qt warn_on release
  Makefile能夠像這樣由".pro"文件生成:
  qmake -o Makefile hello.pro
  如今你的目錄下已經產生了一個 Makefile 文件,輸入"make" 指令就能夠開始編譯 hello.c 成執行文件,執行 ./hello 和 world 打聲招呼吧!打開這個Makefile文件看看,是否是很專業啊!
  
  4.高級操做技巧
  固然,在實際使用過程當中,咱們的工程不可能象這個程序這樣簡單的,它可能有多個目錄,多個頭文件,多個源文件,須要連接器它不一樣的連接庫等等狀況。別急,讓我和你慢慢道來。這些都是很是容易用qmake來實現的。咱們從一個更加複雜的項目文件爲例和你詳細的講訴qmake的高級技巧:
  項目文件示例:
  SOURCES += myqt.cpp
  SOURCES += main.cpp
  HEADERS += myqt.h
  FORMS += xsimform.ui
  TEMPLATE = lib
  CONFIG += debug warn_on qt thread x11 plugin
  TARGET = ../bin/panel_qt
  INCLUDEPATH = ../../../../xsim ../../../../xsim/IMdkit
  DEFINES = BDB_VERSION4 OS_LINUX
  從這個文件能夠知道,SOURCES變量指向項目中的源文件,當項目中有多個源文件時,咱們需對項目中的每個源文件都這樣作,直到結束:

 


  SOURCES += hello.cpp
  SOURCES += main.cpp
  固然,若是你喜歡使用像Make同樣風格的語法,你也能夠寫成這樣,一行寫一個源文件,並用反斜線結尾,而後再起新的一行:
  SOURCES = hello.cpp main.cpp
  HEADERS變量指向項目中的頭文件,多個頭文件的時候,和多個源文件的解決方法一致。
  FORMS變量指向項目中使用到的窗體文件(qtdesign設計的.ui文件),qmake也注意了Qt的特殊需求,能夠自動的包含moc和uic的連編規則。沒有的話或者非qt程序能夠不寫。
  TEMPLATE變量告訴qmake爲這個應用程序生成哪一種makefile。下面是可供使用的選擇:
  app - 創建一個應用程序的makefile。這是默認值,因此若是模板沒有被指定,這個將被使用。
  lib - 創建一個連接庫的makefile。
  vcapp - 創建一個應用程序的Visual Studio項目文件。
  vclib - 創建一個庫的Visual Studio項目文件。
  subdirs - 這是一個特殊的模板,它能夠建立一個可以進入特定目錄而且爲一個項目文件生成makefile而且爲它調用make的mkefile。
  CONFIG變量變量指定了編譯器所要使用的選項和所須要被鏈接的庫。配置變量中能夠添加任何東西,但只有下面這些選項能夠被qmake識別。

 


  下面這些選項控制着使用哪些編譯器標誌:
  release - 應用程序將以release模式連編。若是"debug"被指定,它將被忽略。
  debug - 應用程序將以debug模式連編。
  warn_on - 編譯器會輸出儘量多的警告信息。若是"warn_off"被指定,它將被忽略。
  warn_off - 編譯器會輸出儘量少的警告信息。
  下面這些選項定義了所要連編的庫/應用程序的類型:
  qt - 應用程序是一個Qt應用程序,而且Qt庫將會被鏈接。
  thread - 應用程序是一個多線程應用程序。
  x11 - 應用程序是一個X11應用程序或庫。
  windows - 只用於"app"模板:應用程序是一個Windows下的窗口應用程序。
  console - 只用於"app"模板:應用程序是一個Windows下的控制檯應用程序。
  dll - 只用於"lib"模板:庫是一個共享庫(dll)。
  staticlib - 只用於"lib"模板:庫是一個靜態庫。
  plugin - 只用於"lib"模板:庫是一個插件,這將會使dll選項生效。
  TARGET變量指定生成的二進制代碼的路徑和文件名,若是創建的是一個連接庫的話,它會在文件名前面自動加上"lib"和在最後自動加上".so".
  咱們在使用過程當中可能會使用到另外的一些函數庫,連接庫等。函數庫的頭文件指定使用INCLUDEPATH變量,其它連接庫的指定能夠經過LIBS 變量來指定,例LIBS += -lmath -L/usr/local/lib
  DEFINES變量的指定就如同make的-D選項同樣。
  
  結束語  Autoconf 和 Automake 功能十分強大,但對於普通用戶來講,太過複雜。qmake方便、簡單、快捷,是一個輕量級的makefile生成工具,雖然它是qt工具包的一部分,但它也徹底能夠用來進行其它程序makefile文件的生成,對於大多數人來講,它已是很是的夠用了。你也能夠從qt提供的許多現存的源程序中找到相關的.pro項目文件,它們是學習qmake 更多技巧的最佳範例。

相關文章
相關標籤/搜索