GM6000 Digital Heater Controller Branch: main
SDX-1330
List of all members | Public Member Functions | Static Public Attributes | Protected Attributes
Cpl::Dm::TShell::Dm Class Reference

This class implements a TShell command. More...

Detailed Description

This class implements a TShell command.

Note: Up to 10 different instance of this command can be instantiated - but each instance MUST have a different database number. The database number specified by specifying the actual command name, e.g. 'dm0' is database number 0, 'dm1' is database number 1, etc.

#include <Dm.h>

Inheritance diagram for Cpl::Dm::TShell::Dm:
[legend]
Collaboration diagram for Cpl::Dm::TShell::Dm:
[legend]

Public Member Functions

const char * getUsage () const noexcept
 Dynamic.
 
const char * getHelp () const noexcept
 See Cpl::TShell::Command.
 
 Dm (Cpl::Container::Map< Cpl::TShell::Command > &commandList, Cpl::Dm::ModelDatabaseApi &modelDatabase, const char *cmdNameAndDatabaseNumber="dm", Cpl::TShell::Security::Permission_T minPermLevel=OPTION_TSHELL_CMD_COMMAND_DEFAULT_PERMISSION_LEVEL) noexcept
 Constructor.
 
Cpl::TShell::Command::Result_T execute (Cpl::TShell::Context_ &context, char *cmdString, Cpl::Io::Output &outfd) noexcept
 See Cpl::TShell::Command.
 
- Public Member Functions inherited from Cpl::TShell::Cmd::Command
const char * getVerb () const noexcept
 See Cpl::TShell::Command.
 
Security::Permission_T getMinPermissionRequired () const noexcept
 See Cpl::TShell::Command.
 
- Public Member Functions inherited from Cpl::TShell::Command
virtual ~Command ()
 Virtual destructor.
 
- Public Member Functions inherited from Cpl::Container::Item
bool insert_ (void *newContainerPtr)
 Helper method to trap when inserting an item in multiple containers.
 
bool isInContainer_ (const void *containerPtr) const noexcept
 Returns 'true' if the instance is in the specified container.
 

Static Public Attributes

static constexpr const char * usage
 The command usage string.
 
static constexpr const char * detailedHelp
 The command detailed help string (recommended that lines do not exceed 80 chars) 1 2 3 4 5 6 7 8 12345678901234567890123456789012345678901234567890123456789012345678901234567890.
 

Protected Attributes

Cpl::Dm::ModelDatabaseApim_database
 Model Point Database to access.
 
- Protected Attributes inherited from Cpl::TShell::Cmd::Command
Cpl::Container::KeyLiteralString m_mapKey
 Command.
 
Security::Permission_T m_minPermissionLevel
 Minimum required user permission need to execute me.
 
- Protected Attributes inherited from Cpl::Container::MapItem
voidm_parentPtr_
 Link field to the parent node.
 
bool m_is_NOT_root_
 I am the root node.
 
Balance_T m_balance_
 Balance status.
 
- Protected Attributes inherited from Cpl::Container::DictItem
unsigned int m_hashCode_
 Remember which hash bucket I am stored in.
 

Additional Inherited Members

- Public Types inherited from Cpl::TShell::Command
enum  Result_T {
  eSUCCESS = 0 , eERROR_BAD_SYNTAX = 1 , eERROR_INVALID_CMD = 2 , eERROR_IO = 3 ,
  eERROR_MISSING_ARGS = 4 , eERROR_EXTRA_ARGS = 5 , eERROR_INVALID_ARGS = 6 , eERROR_FAILED = 7
}
 Possible result codes when executing a command. More...
 
- Static Public Member Functions inherited from Cpl::Container::Item
static void remove_ (Item *itemPtr) noexcept
 Helper method to do the proper 'clean-up' for the multiple-containers-error-trap when removing an item from a container.
 
- Public Attributes inherited from Cpl::Container::ExtendedItem
voidm_prevPtr_
 The previous link field.
 
- Public Attributes inherited from Cpl::Container::Item
voidm_nextPtr_
 The link field.
 
voidm_inListPtr_
 Debug field.
 
- Protected Types inherited from Cpl::TShell::Cmd::Command
enum  CondResult_T { eFALSE , eTRUE , eERROR }
 Result when processing a conditional statement. More...
 
- Protected Types inherited from Cpl::Container::MapItem
enum  Balance_T { eLEFT_ =-1 , eEVEN_ =0 , eRIGHT_ =1 }
 Magic values for balance status. More...
 
- Protected Member Functions inherited from Cpl::TShell::Cmd::Command
 Command (Cpl::Container::Map< Cpl::TShell::Command > &commandList, const char *verb, Security::Permission_T minPermLevel=OPTION_TSHELL_CMD_COMMAND_DEFAULT_PERMISSION_LEVEL) noexcept
 Constructor.
 
const Cpl::Container::KeygetKey () const noexcept
 See Cpl::Container::Key.
 
- Protected Member Functions inherited from Cpl::TShell::Command
 Command ()
 Constructor.
 
- Protected Member Functions inherited from Cpl::Container::MapItem
 MapItem ()
 Constructor.
 
 MapItem (const char *ignoreThisParameter_usedToCreateAUniqueConstructor)
 Constructor -->special constructor to allow a Map to be statically allocated.
 
void initialize (MapItem *parent)
 Initialize the node when being inserted in the tree.
 
MapItemgetParent () const
 Get tree connection/pointer.
 
void setParent (MapItem *n)
 Set tree connection/pointer.
 
MapItemgetLeft () const
 Get tree connection/pointer.
 
void setLeft (MapItem *n)
 Set tree connection/pointer.
 
MapItemgetRight () const
 Get tree connection/pointer.
 
void setRight (MapItem *n)
 Set tree connection/pointer.
 
- Protected Member Functions inherited from Cpl::Container::DictItem
 DictItem ()
 Constructor.
 
 DictItem (const char *ignoreThisParameter_usedToCreateAUniqueConstructor)
 Constructor used ONLY with the child class MapItem: -->special constructor to allow a Map to be statically allocated.
 
- Protected Member Functions inherited from Cpl::Container::ExtendedItem
 ExtendedItem ()
 Constructor.
 
 ExtendedItem (const char *ignoreThisParameter_usedToCreateAUniqueConstructor)
 Constructor used ONLY with the child class MapItem: -->special constructor to allow a Map to be statically allocated.
 
- Protected Member Functions inherited from Cpl::Container::Item
 Item ()
 Constructor.
 
 Item (const char *)
 Constructor used ONLY with the child class MapItem: -->special constructor to allow a Map to be statically allocated.
 

Constructor & Destructor Documentation

◆ Dm()

Cpl::Dm::TShell::Dm::Dm ( Cpl::Container::Map< Cpl::TShell::Command > &  commandList,
Cpl::Dm::ModelDatabaseApi modelDatabase,
const char *  cmdNameAndDatabaseNumber = "dm",
Cpl::TShell::Security::Permission_T  minPermLevel = OPTION_TSHELL_CMD_COMMAND_DEFAULT_PERMISSION_LEVEL 
)
noexcept

Constructor.

Member Function Documentation

◆ execute()

Cpl::TShell::Command::Result_T Cpl::Dm::TShell::Dm::execute ( Cpl::TShell::Context_ context,
char *  cmdString,
Cpl::Io::Output outfd 
)
virtualnoexcept

◆ getHelp()

const char * Cpl::Dm::TShell::Dm::getHelp ( ) const
inlinevirtualnoexcept

◆ getUsage()

const char * Cpl::Dm::TShell::Dm::getUsage ( ) const
inlinevirtualnoexcept

Dynamic.

See Cpl::TShell::Command `

Implements Cpl::TShell::Command.

Member Data Documentation

◆ detailedHelp

constexpr const char* Cpl::Dm::TShell::Dm::detailedHelp
staticconstexpr
Initial value:
= " Lists, updates, and displays Model Points contained in the Model Database.\n"
" When 'ls' is used a list of model point names is returned. The <filter>\n"
" argument will only list points that contain <filter>. Updating a Model Point\n"
" is done by specifying a JSON object. See the concrete class definition of the\n"
" Model Point being updated for the JSON format. When displaying a Model Point\n"
" <mpname> is the string name of the Model Point instance to be displayed."

The command detailed help string (recommended that lines do not exceed 80 chars) 1 2 3 4 5 6 7 8 12345678901234567890123456789012345678901234567890123456789012345678901234567890.

◆ m_database

Cpl::Dm::ModelDatabaseApi& Cpl::Dm::TShell::Dm::m_database
protected

Model Point Database to access.

◆ usage

constexpr const char* Cpl::Dm::TShell::Dm::usage
staticconstexpr
Initial value:
= "dm ls [<filter>]\n"
"dm write {<mp-json>}\n"
"dm read <mpname>\n"
"dm touch <mpname>"

The command usage string.


The documentation for this class was generated from the following file: