1 /*
2 * Copyright (c) 2013-2019 Huawei Technologies Co., Ltd. All rights reserved.
3 * Copyright (c) 2020-2021 Huawei Device Co., Ltd. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without modification,
6 * are permitted provided that the following conditions are met:
7 *
8 * 1. Redistributions of source code must retain the above copyright notice, this list of
9 * conditions and the following disclaimer.
10 *
11 * 2. Redistributions in binary form must reproduce the above copyright notice, this list
12 * of conditions and the following disclaimer in the documentation and/or other materials
13 * provided with the distribution.
14 *
15 * 3. Neither the name of the copyright holder nor the names of its contributors may be used
16 * to endorse or promote products derived from this software without specific prior written
17 * permission.
18 *
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
21 * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
22 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR
23 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
24 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
26 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
27 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
28 * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
29 * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30 */
31
32 #include "shcmd.h"
33
34 #define DEFAULT_SCREEN_WIDTH 80
35 #define MAX_CMD_KEY_WIDTH 12
36 #define CMD_ITEM_PER_LINE (DEFAULT_SCREEN_WIDTH / (MAX_CMD_KEY_WIDTH + 1))
37
OsShellCmdHelp(UINT32 argc,const CHAR ** argv)38 UINT32 OsShellCmdHelp(UINT32 argc, const CHAR **argv)
39 {
40 UINT32 loop = 0;
41 CmdItemNode *curCmdItem = NULL;
42 CmdModInfo *cmdInfo = OsCmdInfoGet();
43
44 (VOID)argv;
45 if (argc > 0) {
46 PRINTK("\nUsage: help\n");
47 return OS_ERROR;
48 }
49
50 PRINTK("*******************shell commands:*************************\n");
51 LOS_DL_LIST_FOR_EACH_ENTRY(curCmdItem, &(cmdInfo->cmdList.list), CmdItemNode, list) {
52 if ((loop % CMD_ITEM_PER_LINE) == 0) { /* just align print */
53 PRINTK("\n");
54 }
55 PRINTK("%-12s ", curCmdItem->cmd->cmdKey);
56
57 loop++;
58 }
59 PRINTK("\n\nAfter shell prompt \"OHOS # \":\n"
60 "Use `<cmd> [args ...]` to run built-in shell commands listed above.\n"
61 "Use `exec <cmd> [args ...]` or `./<cmd> [args ...]` to run external commands.\n");
62 return 0;
63 }
64
65 SHELLCMD_ENTRY(help_shellcmd, CMD_TYPE_EX, "help", 0, (CmdCallBackFunc)OsShellCmdHelp);