From 06d1c6b0c166e810f77ab29f1452ce5642553d88 Mon Sep 17 00:00:00 2001 From: rmackay9 Date: Thu, 6 Dec 2012 10:18:00 +0900 Subject: [PATCH] AP_Buffer: bug fix to allow buffer to completely fill up. Also removed redundant _tail parameter which saves 1 byte. --- libraries/AP_Buffer/AP_Buffer.h | 83 +++++++-------------------------- 1 file changed, 18 insertions(+), 65 deletions(-) diff --git a/libraries/AP_Buffer/AP_Buffer.h b/libraries/AP_Buffer/AP_Buffer.h index 2dd74fcf39..176f23d2f1 100644 --- a/libraries/AP_Buffer/AP_Buffer.h +++ b/libraries/AP_Buffer/AP_Buffer.h @@ -39,7 +39,6 @@ public: protected: uint8_t _num_items; // number of items in the buffer uint8_t _head; // first item in the buffer (will be returned with the next get call) - uint8_t _tail; // last item added to the buffer (most recently added with the add method) T _buff[SIZE]; // x values of each point on the curve }; @@ -52,6 +51,7 @@ typedef AP_Buffer AP_BufferUInt8_Size128; typedef AP_Buffer AP_BufferFloat_Size10; typedef AP_Buffer AP_BufferFloat_Size15; +typedef AP_Buffer AP_BufferFloat_Size20; // Constructor template @@ -68,58 +68,34 @@ void AP_Buffer::clear() { // clear the curve _num_items = 0; _head = 0; - _tail = 0; } // add - adds an item to the buffer. returns TRUE if successfully added template bool AP_Buffer::add( T item ) { - // add item at the tail - _buff[_tail] = item; + // determine position of new item + uint8_t tail = _head + _num_items; + if( tail >= SIZE ) { + tail -= SIZE; + } - // move tail forward one position - _tail++; + // add item to buffer + _buff[tail] = item; - // wrap around to front of buffer if required - if( _tail >= SIZE ) - _tail = 0; - - // if the tail bumps into the head, move the head forward (throw away the oldest item) - if( _tail == _head ) { - _head++; - if( _head >= SIZE ) - _head = 0; - }else{ - // increment number of items + // increment number of items + if( _num_items < SIZE ) { _num_items++; + }else{ + // no room for new items so drop oldest item + _head++; + if( _head >= SIZE ) { + _head = 0; + } } // indicate success return true; - -/* Old method that fails when buffer fills up - if( _num_items < SIZE ) { - // add item at the tail - _buff[_tail] = item; - - // move tail forward one position - _tail++; - - // wrap around to front of buffer if required - if( _tail >= SIZE ) - _tail = 0; - - // increment number of items - _num_items++; - - // indicate success - return true; - }else{ - // we do not have room for the new item - return false; - } -*/ } // get - returns the next value in the buffer @@ -155,8 +131,9 @@ T AP_Buffer::peek(uint8_t position) uint8_t j = _head+position; // return zero if position is out of range - if( position >= _num_items ) + if( position >= _num_items ) { return 0; + } // wrap around if necessary if( j >= SIZE ) @@ -166,28 +143,4 @@ T AP_Buffer::peek(uint8_t position) return _buff[j]; } -// displays the contents of the curve (for debugging) -/*template -void AP_Buffer::print_buffer() -{ - uint8_t i; - Serial.print_P(PSTR("AP_Buffer: ")); - for( i = 0; i<_num_items; i++ ){ - if( i > 0 ) { - Serial.print_P(PSTR(", ")); - } - Serial.print(peek(i)); - } - Serial.println(); -}*/ - -/* -// displays the contents of the curve (for debugging) -template -void AP_Buffer::print_buffer() -{ - // we cannot print Vector3f types -} -*/ - #endif // AP_BUFFER \ No newline at end of file