WASimCommander Client implementation. Handles all aspects of communication with the WASimCommander Server WASM module. More...
#include "WASimClient.h"
Public Member Functions | |
WASimClient (uint32_t clientId, const std::string &configFile=std::string()) | |
Instantiate the client with a unique ID and optional configuration file path. | |
~WASimClient () | |
Any open network connections are automatically closed upon destruction, though it is better to close them yourself before deleting the client. | |
Network actions, status, and settings | |
ClientStatus | status () const |
Get current connection status of this client. | |
bool | isInitialized () const |
Check if simulator network link is established. | |
bool | isConnected () const |
Check WASimCommander server connection status. | |
uint32_t | clientVersion () const |
Return the current WASimClient version number. Version numbers are in "BCD" format: MAJOR << 24 | MINOR << 16 | PATCH << 8 | BUILD , eg: 1.23.45.67 = 0x01234567 | |
uint32_t | serverVersion () const |
Return the version number of the last-connected, or successfully pinged, WASimModule (sever), or zero if unknown. See clientVersion() for numbering details. | |
HRESULT | connectSimulator (uint32_t timeout=0) |
Initialize the simulator network link and set up minimum necessary for WASimCommander server ping or connection. Uses default network SimConnect configuration ID. | |
HRESULT | connectSimulator (int networkConfigId, uint32_t timeout=0) |
Initialize the simulator network link and set up minimum necessary for WASimCommander server ping or connection. This overload allows specifying a SimConnect configuration ID and optional timeout value. | |
void | disconnectSimulator () |
Shut down all network connections (and disconnect WASimCommander server if connected). After calling this method, one must call connectSimulator() /connectServer() /pingServer() again before any other commands. | |
uint32_t | pingServer (uint32_t timeout=0) |
Check if WASimCommander Server exists (Simulator running, the WASIM module is installed and working). Returns server version number, or zero if server did not respond. This will implicitly call connectSimulator() first if it hasn't already been done, using the default network configuration settings. Zero will be returned if the connection could not be established. | |
HRESULT | connectServer (uint32_t timeout=0) |
Connect to WASimCommander server. This will implicitly call connectSimulator() first if it hasn't already been done, using the default network configuration setting. | |
void | disconnectServer () |
Disconnect from the WASimCommander server. This does not close the Simulator network connection (use disconnectSimulator() to do that or both at once). | |
uint32_t | defaultTimeout () const |
Get the current default server response timeout value, which is used in all network requests. The initial default setting is read from the client_conf.ini file or set to 1000ms if no config file was found. | |
void | setDefaultTimeout (uint32_t ms) |
Get current connection status of this client. | |
int | networkConfigurationId () const |
SimConnect is used for the network layer. This setting specifies the SimConnect.cfg index to use. The value of -1 forces a local connection. The initial default setting is read from the client_conf.ini file or set to -1 if no config file was found. | |
void | setNetworkConfigurationId (int configId) |
SimConnect is used for the network layer. This setting specifies the SimConnect.cfg index to use, or -1 to force a local connection. Note that this must be called before connectSimulator() invocation in order to have any effect. | |
RPN calculator code execution and reusable events | |
HRESULT | executeCalculatorCode (const std::string &code, WASimCommander::Enums::CalcResultType resultType=WASimCommander::Enums::CalcResultType::None, double *pfResult=nullptr, std::string *psResult=nullptr) const |
Run a string of MSFS Gauge API calculator code in RPN format, possibly with some kind of result expected. | |
HRESULT | registerEvent (const RegisteredEvent &eventData) |
Register a reusable event which executes a pre-set RPN calculator code string. The code is pre-compiled and stored on the server for quicker execution. The event can have an optional custom name for direct use with any SimConnect client. Registered events can also be triggered by using the transmitEvent() method. If the server is not currently connected, the event registration will be queued and sent next time a connection is established. | |
HRESULT | removeEvent (uint32_t eventId) |
Remove an event previously registered with registerEvent() method. This is effectively the same as calling registerEvent() with an empty code parameter. If the server is not currently connected, the removal request will be queued and sent next time a connection is established. | |
HRESULT | transmitEvent (uint32_t eventId) |
Trigger an event previously registered with registerEvent() . This is a more direct alternative to triggering events by name via SimConnect. | |
RegisteredEvent | registeredEvent (uint32_t eventId) |
Returns a copy of a RegisteredEvent which has been previously added with registerEvent() . If the event with the given eventId doesn't exist, an invalid RegisteredEvent is returned which has the members RegisteredEvent::eventId set to -1 , and RegisteredEvent::code and RegisteredEvent::name both empty. | |
std::vector< RegisteredEvent > | registeredEvents () const |
Returns a list of all registered events which have been added to the Client with registerEvent() . The list members are created by copy. | |
Variables accessor methods | |
HRESULT | getVariable (const VariableRequest &variable, double *pfResult, std::string *psResult=nullptr) |
Get a Variable value by name, with optional named unit type. This is primarily useful for local ('L') variables, SimVars ('A') and token variables ('T') which can be read via dedicated Gauge API functions (get_named_variable_value() /get_named_variable_typed_value() , aircraft_varget() , and lookup_var() respectively). Other variables types can also be set this way ('C', 'E', 'M', etc) but such requests are simply converted to a calculator string and evaluated via the Gauge API execute_calculator_code() . Likewise, requesting string-type variables using this method also ends up running a calculator expression on the server side. In both cases, using WASimClient::executeCalculatorCode() directly may be more efficient. Also, unlike executeCalculatorCode() , this method will not return a string representation of a numeric value. | |
HRESULT | getLocalVariable (const std::string &variableName, double *pfResult, const std::string &unitName=std::string()) |
A convenience version of getVariable(VariableRequest(variableName, false, unitName), pfResult) . See getVariable() and VariableRequest for details. | |
HRESULT | getOrCreateLocalVariable (const std::string &variableName, double *pfResult, double defaultValue=0.0, const std::string &unitName=std::string()) |
Gets the value of a local variable just like getLocalVariable() but will also create the variable on the simulator if it doesn't already exist. | |
HRESULT | setVariable (const VariableRequest &variable, const double value) |
Set a Variable value by name, with optional named unit type. Although any settable variable type can set this way, it is primarily useful for local (L ) variables which can be set via dedicated Gauge API functions (set_named_variable_value() and set_named_variable_typed_value() ). Other variables types can also be set this way but such requests are simply converted to a calculator string and evaluated via the Gauge API execute_calculator_code() . Using WASimClient::executeCalculatorCode() directly may be more efficient. The following conditions must be observed: | |
HRESULT | setVariable (const VariableRequest &variable, const std::string &stringValue) |
This is an overloaded method. This version allows setting an 'A' type (SimVar) variable to a string value. Only 'A' type variables can be set this way. Since there is actually no direct way to set string-type values from WASM code, this is just a convenience method and simply invokes SimConnect to do the work. On first use with a new variable name it will set up a mapping of the name to an internally-assigned ID (calling SimConnect_AddToDataDefinition() ) and cache that mapping. Then on subsequent invocations on the same variable the mapped ID will be used directly. The mappings are invalidated when disconnecting from the simulator. | |
HRESULT | setLocalVariable (const std::string &variableName, const double value, const std::string &unitName=std::string()) |
A convenience version of setVariable() for Local variable types. Equivalent to setVariable(VariableRequest(variableName, false, unitName), value) . See setVariable() and VariableRequest for details. | |
HRESULT | setOrCreateLocalVariable (const std::string &variableName, const double value, const std::string &unitName=std::string()) |
Set a Local Variable value by variable name, creating it first if it does not already exist. This first calls the register_named_variable() Gauge API function to get the ID from the name, which creates the variable if it doesn't exist. The returned ID (new or existing) is then used to set the value. Use the lookup() method to check for the existence of a variable name. Equivalent to setVariable(VariableRequest(variableName, true, unitName), value) . See setVariable() and VariableRequest for details. | |
HRESULT | setSimVarVariable (const std::string &variableName, const std::string &unitName, double value) |
Sets a numeric value on an 'A' (aka "SimVar" / "Simulator Variable") type variable. This is a convenience version of setVariable() , equivalent to setVariable(VariableRequest(variableName, unitName), value) . See setVariable() and VariableRequest for details.Note that variableName can optionally contain an index after a colon (eg. VAR NAME:1 ), or the setSimVarVariable(const string& name, uint8_t index, const string& unit, double value) overload could be used to provide the index separately. For MSFS 2024 Sim Vars which use component name suffixes, specify them in the variable name itself. | |
HRESULT | setSimVarVariable (const std::string &variableName, uint8_t index, const std::string &unitName, double value) |
Sets a numeric value on an indexed 'A' (aka "SimVar" / "Simulator Variable") type variable. This is a convenience version of setVariable() , equivalent to setVariable(VariableRequest(variableName, unitName, index), value) . See setVariable() and VariableRequest for details. | |
HRESULT | setSimVarVariable (const std::string &variableName, const std::string &stringValue) |
Sets a string value on an 'A' (aka "SimVar" / "Simulator Variable") type variable. This is a convenience version of setVariable() , equivalent to setVariable(VariableRequest( 'A', variableName), stringValue) . See setVariable(const VariableRequest &, const std::string &) for details. | |
HRESULT | setSimVarVariable (const std::string &variableName, uint8_t index, const std::string &stringValue) |
Sets a string value on an indexed 'A' (aka "SimVar" / "Simulator Variable") type variable. This is a convenience version of setVariable() , equivalent to setVariable(VariableRequest(variableName, {}, index), stringValue) . See setVariable(const VariableRequest &, const std::string &) for details. | |
Data change subscriptions (variables and calculated results) | |
HRESULT | saveDataRequest (const DataRequest &request, bool async=false) |
Add a new WASimCommander::DataRequest for a variable or calculated result, or update an existing data request with the same DataRequest::requestId . Data changes (updates) are delivered asynchronously via the callback function set with setDataCallback() , which then passes a DataRequestRecord structure as the callback argument (this provides both a reference to the original DataRequest registered here, as well as result data). | |
HRESULT | removeDataRequest (const uint32_t requestId) |
Remove a previously-added DataRequest . This clears the subscription and any tracking/meta data from both server and client sides. Using this method is effectively the same as calling dataRequest() with a DataRequest of type RequestType::None . | |
HRESULT | updateDataRequest (uint32_t requestId) |
Trigger a data update on a previously-added DataRequest . Designed to refresh data on subscriptions with update periods of UpdatePeriod::Never or UpdatePeriod::Once , though it can be used with any subscription. Using this update method also skips any equality checks on the server side (though any delta epsilon value remains in effect on client side). | |
DataRequestRecord | dataRequest (uint32_t requestId) const |
Returns a copy of a DataRequestRecord which has been previously added. If the request with the given requestId doesn't exist, an invalid DataRequestRecord is returned which has the members DataRequest::requestId set to -1 , DataRequest::valueSize set to 0 , and DataRequest::requestType set to RequestType::None . | |
std::vector< DataRequestRecord > | dataRequests () const |
Returns a list of all data requests which have been added to the Client so far. (These are returned by copy operation, so for a long list it may get "expensive.") | |
std::vector< uint32_t > | dataRequestIdsList () const |
Returns a list of all DataRequest::requestId s which have been added to the Client so far. | |
HRESULT | setDataRequestsPaused (bool paused) const |
Enables or disables all data request subscription updates at the same time. Use this to temporarily suspend value update checks when they are not needed, but may be again in the future. This is a lot more efficient than disconnecting and re-connecting to the server, since all the data requests need to be re-created upon every new connection (similar to SimConnect itself). | |
Simulator Key Events | |
HRESULT | sendKeyEvent (uint32_t keyEventId, uint32_t v1=0, uint32_t v2=0, uint32_t v3=0, uint32_t v4=0, uint32_t v5=0) const |
Can be used to trigger standard Simulator "Key Events" as well as "custom" Gauge API/SimConnect events. Up to 5 optional values can be passed onto the event handler. This provides functionality similar to the Gauge API function trigger_key_event_EX1() and SimConnect_TransmitClientEvent[_EX1()] . Standard Key Event IDs can be found in the SimConnect SDK header file 'MSFS/Legacy/gauges.h' in the form of KEY_* macro values, and event names can also be resolved to IDs programmatically using the lookup() method. No preliminary setup is required to trigger these events, but a full connection to WASimModule ("server") is needed. These are triggered on the simulator side using trigger_key_event_EX1() function calls. Custom Events for which a numeric ID is already known (typically in the Gauge API THIRD_PARTY_EVENT_ID_MIN /THIRD_PARTY_EVENT_ID_MAX ID range) can also be triggered directly as with standard events. These types of events are also passed directly to trigger_key_event_EX1() . Named Custom Events, for which an ID is not known or predefined, must first be registered with registerCustomKeyEvent() , which creates and maps (and optionally returns) a unique ID corresponding to the custom event name. An active simulator (SimConnect) connection is required to trigger these types of events. They are invoked via SimConnect_TransmitClientEvent[_EX1()] method directly from this client (this is actually just a convenience for the WASimClient user to avoid needing a separate SimConnect session). Which actual SimConnect function is used depends on how the custom event was registered (default is to use the newer "_EX1" version which allows up to 5 event values). See docs for registerCustomKeyEvent() for further details on using custom simulator events. | |
HRESULT | sendKeyEvent (const std::string &keyEventName, uint32_t v1=0, uint32_t v2=0, uint32_t v3=0, uint32_t v4=0, uint32_t v5=0) |
This is an overloaded method. See sendKeyEvent(uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t) const for main details. This version allows triggering Key Events by name instead of an ID. All simulator event names must be resolved, or mapped, to a numeric ID before they can be triggered (used). The first time this method is invoked with a particular event name, it tries to associate that name with an ID (based on the event name, as described below). If successful, the ID is cached, so subsequent calls to this method, with the same event name, will use the cached ID instead of trying to resolve the name again. | |
HRESULT | registerCustomKeyEvent (const std::string &customEventName, uint32_t *puiCustomEventId=nullptr, bool useLegacyTransmit=false) |
Register a "Custom Simulator [Key] Event" by providing an event name. The method optionally returns the generated event ID, which can later be used with sendKeyEvent() method instead of the event name. It can also be used to look up a previous registration's ID if the event name has already been registered. Custom event names are mapped to internally-generated unique IDs using a standard SimConnect call to MapClientEventToSimEvent, and the documentation briefly describes custom event usage and name syntax in the EventName parameter description. This method serves a similar purpose (and in fact eventually calls that same SimConnect function). The mappings must be re-established every time a new connection with SimConnect is made, which WASimClient takes care of automatically. If currently connected to the simulator, the event is immediately mapped, otherwise it will be mapped upon the next connection. An event registration can be removed with removeCustomKeyEvent() which will prevent any SimConnect mapping from being created upon the next connection. If you're not going to store the ID that will be generated anyway, sendKeyEvent(customEventName, ...) can be used directly, which will automatically call this method the first time the event name is used. The ID can always be looked up later if needed (by calling this method). Note that the custom event mapping/triggering feature is actually just a convenience for the WASimClient user and doesn't involve the usual server interactions (WASimModule) at all. | |
HRESULT | removeCustomKeyEvent (const std::string &customEventName) |
Remove a Custom Event previously registered with registerCustomEvent() method using the event's name. This will prevent the custom event from being mapped next time the client connects to SimConnect. | |
HRESULT | removeCustomKeyEvent (uint32_t eventId) |
This is an overloaded method. Same as removeCustomKeyEvent(const string &) but the event can be specified using the associated numeric event ID (originally returned from registerCustomKeyEvent() ) instead of the name. | |
Metadata retrieval | |
HRESULT | list (WASimCommander::Enums::LookupItemType itemsType=WASimCommander::Enums::LookupItemType::LocalVariable) |
Send a request for a list update to the server. The results are delivered using the callback set in setListResultsCallback() . | |
HRESULT | lookup (WASimCommander::Enums::LookupItemType itemType, const std::string &itemName, int32_t *piResult) |
Request a lookup of a named item to find its corresponding numeric ID. Most lookup types are done on the server side, so an active connection is required. The exception is looking up Key Event IDs (Enums::LookupItemType::KeyEventId), which are performed locally. | |
Low level API | |
HRESULT | sendCommand (const Command &command) const |
Sends a command, in the form of a WASimCommander::Command structure, to the server for processing. The various command types and the data requirements for each are described in the WASimCommander::Enums::CommandId documentation. To receive command responses from the server, set a callback with setCommandResultCallback() , then check the results for a Command::token which matches the token set in the command you're sending here. | |
HRESULT | sendCommandWithResponse (const Command &command, Command *response, uint32_t timeout=0) |
Sends a command, in the form of a WASimCommander::Command structure, to the server for processing and waits for a reply (an Ack/Nak response Command ). The various command types and the data requirements for each are described in the WASimCommander::Enums::CommandId documentation. | |
Logging settings | |
WASimCommander::Enums::LogLevel | logLevel (WASimCommander::Enums::LogFacility facility, LogSource source=LogSource::Client) const |
Get the current minimum logging severity level for the specified facility and source . | |
void | setLogLevel (WASimCommander::Enums::LogLevel level, WASimCommander::Enums::LogFacility facility=WASimCommander::Enums::LogFacility::Remote, LogSource source=LogSource::Client) |
Set the current minimum logging severity level for the specified facility and source to level . | |
Callbacks | |
| |
void | setClientEventCallback (clientEventCallback_t cb) |
Sets a callback for Client event updates which indicate status changes. Pass a nullptr value to remove a previously set callback. Usage: | |
template<class Tcaller > | |
void | setClientEventCallback (void(__stdcall Tcaller::*const member)(const ClientEvent &), Tcaller *const caller) |
Same as setClientEventCallback(clientEventCallback_t) . Convenience for avoiding a std::bind expression. Usage: | |
void | setListResultsCallback (listResultsCallback_t cb) |
Sets a callback for list results arriving from the server. Pass a nullptr value to remove a previously set callback. Usage: | |
template<class Tcaller > | |
void | setListResultsCallback (void(__stdcall Tcaller::*const member)(const ListResult &), Tcaller *const caller) |
Same as setListResultsCallback(listResultsCallback_t) . Convenience for avoiding a std::bind expression. Usage: | |
void | setDataCallback (dataCallback_t cb) |
Sets a callback for value update data arriving from the server. Pass a nullptr value to remove a previously set callback. Usage: | |
template<class Tcaller > | |
void | setDataCallback (void(__stdcall Tcaller::*const member)(const DataRequestRecord &), Tcaller *const caller) |
Same as setDataCallback(dataCallback_t) . Convenience overload template for avoiding a std::bind expression. Usage: | |
void | setLogCallback (logCallback_t cb) |
Sets a callback for logging activity, both from the server and the client itself. Pass a nullptr value to remove a previously set callback. Usage: | |
template<class Tcaller > | |
void | setLogCallback (void(__stdcall Tcaller::*const member)(const LogRecord &, LogSource), Tcaller *const caller) |
Same as setLogCallback(logCallback_t) . Convenience template for avoiding a std::bind expression. Usage: | |
void | setCommandResultCallback (commandCallback_t cb) |
Sets a callback for delivering command results returned by the server. Pass a nullptr value to remove a previously set callback. While some of the high-level Client API calls do return an immediate status or result, many of the server commands are sent asynchronously, in a fire-and-forget fashion. If you would like to be notified about all command responses, set this callback. The Command type delivered will have the Command::commandId of type CommandId::Ack or CommandId::Nak . The Command::uData member is set to the commandId of the original command being responded to. Other Command struct members may have other meanings, depending on the actual command being responded to. See documentation for WASimCommander::Enums::CommandId for details. Usage: | |
template<class Tcaller > | |
void | setCommandResultCallback (void(__stdcall Tcaller::*const member)(const Command &), Tcaller *const caller) |
Same as setCommandResultCallback(commandCallback_t) . Convenience overload template for avoiding a std::bind expression. Usage: | |
void | setResponseCallback (commandCallback_t cb) |
Sets a callback for delivering response commands sent to this client by the server module. Note that the server may also initiate a few types of commands (not in response to client commands) such as Ping , List , and Disconnect . In contrast to setCommandResultCallback(commandCallback_t) , this one will report on all commands from the server, not just Ack/Nak . This callback is meant for low-level API usage. Usage: | |
template<class Tcaller > | |
void | setResponseCallback (void(__stdcall Tcaller::*const member)(const Command &), Tcaller *const caller) |
Same as setResponseCallback(commandCallback_t) . Convenience overload template for avoiding a std::bind expression. Usage: | |
WASimCommander Client implementation. Handles all aspects of communication with the WASimCommander Server WASM module.
Definition at line 84 of file WASimClient.h.
|
explicit |
Instantiate the client with a unique ID and optional configuration file path.
clientId | This ID must not be shared with any other Client accessing the Server. The ID is also used as the client name by converting it to a 8-character hexadecimal string. For example 3235839725 = "C0DEFEED". Get creative. The client name is used as a key component of data exchange with the simulator engine. The ID cannot be zero, and server connections will fail if it is. It can also be set/changed after class creation using the setClientId() method, but before connecting to the server. |
configFile | Optionally provide the path to a configuration file for reading initial startup settings. By default the client will look for a client_conf.ini file in the current working directory. The parameter value may include the file name (with extension), or be only a file system path, in which case the default file name of "client_conf.ini" will be appended. |
Definition at line 1613 of file WASimClient.cpp.
WASimClient::~WASimClient | ( | ) |
Any open network connections are automatically closed upon destruction, though it is better to close them yourself before deleting the client.
Definition at line 1617 of file WASimClient.cpp.
ClientStatus WASimCommander::Client::WASimClient::status | ( | ) | const |
Get current connection status of this client.
Definition at line 2051 of file WASimClient.cpp.
bool WASimCommander::Client::WASimClient::isInitialized | ( | ) | const |
Check if simulator network link is established.
Definition at line 2052 of file WASimClient.cpp.
bool WASimCommander::Client::WASimClient::isConnected | ( | ) | const |
Check WASimCommander server connection status.
Definition at line 2053 of file WASimClient.cpp.
uint32_t WASimCommander::Client::WASimClient::clientVersion | ( | ) | const |
Return the current WASimClient version number. Version numbers are in "BCD" format: MAJOR << 24 | MINOR << 16 | PATCH << 8 | BUILD
, eg: 1.23.45.67 = 0x01234567
Definition at line 2054 of file WASimClient.cpp.
uint32_t WASimCommander::Client::WASimClient::serverVersion | ( | ) | const |
Return the version number of the last-connected, or successfully pinged, WASimModule (sever), or zero if unknown. See clientVersion()
for numbering details.
Definition at line 2055 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::connectSimulator | ( | uint32_t | timeout = 0 | ) |
Initialize the simulator network link and set up minimum necessary for WASimCommander server ping or connection. Uses default network SimConnect configuration ID.
timeout | Maximum time to wait for response, in milliseconds. Zero (default) means to use the defaultTimeout() value. |
S_OK
(0) - Success;E_FAIL
(0x80004005) - General failure (most likely simulator is not running);E_TIMEOUT
(0x800705B4) - Connection attempt timed out (simulator/network issue);E_INVALIDARG
(0x80070057) - The Client ID set in constructor is invalid (zero) or the SimConnect.cfg file did not contain the default config index (see networkConfigurationId()
) ; Definition at line 1626 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::connectSimulator | ( | int | networkConfigId, |
uint32_t | timeout = 0 ) |
Initialize the simulator network link and set up minimum necessary for WASimCommander server ping or connection. This overload allows specifying a SimConnect configuration ID and optional timeout value.
networkConfigId | SimConnect is used for the network layer. Specify the SimConnect.cfg index to use, or -1 (default) to force a local connection. |
timeout | Maximum time to wait for response, in milliseconds. Zero (default) means to use the defaultTimeout() value. |
S_OK
(0) - Success;E_FAIL
(0x80004005) - General failure (most likely simulator is not running);E_TIMEOUT
(0x800705B4) - Connection attempt timed out (simulator/network issue);E_INVALIDARG
(0x80070057) - The Client ID set in constructor is invalid (zero) or the SimConnect.cfg file did not contain the config index requested in the simConnectConfigId
parameter; Definition at line 1635 of file WASimClient.cpp.
void WASimCommander::Client::WASimClient::disconnectSimulator | ( | ) |
Shut down all network connections (and disconnect WASimCommander server if connected). After calling this method, one must call connectSimulator()
/connectServer()
/pingServer()
again before any other commands.
Definition at line 1639 of file WASimClient.cpp.
uint32_t WASimCommander::Client::WASimClient::pingServer | ( | uint32_t | timeout = 0 | ) |
Check if WASimCommander Server exists (Simulator running, the WASIM module is installed and working). Returns server version number, or zero if server did not respond.
This will implicitly call connectSimulator()
first if it hasn't already been done, using the default network configuration settings. Zero will be returned if the connection could not be established.
timeout | Maximum time to wait for response, in milliseconds. Zero (default) means to use the defaultTimeout() value. |
0
) if server (or simulator) didn't respond within the timeout period. Definition at line 1651 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::connectServer | ( | uint32_t | timeout = 0 | ) |
Connect to WASimCommander server. This will implicitly call connectSimulator()
first if it hasn't already been done, using the default network configuration setting.
timeout | Maximum time to wait for response, in milliseconds. Zero (default) means to use the defaultTimeout() value. |
S_OK
(0) - Success.E_FAIL
(0x80004005) - General failure (most likely simulator is not running).E_TIMEOUT
(0x800705B4) - Connection attempt timed out (simulator/network issue or WASimCommander WASM module is not installed/running).E_INVALIDARG
(0x80070057) - The Client ID set in constructor is invalid (zero) or the SimConnect.cfg file did not contain the default config index. Definition at line 1643 of file WASimClient.cpp.
void WASimCommander::Client::WASimClient::disconnectServer | ( | ) |
Disconnect from the WASimCommander server. This does not close the Simulator network connection (use disconnectSimulator()
to do that or both at once).
Definition at line 1647 of file WASimClient.cpp.
uint32_t WASimCommander::Client::WASimClient::defaultTimeout | ( | ) | const |
Get the current default server response timeout value, which is used in all network requests. The initial default setting is read from the client_conf.ini
file or set to 1000ms if no config file was found.
Definition at line 2057 of file WASimClient.cpp.
void WASimCommander::Client::WASimClient::setDefaultTimeout | ( | uint32_t | ms | ) |
Get current connection status of this client.
Definition at line 2058 of file WASimClient.cpp.
int WASimCommander::Client::WASimClient::networkConfigurationId | ( | ) | const |
SimConnect is used for the network layer. This setting specifies the SimConnect.cfg index to use. The value of -1 forces a local connection. The initial default setting is read from the client_conf.ini
file or set to -1
if no config file was found.
Definition at line 2060 of file WASimClient.cpp.
void WASimCommander::Client::WASimClient::setNetworkConfigurationId | ( | int | configId | ) |
SimConnect is used for the network layer. This setting specifies the SimConnect.cfg index to use, or -1 to force a local connection. Note that this must be called before connectSimulator()
invocation in order to have any effect.
Definition at line 2061 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::executeCalculatorCode | ( | const std::string & | code, |
WASimCommander::Enums::CalcResultType | resultType = WASimCommander::Enums::CalcResultType::None, | ||
double * | pfResult = nullptr, | ||
std::string * | psResult = nullptr ) const |
Run a string of MSFS Gauge API calculator code in RPN format, possibly with some kind of result expected.
code | The text of the code to execute. See https://docs.flightsimulator.com/html/Additional_Information/Reverse_Polish_Notation.htm |
resultType | Expected result type, or Enums::CalcResultType::None (default) if no result is expected. If the type is Enums::CalcResultType::Formatted then the server runs the code using format_calculator_string() Gauge API function (see @ bottom of RPN docs for formatting options) and the result type is always a string. Otherwise execute_calculator_code() is used and any of the result types can be returned (in fact execute_calculator_code() always returns any results in all 3 types at once, so even if a numeric result is requested, the string result will also be populated). |
pfResult | A pointer to an initialized variable of double to store the result into if resultType is Enums::CalcResultType::Double or Enums::CalcResultType::Integer . |
psResult | A string pointer to store the string result into. The string version is typically populated even for numeric type requests, but definitely for Enums::CalcResultType::String or Enums::CalcResultType::Formatted type requests. |
S_OK
on success, E_NOT_CONNECTED
if not connected to server; E_FAIL
if the server returned Nak response, or E_TIMEOUT
on general server communication failure. resultType
!= Enums::CalcResultType::None
) then this method blocks until either the Server responds or the timeout has expired (see defaultTimeout()
). To request calculated results in a non-blocking fashion, use a data request instead.If you need to execute the same code multiple times, it would be more efficient to save the code as either a data request (for code returning values) or a registered event (for code not returning values). The advantage is that in those cases the calculator string is pre-compiled to byte code and saved once, then each invocation of the Gauge API calculator functions uses the more efficient byte code version. (To prevent automatic data updates for data requests, just set the data request period to Enums::UpdatePeriod::Never
or Enums::UpdatePeriod::Once
and use the updateDataRequest()
method to poll for value updates as needed.) See saveDataRequest()
and registerEvent()
respectively for details.
Definition at line 1679 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::getVariable | ( | const VariableRequest & | variable, |
double * | pfResult, | ||
std::string * | psResult = nullptr ) |
Get a Variable value by name, with optional named unit type. This is primarily useful for local ('L') variables, SimVars ('A') and token variables ('T') which can be read via dedicated Gauge API functions (get_named_variable_value()
/get_named_variable_typed_value()
, aircraft_varget()
, and lookup_var()
respectively).
Other variables types can also be set this way ('C', 'E', 'M', etc) but such requests are simply converted to a calculator string and evaluated via the Gauge API execute_calculator_code()
.
Likewise, requesting string-type variables using this method also ends up running a calculator expression on the server side.
In both cases, using WASimClient::executeCalculatorCode()
directly may be more efficient. Also, unlike executeCalculatorCode()
, this method will not return a string representation of a numeric value.
variable | See VariableRequest documentation for descriptions of the individual fields. |
pfResult | Pointer to a double precision variable to hold the numeric result. |
psResult | Pointer to a string type variable to hold a string-type result. See notes above regarding string types. |
S_OK
on success, E_INVALIDARG
on parameter validation errors, E_NOT_CONNECTED
if not connected to server, E_TIMEOUT
on server communication failure, or E_FAIL
if server returns a Nak response. Definition at line 1708 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::getLocalVariable | ( | const std::string & | variableName, |
double * | pfResult, | ||
const std::string & | unitName = std::string() ) |
A convenience version of getVariable(VariableRequest(variableName, false, unitName), pfResult)
. See getVariable()
and VariableRequest
for details.
variableName | Name of the local variable. |
pfResult | Pointer to a double precision variable to hold the result. |
unitName | Optional unit specifier to use. Most Local vars do not specify a unit and default to a generic "number" type. |
S_OK
on success, E_INVALIDARG
on parameter validation errors, E_NOT_CONNECTED
if not connected to server, E_TIMEOUT
on server communication failure, or E_FAIL
if server returns a Nak response. Definition at line 1717 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::getOrCreateLocalVariable | ( | const std::string & | variableName, |
double * | pfResult, | ||
double | defaultValue = 0.0, | ||
const std::string & | unitName = std::string() ) |
Gets the value of a local variable just like getLocalVariable()
but will also create the variable on the simulator if it doesn't already exist.
variableName | Name of the local variable. |
pfResult | Pointer to a double precision variable to hold the result. |
defaultValue | The L var will be created on the simulator if it doesn't exist yet using this initial value (and this same value will be returned in pfResult ). |
unitName | Optional unit specifier to use. Most Local vars do not specify a unit and default to a generic "number" type. |
S_OK
on success, E_INVALIDARG
on parameter validation errors, E_NOT_CONNECTED
if not connected to server, E_TIMEOUT
on server communication failure, or E_FAIL
if server returns a Nak response. Definition at line 1721 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::setVariable | ( | const VariableRequest & | variable, |
const double | value ) |
Set a Variable value by name, with optional named unit type. Although any settable variable type can set this way, it is primarily useful for local (L
) variables which can be set via dedicated Gauge API functions (set_named_variable_value()
and set_named_variable_typed_value()
).
Other variables types can also be set this way but such requests are simply converted to a calculator string and evaluated via the Gauge API execute_calculator_code()
. Using WASimClient::executeCalculatorCode()
directly may be more efficient.
The following conditions must be observed:
VariableRequest::variableType
must be "settable" ('A', 'B', 'C', 'H', 'K', 'L', or 'Z'), otherwise an E_INVALIDARG
result is returned.VariableRequest::variableName
– using just an ID returns E_INVALIDARG
. VariableRequest::unitName
), not an ID. Using only an ID will not cause an error, but the unit will not be included in the generated RPN code. variable | See VariableRequest documentation for descriptions of the individual fields. |
value | The numeric value to set. |
S_OK
on success, E_INVALIDARG
on parameter validation errors, E_NOT_CONNECTED
if not connected to server, or E_FAIL
on general failure (unlikely). Definition at line 1726 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::setVariable | ( | const VariableRequest & | variable, |
const std::string & | stringValue ) |
This is an overloaded method. This version allows setting an 'A' type (SimVar) variable to a string value. Only 'A' type variables can be set this way.
Since there is actually no direct way to set string-type values from WASM code, this is just a convenience method and simply invokes SimConnect to do the work. On first use with a new variable name it will set up a mapping of the name to an internally-assigned ID (calling SimConnect_AddToDataDefinition()
) and cache that mapping. Then on subsequent invocations on the same variable the mapped ID will be used directly. The mappings are invalidated when disconnecting from the simulator.
Definition at line 1730 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::setLocalVariable | ( | const std::string & | variableName, |
const double | value, | ||
const std::string & | unitName = std::string() ) |
A convenience version of setVariable()
for Local variable types. Equivalent to setVariable(VariableRequest(variableName, false, unitName), value)
. See setVariable()
and VariableRequest
for details.
variableName | Name of the local variable. |
value | The value to set. |
unitName | Optional unit specifier to use. Most Local vars do not specify a unit and default to a generic "number" type. |
S_OK
on success, E_INVALIDARG
on parameter validation errors, E_NOT_CONNECTED
if not connected to server, or E_FAIL
on general failure (unlikely). Definition at line 1734 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::setOrCreateLocalVariable | ( | const std::string & | variableName, |
const double | value, | ||
const std::string & | unitName = std::string() ) |
Set a Local Variable value by variable name, creating it first if it does not already exist. This first calls the register_named_variable()
Gauge API function to get the ID from the name, which creates the variable if it doesn't exist. The returned ID (new or existing) is then used to set the value. Use the lookup()
method to check for the existence of a variable name. Equivalent to setVariable(VariableRequest(variableName, true, unitName), value)
. See setVariable()
and VariableRequest
for details.
variableName | Name of the local variable. |
value | The value to set. Becomes the initial value if the variable is created. |
unitName | Optional unit specifier to use. Most Local vars do not specify a unit and default to a generic "number" type. |
S_OK
on success, E_INVALIDARG
on parameter validation errors, E_NOT_CONNECTED
if not connected to server, or E_FAIL
on general failure (unlikely). Definition at line 1738 of file WASimClient.cpp.
|
inline |
Sets a numeric value on an 'A' (aka "SimVar" / "Simulator Variable") type variable.
This is a convenience version of setVariable()
, equivalent to setVariable(VariableRequest(variableName, unitName), value)
. See setVariable()
and VariableRequest
for details.
Note that variableName
can optionally contain an index after a colon (eg. VAR NAME:1
), or the setSimVarVariable(const string& name, uint8_t index, const string& unit, double value)
overload could be used to provide the index separately. For MSFS 2024 Sim Vars which use component name suffixes, specify them in the variable name itself.
Definition at line 262 of file WASimClient.h.
|
inline |
Sets a numeric value on an indexed 'A' (aka "SimVar" / "Simulator Variable") type variable.
This is a convenience version of setVariable()
, equivalent to setVariable(VariableRequest(variableName, unitName, index), value)
. See setVariable()
and VariableRequest
for details.
Definition at line 266 of file WASimClient.h.
|
inline |
Sets a string value on an 'A' (aka "SimVar" / "Simulator Variable") type variable.
This is a convenience version of setVariable()
, equivalent to setVariable(VariableRequest(
'A', variableName), stringValue)
. See setVariable(const VariableRequest &, const std::string &)
for details.
Definition at line 270 of file WASimClient.h.
|
inline |
Sets a string value on an indexed 'A' (aka "SimVar" / "Simulator Variable") type variable.
This is a convenience version of setVariable()
, equivalent to setVariable(VariableRequest(variableName, {}, index), stringValue)
. See setVariable(const VariableRequest &, const std::string &)
for details.
Definition at line 274 of file WASimClient.h.
HRESULT WASimCommander::Client::WASimClient::saveDataRequest | ( | const DataRequest & | request, |
bool | async = false ) |
Add a new WASimCommander::DataRequest
for a variable or calculated result, or update an existing data request with the same DataRequest::requestId
. Data changes (updates) are delivered asynchronously via the callback function set with setDataCallback()
, which then passes a DataRequestRecord
structure as the callback argument (this provides both a reference to the original DataRequest
registered here, as well as result data).
request | The WASimCommander::DataRequest structure to process. See WASimCommander::DataRequest documentation for details of the structure members. |
async | Set to false (default) to wait for an Ack /Nak response from the server before returning from this method, or true to return without waiting for a response. See return values and the Note below for more details. |
S_OK
on success, E_INVALIDARG
if there is a problem with the DataRequest
contents. async
is false
, may also return E_FAIL
if the server returned Nak
response, or E_TIMEOUT
on general server communication failure. async
param is false
, this method will block until either the Server responds or the timeout has expired (see defaultTimeout()
). If the client is not currently connected to the server, the request is queued until the next connection is established (and this method is non-blocking regardless of async
argument). setCommandResultCallback()
. The server should respond with an Enums::CommandId::Ack or Enums::CommandId::Nak Command where the uData
value is Enums::CommandId::Subscribe and the Command::token will be the requestId
value from the given request
struct. Definition at line 1746 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::removeDataRequest | ( | const uint32_t | requestId | ) |
Remove a previously-added DataRequest
. This clears the subscription and any tracking/meta data from both server and client sides. Using this method is effectively the same as calling dataRequest()
with a DataRequest
of type RequestType::None
.
requestId | ID of the request to remove. |
S_OK
on success, E_FAIL
if the original request wasn't found. saveDataRequest()
) and suspend updates by setting the DataRequest::period
to UpdatePeriod::Never
. To resume updates change the period again. Definition at line 1750 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::updateDataRequest | ( | uint32_t | requestId | ) |
Trigger a data update on a previously-added DataRequest
. Designed to refresh data on subscriptions with update periods of UpdatePeriod::Never
or UpdatePeriod::Once
, though it can be used with any subscription. Using this update method also skips any equality checks on the server side (though any delta epsilon value remains in effect on client side).
requestId | The ID of a previously added DataRequest . |
S_OK
on success, E_FAIL
if the original request wasn't found,. Definition at line 1754 of file WASimClient.cpp.
DataRequestRecord WASimCommander::Client::WASimClient::dataRequest | ( | uint32_t | requestId | ) | const |
Returns a copy of a DataRequestRecord
which has been previously added. If the request with the given requestId
doesn't exist, an invalid DataRequestRecord
is returned which has the members DataRequest::requestId
set to -1
, DataRequest::valueSize
set to 0
, and DataRequest::requestType
set to RequestType::None
.
Definition at line 1761 of file WASimClient.cpp.
vector< DataRequestRecord > WASimCommander::Client::WASimClient::dataRequests | ( | ) | const |
Returns a list of all data requests which have been added to the Client so far. (These are returned by copy operation, so for a long list it may get "expensive.")
Definition at line 1772 of file WASimClient.cpp.
vector< uint32_t > WASimCommander::Client::WASimClient::dataRequestIdsList | ( | ) | const |
Returns a list of all DataRequest::requestId
s which have been added to the Client so far.
Definition at line 1784 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::setDataRequestsPaused | ( | bool | paused | ) | const |
Enables or disables all data request subscription updates at the same time. Use this to temporarily suspend value update checks when they are not needed, but may be again in the future. This is a lot more efficient than disconnecting and re-connecting to the server, since all the data requests need to be re-created upon every new connection (similar to SimConnect itself).
S_OK
on success; If currently connected to the server, may also return E_TIMEOUT
on general server communication failure. Definition at line 1796 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::registerEvent | ( | const RegisteredEvent & | eventData | ) |
Register a reusable event which executes a pre-set RPN calculator code string. The code is pre-compiled and stored on the server for quicker execution. The event can have an optional custom name for direct use with any SimConnect client. Registered events can also be triggered by using the transmitEvent()
method. If the server is not currently connected, the event registration will be queued and sent next time a connection is established.
S_OK
on success, E_INVALIDARG
if the resulting code string is too long or if trying to change the name of an already registered event. Definition at line 1811 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::removeEvent | ( | uint32_t | eventId | ) |
Remove an event previously registered with registerEvent()
method. This is effectively the same as calling registerEvent()
with an empty code
parameter. If the server is not currently connected, the removal request will be queued and sent next time a connection is established.
eventId | ID of the previously registered event. |
S_OK
on success, E_INVALIDARG
if the eventId wasn't found. Definition at line 1846 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::transmitEvent | ( | uint32_t | eventId | ) |
Trigger an event previously registered with registerEvent()
. This is a more direct alternative to triggering events by name via SimConnect.
eventId | ID of the previously registered event. If the event hasn't been registered, the server will log a warning but otherwise nothing will happen. |
S_OK
on success, E_FAIL
on general failure (unlikely), E_NOT_CONNECTED
if not connected to server. Definition at line 1866 of file WASimClient.cpp.
RegisteredEvent WASimCommander::Client::WASimClient::registeredEvent | ( | uint32_t | eventId | ) |
Returns a copy of a RegisteredEvent
which has been previously added with registerEvent()
. If the event with the given eventId
doesn't exist, an invalid RegisteredEvent
is returned which has the members RegisteredEvent::eventId
set to -1
, and RegisteredEvent::code
and RegisteredEvent::name
both empty.
Definition at line 1870 of file WASimClient.cpp.
vector< RegisteredEvent > WASimCommander::Client::WASimClient::registeredEvents | ( | ) | const |
Returns a list of all registered events which have been added to the Client with registerEvent()
. The list members are created by copy.
Definition at line 1879 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::sendKeyEvent | ( | uint32_t | keyEventId, |
uint32_t | v1 = 0, | ||
uint32_t | v2 = 0, | ||
uint32_t | v3 = 0, | ||
uint32_t | v4 = 0, | ||
uint32_t | v5 = 0 ) const |
Can be used to trigger standard Simulator "Key Events" as well as "custom" Gauge API/SimConnect events. Up to 5 optional values can be passed onto the event handler. This provides functionality similar to the Gauge API function trigger_key_event_EX1()
and SimConnect_TransmitClientEvent[_EX1()]
.
Standard Key Event IDs can be found in the SimConnect SDK header file 'MSFS/Legacy/gauges.h' in the form of KEY_*
macro values, and event names can also be resolved to IDs programmatically using the lookup()
method. No preliminary setup is required to trigger these events, but a full connection to WASimModule ("server") is needed. These are triggered on the simulator side using trigger_key_event_EX1()
function calls.
Custom Events for which a numeric ID is already known (typically in the Gauge API THIRD_PARTY_EVENT_ID_MIN
/THIRD_PARTY_EVENT_ID_MAX
ID range) can also be triggered directly as with standard events. These types of events are also passed directly to trigger_key_event_EX1()
.
Named Custom Events, for which an ID is not known or predefined, must first be registered with registerCustomKeyEvent()
, which creates and maps (and optionally returns) a unique ID corresponding to the custom event name. An active simulator (SimConnect) connection is required to trigger these types of events. They are invoked via SimConnect_TransmitClientEvent[_EX1()]
method directly from this client (this is actually just a convenience for the WASimClient user to avoid needing a separate SimConnect session). Which actual SimConnect function is used depends on how the custom event was registered (default is to use the newer "_EX1" version which allows up to 5 event values).
See docs for registerCustomKeyEvent()
for further details on using custom simulator events.
keyEventId | Numeric ID of the Event to trigger. |
v1,v2,v3,v4,v5 | Optional values to pass to the event handler. Defaults are all zeros. |
S_OK
on success, E_NOT_CONNECTED
if not connected (server or sim, see above), E_TIMEOUT
on server communication failure, or E_FAIL
on unexpected SimConnect error. trigger_key_event_EX1()
, Server responds asynchronously with an Ack/Nak response to Enums::CommandId::SendKey command type; A 'Nak' means the event ID is clearly not valid (eg. zero), but otherwise the simulator provides no feedback about event execution (from their docs: "If the event requested is not appropriate, it will simply not happen."). SimConnect_TransmitClientEvent[_EX1()]
, SimConnect may asynchronously send EXCEPTION type response messages if the ID isn't valid (likely because the event hasn't been successfully registered with registerCustomKeyEvent()
). These messages are passed through to WASimClient's logging facilities at the Warning
level. But again there is no actual confirmation that the event is going to do anything. Definition at line 1895 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::sendKeyEvent | ( | const std::string & | keyEventName, |
uint32_t | v1 = 0, | ||
uint32_t | v2 = 0, | ||
uint32_t | v3 = 0, | ||
uint32_t | v4 = 0, | ||
uint32_t | v5 = 0 ) |
This is an overloaded method. See sendKeyEvent(uint32_t, uint32_t, uint32_t, uint32_t, uint32_t, uint32_t) const
for main details. This version allows triggering Key Events by name instead of an ID.
All simulator event names must be resolved, or mapped, to a numeric ID before they can be triggered (used). The first time this method is invoked with a particular event name, it tries to associate that name with an ID (based on the event name, as described below). If successful, the ID is cached, so subsequent calls to this method, with the same event name, will use the cached ID instead of trying to resolve the name again.
registerCustomKeyEvent()
and the resulting ID is cached if that succeeds.keyEventName | Name of the Event to trigger. |
v1,v2,v3,v4,v5 | Optional values to pass to the event handler. Defaults are all zeros. |
S_OK
on success, E_INVALIDARG
if event name could not be resolved to an ID, E_NOT_CONNECTED
if not connected (server or sim, depending on event type), E_TIMEOUT
on server communication failure, or E_FAIL
on unexpected SimConnect error. std::unordered_map
type, so if you have a better way to save the event IDs from lookup()
or registerCustomKeyEvent()
, use that instead, and call the more efficient sendKeyEvent(eventId, ...)
overload directly. Definition at line 1907 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::registerCustomKeyEvent | ( | const std::string & | customEventName, |
uint32_t * | puiCustomEventId = nullptr, | ||
bool | useLegacyTransmit = false ) |
Register a "Custom Simulator [Key] Event" by providing an event name. The method optionally returns the generated event ID, which can later be used with sendKeyEvent()
method instead of the event name. It can also be used to look up a previous registration's ID if the event name has already been registered.
Custom event names are mapped to internally-generated unique IDs using a standard SimConnect call to MapClientEventToSimEvent, and the documentation briefly describes custom event usage and name syntax in the EventName
parameter description. This method serves a similar purpose (and in fact eventually calls that same SimConnect function).
The mappings must be re-established every time a new connection with SimConnect is made, which WASimClient takes care of automatically. If currently connected to the simulator, the event is immediately mapped, otherwise it will be mapped upon the next connection. An event registration can be removed with removeCustomKeyEvent()
which will prevent any SimConnect mapping from being created upon the next connection.
If you're not going to store the ID that will be generated anyway, sendKeyEvent(customEventName, ...)
can be used directly, which will automatically call this method the first time the event name is used. The ID can always be looked up later if needed (by calling this method).
Note that the custom event mapping/triggering feature is actually just a convenience for the WASimClient user and doesn't involve the usual server interactions (WASimModule) at all.
customEventName | Name of the Event to register. The event name must contain a "." (period) or start with a "#", otherwise an E_INVALIDARG result is returned. If an event with the same name has already been registered, the method returns S_OK and no further actions are performed (besides setting the optional puiCustomEventId pointer value, see below). |
puiCustomEventId | Optional pointer to 32-bit unsigned integer variable to return the generated event ID. This ID can be used to trigger the event later using sendKeyEvent() (which is more efficient than using the event name each time). The ID will always be unique per given event name, and is always equal to or greater than the Client::CUSTOM_KEY_EVENT_ID_MIN constant value. The pointer's value will be populated even if the event name was already registered (with the result of the previously generated ID). |
useLegacyTransmit | Optional, default false . Boolean value indicating that the deprecated SimConnect_TransmitClientEvent() function should be used to trigger the event instead of the newer SimConnect_TransmitClientEvent_EX1() . This may be necessary to support models which haven't updated to the newer version of the event handler. Note that the old TransmitClientEvent() function only supports sending 1 event value (vs. 5 for the "_EX1" version). To re-register the same event name but with a different value for useLegacyTransmit parameter, first remove the initial registration with removeCustomKeyEvent() and then call this method again. |
S_OK
on success, E_INVALIDARG
if the event name is invalid. Definition at line 1946 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::removeCustomKeyEvent | ( | const std::string & | customEventName | ) |
Remove a Custom Event previously registered with registerCustomEvent()
method using the event's name. This will prevent the custom event from being mapped next time the client connects to SimConnect.
customEventName | full name of the previously registered event. Must be the same name as used with registerCustomKeyEvent() . |
S_OK
on success, E_INVALIDARG
if the eventId wasn't found. Definition at line 1965 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::removeCustomKeyEvent | ( | uint32_t | eventId | ) |
This is an overloaded method. Same as removeCustomKeyEvent(const string &)
but the event can be specified using the associated numeric event ID (originally returned from registerCustomKeyEvent()
) instead of the name.
eventId | ID of the previously registered event. |
S_OK
on success, E_INVALIDARG
if the eventId wasn't found. Definition at line 1955 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::list | ( | WASimCommander::Enums::LookupItemType | itemsType = WASimCommander::Enums::LookupItemType::LocalVariable | ) |
Send a request for a list update to the server. The results are delivered using the callback set in setListResultsCallback()
.
itemsType | The type of thing to list. Supported types are local variables (Enums::LookupItemType::LocalVariable , default), subscribed Data Requests (Enums::LookupItemType::DataRequest ), and Registered Events (Enums::LookupItemType::RegisteredEvent ). |
S_OK
on success, E_INVALIDARG
if the item type is not supported, E_NOT_CONNECTED
if not connected to server. ListResult::result
HRESULT return code to be sure the list command completed successfully (which may be S_OK
, E_FAIL
if server returned Nak
, or E_TIMEOUT
if the list request did not complete (results may be empty or partial)). Definition at line 1975 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::lookup | ( | WASimCommander::Enums::LookupItemType | itemType, |
const std::string & | itemName, | ||
int32_t * | piResult ) |
Request a lookup of a named item to find its corresponding numeric ID.
Most lookup types are done on the server side, so an active connection is required. The exception is looking up Key Event IDs (Enums::LookupItemType::KeyEventId), which are performed locally.
itemType | The type of item to look up. A type of variable or a measurement unit. See the Enums::LookupItemType documentation for details. |
itemName | The name of the thing to check for. |
piResult | Pointer to 32-bit signed integer variable to hold the result. |
S_OK
on success, E_FAIL
if server returns a Nak response (typically means the item name wasn't found), E_NOT_CONNECTED
if not connected to server, E_TIMEOUT
on server communication failure. Definition at line 2005 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::sendCommand | ( | const Command & | command | ) | const |
Sends a command, in the form of a WASimCommander::Command
structure, to the server for processing. The various command types and the data requirements for each are described in the WASimCommander::Enums::CommandId
documentation. To receive command responses from the server, set a callback with setCommandResultCallback()
, then check the results for a Command::token
which matches the token
set in the command you're sending here.
S_OK
on success, E_NOT_CONNECTED
if not connected to server, E_TIMEOUT
on server communication failure. Definition at line 2039 of file WASimClient.cpp.
HRESULT WASimCommander::Client::WASimClient::sendCommandWithResponse | ( | const Command & | command, |
Command * | response, | ||
uint32_t | timeout = 0 ) |
Sends a command, in the form of a WASimCommander::Command
structure, to the server for processing and waits for a reply (an Ack/Nak
response Command
). The various command types and the data requirements for each are described in the WASimCommander::Enums::CommandId
documentation.
command | The Command struct defining the command and associated data to send. |
response | Pointer to an initialised Command structure for storing the resulting response (a Command with a commandId of Ack or Nak ), if any. |
timeout | The maximum time to wait for a response, in milliseconds. If 0 (default) then the default network timeout value is used (defaultTimeout() , setDefaultTimeout() ). |
S_OK
on success, E_NOT_CONNECTED
if not connected to server, E_TIMEOUT
on server communication failure, or possibly E_FAIL
on unknown error (check log for details). Definition at line 2043 of file WASimClient.cpp.
LogLevel WASimCommander::Client::WASimClient::logLevel | ( | WASimCommander::Enums::LogFacility | facility, |
LogSource | source = LogSource::Client ) const |
Get the current minimum logging severity level for the specified facility
and source
.
facility | One of WASimCommander::LogFacility enum flag values. This must be only one of the available flags, not a combination. The Remote facility is the one delivered via the log callback handler. |
source | One of Client::LogSource enum values. |
WASimCommander::LogLevel
value, or LogLevel::None
if the parameters were ivalid or the actual level is unknown (see Note below). File
and Console
facilities is unknown at Client startup. The returned values are only going to be correct if they were set by this instance of the Client (using setLogLevel()
). Definition at line 2063 of file WASimClient.cpp.
void WASimCommander::Client::WASimClient::setLogLevel | ( | WASimCommander::Enums::LogLevel | level, |
WASimCommander::Enums::LogFacility | facility = WASimCommander::Enums::LogFacility::Remote, | ||
LogSource | source = LogSource::Client ) |
Set the current minimum logging severity level for the specified facility
and source
to level
.
level | The new minimum level. One of WASimCommander::LogLevel enum values. Use LogLevel::None to disable logging on the given facility/source. |
facility | One or more of WASimCommander::LogFacility enum flags. The LogFacility::Remote facility is the one delivered via the log callback handler. |
source | One of Client::LogSource enum values. |
Definition at line 2064 of file WASimClient.cpp.
void WASimCommander::Client::WASimClient::setClientEventCallback | ( | clientEventCallback_t | cb | ) |
Sets a callback for Client event updates which indicate status changes. Pass a nullptr
value to remove a previously set callback.
Usage:
This callback may be invoked from the main thread (where WASimClient was created), the dedicated "dispatch" thread the client maintains, or a temporary thread in one specific case when SimConnect sends a "Quit" command.
Definition at line 2080 of file WASimClient.cpp.
|
inline |
Same as setClientEventCallback(clientEventCallback_t)
. Convenience for avoiding a std::bind expression.
Usage:
Definition at line 581 of file WASimClient.h.
void WASimCommander::Client::WASimClient::setListResultsCallback | ( | listResultsCallback_t | cb | ) |
Sets a callback for list results arriving from the server. Pass a nullptr
value to remove a previously set callback.
Usage:
This callback is invoked from temporary thread which accumulates incoming list results until the listing is complete (or times out). Currently, only one pending list request can be active at any time, though this may change in the future.
Definition at line 2081 of file WASimClient.cpp.
|
inline |
Same as setListResultsCallback(listResultsCallback_t)
. Convenience for avoiding a std::bind
expression.
Usage:
Definition at line 587 of file WASimClient.h.
void WASimCommander::Client::WASimClient::setDataCallback | ( | dataCallback_t | cb | ) |
Sets a callback for value update data arriving from the server. Pass a nullptr
value to remove a previously set callback.
Usage:
This callback is invoked from the dedicated "dispatch" thread the client maintains.
Definition at line 2082 of file WASimClient.cpp.
|
inline |
Same as setDataCallback(dataCallback_t)
. Convenience overload template for avoiding a std::bind expression.
Usage:
Definition at line 593 of file WASimClient.h.
void WASimCommander::Client::WASimClient::setLogCallback | ( | logCallback_t | cb | ) |
Sets a callback for logging activity, both from the server and the client itself. Pass a nullptr
value to remove a previously set callback.
Usage:
This callback may be invoked from either the main thread (where WASimClient was created), or the dedicated "dispatch" thread which the client maintains.
Definition at line 2083 of file WASimClient.cpp.
|
inline |
Same as setLogCallback(logCallback_t)
. Convenience template for avoiding a std::bind expression.
Usage:
Definition at line 599 of file WASimClient.h.
void WASimCommander::Client::WASimClient::setCommandResultCallback | ( | commandCallback_t | cb | ) |
Sets a callback for delivering command results returned by the server. Pass a nullptr
value to remove a previously set callback. While some of the high-level Client API calls do return an immediate status or result, many of the server commands are sent asynchronously, in a fire-and-forget fashion. If you would like to be notified about all command responses, set this callback. The Command
type delivered will have the Command::commandId
of type CommandId::Ack
or CommandId::Nak
. The Command::uData
member is set to the commandId
of the original command being responded to. Other Command
struct members may have other meanings, depending on the actual command being responded to. See documentation for WASimCommander::Enums::CommandId
for details.
Usage:
This callback is invoked from the dedicated "dispatch" thread the client maintains.
Definition at line 2084 of file WASimClient.cpp.
|
inline |
Same as setCommandResultCallback(commandCallback_t)
. Convenience overload template for avoiding a std::bind expression.
Usage:
Definition at line 605 of file WASimClient.h.
void WASimCommander::Client::WASimClient::setResponseCallback | ( | commandCallback_t | cb | ) |
Sets a callback for delivering response commands sent to this client by the server module. Note that the server may also initiate a few types of commands (not in response to client commands) such as Ping
, List
, and Disconnect
. In contrast to setCommandResultCallback(commandCallback_t)
, this one will report on all commands from the server, not just Ack/Nak
. This callback is meant for low-level API usage.
Usage:
This callback is invoked from the dedicated "dispatch" thread the client maintains.
Definition at line 2085 of file WASimClient.cpp.
|
inline |
Same as setResponseCallback(commandCallback_t)
. Convenience overload template for avoiding a std::bind expression.
Usage:
Definition at line 611 of file WASimClient.h.