log4c
1.2.4
|
Log4c rolling policy interface. Defines the interface for managing and providing rolling policies. More...
Go to the source code of this file.
Data Structures | |
struct | log4c_rollingpolicy_type |
log4c rollingpolicy type. Defines the interface a specific policy must provide to the rollingfile appender. More... | |
Macros | |
#define | ROLLINGPOLICY_ROLLOVER_ERR_CAN_LOG 0x05 |
Typedefs | |
typedef struct __log4c_rollingpolicy | log4c_rollingpolicy_t |
typedef struct log4c_rollingpolicy_type | log4c_rollingpolicy_type_t |
log4c rollingpolicy type. Defines the interface a specific policy must provide to the rollingfile appender. More... | |
Functions | |
log4c_rollingpolicy_t * | log4c_rollingpolicy_get (const char *policy_name) |
const log4c_rollingpolicy_type_t * | log4c_rollingpolicy_type_set (const log4c_rollingpolicy_type_t *a_type) |
void | log4c_rollingpolicy_set_udata (log4c_rollingpolicy_t *policyp, void *udatap) |
int | log4c_rollingpolicy_init (log4c_rollingpolicy_t *policyp, rollingfile_udata_t *rfup) |
int | log4c_rollingpolicy_fini (log4c_rollingpolicy_t *policyp) |
int | log4c_rollingpolicy_is_triggering_event (log4c_rollingpolicy_t *policyp, const log4c_logging_event_t *evtp, long current_file_size) |
const log4c_rollingpolicy_type_t * | log4c_rollingpolicy_set_type (log4c_rollingpolicy_t *a_rollingpolicy, const log4c_rollingpolicy_type_t *a_type) |
const log4c_rollingpolicy_type_t * | log4c_rollingpolicy_type_get (const char *a_name) |
void * | log4c_rollingpolicy_get_udata (const log4c_rollingpolicy_t *policyp) |
rollingfile_udata_t * | log4c_rollingpolicy_get_rfudata (const log4c_rollingpolicy_t *policyp) |
Log4c rolling policy interface. Defines the interface for managing and providing rolling policies.
A rolling policy is used to confogure a rollingfile appender to tell it when to trigger a rolover event.
#define ROLLINGPOLICY_ROLLOVER_ERR_CAN_LOG 0x05 |
Effect a rollover according to policyp on the given file stream.
policyp | pointer to the rolling policy |
fp | filestream to rollover. |
typedef struct __log4c_rollingpolicy log4c_rollingpolicy_t |
log4c rollingpolicy type
typedef struct log4c_rollingpolicy_type log4c_rollingpolicy_type_t |
log4c rollingpolicy type. Defines the interface a specific policy must provide to the rollingfile appender.
Attributes description:
name
rollingpolicy type name init()
init the rollingpolicy is_triggering_event()
rollover()
int log4c_rollingpolicy_fini | ( | log4c_rollingpolicy_t * | policyp | ) |
Call the un initialization code of a rolling policy. This will call the fini routine of the particular rollingpolicy type to allow it to free up resources. If the call to fini in the rollingpolicy type fails then the rollingpolicy is not uninitialized. Try again later model...
policyp | pointer to the rolling policy |
log4c_rollingpolicy_t* log4c_rollingpolicy_get | ( | const char * | policy_name | ) |
Get a new rolling policy
policy_name | a name for the policy |
rollingfile_udata_t* log4c_rollingpolicy_get_rfudata | ( | const log4c_rollingpolicy_t * | policyp | ) |
Get the rollingfile appender associated with this policy.
policyp | pointer to the rolling policy |
void* log4c_rollingpolicy_get_udata | ( | const log4c_rollingpolicy_t * | policyp | ) |
Get the rolling policy configuration.
policyp | pointer to the rolling policy |
int log4c_rollingpolicy_init | ( | log4c_rollingpolicy_t * | policyp, |
rollingfile_udata_t * | rfup | ||
) |
Call the initialization code of a rolling policy.
policyp | pointer to the rolling policy |
rfup | the rolling appender user data this policy is used with |
int log4c_rollingpolicy_is_triggering_event | ( | log4c_rollingpolicy_t * | policyp, |
const log4c_logging_event_t * | evtp, | ||
long | current_file_size | ||
) |
Determine if a logging event should trigger a rollover according to the given policy.
policyp | pointer to the rolling policy |
evtp | the logging event pointer. |
current_file_size | the size of the current file being logged to. |
const log4c_rollingpolicy_type_t* log4c_rollingpolicy_set_type | ( | log4c_rollingpolicy_t * | a_rollingpolicy, |
const log4c_rollingpolicy_type_t * | a_type | ||
) |
sets the rolling policy type
a_rollingpolicy | the log4c_rollingpolicy_t object |
a_type | the new rollingpolicy type |
void log4c_rollingpolicy_set_udata | ( | log4c_rollingpolicy_t * | policyp, |
void * | udatap | ||
) |
Configure a rolling policy with a specific policy.
policyp | pointer to the rolling policy |
udatap | a specific policy type, for example sizewin. |
const log4c_rollingpolicy_type_t* log4c_rollingpolicy_type_get | ( | const char * | a_name | ) |
Get a pointer to an existing rollingpolicy type.
a_name | the name of the rollingpolicy type to return. |
const log4c_rollingpolicy_type_t* log4c_rollingpolicy_type_set | ( | const log4c_rollingpolicy_type_t * | a_type | ) |
Use this function to register a rollingpolicy type with log4c. Once this is done you may refer to this type by name both programmatically and in the log4c configuration file.
a_type | a pointer to the new rollingpolicy type to register. |
Example code fragment: