0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

一個開源MCU級的命令行交互組件

jf_pJlTbmA9 ? 來源:維護:Nrusher ? 作者:維護:Nrusher ? 2023-10-17 16:26 ? 次閱讀

1、nr_micro_shell介紹

在進行調試和維護時,常常需要與單片機進行交互,獲取、設置某些參數(shù)或執(zhí)行某些操作,nr_micro_shell正是為滿足這一需求,針對資源較少的MCU編寫的基本命令行工具。雖然RT_Thread組件中已經(jīng)提供了強大的finsh命令行交互工具,但對于ROM、RAM資源較少的單片機,finsh還是略顯的龐大,在這些平臺上,若仍想保留基本的命令行交互功能,nr_micro_shell是一個不錯的選擇。

nr_micro_shell具有以下優(yōu)點

1.占用資源少,使用簡單,靈活方便。使用過程只涉及兩個shell_init()和shell()兩個函數(shù),無論是使用RTOS還是裸機都可以方便的應用該工具,不需要額外的編碼工作。

2.交互體驗好。完全類似于linux shell命令行,當串口終端支持ANSI(如Hypertrm終端)時,其不僅支持基本的命令行交互,還提供Tab鍵命令補全,查詢歷史命令,方向鍵移動光標修改功能。

3.擴展性好。nr_micro_shell為用戶提供自定義命令的標準函數(shù)原型,只需要按照命令編寫命令函數(shù),并注冊命令函數(shù),即可使用命令。

nr_micro_shell和相同配置下的finsh (finsh不使用msh)占用資源對比

wKgZomUD6LyACC8CAAA_iWGFbWE152.png

兩者配置都為

最多3條歷史命令。

支持Tab補全 。

命令行最大長度為100。

最多10個命令參數(shù)。

命令行線程堆棧為512字節(jié)。

nr_micro_shell演示效果如下

wKgaomUD6L6AH7MJAAj12eu6YWo543.gif
wKgaomUD6MCAf9uYAAYQ5gkcWX4476.gif

1.1 目錄結構

wKgZomUD6MGALN-oAABnkJblsnk087.png

1.2 許可證

nr_micro_shell package 遵循 MIT 許可,詳見 LICENSE 文件。

1.3 依賴

無依賴

2、Rt_Thread下ENV工具使用nr_micro_shell

RT_Thread 使用 nr_micro_shell package package 需要在 RT-Thread 的包管理器中選擇它,具體路徑如下:

RT-Thread online packages
    tools packages ---> 
        [*] nr_micro_shell:Lightweight command line interaction tool. --->

相關的設置在按下sapce鍵選中后,按enter可進行相關參數(shù)配置。然后讓 RT-Thread 的包管理器自動更新,或者使用 pkgs --update 命令更新包到 BSP 中。

若您需要運行示例,請保證RT_Thread配置中的Using console for kt_printf.選項是被打開的,kt_printf可以正常工作,且Use components automatically initialization.選項打開。編譯直接下載仿真便可以使用nr_micro_shell。命令行空白時按Tab,可顯示所有支持的命令,測試示例命令可見doc/pic下的使用示例動圖。自定義命令過程,參照下文3. 裸機下使用nr_micro_shell package中的方法。

3、裸機下使用nr_micro_shell package

3.1 配置:

所有配置工作都可以在 nr_micro_shell_config.h 中完成。有關詳細信息,請參見文件中的注釋。

3.2 用法:

確保所有文件都已添加到項目中。

確保nr_micro_shell_config.h中的宏函數(shù)"shell_printf(),ansi_show_char()"可以在項目中正常使用。

使用示例如下

#include "nr_micro_shell.h"

int main(void)
{
    /* 初始化 */
    shell_init();

    while(1)
    {
        if(USART GET A CHAR 'c')
        {
            /* nr_micro_shell接收字符 */
            shell(c);
        }
    }
}

建議直接使用硬件輸入前,建議使用如下代碼(確??梢哉4蛴⌒畔?,驗證nr_micro_shell是否可以正常運行

#include "nr_micro_shell.h"

int main(void)
{
    unsigned int i = 0;
    //匹配好結束符配置 NR_SHELL_END_OF_LINE 0
    char test_line[] = "test 1 2 3n"
    /* 初始化 */
    shell_init();
    
    /* 初步測試代碼 */
    for(i = 0; i < sizeof(test_line)-1; i++)
    {
        shell(test_line[i]);
    }

    /* 正式工作代碼 */
    while(1)
    {
        if(USART GET A CHAR 'c')
        {
            /* nr_micro_shell接收字符 */
            shell(c);
        }
    }
}

3.3 添加自己的命令

STEP1:

您需要在nr_micro_shell_commands.c*中實現(xiàn)一個命令函數(shù)。命令函數(shù)的原型如下

void your_command_funtion(char argc, char *argv)
{
    .....
}

argc是參數(shù)的數(shù)目。argv存儲每個參數(shù)的起始地址和內(nèi)容。如果輸入字符串是

test -a 1

則argc為3,argv的內(nèi)容為

-------------------------------------------------------------
0x03|0x08|0x0b|'t'|'e'|'s'|'t'|''|'-'|'a'|''|'1'|''|
-------------------------------------------------------------

如果想知道第一個或第二個參數(shù)的內(nèi)容,應該使用

/* "-a" */
printf(argv[argv[1]])
/* "1" */
printf(argv[argv[2]])

STEP2: 在使用命令前需要注冊命令,共有兩種方法注冊命令

1.當配置文件中NR_SHELL_USING_EXPORT_CMD未被定義,在 static_cmd[] 表中寫入

const static_cmd_st static_cmd[] =
{
   .....
   {"your_command_name",your_command_funtion},
   .....
   {"",NULL}
};

注意:不要刪除{"",NULL}!

2.當配置文件中NR_SHELL_USING_EXPORT_CMD被定義,且NR_SHELL_CMD_EXPORT()支持使用的編譯器時,可以使用以下方式注冊命令

NR_SHELL_CMD_EXPORT(your_command_name,your_command_funtion);

4、Linux下使用nr_micro_shell仿真

在工程./examples/simulator/目錄下存放著nr_micro_shell仿真代碼,仍在./examples/nr_micro_shell_commands.c文件中按上述方式添加自定義命令,添加完成后可以使用make命令編譯源碼,生產(chǎn)的可執(zhí)行文件為./examples/simulator/out/nr_micro_shell或./examples/simulator/out/nr_micro_shell_db??墒褂玫膍ake命令如下

# 編譯可執(zhí)行文件
make
# 編譯可仿真執(zhí)行文件
make debug
# 清除編譯生成文件
make clean

5、注意事項

根據(jù)你的使用習慣使用NR_SHELL_USING_EXPORT_CMD選擇命令注冊方式。

使用注冊表注冊命令時,確保您的工程中存在注冊表

const static_cmd_st static_cmd[] =
{
   .....
   {"",NULL}
};

使用NR_SHELL_CMD_EXPORT()時確保,NR_SHELL_CMD_EXPORT()支持使用的編譯器,否則會報錯。

nr_micro_shell 不支持ESC鍵等控制鍵(控制符)。

直接來源:最后一個bug
原文來源:維護:Nrusher
免責聲明:本文為轉載文章,轉載此文目的在于傳遞更多信息,版權歸原作者所有。本文所用視頻、圖片、文字如涉及作品版權問題,請聯(lián)系小編進行處理

審核編輯 黃宇

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權轉載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • mcu
    mcu
    +關注

    關注

    146

    文章

    16793

    瀏覽量

    349319
  • 開源
    +關注

    關注

    3

    文章

    3181

    瀏覽量

    42235
收藏 人收藏

    評論

    相關推薦

    HarmonyOS開發(fā):【基于命令行(安裝庫和工具集)】

    使用命令行進行設備開發(fā)時,可以通過以下步驟安裝編譯OpenHarmony需要的庫和工具。
    的頭像 發(fā)表于 04-25 21:03 ?323次閱讀
    HarmonyOS開發(fā):【基于<b class='flag-5'>命令行</b>(安裝庫和工具集)】

    香港vps的centos如何切換命令行和桌面?

    要在CentOS上切換命令行和桌面環(huán)境,您可以通過以下步驟進行: 1、安裝桌面環(huán)境:如果您的CentOS VPS上還沒有安裝圖形桌面環(huán)境,您需要安裝。般來說,常用的桌面環(huán)境有GN
    的頭像 發(fā)表于 04-10 17:41 ?512次閱讀

    idea如何輸入命令行參數(shù)

    。 在大多數(shù)編程語言中,都提供了內(nèi)置的機制來處理命令行參數(shù),以便程序可以根據(jù)用戶的需求進行不同的操作。下面我們將逐步介紹如何在常見的編程語言中輸入命令行參數(shù)。 、C/C++語言: 在C/C++中,主函數(shù)(main)的原型為:
    的頭像 發(fā)表于 12-06 15:01 ?933次閱讀

    eclipse怎么使用命令行

    。JDK是運行Java程序所必需的環(huán)境,而Eclipse則是基于Java開發(fā)的IDE。在確保安裝完畢后,我們可以通過以下步驟來在命令行
    的頭像 發(fā)表于 12-06 11:26 ?2197次閱讀

    Uboot啟動延時和讀取命令行輸入

    就會中斷等待,進入命令行輸入模式。 如果沒有配置啟動延時功能或者啟動延時超過了設置的時間, U-Boot 運行啟動命令行參數(shù),啟動命令參數(shù)在頂層配置文件中,由 CONFIG_BOOTCOMMAND 宏定義。 2.讀取
    的頭像 發(fā)表于 12-04 17:16 ?1316次閱讀

    如何在命令行中配置DDS

    DDS這么好,那該如何配置和使用呢?我們先帶大家入門。 案例:在命令行中配置DDS 我們先來試試在命令行中配置DDS的參數(shù)。 啟動第
    的頭像 發(fā)表于 11-24 18:03 ?820次閱讀
    如何在<b class='flag-5'>命令行</b>中配置DDS

    pycharm命令行終端運行代碼

    Python是種非常流行的編程語言,許多開發(fā)者使用它來編寫各種應用程序和腳本。為了方便開發(fā)者編寫和測試代碼,PyCharm是種集成開發(fā)環(huán)境(IDE),它提供了許多功能和工具,其中包括命令行終端
    的頭像 發(fā)表于 11-22 11:20 ?3866次閱讀

    總結linux命令行的主要用法

    Linux命令行種在Linux操作系統(tǒng)中通過文本界面來執(zhí)行指令和管理系統(tǒng)的方式。它提供了豐富的功能和靈活性,幫助用戶完成各種任務。本文將詳細介紹Linux命令行的主要用法,包括常見命令
    的頭像 發(fā)表于 11-17 10:19 ?576次閱讀

    linux命令行運行步驟

    現(xiàn)光標右邊出現(xiàn)了類似于“ ”或“#”的字符,這就是命令行提示符。在大多數(shù)Linux發(fā)行版中,普通用戶的提示符是“ ”,而管理員或root用戶的提示符是“#”。 查找可用的命令 Li
    的頭像 發(fā)表于 11-17 10:18 ?695次閱讀

    linux虛擬機命令行界面如何操作

    Linux虛擬機是種運行在虛擬化環(huán)境下的操作系統(tǒng),與物理機器相似,它也有命令行界面,也稱為終端或控制臺。通過命令行界面,您可以使用
    的頭像 發(fā)表于 11-17 09:57 ?1564次閱讀

    linux虛擬機怎么調出命令行

    命令行的方式可以因不同的虛擬機軟件而異,下面將介紹幾種常用的虛擬機軟件以及它們調出命令行的方法。 VMware虛擬機 VMware是功能強大的虛擬機軟件,它具有廣泛的應用領域和用戶
    的頭像 發(fā)表于 11-17 09:55 ?3437次閱讀

    linux切換到命令行模式

    在Linux中,可以通過以下步驟切換到命令行模式: 打開終端??梢栽趹貌藛沃姓业浇K端或命令行終端。 在終端中輸入命令“exit”或“l(fā)ogout”,然后按回車鍵。 系統(tǒng)會提示您輸入管理員密碼。輸入
    的頭像 發(fā)表于 11-13 16:47 ?1602次閱讀

    linux虛擬機怎么調出命令行

    在Linux虛擬機中調出命令行界面,可以通過以下步驟實現(xiàn): 打開虛擬機,進入到Linux系統(tǒng)。 在桌面或應用菜單中找到終端或命令行圖標,點擊打開。 輸入命令行指令,執(zhí)行相應的操作。 另外,也可以通過
    的頭像 發(fā)表于 11-08 11:28 ?2781次閱讀

    linux命令行與shell編程實戰(zhàn)

    Linux命令行與Shell編程實戰(zhàn)主要涉及以下內(nèi)容: Linux命令行基礎:學習Linux命令行的基本操作,如文件管理、進程管理、網(wǎng)絡配置等。熟悉使用命令行能夠提高工作效率,提升自己
    的頭像 發(fā)表于 11-08 10:57 ?676次閱讀

    單片機上如何做shell命令行交互

    做個shell命令行交互?答案當然是可以的,在網(wǎng)上類似的文章和代碼籮筐, 基本原理: 監(jiān)測用戶的輸入,然后到
    的頭像 發(fā)表于 11-01 15:16 ?1180次閱讀