mirror of
https://github.com/arduino/Arduino.git
synced 2025-01-18 07:52:14 +01:00
A modification of [New]SoftSerial to meet certain requests David
Mellis asked about in preparation for integration into core: 1. Remove notion of library version 2. Remove little used "enable_timer0" method. 3. Rename is_listening to isListening i :insert : :set showmode
This commit is contained in:
parent
38d4a34fec
commit
2832e8e0a8
@ -421,7 +421,7 @@ void SoftwareSerial::end()
|
||||
// Read data from buffer
|
||||
int SoftwareSerial::read()
|
||||
{
|
||||
if (!is_listening())
|
||||
if (!isListening())
|
||||
return -1;
|
||||
|
||||
// Empty buffer?
|
||||
@ -436,7 +436,7 @@ int SoftwareSerial::read()
|
||||
|
||||
int SoftwareSerial::available()
|
||||
{
|
||||
if (!is_listening())
|
||||
if (!isListening())
|
||||
return 0;
|
||||
|
||||
return (_receive_buffer_tail + _SS_MAX_RX_BUFF - _receive_buffer_head) % _SS_MAX_RX_BUFF;
|
||||
@ -488,30 +488,9 @@ void SoftwareSerial::write(uint8_t b)
|
||||
tunedDelay(_tx_delay);
|
||||
}
|
||||
|
||||
#if !defined(cbi)
|
||||
#define cbi(sfr, bit) (_SFR_BYTE(sfr) &= ~_BV(bit))
|
||||
#define sbi(sfr, bit) (_SFR_BYTE(sfr) |= _BV(bit))
|
||||
#endif
|
||||
|
||||
void SoftwareSerial::enable_timer0(bool enable)
|
||||
{
|
||||
if (enable)
|
||||
#if defined(__AVR_ATmega8__)
|
||||
sbi(TIMSK, TOIE0);
|
||||
#else
|
||||
sbi(TIMSK0, TOIE0);
|
||||
#endif
|
||||
else
|
||||
#if defined(__AVR_ATmega8__)
|
||||
cbi(TIMSK, TOIE0);
|
||||
#else
|
||||
cbi(TIMSK0, TOIE0);
|
||||
#endif
|
||||
}
|
||||
|
||||
void SoftwareSerial::flush()
|
||||
{
|
||||
if (!is_listening())
|
||||
if (!isListening())
|
||||
return;
|
||||
|
||||
uint8_t oldSREG = SREG;
|
||||
@ -522,7 +501,7 @@ void SoftwareSerial::flush()
|
||||
|
||||
int SoftwareSerial::peek()
|
||||
{
|
||||
if (!is_listening())
|
||||
if (!isListening())
|
||||
return -1;
|
||||
|
||||
// Empty buffer?
|
||||
|
@ -40,7 +40,6 @@ http://arduiniana.org.
|
||||
******************************************************************************/
|
||||
|
||||
#define _SS_MAX_RX_BUFF 64 // RX buffer size
|
||||
#define _SS_VERSION 11 // software version of this library
|
||||
#ifndef GCC_VERSION
|
||||
#define GCC_VERSION (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__)
|
||||
#endif
|
||||
@ -86,10 +85,8 @@ public:
|
||||
void begin(long speed);
|
||||
bool listen();
|
||||
void end();
|
||||
bool is_listening() { return this == active_object; }
|
||||
bool isListening() { return this == active_object; }
|
||||
bool overflow() { bool ret = _buffer_overflow; _buffer_overflow = false; return ret; }
|
||||
static int library_version() { return _SS_VERSION; }
|
||||
static void enable_timer0(bool enable);
|
||||
int peek();
|
||||
|
||||
virtual void write(uint8_t byte);
|
||||
|
@ -58,7 +58,7 @@ http://arduiniana.org.
|
||||
( ((p) == 50) ? 3 : \
|
||||
( ((p) == 51) ? 2 : \
|
||||
( ((p) == 52) ? 1 : \
|
||||
( ((p) ==53) ? 0 : \
|
||||
( ((p) == 53) ? 0 : \
|
||||
( (((p) >= 62) && ((p) <= 69)) ? ((p) - 62) : \
|
||||
0 ) ) ) ) ) )
|
||||
|
||||
|
@ -16,10 +16,8 @@ begin KEYWORD2
|
||||
end KEYWORD2
|
||||
read KEYWORD2
|
||||
available KEYWORD2
|
||||
is_listening KEYWORD2
|
||||
isListening KEYWORD2
|
||||
overflow KEYWORD2
|
||||
library_version KEYWORD2
|
||||
enable_timer0 KEYWORD2
|
||||
flush KEYWORD2
|
||||
listen KEYWORD2
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user