31908b3128
Currently NSH prompt is defined at build time, thus improper for AMP cases where the same NSH binary is used on different nodes as the same NSH prompt shows on all nodes. This patch attempts to support runtime prompt string population from ordered sources: - the environment variable defined by NSH_PROMPT_ENV plus suffix - the NSH_PROMPT_STRING - the HOSTNAME plus suffix The suffix is defined by NSH_PROMPT_SUFFIX so that to clearly separate the command inputs. Changes in `nshlib/` - Kconfig: add configs NSH_PROMPT_MAX/ENV/SUFFIX etc - nsh.h: adjust g_nshprompt defs, add nsh_update_prompt - nsh_parse.c relocate g_nshpromt to nsh_prompt.c - nsh_init.c revise to use nsh_update_prompt once - nsh_session.c revise to use methods in nsh_prompt.c - Makefile add nsh_prompt.c - CMakeLists.txt add nsh_prompt.c New additions in `nshlib/` - nsh_prompt.c prompt related data structures and methods. Signed-off-by: Yanfeng Liu <yfliu2008@qq.com>
1494 lines
47 KiB
C
1494 lines
47 KiB
C
/****************************************************************************
|
|
* apps/nshlib/nsh.h
|
|
*
|
|
* Licensed to the Apache Software Foundation (ASF) under one or more
|
|
* contributor license agreements. See the NOTICE file distributed with
|
|
* this work for additional information regarding copyright ownership. The
|
|
* ASF licenses this file to you under the Apache License, Version 2.0 (the
|
|
* "License"); you may not use this file except in compliance with the
|
|
* License. You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
|
|
* License for the specific language governing permissions and limitations
|
|
* under the License.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifndef __APPS_NSHLIB_NSH_H
|
|
#define __APPS_NSHLIB_NSH_H
|
|
|
|
/****************************************************************************
|
|
* Included Files
|
|
****************************************************************************/
|
|
|
|
#include <nuttx/config.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <stdint.h>
|
|
#include <stdbool.h>
|
|
#include <unistd.h>
|
|
#include <errno.h>
|
|
|
|
#ifdef CONFIG_NSH_STRERROR
|
|
# include <string.h>
|
|
#endif
|
|
|
|
#include <nuttx/usb/usbdev_trace.h>
|
|
|
|
/****************************************************************************
|
|
* Pre-processor Definitions
|
|
****************************************************************************/
|
|
|
|
/* Configuration ************************************************************/
|
|
|
|
/* The background commands require pthread support */
|
|
|
|
#ifdef CONFIG_DISABLE_PTHREAD
|
|
# ifndef CONFIG_NSH_DISABLEBG
|
|
# define CONFIG_NSH_DISABLEBG 1
|
|
# endif
|
|
#endif
|
|
|
|
/* rmdir, mkdir, rm, and mv are only available if mountpoints are enabled
|
|
* AND there is a writeable file system OR if these operations on the
|
|
* pseudo-filesystem are not disabled.
|
|
*/
|
|
|
|
#undef NSH_HAVE_DIROPTS
|
|
#if !defined(CONFIG_DISABLE_MOUNTPOINT) || !defined(CONFIG_DISABLE_PSEUDOFS_OPERATIONS)
|
|
# define NSH_HAVE_DIROPTS 1
|
|
#endif
|
|
|
|
/* If CONFIG_NSH_CMDPARMS is selected, then the path to a directory to
|
|
* hold temporary files must be provided.
|
|
*/
|
|
|
|
#if defined(CONFIG_NSH_CMDPARMS) && !defined(CONFIG_LIBC_TMPDIR)
|
|
# define CONFIG_LIBC_TMPDIR "/tmp"
|
|
#endif
|
|
|
|
/* Some networking commands do not make sense unless there is a network
|
|
* device. There might not be a network device if, for example, only Unix
|
|
* domain sockets were enable.
|
|
*/
|
|
|
|
/* Telnetd requires networking support */
|
|
|
|
#ifndef CONFIG_NET
|
|
# undef CONFIG_NSH_TELNET
|
|
#endif
|
|
|
|
/* get and put require TFTP client support */
|
|
|
|
#ifndef CONFIG_NETUTILS_TFTPC
|
|
# undef CONFIG_NSH_DISABLE_PUT
|
|
# undef CONFIG_NSH_DISABLE_GET
|
|
# define CONFIG_NSH_DISABLE_PUT 1
|
|
# define CONFIG_NSH_DISABLE_GET 1
|
|
#endif
|
|
|
|
/* Route depends on routing table support and procfs support */
|
|
|
|
#if !defined(CONFIG_FS_PROCFS) || defined(CONFIG_FS_PROCFS_EXCLUDE_NET) || \
|
|
defined(CONFIG_FS_PROCFS_EXCLUDE_ROUTE) || !defined(CONFIG_NET_ROUTE) || \
|
|
(!defined(CONFIG_NET_IPv4) && !defined(CONFIG_NET_IPv6))
|
|
# ifndef CONFIG_NSH_DISABLE_ROUTE
|
|
# define CONFIG_NSH_DISABLE_ROUTE 1
|
|
# endif
|
|
#endif
|
|
|
|
/* wget depends on web client support */
|
|
|
|
#ifndef CONFIG_NETUTILS_WEBCLIENT
|
|
# undef CONFIG_NSH_DISABLE_WGET
|
|
# define CONFIG_NSH_DISABLE_WGET 1
|
|
#endif
|
|
|
|
/* mksmartfs depends on smartfs and mksmartfs support */
|
|
|
|
#if !defined(CONFIG_FS_SMARTFS) || !defined(CONFIG_FSUTILS_MKSMARTFS)
|
|
# undef CONFIG_NSH_DISABLE_MKSMARTFS
|
|
# define CONFIG_NSH_DISABLE_MKSMARTFS 1
|
|
#endif
|
|
|
|
/* One front end must be defined */
|
|
|
|
#if !defined(CONFIG_NSH_CONSOLE) && !defined(CONFIG_NSH_TELNET)
|
|
# error "No NSH front end defined"
|
|
#endif
|
|
|
|
/* If a USB device is selected for the NSH console then we need to handle
|
|
* some special start-up conditions.
|
|
*/
|
|
|
|
#undef HAVE_USB_CONSOLE
|
|
#if defined(CONFIG_USBDEV)
|
|
|
|
/* Check for a PL2303 serial console. Use console device "/dev/console". */
|
|
|
|
# if defined(CONFIG_PL2303) && defined(CONFIG_PL2303_CONSOLE)
|
|
# define HAVE_USB_CONSOLE 1
|
|
|
|
/* Check for a CDC/ACM serial console. Use console device "/dev/console". */
|
|
|
|
# elif defined(CONFIG_CDCACM) && defined(CONFIG_CDCACM_CONSOLE)
|
|
# define HAVE_USB_CONSOLE 1
|
|
|
|
/* Check for a generic USB console. In this case, the USB console device
|
|
* must be provided in CONFIG_NSH_USBCONDEV.
|
|
*/
|
|
|
|
# elif defined(CONFIG_NSH_USBCONSOLE)
|
|
# define HAVE_USB_CONSOLE 1
|
|
# endif
|
|
#endif
|
|
|
|
/* Defaults for the USB console */
|
|
|
|
#ifdef HAVE_USB_CONSOLE
|
|
|
|
/* The default USB console device minor number is 0 */
|
|
|
|
# ifndef CONFIG_NSH_USBDEV_MINOR
|
|
# define CONFIG_NSH_USBDEV_MINOR 0
|
|
# endif
|
|
|
|
/* The default USB serial console device */
|
|
|
|
# ifndef CONFIG_NSH_USBCONDEV
|
|
# if defined(CONFIG_CDCACM)
|
|
# define CONFIG_NSH_USBCONDEV "/dev/ttyACM0"
|
|
# elif defined(CONFIG_PL2303)
|
|
# define CONFIG_NSH_USBCONDEV "/dev/ttyUSB0"
|
|
# else
|
|
# define CONFIG_NSH_USBCONDEV "/dev/console"
|
|
# endif
|
|
# endif
|
|
|
|
#endif /* HAVE_USB_CONSOLE */
|
|
|
|
/* If a USB keyboard device is selected for NSH input then we need to handle
|
|
* some special start-up conditions.
|
|
*/
|
|
|
|
#undef HAVE_USB_KEYBOARD
|
|
|
|
/* Check pre-requisites */
|
|
|
|
#if !defined(CONFIG_USBHOST) || !defined(CONFIG_USBHOST_HIDKBD) || \
|
|
defined(HAVE_USB_CONSOLE)
|
|
# undef CONFIG_NSH_USBKBD
|
|
#endif
|
|
|
|
/* Check default settings */
|
|
|
|
#if defined(CONFIG_NSH_USBKBD)
|
|
|
|
/* Check for a USB HID keyboard in the configuration */
|
|
|
|
# define HAVE_USB_KEYBOARD 1
|
|
|
|
/* The default keyboard device is /dev/kbda */
|
|
|
|
# ifndef NSH_USBKBD_DEVNAME
|
|
# define NSH_USBKBD_DEVNAME "/dev/kbda"
|
|
# endif
|
|
|
|
/* In this case NSH_ALTSTDIN should be "/dev/kbda" */
|
|
|
|
# undef CONFIG_NSH_ALTSTDIN
|
|
# define CONFIG_NSH_ALTSTDIN NSH_USBKBD_DEVNAME
|
|
|
|
#endif /* HAVE_USB_KEYBOARD */
|
|
|
|
/* USB trace settings */
|
|
|
|
#ifndef CONFIG_USBDEV_TRACE
|
|
# undef CONFIG_NSH_USBDEV_TRACE
|
|
#endif
|
|
|
|
#ifdef CONFIG_NSH_USBDEV_TRACE
|
|
# ifdef CONFIG_NSH_USBDEV_TRACEINIT
|
|
# define TRACE_INIT_BITS (TRACE_INIT_BIT)
|
|
# else
|
|
# define TRACE_INIT_BITS (0)
|
|
# endif
|
|
|
|
# define TRACE_ERROR_BITS (TRACE_DEVERROR_BIT|TRACE_CLSERROR_BIT)
|
|
|
|
# ifdef CONFIG_NSH_USBDEV_TRACECLASS
|
|
# define TRACE_CLASS_BITS (TRACE_CLASS_BIT|TRACE_CLASSAPI_BIT|\
|
|
TRACE_CLASSSTATE_BIT)
|
|
# else
|
|
# define TRACE_CLASS_BITS (0)
|
|
# endif
|
|
|
|
# ifdef CONFIG_NSH_USBDEV_TRACETRANSFERS
|
|
# define TRACE_TRANSFER_BITS (TRACE_OUTREQQUEUED_BIT|TRACE_INREQQUEUED_BIT|\
|
|
TRACE_READ_BIT|TRACE_WRITE_BIT|\
|
|
TRACE_COMPLETE_BIT)
|
|
# else
|
|
# define TRACE_TRANSFER_BITS (0)
|
|
# endif
|
|
|
|
# ifdef CONFIG_NSH_USBDEV_TRACECONTROLLER
|
|
# define TRACE_CONTROLLER_BITS (TRACE_EP_BIT|TRACE_DEV_BIT)
|
|
# else
|
|
# define TRACE_CONTROLLER_BITS (0)
|
|
# endif
|
|
|
|
# ifdef CONFIG_NSH_USBDEV_TRACEINTERRUPTS
|
|
# define TRACE_INTERRUPT_BITS (TRACE_INTENTRY_BIT|TRACE_INTDECODE_BIT|\
|
|
TRACE_INTEXIT_BIT)
|
|
# else
|
|
# define TRACE_INTERRUPT_BITS (0)
|
|
# endif
|
|
|
|
# define TRACE_BITSET (TRACE_INIT_BITS|TRACE_ERROR_BITS|\
|
|
TRACE_CLASS_BITS|TRACE_TRANSFER_BITS|\
|
|
TRACE_CONTROLLER_BITS|TRACE_INTERRUPT_BITS)
|
|
|
|
#endif /* CONFIG_NSH_USBDEV_TRACE */
|
|
|
|
/* If Telnet is selected for the NSH console, then we must configure
|
|
* the resources used by the Telnet daemon and by the Telnet clients.
|
|
*
|
|
* CONFIG_NSH_TELNET_LOGIN - Support a simple Telnet login.
|
|
*
|
|
* If CONFIG_NSH_TELNET_LOGIN is defined, then these additional
|
|
* options may be specified:
|
|
*
|
|
* CONFIG_NSH_LOGIN_USERNAME - Login user name. Default: "admin"
|
|
* CONFIG_NSH_LOGIN_PASSWORD - Login password: Default: "Administrator"
|
|
* CONFIG_NSH_LOGIN_FAILCOUNT - Number of login retry attempts.
|
|
* Default 3.
|
|
*/
|
|
|
|
#ifdef CONFIG_NSH_TELNET_LOGIN
|
|
|
|
# ifndef CONFIG_NSH_LOGIN_USERNAME
|
|
# define CONFIG_NSH_LOGIN_USERNAME "admin"
|
|
# endif
|
|
|
|
# ifndef CONFIG_NSH_LOGIN_PASSWORD
|
|
# define CONFIG_NSH_LOGIN_PASSWORD "nuttx"
|
|
# endif
|
|
|
|
# ifndef CONFIG_NSH_LOGIN_FAILCOUNT
|
|
# define CONFIG_NSH_LOGIN_FAILCOUNT 3
|
|
# endif
|
|
|
|
#endif /* CONFIG_NSH_TELNET_LOGIN */
|
|
|
|
/* Verify support for ROMFS /etc directory support options */
|
|
|
|
#ifdef CONFIG_ETC_ROMFS
|
|
|
|
# ifndef CONFIG_NSH_SYSINITSCRIPT
|
|
# define CONFIG_NSH_SYSINITSCRIPT "init.d/rc.sysinit"
|
|
# endif
|
|
|
|
# ifndef CONFIG_NSH_INITSCRIPT
|
|
# define CONFIG_NSH_INITSCRIPT "init.d/rcS"
|
|
# endif
|
|
|
|
# undef NSH_SYSINITPATH
|
|
# define NSH_SYSINITPATH CONFIG_ETC_ROMFSMOUNTPT "/" CONFIG_NSH_SYSINITSCRIPT
|
|
|
|
# undef NSH_INITPATH
|
|
# define NSH_INITPATH CONFIG_ETC_ROMFSMOUNTPT "/" CONFIG_NSH_INITSCRIPT
|
|
|
|
# ifdef CONFIG_NSH_ROMFSRC
|
|
# ifndef CONFIG_NSH_RCSCRIPT
|
|
# define CONFIG_NSH_RCSCRIPT ".nshrc"
|
|
# endif
|
|
|
|
# undef NSH_RCPATH
|
|
# define NSH_RCPATH CONFIG_ETC_ROMFSMOUNTPT "/" CONFIG_NSH_RCSCRIPT
|
|
# endif
|
|
|
|
#else
|
|
|
|
# undef CONFIG_NSH_ROMFSRC
|
|
# undef CONFIG_NSH_INITSCRIPT
|
|
# undef CONFIG_NSH_RCSCRIPT
|
|
|
|
#endif
|
|
|
|
/* This is the maximum number of arguments that will be accepted for a
|
|
* command. Here we attempt to select the smallest number possible depending
|
|
* upon the of commands that are available. Most commands use seven or fewer
|
|
* arguments, but there are a few that require more.
|
|
*
|
|
* This value is also configurable with CONFIG_NSH_MAXARGUMENTS. This
|
|
* configurability is necessary since there may also be external, "built-in"
|
|
* commands that require more commands than NSH is aware of.
|
|
*/
|
|
|
|
#if CONFIG_NSH_MAXARGUMENTS < 11
|
|
# if defined(CONFIG_NET) && !defined(CONFIG_NSH_DISABLE_IFCONFIG)
|
|
# undef CONFIG_NSH_MAXARGUMENTS
|
|
# define CONFIG_NSH_MAXARGUMENTS 11
|
|
# endif
|
|
#endif
|
|
|
|
/* Argument list size
|
|
*
|
|
* argv[0]: The command name.
|
|
* argv[1]: The beginning of argument (up to CONFIG_NSH_MAXARGUMENTS)
|
|
* argv[argc-3]: Possibly '>' or '>>'
|
|
* argv[argc-2]: Possibly <file>
|
|
* argv[argc-1]: Possibly '&' (if pthreads are enabled)
|
|
* argv[argc]: NULL terminating pointer
|
|
*
|
|
* Maximum size is CONFIG_NSH_MAXARGUMENTS+5
|
|
*/
|
|
|
|
#ifndef CONFIG_NSH_DISABLEBG
|
|
# define MAX_ARGV_ENTRIES (CONFIG_NSH_MAXARGUMENTS+5)
|
|
#else
|
|
# define MAX_ARGV_ENTRIES (CONFIG_NSH_MAXARGUMENTS+4)
|
|
#endif
|
|
|
|
/* strerror() produces much nicer output but is, however, quite large and
|
|
* will only be used if CONFIG_NSH_STRERROR is defined. Note that the
|
|
* strerror interface must also have been enabled with CONFIG_LIBC_STRERROR.
|
|
*/
|
|
|
|
#ifndef CONFIG_LIBC_STRERROR
|
|
# undef CONFIG_NSH_STRERROR
|
|
#endif
|
|
|
|
#ifdef CONFIG_NSH_STRERROR
|
|
# define NSH_ERRNO strerror(errno)
|
|
# define NSH_ERRNO_OF(err) strerror(err)
|
|
# define NSH_HERRNO gai_strerror(h_errno)
|
|
# define NSH_HERRNO_OF(err) gai_strerror(err)
|
|
#else
|
|
# define NSH_ERRNO (errno)
|
|
# define NSH_ERRNO_OF(err) (err)
|
|
# define NSH_HERRNO (h_errno)
|
|
# define NSH_HERRNO_OF(err) (err)
|
|
#endif
|
|
|
|
/* Maximum size of one command line (telnet or serial) */
|
|
|
|
#ifndef CONFIG_NSH_LINELEN
|
|
# define CONFIG_NSH_LINELEN 80
|
|
#endif
|
|
|
|
/* The maximum number of nested if-then[-else]-fi sequences that
|
|
* are permissible.
|
|
*/
|
|
|
|
#ifndef CONFIG_NSH_NESTDEPTH
|
|
# define CONFIG_NSH_NESTDEPTH 3
|
|
#endif
|
|
|
|
/* Define to enable dumping of all input/output buffers */
|
|
|
|
#undef CONFIG_NSH_TELNETD_DUMPBUFFER
|
|
|
|
/* Make sure that the home directory is defined */
|
|
|
|
#ifndef CONFIG_LIBC_HOMEDIR
|
|
# define CONFIG_LIBC_HOMEDIR "/"
|
|
#endif
|
|
|
|
#undef NSH_HAVE_VARS
|
|
#if defined(CONFIG_NSH_VARS) || !defined(CONFIG_DISABLE_ENVIRON)
|
|
# define NSH_HAVE_VARS
|
|
#endif
|
|
|
|
/* Stubs used when working directory is not supported */
|
|
|
|
#ifdef CONFIG_DISABLE_ENVIRON
|
|
# define nsh_getfullpath(v,p) ((FAR char*)(p))
|
|
# define nsh_freefullpath(p)
|
|
#endif
|
|
|
|
/* The size of the I/O buffer may be specified in the
|
|
* boards/<arch>/<chip>/<board>/configs/<config>defconfig file -- provided
|
|
* that it is at least as large as PATH_MAX.
|
|
*/
|
|
|
|
#define NSH_HAVE_IOBUFFER 1
|
|
|
|
/* The I/O buffer is needed for the ls, cp, and ps commands. It is also
|
|
* needed if the platform supplied MOTD is configured.
|
|
*/
|
|
|
|
#if defined(CONFIG_NSH_DISABLE_LS) && defined(CONFIG_NSH_DISABLE_CP) && \
|
|
defined(CONFIG_NSH_DISABLE_PS) && !defined(CONFIG_NSH_PLATFORM_MOTD) && \
|
|
defined(CONFIG_DISABLE_ENVIRON)
|
|
# undef NSH_HAVE_IOBUFFER
|
|
#endif
|
|
|
|
#ifdef NSH_HAVE_IOBUFFER
|
|
# ifdef CONFIG_NSH_FILEIOSIZE
|
|
# if CONFIG_NSH_FILEIOSIZE > (PATH_MAX + 1)
|
|
# define IOBUFFERSIZE CONFIG_NSH_FILEIOSIZE
|
|
# else
|
|
# define IOBUFFERSIZE (PATH_MAX + 1)
|
|
# endif
|
|
# else
|
|
# define IOBUFFERSIZE 1024
|
|
# endif
|
|
#else
|
|
# define IOBUFFERSIZE (PATH_MAX + 1)
|
|
#endif
|
|
|
|
/* Certain commands/features are only available if the procfs file system is
|
|
* enabled.
|
|
*/
|
|
|
|
#if !defined(CONFIG_FS_PROCFS) || defined(CONFIG_FS_PROCFS_EXCLUDE_NET)
|
|
# undef CONFIG_NSH_DISABLE_IFCONFIG /* 'ifconfig' depends on network procfs */
|
|
# define CONFIG_NSH_DISABLE_IFCONFIG 1
|
|
|
|
# undef CONFIG_NSH_DISABLE_IFUPDOWN /* 'ifup/down' depend on network procfs */
|
|
# define CONFIG_NSH_DISABLE_IFUPDOWN 1
|
|
#endif
|
|
|
|
#if !defined(CONFIG_FS_PROCFS) || defined(CONFIG_FS_PROCFS_EXCLUDE_PROCESS)
|
|
# undef CONFIG_NSH_DISABLE_PS /* 'ps' depends on process procfs */
|
|
# define CONFIG_NSH_DISABLE_PS 1
|
|
#endif
|
|
|
|
#define NSH_HAVE_CPULOAD 1
|
|
#if !defined(CONFIG_FS_PROCFS) || defined(CONFIG_FS_PROCFS_EXCLUDE_CPULOAD) || \
|
|
defined(CONFIG_SCHED_CPULOAD_NONE) || defined(CONFIG_NSH_DISABLE_PS)
|
|
# undef NSH_HAVE_CPULOAD
|
|
#endif
|
|
|
|
#if !defined(CONFIG_FS_PROCFS) || (defined(CONFIG_FS_PROCFS_EXCLUDE_BLOCKS) && \
|
|
defined(CONFIG_FS_PROCFS_EXCLUDE_USAGE))
|
|
# undef CONFIG_NSH_DISABLE_DF /* 'df' depends on fs procfs */
|
|
# define CONFIG_NSH_DISABLE_DF 1
|
|
#endif
|
|
|
|
#if defined(CONFIG_FS_PROCFS) || !defined(CONFIG_NSH_DISABLE_DF)
|
|
# define HAVE_DF_HUMANREADBLE 1
|
|
# define HAVE_DF_BLOCKOUTPUT 1
|
|
# if defined(CONFIG_FS_PROCFS_EXCLUDE_USAGE)
|
|
# undef HAVE_DF_HUMANREADBLE
|
|
# endif
|
|
# if defined(CONFIG_FS_PROCFS_EXCLUDE_BLOCKS)
|
|
# undef HAVE_DF_BLOCKOUTPUT
|
|
# endif
|
|
#endif
|
|
|
|
#undef HAVE_IRQINFO
|
|
#if !defined(CONFIG_DISABLE_MOUNTPOINT) && defined(CONFIG_FS_PROCFS) && \
|
|
defined(CONFIG_SCHED_IRQMONITOR)
|
|
# define HAVE_IRQINFO 1
|
|
#endif
|
|
|
|
#undef HAVE_MOUNT_LIST
|
|
#if defined(CONFIG_FS_PROCFS) && !defined(CONFIG_NSH_DISABLE_MOUNT) && \
|
|
!defined(CONFIG_FS_PROCFS_EXCLUDE_MOUNT)
|
|
# define HAVE_MOUNT_LIST 1
|
|
#endif
|
|
|
|
#if !defined(CONFIG_FS_PROCFS) || defined(CONFIG_FS_PROCFS_EXCLUDE_MEMINFO)
|
|
# undef CONFIG_NSH_DISABLE_FREE
|
|
# define CONFIG_NSH_DISABLE_FREE 1
|
|
#endif
|
|
|
|
#if !defined(CONFIG_FS_PROCFS) || defined(CONFIG_FS_PROCFS_EXCLUDE_MEMDUMP)
|
|
# undef CONFIG_NSH_DISABLE_MEMDUMP
|
|
# define CONFIG_NSH_DISABLE_MEMDUMP 1
|
|
#endif
|
|
|
|
/* Suppress unused file utilities */
|
|
|
|
#define NSH_HAVE_CATFILE 1
|
|
#define NSH_HAVE_WRITEFILE 1
|
|
#define NSH_HAVE_READFILE 1
|
|
#define NSH_HAVE_FOREACH_DIRENTRY 1
|
|
#define NSH_HAVE_TRIMDIR 1
|
|
#define NSH_HAVE_TRIMSPACES 1
|
|
|
|
#if !defined(CONFIG_FS_PROCFS) || defined(CONFIG_DISABLE_ENVIRON) || \
|
|
defined(CONFIG_FS_PROCFS_EXCLUDE_ENVIRON) || !defined(NSH_HAVE_CATFILE)
|
|
# undef CONFIG_NSH_DISABLE_ENV
|
|
# define CONFIG_NSH_DISABLE_ENV 1
|
|
#endif
|
|
|
|
#if !defined(CONFIG_NSH_VARS) || defined(CONFIG_DISABLE_ENVIRON)
|
|
# undef CONFIG_NSH_DISABLE_EXPORT
|
|
# define CONFIG_NSH_DISABLE_EXPORT 1
|
|
#endif
|
|
|
|
/* nsh_catfile used by cat, ifconfig, ifup/down, df, free, env, irqinfo, and
|
|
* mount (with no arguments).
|
|
*/
|
|
|
|
#if !defined(CONFIG_NSH_DISABLE_CAT) && !defined(CONFIG_NSH_DISABLE_IFCONFIG) && \
|
|
!defined(CONFIG_NSH_DISABLE_IFUPDOWN) && !defined(CONFIG_NSH_DISABLE_DF) && \
|
|
!defined(CONFIG_NSH_DISABLE_FREE) && !defined(CONFIG_NSH_DISABLE_ENV) && \
|
|
!defined(HAVE_IRQINFO) && !defined(HAVE_MOUNT_LIST)
|
|
# undef NSH_HAVE_CATFILE
|
|
#endif
|
|
|
|
/* nsh_readfile used by ps command */
|
|
|
|
#if defined(CONFIG_NSH_DISABLE_PS)
|
|
# undef NSH_HAVE_READFILE
|
|
#endif
|
|
|
|
/* nsh_foreach_direntry used by the commands:
|
|
* ls, ps, fdinfo, rptun, pmconfig
|
|
*/
|
|
|
|
#if defined(CONFIG_NSH_DISABLE_LS) && defined(CONFIG_NSH_DISABLE_PS) && \
|
|
defined(CONFIG_NSH_DISABLE_RPTUN) && defined(CONFIG_NSH_DISABLE_PMCONFIG) && \
|
|
defined(CONFIG_NSH_DISABLE_FDINFO) && defined(CONFIG_NSH_DISABLE_PIDOF)
|
|
# undef NSH_HAVE_FOREACH_DIRENTRY
|
|
#endif
|
|
|
|
#if defined(CONFIG_NSH_DISABLE_CP)
|
|
# undef NSH_HAVE_TRIMDIR
|
|
#endif
|
|
|
|
/* nsh_trimspaces used by the set and ps commands */
|
|
|
|
#if defined(CONFIG_NSH_DISABLE_SET) && defined(CONFIG_NSH_DISABLE_PS)
|
|
# undef NSH_HAVE_TRIMSPACES
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLESCRIPT
|
|
# define NSH_NP_SET_OPTIONS "ex" /* Maintain order see nsh_npflags_e */
|
|
# define NSH_NP_SET_OPTIONS_INIT (NSH_PFLAG_SILENT)
|
|
#endif
|
|
|
|
#if !defined(NSH_HAVE_VARS) && defined(CONFIG_NSH_DISABLESCRIPT)
|
|
# undef CONFIG_NSH_DISABLE_SET
|
|
# define CONFIG_NSH_DISABLE_SET 1
|
|
# undef CONFIG_NSH_DISABLE_UNSET
|
|
# define CONFIG_NSH_DISABLE_UNSET 1
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Public Types
|
|
****************************************************************************/
|
|
|
|
enum nsh_login_e
|
|
{
|
|
NSH_LOGIN_NONE = 0, /* Don't Performs the login sequence */
|
|
NSH_LOGIN_LOCAL, /* Performs the login sequence as local user */
|
|
NSH_LOGIN_TELNET /* Performs the login sequence as telnet client */
|
|
};
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_ITEF
|
|
/* State when parsing and if-then-else sequence */
|
|
|
|
enum nsh_itef_e
|
|
{
|
|
NSH_ITEF_NORMAL = 0, /* Not in an if-then-else sequence */
|
|
NSH_ITEF_IF, /* Just parsed 'if', expect condition */
|
|
NSH_ITEF_THEN, /* Just parsed 'then', looking for 'else' or 'fi' */
|
|
NSH_ITEF_ELSE /* Just parsed 'else', look for 'fi' */
|
|
};
|
|
|
|
/* All state data for parsing one if-then-else sequence */
|
|
|
|
struct nsh_itef_s
|
|
{
|
|
uint8_t ie_ifcond : 1; /* Value of command in 'if' statement */
|
|
uint8_t ie_disabled : 1; /* TRUE: Unconditionally disabled */
|
|
uint8_t ie_inverted : 1; /* TRUE: inverted logic ('if ! <cmd>') */
|
|
uint8_t ie_unused : 3;
|
|
uint8_t ie_state : 2; /* If-then-else state (see enum nsh_itef_e) */
|
|
};
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_LOOPS
|
|
/* State when parsing and while-do-done or until-do-done sequence */
|
|
|
|
enum nsh_lp_e
|
|
{
|
|
NSH_LOOP_NORMAL = 0, /* Not in a while-do-done or until-do-done sequence */
|
|
NSH_LOOP_WHILE, /* Just parsed 'while', expect condition */
|
|
NSH_LOOP_UNTIL, /* Just parsed 'until', expect condition */
|
|
NSH_LOOP_DO /* Just parsed 'do', looking for 'done' */
|
|
};
|
|
|
|
/* All state data for parsing one while-do-done or until-do-done sequence */
|
|
|
|
struct nsh_loop_s
|
|
{
|
|
uint8_t lp_enable : 1; /* Loop command processing is enabled */
|
|
uint8_t lp_unused : 5;
|
|
uint8_t lp_state : 2; /* Loop state (see enume nsh_lp_e) */
|
|
#ifndef CONFIG_NSH_DISABLE_ITEF
|
|
uint8_t lp_iendx; /* Saved if-then-else-fi index */
|
|
#endif
|
|
long lp_topoffs; /* Top of loop file offset */
|
|
};
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLESCRIPT
|
|
/* Define the bits that correspond to the option defined in
|
|
* NSH_NP_SET_OPTIONS. The bit value is 1 shifted left the offset
|
|
* of the char in NSH_NP_SET_OPTIONS string.
|
|
*/
|
|
|
|
enum nsh_npflags_e
|
|
{
|
|
NSH_PFLAG_IGNORE = 1, /* set for +e no exit on errors,
|
|
* cleared -e exit on error */
|
|
NSH_PFLAG_SILENT = 2, /* cleared -x print a trace of commands
|
|
* when parsing.
|
|
* set +x no print a trace of commands */
|
|
};
|
|
#endif
|
|
|
|
/* These structure provides the overall state of the parser */
|
|
|
|
struct nsh_parser_s
|
|
{
|
|
#ifndef CONFIG_NSH_DISABLEBG
|
|
bool np_bg; /* true: The last command executed in background */
|
|
#endif
|
|
bool np_redirect; /* true: Output from the last command was re-directed */
|
|
bool np_fail; /* true: The last command failed */
|
|
#ifndef CONFIG_NSH_DISABLESCRIPT
|
|
uint8_t np_flags; /* See nsh_npflags_e above */
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLEBG
|
|
int np_nice; /* "nice" value applied to last background cmd */
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLESCRIPT
|
|
int np_fd; /* Stream of current script */
|
|
#ifndef CONFIG_NSH_DISABLE_LOOPS
|
|
long np_foffs; /* File offset to the beginning of a line */
|
|
#ifndef NSH_DISABLE_SEMICOLON
|
|
uint16_t np_loffs; /* Byte offset to the beginning of a command */
|
|
bool np_jump; /* "Jump" to the top of the loop */
|
|
#endif
|
|
uint8_t np_lpndx; /* Current index into np_lpstate[] */
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_ITEF
|
|
uint8_t np_iendx; /* Current index into np_iestate[] */
|
|
#endif
|
|
|
|
/* This is a stack of parser state information. */
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_ITEF
|
|
struct nsh_itef_s np_iestate[CONFIG_NSH_NESTDEPTH];
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_LOOPS
|
|
struct nsh_loop_s np_lpstate[CONFIG_NSH_NESTDEPTH];
|
|
#endif
|
|
#endif
|
|
};
|
|
|
|
#ifdef CONFIG_NSH_ALIAS
|
|
struct nsh_alias_s
|
|
{
|
|
FAR struct nsh_alias_s *next; /* Single link list for traversing */
|
|
FAR char *name; /* Name of the alias */
|
|
FAR char *value; /* Value behind the name */
|
|
union
|
|
{
|
|
struct
|
|
{
|
|
uint8_t exp : 1; /* Already expanded ? */
|
|
uint8_t rem : 1; /* Marked for deletion */
|
|
};
|
|
|
|
uint8_t flags; /* Raw value */
|
|
};
|
|
};
|
|
#endif
|
|
|
|
/* This is the general form of a command handler */
|
|
|
|
struct nsh_vtbl_s; /* Defined in nsh_console.h */
|
|
typedef CODE int (*nsh_cmd_t)(FAR struct nsh_vtbl_s *vtbl, int argc,
|
|
FAR char **argv);
|
|
|
|
/* This is the form of a callback from nsh_foreach_direntry() */
|
|
|
|
struct dirent; /* Defined in dirent.h */
|
|
typedef CODE int (*nsh_direntry_handler_t)(FAR struct nsh_vtbl_s *vtbl,
|
|
FAR const char *dirpath,
|
|
FAR struct dirent *entryp,
|
|
FAR void *pvarg);
|
|
|
|
#if defined(CONFIG_NSH_VARS) && !defined(CONFIG_NSH_DISABLE_SET)
|
|
/* Used with nsh_foreach_var() */
|
|
|
|
typedef int (*nsh_foreach_var_t)(FAR struct nsh_vtbl_s *vtbl, FAR void *arg,
|
|
FAR const char *pair);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Public Data
|
|
****************************************************************************/
|
|
|
|
extern const char g_nshgreeting[];
|
|
#if defined(CONFIG_NSH_MOTD) && !defined(CONFIG_NSH_PLATFORM_MOTD)
|
|
extern const char g_nshmotd[];
|
|
#endif
|
|
#ifdef CONFIG_NSH_LOGIN
|
|
#if defined(CONFIG_NSH_TELNET_LOGIN) && defined(CONFIG_NSH_TELNET)
|
|
extern const char g_telnetgreeting[];
|
|
#endif
|
|
extern const char g_userprompt[];
|
|
extern const char g_passwordprompt[];
|
|
extern const char g_loginsuccess[];
|
|
extern const char g_badcredentials[];
|
|
extern const char g_loginfailure[];
|
|
#endif
|
|
extern const char g_fmtsyntax[];
|
|
extern const char g_fmtargrequired[];
|
|
extern const char g_fmtnomatching[];
|
|
extern const char g_fmtarginvalid[];
|
|
extern const char g_fmtargrange[];
|
|
extern const char g_fmtcmdnotfound[];
|
|
extern const char g_fmtnosuch[];
|
|
extern const char g_fmttoomanyargs[];
|
|
extern const char g_fmtdeepnesting[];
|
|
extern const char g_fmtcontext[];
|
|
extern const char g_fmtcmdfailed[];
|
|
extern const char g_fmtcmdoutofmemory[];
|
|
extern const char g_fmtinternalerror[];
|
|
extern const char g_fmtsignalrecvd[];
|
|
|
|
/****************************************************************************
|
|
* Public Function Prototypes
|
|
****************************************************************************/
|
|
|
|
#if defined(__cplusplus)
|
|
extern "C"
|
|
{
|
|
#endif
|
|
|
|
/* Initialization */
|
|
|
|
#ifdef HAVE_USB_CONSOLE
|
|
int nsh_usbconsole(void);
|
|
#else
|
|
# define nsh_usbconsole() (-ENOSYS)
|
|
#endif
|
|
|
|
#ifdef CONFIG_NSH_ALIAS
|
|
FAR struct nsh_alias_s *nsh_aliasfind(FAR struct nsh_vtbl_s *vtbl,
|
|
FAR const char *token);
|
|
void nsh_aliasfree(FAR struct nsh_vtbl_s *vtbl,
|
|
FAR struct nsh_alias_s *alias);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLESCRIPT
|
|
int nsh_script(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|
FAR const char *path, bool log);
|
|
#ifdef CONFIG_ETC_ROMFS
|
|
int nsh_sysinitscript(FAR struct nsh_vtbl_s *vtbl);
|
|
int nsh_initscript(FAR struct nsh_vtbl_s *vtbl);
|
|
#ifdef CONFIG_NSH_ROMFSRC
|
|
int nsh_loginscript(FAR struct nsh_vtbl_s *vtbl);
|
|
#endif
|
|
#endif
|
|
#endif
|
|
|
|
/* Certain commands are only available if the boardctl() interface is
|
|
* available:
|
|
*/
|
|
|
|
/* Architecture-specific initialization depends on boardctl(BOARDIOC_INIT) */
|
|
|
|
#if defined(CONFIG_NSH_ARCHINIT) && !defined(CONFIG_BOARDCTL)
|
|
# warning CONFIG_NSH_ARCHINIT is set, but CONFIG_BOARDCTL is not
|
|
# undef CONFIG_NSH_ARCHINIT
|
|
#endif
|
|
|
|
/* The mkrd command depends on boardctl(BOARDIOC_MKRD) */
|
|
|
|
#if !defined(CONFIG_BOARDCTL) || !defined(CONFIG_BOARDCTL_MKRD)
|
|
# undef CONFIG_NSH_DISABLE_MKRD
|
|
# define CONFIG_NSH_DISABLE_MKRD 1
|
|
#endif
|
|
|
|
/* Basic session and message handling */
|
|
|
|
struct console_stdio_s;
|
|
int nsh_session(FAR struct console_stdio_s *pstate,
|
|
int login, int argc, FAR char *argv[]);
|
|
int nsh_parse(FAR struct nsh_vtbl_s *vtbl, FAR char *cmdline);
|
|
|
|
/* Prompt string handling */
|
|
|
|
FAR const char *nsh_prompt(void);
|
|
void nsh_update_prompt(void);
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_login
|
|
*
|
|
* Description:
|
|
* Prompt the user for a username and password. Return a failure if valid
|
|
* credentials are not returned (after some retries.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef CONFIG_NSH_CONSOLE_LOGIN
|
|
int nsh_login(FAR struct console_stdio_s *pstate);
|
|
#endif
|
|
|
|
#ifdef CONFIG_NSH_TELNET_LOGIN
|
|
int nsh_telnetlogin(FAR struct console_stdio_s *pstate);
|
|
#endif
|
|
|
|
/* Application interface */
|
|
|
|
int nsh_command(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char *argv[]);
|
|
|
|
#ifdef CONFIG_NSH_BUILTIN_APPS
|
|
int nsh_builtin(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|
FAR char **argv, FAR const char *redirfile, int oflags);
|
|
#endif
|
|
|
|
#ifdef CONFIG_NSH_FILE_APPS
|
|
int nsh_fileapp(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|
FAR char **argv, FAR const char *redirfile, int oflags);
|
|
#endif
|
|
|
|
#ifndef CONFIG_DISABLE_ENVIRON
|
|
/* Working directory support */
|
|
|
|
FAR const char *nsh_getcwd(void);
|
|
FAR char *nsh_getfullpath(FAR struct nsh_vtbl_s *vtbl,
|
|
FAR const char *relpath);
|
|
void nsh_freefullpath(FAR char *fullpath);
|
|
#endif
|
|
|
|
/* Debug */
|
|
|
|
void nsh_dumpbuffer(FAR struct nsh_vtbl_s *vtbl, FAR const char *msg,
|
|
FAR const uint8_t *buffer, ssize_t nbytes);
|
|
|
|
#ifdef CONFIG_NSH_USBDEV_TRACE
|
|
/* USB debug support */
|
|
|
|
void nsh_usbtrace(void);
|
|
#endif
|
|
|
|
/* Shell command handlers */
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_BASENAME
|
|
int cmd_basename(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#if !defined(CONFIG_NSH_DISABLESCRIPT) && !defined(CONFIG_NSH_DISABLE_LOOPS)
|
|
int cmd_break(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_DIRNAME
|
|
int cmd_dirname(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_ECHO
|
|
int cmd_echo(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_PRINTF
|
|
int cmd_printf(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_EXEC
|
|
int cmd_exec(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_EXPORT
|
|
int cmd_export(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_MB
|
|
int cmd_mb(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_MH
|
|
int cmd_mh(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_MW
|
|
int cmd_mw(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_FREE
|
|
int cmd_free(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_MEMDUMP
|
|
int cmd_memdump(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_TIME
|
|
int cmd_time(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_PS
|
|
int cmd_ps(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#if defined(CONFIG_FS_PROCFS) && !defined(CONFIG_NSH_DISABLE_PIDOF)
|
|
int cmd_pidof(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#if defined(CONFIG_FS_PROCFS) && !defined(CONFIG_NSH_DISABLE_FDINFO)
|
|
int cmd_fdinfo(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_XD
|
|
int cmd_xd(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_MODULE) && !defined(CONFIG_NSH_DISABLE_MODCMDS)
|
|
int cmd_insmod(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
int cmd_rmmod(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#if defined(CONFIG_FS_PROCFS) && !defined(CONFIG_FS_PROCFS_EXCLUDE_MODULE)
|
|
int cmd_lsmod(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#endif
|
|
|
|
#ifdef HAVE_IRQINFO
|
|
int cmd_irqinfo(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if !defined(CONFIG_NSH_DISABLESCRIPT) && !defined(CONFIG_NSH_DISABLE_TEST)
|
|
int cmd_test(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
int cmd_lbracket(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_TIMEDATECTL
|
|
int cmd_timedatectl(FAR struct nsh_vtbl_s *vtbl, int argc,
|
|
FAR char **argv);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_DATE
|
|
int cmd_date(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_CAT
|
|
int cmd_cat(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_CP
|
|
int cmd_cp(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_CMP
|
|
int cmd_cmp(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_DD
|
|
int cmd_dd(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_HEXDUMP
|
|
int cmd_hexdump(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#if !defined(CONFIG_NSH_DISABLE_LN) && defined(CONFIG_PSEUDOFS_SOFTLINKS)
|
|
int cmd_ln(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_LS
|
|
int cmd_ls(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#if defined(CONFIG_SYSLOG_DEVPATH) && !defined(CONFIG_NSH_DISABLE_DMESG)
|
|
int cmd_dmesg(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#if !defined(CONFIG_NSH_DISABLE_READLINK) && defined(CONFIG_PSEUDOFS_SOFTLINKS)
|
|
int cmd_readlink(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#if !defined(CONFIG_NSH_DISABLESCRIPT) && !defined(CONFIG_NSH_DISABLE_SOURCE)
|
|
int cmd_source(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#ifdef NSH_HAVE_DIROPTS
|
|
# ifndef CONFIG_NSH_DISABLE_MKDIR
|
|
int cmd_mkdir(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_MV
|
|
int cmd_mv(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_RM
|
|
int cmd_rm(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_RMDIR
|
|
int cmd_rmdir(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
#endif /* NSH_HAVE_DIROPTS */
|
|
|
|
#ifndef CONFIG_DISABLE_MOUNTPOINT
|
|
# if defined(CONFIG_DEV_LOOP) && !defined(CONFIG_NSH_DISABLE_LOSETUP)
|
|
int cmd_losetup(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# if defined(CONFIG_SMART_DEV_LOOP) && !defined(CONFIG_NSH_DISABLE_LOSMART)
|
|
int cmd_losmart(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# if defined(CONFIG_MTD_LOOP) && !defined(CONFIG_NSH_DISABLE_LOMTD)
|
|
int cmd_lomtd(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# if defined(CONFIG_PIPES) && CONFIG_DEV_FIFO_SIZE > 0 && \
|
|
!defined(CONFIG_NSH_DISABLE_MKFIFO)
|
|
int cmd_mkfifo(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifdef NSH_HAVE_CATFILE
|
|
# ifndef CONFIG_NSH_DISABLE_DF
|
|
int cmd_df(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_MOUNT
|
|
int cmd_mount(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_UMOUNT
|
|
int cmd_umount(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_MKRD
|
|
int cmd_mkrd(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifdef CONFIG_FSUTILS_MKFATFS
|
|
# ifndef CONFIG_NSH_DISABLE_MKFATFS
|
|
int cmd_mkfatfs(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# endif /* CONFIG_FSUTILS_MKFATFS */
|
|
# if defined(CONFIG_FS_SMARTFS) && defined(CONFIG_FSUTILS_MKSMARTFS)
|
|
# ifndef CONFIG_NSH_DISABLE_MKSMARTFS
|
|
int cmd_mksmartfs(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# endif /* CONFIG_FS_SMARTFS */
|
|
# ifndef CONFIG_NSH_DISABLE_TRUNCATE
|
|
int cmd_truncate(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# if defined(CONFIG_NSH_LOGIN_PASSWD) && \
|
|
!defined(CONFIG_FSUTILS_PASSWD_READONLY)
|
|
# ifndef CONFIG_NSH_DISABLE_USERADD
|
|
int cmd_useradd(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_USERDEL
|
|
int cmd_userdel(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_PASSWD
|
|
int cmd_passwd(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# endif
|
|
#endif /* !CONFIG_DISABLE_MOUNTPOINT */
|
|
|
|
#if !defined(CONFIG_DISABLE_ENVIRON)
|
|
# ifndef CONFIG_NSH_DISABLE_CD
|
|
int cmd_cd(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_PWD
|
|
int cmd_pwd(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
#endif /* !CONFIG_DISABLE_MOUNTPOINT */
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_ENV
|
|
int cmd_env(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_NET)
|
|
# if defined(CONFIG_NET_ARP) && !defined(CONFIG_NSH_DISABLE_ARP)
|
|
int cmd_arp(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# if defined(CONFIG_NET_ROUTE) && !defined(CONFIG_NSH_DISABLE_ADDROUTE)
|
|
int cmd_addroute(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# if defined(CONFIG_NET_ROUTE) && !defined(CONFIG_NSH_DISABLE_DELROUTE)
|
|
int cmd_delroute(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifdef CONFIG_NET_UDP
|
|
# ifndef CONFIG_NSH_DISABLE_GET
|
|
int cmd_get(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_IFCONFIG
|
|
int cmd_ifconfig(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_IFUPDOWN
|
|
int cmd_ifup(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
int cmd_ifdown(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# if !defined(CONFIG_DISABLE_MOUNTPOINT) && defined(CONFIG_NFS)
|
|
# ifndef CONFIG_NSH_DISABLE_NFSMOUNT
|
|
int cmd_nfsmount(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# endif
|
|
# ifdef CONFIG_NET_UDP
|
|
# ifndef CONFIG_NSH_DISABLE_PUT
|
|
int cmd_put(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# endif
|
|
# ifdef CONFIG_NET_TCP
|
|
# ifndef CONFIG_NSH_DISABLE_WGET
|
|
int cmd_wget(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_ROUTE
|
|
int cmd_route(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
#endif /* CONFIG_NET */
|
|
|
|
#if defined(CONFIG_LIBC_NETDB) && !defined(CONFIG_NSH_DISABLE_NSLOOKUP)
|
|
int cmd_nslookup(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_BOARDCTL_POWEROFF) && !defined(CONFIG_NSH_DISABLE_POWEROFF)
|
|
int cmd_poweroff(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_PM) && !defined(CONFIG_NSH_DISABLE_PMCONFIG)
|
|
int cmd_pmconfig(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_BOARDCTL_SWITCH_BOOT) && !defined(CONFIG_NSH_DISABLE_SWITCHBOOT)
|
|
int cmd_switchboot(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_BOARDCTL_BOOT_IMAGE) && !defined(CONFIG_NSH_DISABLE_BOOT)
|
|
int cmd_boot(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_BOARDCTL_RESET) && !defined(CONFIG_NSH_DISABLE_REBOOT)
|
|
int cmd_reboot(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_BOARDCTL_RESET_CAUSE) && !defined(CONFIG_NSH_DISABLE_RESET_CAUSE)
|
|
int cmd_reset_cause(FAR struct nsh_vtbl_s *vtbl, int argc,
|
|
FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_RPMSG) && !defined(CONFIG_NSH_DISABLE_RPMSG)
|
|
int cmd_rpmsg(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_RPTUN) && !defined(CONFIG_NSH_DISABLE_RPTUN)
|
|
int cmd_rptun(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if (defined(CONFIG_BOARDCTL_POWEROFF) || defined(CONFIG_BOARDCTL_RESET)) && \
|
|
!defined(CONFIG_NSH_DISABLE_SHUTDOWN)
|
|
int cmd_shutdown(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_UNAME
|
|
int cmd_uname(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_SET
|
|
int cmd_set(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_UNSET
|
|
int cmd_unset(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_KILL
|
|
int cmd_kill(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_SLEEP
|
|
int cmd_sleep(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
#ifndef CONFIG_NSH_DISABLE_USLEEP
|
|
int cmd_usleep(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#ifndef CONFIG_NSH_DISABLE_UPTIME
|
|
int cmd_uptime(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
#if defined(CONFIG_NETUTILS_CODECS) && defined(CONFIG_CODECS_BASE64)
|
|
# ifndef CONFIG_NSH_DISABLE_BASE64DEC
|
|
int cmd_base64decode(FAR struct nsh_vtbl_s *vtbl, int argc,
|
|
FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_BASE64ENC
|
|
int cmd_base64encode(FAR struct nsh_vtbl_s *vtbl, int argc,
|
|
FAR char **argv);
|
|
# endif
|
|
#endif
|
|
|
|
#if defined(CONFIG_NETUTILS_CODECS) && defined(CONFIG_CODECS_HASH_MD5)
|
|
# ifndef CONFIG_NSH_DISABLE_MD5
|
|
int cmd_md5(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
#endif
|
|
|
|
#if defined(CONFIG_NETUTILS_CODECS) && defined(CONFIG_CODECS_URLCODE)
|
|
# ifndef CONFIG_NSH_DISABLE_URLDECODE
|
|
int cmd_urlencode(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
# ifndef CONFIG_NSH_DISABLE_URLENCODE
|
|
int cmd_urldecode(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
# endif
|
|
#endif
|
|
|
|
#ifdef CONFIG_NSH_ALIAS
|
|
int cmd_alias(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
int cmd_unalias(FAR struct nsh_vtbl_s *vtbl, int argc, FAR char **argv);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_extmatch_count
|
|
*
|
|
* Description:
|
|
* This support function is used to provide support for realine tab-
|
|
* completion logic nsh_extmatch_count() counts the number of matching
|
|
* nsh command names
|
|
*
|
|
* Input Parameters:
|
|
* name - A point to the name containing the name to be matched.
|
|
* matches - A table is size CONFIG_READLINE_MAX_EXTCMDS that can
|
|
* be used to remember matching name indices.
|
|
* namelen - The length of the name to match
|
|
*
|
|
* Returned Values:
|
|
* The number commands that match to the first namelen characters.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#if defined(CONFIG_NSH_READLINE) && defined(CONFIG_READLINE_TABCOMPLETION) && \
|
|
defined(CONFIG_READLINE_HAVE_EXTMATCH)
|
|
int nsh_extmatch_count(FAR char *name, FAR int *matches, int namelen);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_extmatch_getname
|
|
*
|
|
* Description:
|
|
* This support function is used to provide support for realine tab-
|
|
* completion logic nsh_extmatch_getname() will return the full command
|
|
* string from an index that was previously saved by nsh_exmatch_count().
|
|
*
|
|
* Input Parameters:
|
|
* index - The index of the command name to be returned.
|
|
*
|
|
* Returned Values:
|
|
* The numb
|
|
*
|
|
****************************************************************************/
|
|
|
|
#if defined(CONFIG_NSH_READLINE) && defined(CONFIG_READLINE_TABCOMPLETION) && \
|
|
defined(CONFIG_READLINE_HAVE_EXTMATCH)
|
|
FAR const char *nsh_extmatch_getname(int index);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_catfile
|
|
*
|
|
* Description:
|
|
* Dump the contents of a file to the current NSH terminal.
|
|
*
|
|
* Input Paratemets:
|
|
* vtbl - The console vtable
|
|
* cmd - NSH command name to use in error reporting
|
|
* filepath - The full path to the file to be dumped
|
|
*
|
|
* Returned Value:
|
|
* Zero (OK) on success; -1 (ERROR) on failure.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef NSH_HAVE_CATFILE
|
|
int nsh_catfile(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|
FAR const char *filepath);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_readfile
|
|
*
|
|
* Description:
|
|
* Read a small file into a user-provided buffer. The data is assumed to
|
|
* be a string and is guaranteed to be NULL-terminated. An error occurs if
|
|
* the file content (+terminator) will not fit into the provided 'buffer'.
|
|
*
|
|
* Input Parameters:
|
|
* vtbl - The console vtable
|
|
* cmd - NSH command name to use in error reporting
|
|
* filepath - The full path to the file to be read
|
|
* buffer - The user-provided buffer into which the file is read.
|
|
* buflen - The size of the user provided buffer
|
|
*
|
|
* Returned Value:
|
|
* Zero (OK) is returned on success; -1 (ERROR) is returned on any
|
|
* failure to read the fil into the buffer.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef NSH_HAVE_READFILE
|
|
int nsh_readfile(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|
FAR const char *filepath, FAR char *buffer, size_t buflen);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_writefile
|
|
*
|
|
* Description:
|
|
* Dump the contents of a file to the current NSH terminal.
|
|
*
|
|
* Input Paratemets:
|
|
* vtbl - session vtbl
|
|
* cmd - NSH command name to use in error reporting
|
|
* buffer - The pointer of writing buffer
|
|
* len - The length of writing buffer
|
|
* filepath - The full path to the file to be dumped
|
|
*
|
|
* Returned Value:
|
|
* Zero (OK) on success; -1 (ERROR) on failure.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef NSH_HAVE_WRITEFILE
|
|
int nsh_writefile(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|
FAR const char *buffer, size_t len,
|
|
FAR const char *filepath);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_foreach_direntry
|
|
*
|
|
* Description:
|
|
* Call the provided 'handler' for each entry found in the directory at
|
|
* 'dirpath'.
|
|
*
|
|
* Input Parameters
|
|
* vtbl - The console vtable
|
|
* cmd - NSH command name to use in error reporting
|
|
* dirpath - The full path to the directory to be traversed
|
|
* handler - The handler to be called for each entry of the directory
|
|
* pvarg - User provided argument to be passed to the 'handler'
|
|
*
|
|
* Returned Value:
|
|
* Zero (OK) returned on success; -1 (ERROR) returned on failure.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef NSH_HAVE_FOREACH_DIRENTRY
|
|
int nsh_foreach_direntry(FAR struct nsh_vtbl_s *vtbl, FAR const char *cmd,
|
|
FAR const char *dirpath,
|
|
nsh_direntry_handler_t handler, void *pvarg);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_getpid
|
|
*
|
|
* Description:
|
|
* Obtain pid through process name
|
|
*
|
|
* Input Parameters:
|
|
* vtbl - NSH session data
|
|
* name - the name of the process
|
|
* pids - allocated array for storing pid
|
|
* count - the maximum number of pids obtained
|
|
*
|
|
* Returned value:
|
|
* the actual number of pids obtained
|
|
*
|
|
****************************************************************************/
|
|
|
|
#if defined(CONFIG_FS_PROCFS) && !defined(CONFIG_NSH_DISABLE_PIDOF)
|
|
ssize_t nsh_getpid(FAR struct nsh_vtbl_s *vtbl, FAR const char *name,
|
|
FAR pid_t *pids, size_t count);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_trimdir
|
|
*
|
|
* Description:
|
|
* Skip any trailing '/' characters (unless it is also the leading '/')
|
|
*
|
|
* Input Parameters:
|
|
* dirpath - The directory path to be trimmed. May be modified!
|
|
*
|
|
* Returned value:
|
|
* None
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef NSH_HAVE_TRIMDIR
|
|
void nsh_trimdir(FAR char *dirpath);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_trimspaces
|
|
*
|
|
* Description:
|
|
* Trim any leading or trailing spaces from a string.
|
|
*
|
|
* Input Parameters:
|
|
* str - The string to be trimmed. May be modified!
|
|
*
|
|
* Returned value:
|
|
* The new string pointer.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef NSH_HAVE_TRIMSPACES
|
|
FAR char *nsh_trimspaces(FAR char *str);
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_getdirpath
|
|
*
|
|
* Description:
|
|
* Combine dirpath with a file/path, this will generated a new string,
|
|
* which need free outside.
|
|
*
|
|
* Input Parameters:
|
|
* dirpath - the dirpath
|
|
* path - the file/path
|
|
*
|
|
* Returned value:
|
|
* The new string pointer, need free in caller.
|
|
*
|
|
****************************************************************************/
|
|
|
|
FAR char *nsh_getdirpath(FAR struct nsh_vtbl_s *vtbl,
|
|
FAR const char *dirpath, FAR const char *path);
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_getvar, nsh_setvar, and nsh_setvar
|
|
*
|
|
* Description:
|
|
* Get, set, or unset an NSH variable.
|
|
*
|
|
* Input Parameters:
|
|
* vtbl - NSH session data
|
|
* name - The name of the variable to get or set
|
|
* value - The value to use with nsh_setvar()
|
|
*
|
|
* Returned value:
|
|
* nsh_getvar() returns a read-only reference to the variable value on
|
|
* success or NULL on failure.
|
|
* nset_unsetvar() returns OK on success or an negated errno value on
|
|
* failure.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#ifdef CONFIG_NSH_VARS
|
|
FAR char *nsh_getvar(FAR struct nsh_vtbl_s *vtbl, FAR const char *name);
|
|
#ifndef CONFIG_NSH_DISABLE_SET
|
|
int nsh_setvar(FAR struct nsh_vtbl_s *vtbl, FAR const char *name,
|
|
FAR const char *value);
|
|
#endif
|
|
#if !defined(CONFIG_NSH_DISABLE_UNSET) || !defined(CONFIG_NSH_DISABLE_EXPORT)
|
|
int nsh_unsetvar(FAR struct nsh_vtbl_s *vtbl, FAR const char *name);
|
|
#endif
|
|
#endif
|
|
|
|
/****************************************************************************
|
|
* Name: nsh_foreach_var
|
|
*
|
|
* Description:
|
|
* Visit each name-value pair in the environment.
|
|
*
|
|
* Input Parameters:
|
|
* vtbl - NSH session data
|
|
* cb - The callback function to be invoked for each environment
|
|
* variable.
|
|
*
|
|
* Returned Value:
|
|
* Zero if the all NSH variables have been traversed. A non-zero value
|
|
* means that the callback function requested early termination by
|
|
* returning a nonzero value.
|
|
*
|
|
****************************************************************************/
|
|
|
|
#if defined(CONFIG_NSH_VARS) && !defined(CONFIG_NSH_DISABLE_SET)
|
|
int nsh_foreach_var(FAR struct nsh_vtbl_s *vtbl, nsh_foreach_var_t cb,
|
|
FAR void *arg);
|
|
#endif
|
|
|
|
#if defined(__cplusplus)
|
|
}
|
|
#endif
|
|
|
|
#endif /* __APPS_NSHLIB_NSH_H */
|