diff options
-rw-r--r-- | src/simpl/base.cpp | 17 | ||||
-rw-r--r-- | tests/test_base.cpp | 25 | ||||
-rw-r--r-- | tests/test_base.h | 2 |
3 files changed, 37 insertions, 7 deletions
diff --git a/src/simpl/base.cpp b/src/simpl/base.cpp index d56cdd3..6671b53 100644 --- a/src/simpl/base.cpp +++ b/src/simpl/base.cpp @@ -357,13 +357,18 @@ void Frame::audio(sample* new_audio, int size) { throw Exception(std::string("Memory not managed by Frame.")); } - // copy size should also be less than or equal to the current frame size - if(size > _size) { - throw Exception(std::string("Specified copy size is too large, " - "it must be less than the Frame size.")); + if((size < _size) && (_size % size == 0)) { + std::rotate(_audio, _audio + size, _audio + _size); + std::copy(new_audio, new_audio + size, _audio + (_size - size)); + } + else if(size == _size) { + std::copy(new_audio, new_audio + size, _audio); + } + else { + printf("size: %d (%d)\n", size, _size); + throw Exception(std::string("Specified copy size must be a multiple " + "of the current Frame size.")); } - - memcpy(_audio, new_audio, sizeof(sample) * size); } sample* Frame::audio() { diff --git a/tests/test_base.cpp b/tests/test_base.cpp index 1a0816f..44b353c 100644 --- a/tests/test_base.cpp +++ b/tests/test_base.cpp @@ -19,7 +19,7 @@ void TestPeak::tearDown() { // --------------------------------------------------------------------------- void TestFrame::setUp() { - frame = new Frame(); + frame = new Frame(512, true); } void TestFrame::tearDown() { @@ -66,3 +66,26 @@ void TestFrame::test_clear() { frame->clear(); CPPUNIT_ASSERT(frame->num_peaks() == 0); } + +void TestFrame::test_audio() { + sample samples[8] = {0, 1, 2, 3, 4, 5, 6, 7}; + frame->size(8); + frame->audio(&samples[0], 8); + + CPPUNIT_ASSERT(frame->size() == 8); + + for(int i = 0; i < 8; i++) { + CPPUNIT_ASSERT(frame->audio()[i] == samples[i]); + } + + sample new_samples[2] = {8, 9}; + sample rotated_samples[8] = {2, 3, 4, 5, 6, 7, 8, 9}; + + frame->audio(&new_samples[0], 2); + + CPPUNIT_ASSERT(frame->size() == 8); + + for(int i = 0; i < 8; i++) { + CPPUNIT_ASSERT(frame->audio()[i] == rotated_samples[i]); + } +} diff --git a/tests/test_base.h b/tests/test_base.h index 2ab20a4..73aceed 100644 --- a/tests/test_base.h +++ b/tests/test_base.h @@ -41,6 +41,7 @@ class TestFrame : public CPPUNIT_NS::TestCase { CPPUNIT_TEST(test_max_partials); CPPUNIT_TEST(test_add_peak); CPPUNIT_TEST(test_clear); + CPPUNIT_TEST(test_audio); CPPUNIT_TEST_SUITE_END(); public: @@ -56,6 +57,7 @@ protected: void test_max_partials(); void test_add_peak(); void test_clear(); + void test_audio(); }; } // end of namespace simpl |