KFbxUserNotification
#include<kfbxusernotification.h>

List of all members.

Detailed Description

This class accumulates user notifications and sends them to any device opened by the derived classes.

If this class is not derived, the data can only be sent to a log file. To send data to a log file, it must be opened before attempting to send data, otherwise, the messages will be lost.

Definition at line132of filekfbxusernotification.h.


Accumulator Output

enum OutputSource
bool Output(OutputSource pOutSrc=eACCUMULATOR_ENTRY, int pIndex=-1, bool pExtraDevicesOnly=false)
 Send the accumulator entries to the output devices.
bool OutputById(AEid pId, OutputSource pOutSrc=eACCUMULATOR_ENTRY, bool pExtraDevicesOnly=false)
 Send the accumulator entry to the output devices.
bool Output(constKString&pName, constKString&pDescr, AccumulatorEntry::AEClass pClass, bool pExtraDevicesOnly=false)
 Send an immediate entry to the output devices.
bool Output(KFbxUserNotificationFilteredIterator&pAEFIter, bool pExtraDevicesOnly=false)
 Sends the content of the iterator to the output devices.

Public Member Functions

 KFbxUserNotification(KFbxSdkManager*pManager,KStringconst&pLogFileName,KStringconst&pSessionDescription)
 Instanciate aKFbxUserNotificationbut leave it uninitialized.
void InitAccumulator()
 This method must be called before using the Accumulator.
void ClearAccumulator()
 This method must be called when the Accumulator is no longer needed.
Accumulator Management
int AddEntry(const int pID, constKString&pName, constKString&pDescr, AccumulatorEntry::AEClass pClass=AccumulatorEntry::eAE_WARNING)
 Adds one entry into the accumulator.
int AddDetail(int pEntryId)
 Completes the accumulator entry (there can be more that one detail for each entry) and implicitly defines the sequence of events.
int AddDetail(int pEntryId,KStringpString)
 Completes the accumulator entry (there can be more that one detail for each entry) and implicitly defines the sequence of events.
int AddDetail(int pEntryId,KFbxNode*pNode)
 Completes the accumulator entry (there can be more that one detail for each entry) and implicitly defines the sequence of events.
int GetNbEntries() const
 Returns the number of AccumulatorEntries currently stored in this accumulator.
constAccumulatorEntryGetEntry(int pEntryId) const
 Get the specifiedAccumulatorEntry.
constAccumulatorEntryGetEntryAt(int pEntryIndex) const
 Get theAccumulatorEntryat the specified index.
int GetNbDetails() const
 Returns the number of Details recorded so far in this accumulator.
int GetDetail(int pDetailId, constAccumulatorEntry*&pAE) const
 Get the specified detail.
Utilities
virtual void GetLogFilePath(KString&pPath)
 Returns the absolute path to the log file.
KString GetLogFileName()
 Returns the log file name.

Protected Member Functions

virtual bool PostTerminate()
 Allow a derived class to finalize processing AFTER the log file handle has been deleted.
virtual void AccumulatorInit()
 Allow the implementation class to perform accumulator initializations before the Extra devices are opened.
virtual void AccumulatorClear()
 Allow the implementation class to perform accumulator clear after the Extra devices are closed.
virtual void OpenExtraDevices()
 Allow the implementation class to opens its output devices (called by InitAccumulator).
virtual bool SendToExtraDevices(bool pOutputNow, KArrayTemplate<AccumulatorEntry*>&pEntries)
 Allow the implementation class to send all the accumulator entries to the devices.
virtual bool SendToExtraDevices(bool pOutputNow, KArrayTemplate<AESequence *>&pAESequence)
 Allow the implementation class to send all the accumulator entries to the devices.
virtual bool SendToExtraDevices(bool pOutputNow, constAccumulatorEntry*pAccEntry, int pDetailId=-1)
 Allow the implementation class to send one accumulator entry to the devices.
virtual void CloseExtraDevices()
 Allow the implementation class to close it's output devices (called in the ClearAccumulator) By default this method does nothing.
void ResetAccumulator()
 Clears the Accumulator list.
void ResetSequence()
 Clears the Sequence list.
void SendToLog(OutputSource pOutSrc, int pId)
 Send the pIdth element of the accumulator or sequence list to the log file.
void SendToLog(constAccumulatorEntry*pAccEntry, int pDetailId=-1)
 Send the accumulator entry to the log file.

Constructor&Destructor Documentation

KFbxUserNotification(KFbxSdkManagerpManager,
KStringconst& pLogFileName,
KStringconst& pSessionDescription 
)

Instanciate aKFbxUserNotificationbut leave it uninitialized.

The caller must explicitly call InitAccumulator to initialize it and ClearAccumulator when finished using it.

Parameters:
pManager 
pLogFileName Name of the log file that will be open in the directory defined by the GetLogFilePath method.
Remarks:
If pLogFileName is an empty string the logfile does not get created and any output sent to it is lost.
Parameters:
pSessionDescription This string is used to separate session logs in the file.
Remarks:
If the specified logfile already exists, messages are appended to it. This class never deletes the log file. Derived classes may delete the log file before opening (it must be done in the constructor because the log file is opened in the InitAccumulator) or at the end of the processing in the PostTerminate method.

Member Function Documentation

void InitAccumulator( ) 

This method must be called before using the Accumulator.

It opens the log file and calls AccumulatorInit followed by OpenExtraDevices. Failing to call this method will prevent other actions except ClearAccumulator, GetLogFileName and GetLogFilePath.

void ClearAccumulator( ) 

This method must be called when the Accumulator is no longer needed.

It calls CloseExtraDevices, followed by the AccumulatorClear, and then closes the log file.

int AddEntry(const int pID,
constKStringpName,
constKStringpDescr,
AccumulatorEntry::AEClass pClass=AccumulatorEntry::eAE_WARNING 
)

Adds one entry into the accumulator.

Parameters:
pID This entry unique ID.
pName This entry name.
pDescr The description of this entry.
pClass The category of this entry.
Returns:
The ID of the newly allocated entry. This ID is pEntryId.

int AddDetail(int pEntryId ) 

Completes the accumulator entry (there can be more that one detail for each entry) and implicitly defines the sequence of events.

Each call to this method is internally recorded, making it possible to output each notification in the order they have been defined. Also, when a detail is added to an entry, it is automatically unmuted so it can be sent to the devices (mutedAccumulatorEntryobjects are not processed).

Parameters:
pEntryId The entry index (as returned by AddEntry).
Returns:
The id of the detail in the recorded sequence of events. This Id should be used when the call to Output has the eSEQUENCED_DETAILS set as a source. If an error occurs, the returned value is -1

int AddDetail(int pEntryId,
KString pString 
)

Completes the accumulator entry (there can be more that one detail for each entry) and implicitly defines the sequence of events.

Each call to this method is internally recorded, making it possible to output each notification in the order they have been defined. Also, when a detail is added to an entry, it is automatically unmuted so it can be sent to the devices (mutedAccumulatorEntryobjects are not processed).

Parameters:
pEntryId The entry index (as returned by AddEntry).
pString The detail string to add to the entry.
Returns:
The id of the detail in the recorded sequence of events. This Id should be used when the call to Output has the eSEQUENCED_DETAILS set as a source. If an error occurs, the returned value is -1

int AddDetail(int pEntryId,
KFbxNodepNode 
)

Completes the accumulator entry (there can be more that one detail for each entry) and implicitly defines the sequence of events.

Each call to this method is internally recorded, making it possible to output each notification in the order they have been defined. Also, when a detail is added to an entry, it is automatically unmuted so it can be sent to the devices (mutedAccumulatorEntryobjects are not processed).

Parameters:
pEntryId The entry index (as returned by AddEntry).
pNode The node to add to the entry.
Returns:
The id of the detail in the recorded sequence of events. This Id should be used when the call to Output has the eSEQUENCED_DETAILS set as a source. If an error occurs, the returned value is -1

int GetNbEntries( ) const

Returns the number of AccumulatorEntries currently stored in this accumulator.

constAccumulatorEntry* GetEntry(int pEntryId ) const

Get the specifiedAccumulatorEntry.

Parameters:
pEntryId ID of the entry to retrieve.
Returns:
Pointer to the specified entry, otherwiseNULLif either the id is invalid or the Accumulator is not properly initialized.

constAccumulatorEntry* GetEntryAt(int pEntryIndex ) const

Get theAccumulatorEntryat the specified index.

Parameters:
pEntryIndex index of the entry to retrieve.
Returns:
Pointer to the specified entry, otherwiseNULLif either the index is invalid or the Accumulator is not properly initialized..

int GetNbDetails( ) const

Returns the number of Details recorded so far in this accumulator.

int GetDetail(int pDetailId,
constAccumulatorEntry*& pAE 
)const

Get the specified detail.

Parameters:
pDetailId Index of the detail. This is the idth detail of type pClass as inserted when the AddDetail
pAE Pointer to theAccumulatorEntryobject that contains the requested detail. The returned valued can be NULL if an error occured.
Returns:
The index of the detail to be used when calling the GetDetail of theAccumulatorEntry.
Remarks:
A value of -1 is acceptable and means that theAccumulatorEntryhas no details. However, if pAE is NULL, the return value is meaningless.

bool Output(OutputSource pOutSrc=eACCUMULATOR_ENTRY,
int pIndex=-1,
bool pExtraDevicesOnly=false 
)

Send the accumulator entries to the output devices.

This method needs to be explicitly called by the program that uses this class.

Parameters:
pOutSrc Specify which data has to be sent to the output devices. Set to SEQUENCED_DETAILS to send the Details in the recorded order. Set to ACCUMULATOR_ENTRY to send each entry with its details regardless of the order in which the events occurred.
pIndex If this parameter>= 0, only send the specified entry/detail index to the output devices. Otherwise send all of them.
pExtraDevicesOnly If this parameter is True, the output is not sent to the log file.
Remarks:
The pExtraDevicesOnly parameter is ignored if the log file has been disabled.

bool OutputById(AEid pId,
OutputSource pOutSrc=eACCUMULATOR_ENTRY,
bool pExtraDevicesOnly=false 
)

Send the accumulator entry to the output devices.

Parameters:
pId Send the entry/detail that matching pIdx to the output devices, otherwise send all of them.
pOutSrc Specify which data has to be sent to the output devices. Set to SEQUENCED_DETAILS to send the Details in the recorded order. Set to ACCUMULATOR_ENTRY to send each entry with its details regardless of the order in which the events occurred..
pExtraDevicesOnly If this parameter is True, the output is not sent to the log file.

bool Output(constKStringpName,
constKStringpDescr,
AccumulatorEntry::AEClass pClass,
bool pExtraDevicesOnly=false 
)

Send an immediate entry to the output devices.

This metohod bypasses the accumulator by sending the entry directly to the output devices and discarding it right after. The internal accumulator lists are left unchanged by this call.

Parameters:
pName This entry name.
pDescr The description of this entry.
pClass The category of this entry.
pExtraDevicesOnly If this parameter is True, the output is not sent to the log file.
Remarks:
The pExtraDevicesOnly parameter is ignored if the log file has been disabled.

bool Output(KFbxUserNotificationFilteredIteratorpAEFIter,
bool pExtraDevicesOnly=false 
)

Sends the content of the iterator to the output devices.

This metohod bypasses the accumulator by sending each entry in the iterator directly to the output devices. The internal accumulator lists are left unchanged by this call.

Parameters:
pAEFIter The FilteredAccumulatorEntryiterator object.
pExtraDevicesOnly If this parameter is True, the output is not sent to the log file.
Remarks:
The pExtraDevicesOnly parameter is ignored if the log file has been disabled.

virtual void GetLogFilePath(KStringpPath ) [virtual]

Returns the absolute path to the log file.

If this method is not overridden in a derived class, it returns the TEMP directory.

Parameters:
pPath The returned path.

KStringGetLogFileName( ) [inline]

Returns the log file name.

Definition at line327of filekfbxusernotification.h.

virtual bool PostTerminate( ) [protected, virtual]

Allow a derived class to finalize processing AFTER the log file handle has been deleted.

This may be required if the logfile needs to be moved or shown.

Returns:
True if the object is properly cleaned.

virtual void AccumulatorInit( ) [protected, virtual]

Allow the implementation class to perform accumulator initializations before the Extra devices are opened.

By default this method does nothing.

virtual void AccumulatorClear( ) [protected, virtual]

Allow the implementation class to perform accumulator clear after the Extra devices are closed.

By default this method does nothing.

virtual void OpenExtraDevices( ) [protected, virtual]

Allow the implementation class to opens its output devices (called by InitAccumulator).

By default this method does nothing.

virtual bool SendToExtraDevices(bool pOutputNow,
KArrayTemplate<AccumulatorEntry*>& pEntries 
)[protected, virtual]

Allow the implementation class to send all the accumulator entries to the devices.

By default this method loop trough all the elements of the received array and call the SendToExtraDevices method with the appropriateAccumulatorEntryelement and id.

Parameters:
pOutputNow Flag indicates whether to output now.
pEntries Accumulator entries to output.
Returns:
trueif successful,falseotherwise.

virtual bool SendToExtraDevices(bool pOutputNow,
KArrayTemplate<AESequence *>& pAESequence 
)[protected, virtual]

Allow the implementation class to send all the accumulator entries to the devices.

By default this method loop trough all the elements of the received array and call the SendToExtraDevices method with the appropriateAccumulatorEntryelement and id.

Parameters:
pOutputNow Flag indicates whether to output now.
pAESequence Accumulator entries to output.
Returns:
trueif successful,falseotherwise.

virtual bool SendToExtraDevices(bool pOutputNow,
constAccumulatorEntrypAccEntry,
int pDetailId=-1 
)[protected, virtual]

Allow the implementation class to send one accumulator entry to the devices.

By default this method does nothing.

Parameters:
pOutputNow Flag indicates whether to output now.
pAccEntry Accumulator entry to output.
pDetailId Detail id.
Returns:
trueif successful,falseotherwise.
Remarks:
Derived methods should check for the IsMuted() state to decide if the accumulator entry should get through or get discaded. See AddDetail for more details.

virtual void CloseExtraDevices( ) [protected, virtual]

Allow the implementation class to close it's output devices (called in the ClearAccumulator) By default this method does nothing.

void ResetAccumulator( ) [protected]

Clears the Accumulator list.

void ResetSequence( ) [protected]

Clears the Sequence list.

void SendToLog(OutputSource pOutSrc,
int pId 
)[protected]

Send the pIdth element of the accumulator or sequence list to the log file.

Parameters:
pOutSrc The output source, accumulator or sequence list.
pId Element id.

void SendToLog(constAccumulatorEntrypAccEntry,
int pDetailId=-1 
)[protected]

Send the accumulator entry to the log file.

Parameters:
pAccEntry The accumulator entry.
pDetailId Detail id.