CMD_ENTRY structure (netsh.h)
The CMD_ENTRY structure defines a helper command.
Syntax
typedef struct _CMD_ENTRY {
LPCWSTR pwszCmdToken;
PFN_HANDLE_CMD pfnCmdHandler;
DWORD dwShortCmdHelpToken;
DWORD dwCmdHlpToken;
DWORD dwFlags;
PNS_OSVERSIONCHECK pOsVersionCheck;
} CMD_ENTRY, *PCMD_ENTRY;
Members
pwszCmdToken
The token (name) for the command.
pfnCmdHandler
A function that handles the command. For more information, see FN_HANDLE_CMD.
dwShortCmdHelpToken
A short help message. This is the message identifier from the resource file of the helper DLL.
dwCmdHlpToken
The message to display if the command is followed only by a help token (HELP, /?, -?, or ?). This is the message identifier from the resource file of the helper DLL.
dwFlags
The flags for the command. For more information, see Netshell Flags.
pOsVersionCheck
The operating system version check function. This is the function used to determine whether the command can be run on the operating system running on the local and/or remote context before invoking or displaying commands. For more information, see NS_OSVERSIONCHECK.
Remarks
Macros are available that can simplify the creation of the CMD_ENTRY structure, as follows:
#define CREATE_CMD_ENTRY_EX(t,f,i) {CMD_##t, f, HLP_##t, HLP_##t##_EX, i, NULL}
#define CREATE_CMD_ENTRY_EX_VER(t,f,i,v) {CMD_##t, f, HLP_##t, HLP_##t##_EX, i, v}
#define CREATE_CMD_ENTRY(t,f) {CMD_##t, f, HLP_##t, HLP_##t##_EX, CMD_FLAG_PRIVATE, NULL}
If these macros are used, the following constants must be defined in the helper DLL:
The following are example uses of these macros:
#define HLP_SAMPLE_ADD_BAR 1001
#define HLP_SAMPLE_ADD_BAR_EX 1002
#define HLP_SAMPLE_DELETE_BAR 1003
#define HLP_SAMPLE_DELETE_BAR_EX 1004
#define HLP_SAMPLE_SET_GLOBAL 1005
#define HLP_SAMPLE_SET_GLOBAL_EX 1006
#define HLP_SAMPLE_SET_BAR 1007
#define HLP_SAMPLE_SET_BAR_EX 1008
#define HLP_SAMPLE_SET_FILTER 1009
#define HLP_SAMPLE_SET_FILTER_EX 1010
#define HLP_SAMPLE_SHOW_GLOBAL 1011
#define HLP_SAMPLE_SHOW_GLOBAL_EX 1012
#define HLP_SAMPLE_SHOW_BAR 1013
#define HLP_SAMPLE_SHOW_BAR_EX 1014
#define HLP_SAMPLE_SHOW_FILTER 1015
#define HLP_SAMPLE_SHOW_FILTER_EX 1016
#define CMD_SAMPLE_ADD_BAR L"add_bar"
#define CMD_SAMPLE_DELETE_BAR L"delete_bar"
#define CMD_SAMPLE_SET_GLOBAL L"set_global"
#define CMD_SAMPLE_SET_BAR L"set_bar"
#define CMD_SAMPLE_SET_FILTER L"set_filter"
#define CMD_SAMPLE_SHOW_GLOBAL L"show_global"
#define CMD_SAMPLE_SHOW_BAR L"show_bar"
#define CMD_SAMPLE_SHOW_FILTER L"show_filter"
CMD_ENTRY g_SampleAddCmdTable[] =
{
CREATE_CMD_ENTRY(SAMPLE_ADD_BAR, HandleSampleAddBar),
};
CMD_ENTRY g_SampleDeleteCmdTable[] =
{
CREATE_CMD_ENTRY(SAMPLE_DELETE_BAR, HandleSampleDeleteBar),
};
CMD_ENTRY g_SampleSetCmdTable[] =
{
CREATE_CMD_ENTRY(SAMPLE_SET_GLOBAL, HandleSampleSetGlobal),
CREATE_CMD_ENTRY_EX(SAMPLE_SET_BAR, HandleSampleSetBar, (CMD_FLAG_PRIVATE | CMD_FLAG_ONLINE) ),
CREATE_CMD_ENTRY_EX_VER(SAMPLE_SET_FILTER, HandleSampleSetFilter, (CMD_FLAG_PRIVATE | CMD_FLAG_ONLINE), CheckRunningOnWindowsXP),
};
CMD_ENTRY g_SampleShowCmdTable[] =
{
CREATE_CMD_ENTRY(SAMPLE_SHOW_GLOBAL, HandleSampleShowGlobal),
CREATE_CMD_ENTRY_EX(SAMPLE_SHOW_BAR, HandleSampleShowBar, (CMD_FLAG_PRIVATE | CMD_FLAG_ONLINE) ),
CREATE_CMD_ENTRY_EX_VER(SAMPLE_SHOW_FILTER, HandleSampleShowFilter, (CMD_FLAG_PRIVATE | CMD_FLAG_ONLINE), CheckRunningOnWindowsXP),
};
Requirements
Requirement | Value |
---|---|
Minimum supported client | Windows XP [desktop apps only] |
Minimum supported server | Windows Server 2003 [desktop apps only] |
Header | netsh.h |