ham_action_log()
Insert a log message into the activity log of the HAM
Synopsis:
#include <ha/ham.h>
ham_action_t *ham_action_log(
                ham_condition_t *chdl,
                const char *aname,
                const char *msg,
                unsigned attachprefix,
                int verbosity,
                unsigned flags);
Arguments:
- chdl
- The HAM condition handle.
- aname
- The name of the action.
- msg
- The message to be inserted into the activity log stream.
- attachprefix
- If non-zero, the log action owner's name will be attached to the inserted message as a prefix.
- verbosity
- The action's verbosity that will be compared with the verbosity of the HAM. The inserted message will be generated if the verbosity of the HAM is greater than or equal to the value specified in verbosity.
- flags
- The flag indicating how the function will be rearmed.. See below.
Library:
libham
Description:
You can use the ham_action_log() function to insert log messages into the activity log stream that the HAM maintains.
The handle (chdl) is obtained either:
- 
            from one of the ham_condition*() functions to add conditions 
            or: 
- by calling any of the ham_condition_handle() functions to request a handle to a specific condition.
The log message to be inserted is specified by msg, and will be generated if the verbosity of the HAM is greater than or equal to the value specified in verbosity. Also, if attachprefix is non-zero, a prefix will be added to the log message that contains the current entity/condition/action that this message is related to.
The following flag is currently defined:
- HREARMAFTERRESTART
- Indicates that the action is to be automatically rearmed after the entity that it belongs to is restarted.
Returns:
A valid handle to an action to a condition, or NULL if an error occurred (errno is set).
Errors:
- EBADF
- Couldn't connect to the HAM.
- EEXIST
- The action specified by aname already exists.
- EINVAL
- 
                The name given in aname is invalid (e.g., it contains
                the 
 character) or is NULL./
- ENAMETOOLONG
- 
                The name given (in aname) is too long
                (i.e., it exceeds _POSIX_PATH_MAX,
                defined in <limits.h>).
                Note:The combined name length of an entity, condition, or action is also limited by _POSIX_PATH_MAX.
- ENOENT
- There's no entity or condition specified by the given handle (chdl).
- ENOMEM
- Not enough memory to create a new handle.
In addition to the above errors, the HAM returns any error it encounters while servicing this request.
Classification:
| Safety: | |
|---|---|
| Cancellation point | No | 
| Signal handler | No | 
| Thread | Yes | 
