|
@ -61,7 +61,7 @@ struct ConditionalSerial : public SerialBase< ConditionalSerial<SerialT> > { |
|
|
|
|
|
|
|
|
bool & condition; |
|
|
bool & condition; |
|
|
SerialT & out; |
|
|
SerialT & out; |
|
|
size_t write(uint8_t c) { if (condition) return out.write(c); return 0; } |
|
|
NO_INLINE size_t write(uint8_t c) { if (condition) return out.write(c); return 0; } |
|
|
void flush() { if (condition) out.flush(); } |
|
|
void flush() { if (condition) out.flush(); } |
|
|
void begin(long br) { out.begin(br); } |
|
|
void begin(long br) { out.begin(br); } |
|
|
void end() { out.end(); } |
|
|
void end() { out.end(); } |
|
@ -83,7 +83,7 @@ struct ForwardSerial : public SerialBase< ForwardSerial<SerialT> > { |
|
|
typedef SerialBase< ForwardSerial<SerialT> > BaseClassT; |
|
|
typedef SerialBase< ForwardSerial<SerialT> > BaseClassT; |
|
|
|
|
|
|
|
|
SerialT & out; |
|
|
SerialT & out; |
|
|
size_t write(uint8_t c) { return out.write(c); } |
|
|
NO_INLINE size_t write(uint8_t c) { return out.write(c); } |
|
|
void flush() { out.flush(); } |
|
|
void flush() { out.flush(); } |
|
|
void begin(long br) { out.begin(br); } |
|
|
void begin(long br) { out.begin(br); } |
|
|
void end() { out.end(); } |
|
|
void end() { out.end(); } |
|
@ -111,12 +111,12 @@ struct RuntimeSerial : public SerialBase< RuntimeSerial<SerialT> >, public Seria |
|
|
EndOfMessageHook eofHook; |
|
|
EndOfMessageHook eofHook; |
|
|
void * userPointer; |
|
|
void * userPointer; |
|
|
|
|
|
|
|
|
size_t write(uint8_t c) { |
|
|
NO_INLINE size_t write(uint8_t c) { |
|
|
if (writeHook) writeHook(userPointer, c); |
|
|
if (writeHook) writeHook(userPointer, c); |
|
|
return SerialT::write(c); |
|
|
return SerialT::write(c); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
void msgDone() { |
|
|
NO_INLINE void msgDone() { |
|
|
if (eofHook) eofHook(userPointer); |
|
|
if (eofHook) eofHook(userPointer); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -131,6 +131,10 @@ struct RuntimeSerial : public SerialBase< RuntimeSerial<SerialT> >, public Seria |
|
|
using BaseClassT::print; |
|
|
using BaseClassT::print; |
|
|
using BaseClassT::println; |
|
|
using BaseClassT::println; |
|
|
|
|
|
|
|
|
|
|
|
// Underlying implementation might use Arduino's bool operator
|
|
|
|
|
|
bool connected() { |
|
|
|
|
|
return Private::HasMember_connected<SerialT>::value ? CALL_IF_EXISTS(bool, static_cast<SerialT*>(this), connected) : static_cast<SerialT*>(this)->operator bool(); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
void setHook(WriteHook writeHook = 0, EndOfMessageHook eofHook = 0, void * userPointer = 0) { |
|
|
void setHook(WriteHook writeHook = 0, EndOfMessageHook eofHook = 0, void * userPointer = 0) { |
|
|
// Order is important here as serial code can be called inside interrupts
|
|
|
// Order is important here as serial code can be called inside interrupts
|
|
@ -165,13 +169,13 @@ struct MultiSerial : public SerialBase< MultiSerial<Serial0T, Serial1T, offset> |
|
|
AllMask = FirstOutputMask | SecondOutputMask, |
|
|
AllMask = FirstOutputMask | SecondOutputMask, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
size_t write(uint8_t c) { |
|
|
NO_INLINE size_t write(uint8_t c) { |
|
|
size_t ret = 0; |
|
|
size_t ret = 0; |
|
|
if (portMask & FirstOutputMask) ret = serial0.write(c); |
|
|
if (portMask & FirstOutputMask) ret = serial0.write(c); |
|
|
if (portMask & SecondOutputMask) ret = serial1.write(c) | ret; |
|
|
if (portMask & SecondOutputMask) ret = serial1.write(c) | ret; |
|
|
return ret; |
|
|
return ret; |
|
|
} |
|
|
} |
|
|
void msgDone() { |
|
|
NO_INLINE void msgDone() { |
|
|
if (portMask & FirstOutputMask) serial0.msgDone(); |
|
|
if (portMask & FirstOutputMask) serial0.msgDone(); |
|
|
if (portMask & SecondOutputMask) serial1.msgDone(); |
|
|
if (portMask & SecondOutputMask) serial1.msgDone(); |
|
|
} |
|
|
} |
|
@ -182,7 +186,7 @@ struct MultiSerial : public SerialBase< MultiSerial<Serial0T, Serial1T, offset> |
|
|
default: return false; |
|
|
default: return false; |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
int read(uint8_t index) { |
|
|
NO_INLINE int read(uint8_t index) { |
|
|
switch(index) { |
|
|
switch(index) { |
|
|
case 0 + offset: return serial0.read(); |
|
|
case 0 + offset: return serial0.read(); |
|
|
case 1 + offset: return serial1.read(); |
|
|
case 1 + offset: return serial1.read(); |
|
@ -208,11 +212,11 @@ struct MultiSerial : public SerialBase< MultiSerial<Serial0T, Serial1T, offset> |
|
|
using BaseClassT::read; |
|
|
using BaseClassT::read; |
|
|
|
|
|
|
|
|
// Redirect flush
|
|
|
// Redirect flush
|
|
|
void flush() { |
|
|
NO_INLINE void flush() { |
|
|
if (portMask & FirstOutputMask) serial0.flush(); |
|
|
if (portMask & FirstOutputMask) serial0.flush(); |
|
|
if (portMask & SecondOutputMask) serial1.flush(); |
|
|
if (portMask & SecondOutputMask) serial1.flush(); |
|
|
} |
|
|
} |
|
|
void flushTX() { |
|
|
NO_INLINE void flushTX() { |
|
|
if (portMask & FirstOutputMask) CALL_IF_EXISTS(void, &serial0, flushTX); |
|
|
if (portMask & FirstOutputMask) CALL_IF_EXISTS(void, &serial0, flushTX); |
|
|
if (portMask & SecondOutputMask) CALL_IF_EXISTS(void, &serial1, flushTX); |
|
|
if (portMask & SecondOutputMask) CALL_IF_EXISTS(void, &serial1, flushTX); |
|
|
} |
|
|
} |
|
|