你們好,我是痞子衡,是正經搞技術的痞子。今天痞子衡給你們介紹的是MCUXpresso IDE下添加新路徑下源文件進工程編譯的方法。html
接着上篇文章 《MCUXpresso IDE下SDK工程導入與workspace管理機制》 接着聊,痞子衡說過不建議從零開始建立新工程項目,最好就是導入一個SDK裏的現成項目(儘可能跟你最終需求相近,主要是須要的SDK基礎驅動都要包含),而後在這個項目基礎上修改爲本身想要的最終工程。微信
若是你是一個習慣於IAR或者MDK這種非Eclipse式集成開發環境的用戶,你可能會對MCUXpresso IDE下管理工程(主要是在工程裏增長源文件)的方式感到不適應。本文痞子衡將爲你指明MCUXpresso IDE下增長源文件讓你不適應的地方。函數
上篇文章 《MCUXpresso IDE下SDK工程導入與workspace管理機制》 裏咱們導入了RT500的一個hello world項目進workspace空間,讓咱們將這個項目拷貝到以下自定義的路徑,而後在MCUXpresso IDE下使用 Import project(s) from file system 方式而且不勾選 Copy projects into workspace 選項去打開自定義路徑下的hello world工程。測試
爲簡單起見,咱們再建立三組源文件:sw_delay1.c/h、sw_delay2.c/.h、sw_delay3.c/.h,咱們會用這三組源文件來測試三種不一樣路徑類型下添加源文件進工程的狀況。ui
////////////////sw_delayx.c//////////////// #include "sw_delayx.h" void sw_delayx(uint32_t n) { while (n != 0U) { n--; } } ////////////////sw_delayx.h//////////////// #include <stdint.h> #if defined(__cplusplus) extern "C" { #endif void sw_delayx(uint32_t n); #if defined(__cplusplus) } #endif
第一種測試狀況最簡單,咱們直接把sw_delay1.c/h文件放到\mcux_test\evkmimxrt595_hello_world\source\路徑下,跟主函數源文件hello_world.c放在一塊兒。當咱們將新源文件放到已有路徑下時,在MCUXpresso IDE工程裏新文件就馬上顯示在了界面左上角的workspace裏(能夠理解爲直接被添加進工程了),根本不用你手動添加(這是跟IAR/MDK相比第一個不一樣的地方,也是你可能不適應的地方),這時候咱們能夠在主函數文件裏直接引用和調用sw_delay1.c/h裏的內容,不須要再額外作任何工程設置。spa
自動刷新工程路徑下源文件進工程是Eclipse型IDE的特點,這個特點其實挺好,只有一種狀況下不太方便,那就是多個不一樣源文件中均有相同函數定義(多是測試目的,或者刻意保留不一樣版本函數實現),這種狀況下在工程編譯時會報錯,須要在IDE裏主動右擊你不想添加進工程的源文件,在Properties框裏勾選上 Exclude resource from build。.net
如今咱們換一種狀況,仍是在當前工程路徑\mcux_test\evkmimxrt595_hello_world下,可是新建一個名爲sw_delay2的文件夾,而且將sw_delay2.c/h文件放到\mcux_test\evkmimxrt595_hello_world\sw_delay2\路徑下。由於有了新路徑,此時還須要在工程Properties選項的MCU C Compiler / Includes裏(最好在MCU Assembler / General 裏也一樣設置)將該新路徑添加進去。3d
此時新文件夾sw_delay2及其中源文件好像一樣被自動更新到了工程workspace中,咱們試試在主函數源文件中調用sw_delay2(),並編譯工程。很遺憾,工程編譯報錯,提示undefined reference to `sw_delay2',就是找不到sw_delay2()函數,這是爲何?code
這裏要介紹第二個讓你不適應的地方,那就是工程文件所在路徑下的新建文件夾看起來被自動更新顯示到工程workspace中了,但其實其中源文件並無真正被添加進工程,還須要你手動作一次路徑添加,在工程Properties選項的C/C++ General的Paths and Symbols下作以下操做。作完以後,你能夠在workspace裏看到此時sw_delay2文件夾被提到了Debug上面顯示(在SDK工程裏,Debug和doc文件夾通常顯示在最下面,這兩個並無被真正添加進工程源文件路徑,凡是顯示在它們後面的文件夾都是沒有被真正加入工程的),如今工程能夠正常編譯了。htm
最後介紹一種最複雜的狀況,此次不在工程路徑\mcux_test\evkmimxrt595_hello_world下作文章,咱們在\mcux_test\路徑下新建一個名爲sw_delay3的文件夾,而且將sw_delay3.c/h文件放到\mcux_test\sw_delay3\路徑下。由於這個新路徑跟工程路徑不相關,所以工程workspace沒有自動顯示它,此時固然須要咱們手動來添加這個文件夾進工程。右擊工程選擇 New / Folder,使用Folder選項裏Advanced下面的 Link to alternate location 功能將sw_delay3文件夾及其源文件添加進工程。
此時工程workspace中已經顯示了sw_delay3文件夾,可是顯示在最下面(Debug和doc以後),這時候咱們能夠當sw_delay3文件夾剛剛被放到\mcux_test\evkmimxrt595_hello_world\下面同樣,按3.1節裏的方法走一遍,MCU C Compiler / Includes和C/C++ General - Paths and Symbols下都分別再設置一下。
這裏有第三個讓你不適應的地方,非工程文件所在路徑下的源文件夾在被強制鏈到工程裏時,其Include路徑直接轉變成了當前工程路徑/${ProjName}/下,並不須要像IAR/MDK那樣使用 ../ 去回退尋找具體的相對路徑。
至此,MCUXpresso IDE下添加新路徑下源文件進工程編譯的方法痞子衡便介紹完畢了,掌聲在哪裏~~~
文章會同時發佈到個人 博客園主頁、CSDN主頁、知乎主頁、微信公衆號 平臺上。
微信搜索"痞子衡嵌入式"或者掃描下面二維碼,就能夠在手機上第一時間看了哦。