API
 
Loading...
Searching...
No Matches
string_log.hpp
Go to the documentation of this file.
1/** \file string_log.hpp
2 * \brief The MagAO-X logger string_log log type.
3 * \author Jared R. Males (jaredmales@gmail.com)
4 *
5 * \ingroup logger_types_files
6 *
7 * History:
8 * - 2018-08-18 created by JRM
9 */
10#ifndef logger_types_string_log_hpp
11#define logger_types_string_log_hpp
12
14#include "flatbuffer_log.hpp"
15
16namespace MagAOX
17{
18
19namespace logger
20{
21
22/// Base class for logs consisting of a string message.
23/** Does not have eventCode or defaultLevel, so this can not be used as a log type in logger.
24 *
25 * \ingroup logger_types_basic
26 */
28{
29 /// The type of the message
30 struct messageT : public fbMessage
31 {
32 messageT( const char *msg )
33 {
34 auto _msg = builder.CreateString( msg );
35
36 auto gs = CreateString_log_fb( builder, _msg );
37 builder.Finish( gs );
38 }
39
40 messageT( const std::string &msg )
41 {
42 auto _msg = builder.CreateString( msg );
43
44 auto gs = CreateString_log_fb( builder, _msg );
45 builder.Finish( gs );
46 }
47 };
48
49 static bool verify( flatlogs::bufferPtrT &logBuff, ///< [in] Buffer containing the flatbuffer serialized message.
50 flatlogs::msgLenT len ///< [in] length of msgBuffer.
51 )
52 {
53 auto verifier = flatbuffers::Verifier( static_cast<uint8_t *>( flatlogs::logHeader::messageBuffer( logBuff ) ),
54 static_cast<size_t>( len ) );
55 return VerifyString_log_fbBuffer( verifier );
56 }
57
58 /// Get the message formatted for human consumption.
59 static std::string msgString( void *msgBuffer, /**< [in] Buffer containing the flatbuffer serialized message.*/
60 flatlogs::msgLenT len /**< [in] [unused] length of msgBuffer.*/
61 )
62 {
63 static_cast<void>( len );
64
65 auto rgs = GetString_log_fb( msgBuffer );
66
67 if( rgs->message() == nullptr )
68 return "";
69 else
70 return rgs->message()->c_str();
71 }
72
73 /// Access the message field
74 static std::string message( void *msgBuffer /**< [in] Buffer containing the flatbuffer serialized message.*/ )
75 {
76 auto rgs = GetString_log_fb( msgBuffer );
77 if( rgs->message() == nullptr )
78 {
79 return "";
80 }
81 else
82 {
83 return rgs->message()->c_str();
84 }
85 }
86
87 /// Get the logMetaDetail for a member by name
88 /**
89 * \returns the a logMetaDetail filled in with the appropriate details
90 * \returns an empty logMetaDetail if member not recognized
91 */
92 static logMetaDetail getAccessor( const std::string &member /**< [in] the name of the member */ )
93 {
94 if( member == "message" )
95 {
96 return logMetaDetail( { "MESSAGE",
97 "log message",
100 reinterpret_cast<void *>( &message ),
101 false } );
102 }
103 else
104 {
105 std::cerr << "No member " << member << " in string_log\n";
106 return logMetaDetail();
107 }
108 }
109};
110
111} // namespace logger
112} // namespace MagAOX
113
114#endif // logger_types_string_log_hpp
The MagAO-X logger flatbuffer log base type.
msgLen2T msgLenT
The type used to refer to the message length, regardless of length.
Definition logDefs.hpp:69
static void * messageBuffer(bufferPtrT &logBuffer)
Get the message buffer address.
std::shared_ptr< char > bufferPtrT
The log entry buffer smart pointer.
Definition logHeader.hpp:58
const MagAOX::logger::String_log_fb * GetString_log_fb(const void *buf)
bool VerifyString_log_fbBuffer(::flatbuffers::Verifier &verifier)
inline ::flatbuffers::Offset< String_log_fb > CreateString_log_fb(::flatbuffers::FlatBufferBuilder &_fbb, ::flatbuffers::Offset<::flatbuffers::String > message=0)
Definition dm.hpp:28
Message type for resolving log messages with a f.b. builder.
flatbuffers::FlatBufferBuilder builder
Base class for logs consisting of a flatbuffer message.
messageT(const std::string &msg)
Base class for logs consisting of a string message.
static logMetaDetail getAccessor(const std::string &member)
Get the logMetaDetail for a member by name.
static bool verify(flatlogs::bufferPtrT &logBuff, flatlogs::msgLenT len)
static std::string msgString(void *msgBuffer, flatlogs::msgLenT len)
Get the message formatted for human consumption.
static std::string message(void *msgBuffer)
Access the message field.