/* * MessageType.h * * Created on: 21 May 2016 * Authors: David and Christian */ #ifndef MESSAGETYPE_H_ #define MESSAGETYPE_H_ #include // Supported message destinations. This is now a bitmap. Note that this type is used by the SBC service as well enum MessageType : uint32_t { // Destinations (bytes 1-2) // Keep the following in sync with the order of GCodeBuffers in the GCodes class HttpMessage = 0x01u, // A message that is to be sent to the web (HTTP) TelnetMessage = 0x02u, // A message that is to be sent to a Telnet client FileMessage = 0x04u, // A message that is to be sent to a file processor UsbMessage = 0x08u, // A message that is to be sent in non-blocking mode to the host via USB AuxMessage = 0x10u, // A message that is to be sent to an auxiliary device (PanelDue) TriggerMessage = 0x20u, // A message that is to be sent to a trigger processor CodeQueueMessage = 0x40u, // A message that is to be sent to the code queue channel LcdMessage = 0x80u, // A message that is to be sent to the panel SbcMessage = 0x100u, // A message that is to be sent to the SBC DaemonMessage = 0x200u, // A message that is sent to the daemon processor Aux2Message = 0x400u, // A message that is to be sent to the second aux device AutoPauseMessage = 0x800u, // A message that is to be sent to an auto-pause processor // Special destinations (byte 3) BlockingUsbMessage = 0x10000u, // A message that is to be sent to USB in blocking mode ImmediateAuxMessage = 0x20000u, // A message that is to be sent to LCD in immediate mode DestinationsMask = 0x308FFu, // Mask for all the destinations // Special indicators (byte 4) // The first two are not processed when calling the version of Platform::Message that takes an OutputBuffer. ErrorMessageFlag = 0x1000000u, // This is an error message WarningMessageFlag = 0x2000000u, // This is a warning message RawMessageFlag = 0x8000000u, // Do not encapsulate this message BinaryCodeReplyFlag = 0x10000000u, // This message comes from a binary G-Code buffer PushFlag = 0x20000000u, // There is more to come; the message has been truncated LogMessageLowBit = 0x40000000u, // Log level consists of two bits this is the low bit LogMessageHighBit = 0x80000000u, // Log level consists of two bits this is the high bit LogLevelMask = 0xC0000000u, // Mask for all the log level bits LogLevelShift = 30, // How many bits we have to shift a MessageType right by to get the logging level // Common combinations NoDestinationMessage = 0u, // A message that is going nowhere GenericMessage = UsbMessage | AuxMessage | HttpMessage | TelnetMessage, // A message that is to be sent to the web, Telnet, USB and panel LogOff = LogMessageLowBit | LogMessageHighBit, // Log level "off (3): do not log this message LogWarn = LogMessageHighBit, // Log level "warn" (2): all messages of type Error and Warning are logged LogInfo = LogMessageLowBit, // Log level "info" (1): all messages of level "warn" plus info messages LoggedGenericMessage = GenericMessage | LogWarn, // A GenericMessage that is also logged DirectAuxMessage = AuxMessage | RawMessageFlag, // Direct message to PanelDue ErrorMessage = GenericMessage | LogWarn | ErrorMessageFlag, // An error message WarningMessage = GenericMessage | LogWarn | WarningMessageFlag, // A warning message FirmwareUpdateMessage = UsbMessage | ImmediateAuxMessage, // A message that conveys progress of a firmware update FirmwareUpdateErrorMessage = FirmwareUpdateMessage | ErrorMessageFlag, // A message that reports an error during a firmware update NetworkInfoMessage = UsbMessage | AuxMessage | LogWarn, // A message that conveys information about the state of the network interface NetworkErrorMessage = UsbMessage | AuxMessage | LogWarn | ErrorMessageFlag // A message that conveys information about the state of the network interface }; inline constexpr MessageType AddLogDebug(MessageType mt) noexcept { // Debug level has no flags set such that any non-flagged message automatically // is part of this log level - force it by removing the existing flags return (MessageType)((uint32_t)mt & ~((uint32_t)LogMessageLowBit | (uint32_t)LogMessageHighBit)); } inline constexpr MessageType AddLogWarn(MessageType mt) noexcept { // Since increasing log levels have lower numbers we need to delete // any existing log flags first - otherwise this could lead to MessageLogLevel // rising to 3 which is equivalent to OFF return (MessageType)((uint32_t)AddLogDebug(mt) | (uint32_t)LogWarn); } inline constexpr MessageType AddLogInfo(MessageType mt) noexcept { // Since increasing log levels have lower numbers we need to delete // any existing log flags first - otherwise this could lead to MessageLogLevel // rising to 3 which is equivalent to OFF return (MessageType)((uint32_t)AddLogDebug(mt) | (uint32_t)LogInfo); } inline constexpr MessageType RemoveLogging(MessageType mt) noexcept { return (MessageType)((uint32_t)mt | (uint32_t)LogOff); } inline constexpr MessageType AddError(MessageType mt) noexcept { return AddLogWarn((MessageType)((uint32_t)mt | (uint32_t)ErrorMessageFlag)); } inline constexpr MessageType AddWarning(MessageType mt) noexcept { return AddLogWarn((MessageType)((uint32_t)mt | (uint32_t)WarningMessageFlag)); } #endif /* MESSAGETYPE_H_ */