blob: d943a2e1d0b7471f2c0eb66e2cff348ed3d4f5a2 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "FloatBuffer.h"
#include <decaf/lang/Float.h>
#include <decaf/lang/Math.h>
#include "decaf/internal/nio/BufferFactory.h"
using namespace std;
using namespace decaf;
using namespace decaf::nio;
using namespace decaf::internal::nio;
using namespace decaf::lang;
using namespace decaf::lang::exceptions;
////////////////////////////////////////////////////////////////////////////////
FloatBuffer::FloatBuffer( int capacity ) : Buffer( capacity ) {
}
////////////////////////////////////////////////////////////////////////////////
FloatBuffer* FloatBuffer::allocate( int capacity ) {
try{
return BufferFactory::createFloatBuffer( capacity );
}
DECAF_CATCH_RETHROW( Exception )
DECAF_CATCHALL_THROW( Exception )
}
////////////////////////////////////////////////////////////////////////////////
FloatBuffer* FloatBuffer::wrap( float* buffer, int size, int offset, int length ) {
try{
if( buffer == NULL ) {
throw NullPointerException(
__FILE__, __LINE__,
"FloatBuffer::wrap - Passed Buffer is Null.");
}
return BufferFactory::createFloatBuffer( buffer, size, offset, length );
}
DECAF_CATCH_RETHROW( NullPointerException )
DECAF_CATCH_EXCEPTION_CONVERT( Exception, NullPointerException )
DECAF_CATCHALL_THROW( NullPointerException )
}
////////////////////////////////////////////////////////////////////////////////
FloatBuffer* FloatBuffer::wrap( std::vector<float>& buffer ) {
try{
if( buffer.empty() ) {
throw NullPointerException(
__FILE__, __LINE__,
"FloatBuffer::wrap - Passed Buffer is Empty.");
}
return BufferFactory::createFloatBuffer( &buffer[0], (int)buffer.size(), 0, (int)buffer.size() );
}
DECAF_CATCH_RETHROW( NullPointerException )
DECAF_CATCH_EXCEPTION_CONVERT( Exception, NullPointerException )
DECAF_CATCHALL_THROW( NullPointerException )
}
////////////////////////////////////////////////////////////////////////////////
std::string FloatBuffer::toString() const {
std::ostringstream stream;
stream << "FloatBuffer, status: "
<< "capacity =" << this->capacity()
<< " position =" << this->position()
<< " limit = " << this->limit();
return stream.str();
}
////////////////////////////////////////////////////////////////////////////////
FloatBuffer& FloatBuffer::get( std::vector<float> buffer ) {
try{
if( !buffer.empty() ) {
this->get( &buffer[0], (int)buffer.size(), 0, (int)buffer.size() );
}
return *this;
}
DECAF_CATCH_RETHROW( BufferUnderflowException )
DECAF_CATCH_EXCEPTION_CONVERT( Exception, BufferUnderflowException )
DECAF_CATCHALL_THROW( BufferUnderflowException )
}
////////////////////////////////////////////////////////////////////////////////
FloatBuffer& FloatBuffer::get( float* buffer, int size, int offset, int length ) {
try{
if( length == 0 ) {
return *this;
}
if( buffer == NULL ) {
throw NullPointerException(
__FILE__, __LINE__,
"FloatBuffer::get - Passed Buffer is Null" );
}
if( size < 0 || offset < 0 || length < 0 || (long long)offset + (long long)length > (long long)size ) {
throw IndexOutOfBoundsException(
__FILE__, __LINE__, "Arguments violate array bounds." );
}
if( length > remaining() ) {
throw BufferUnderflowException(
__FILE__, __LINE__,
"FloatBuffer::get - Not enough data to fill length = %d", length );
}
for( int ix = 0; ix < length; ++ix ){
buffer[offset + ix] = this->get();
}
return *this;
}
DECAF_CATCH_RETHROW( BufferUnderflowException )
DECAF_CATCH_RETHROW( IndexOutOfBoundsException )
DECAF_CATCH_RETHROW( NullPointerException )
DECAF_CATCH_EXCEPTION_CONVERT( Exception, BufferUnderflowException )
DECAF_CATCHALL_THROW( BufferUnderflowException )
}
////////////////////////////////////////////////////////////////////////////////
FloatBuffer& FloatBuffer::put( FloatBuffer& src ) {
try{
if( this == &src ) {
throw IllegalArgumentException(
__FILE__, __LINE__,
"FloatBuffer::put - Can't put Self" );
}
if( this->isReadOnly() ) {
throw ReadOnlyBufferException(
__FILE__, __LINE__,
"FloatBuffer::put - This buffer is Read Only.");
}
if( src.remaining() > this->remaining() ) {
throw BufferOverflowException(
__FILE__, __LINE__,
"FloatBuffer::put - Not enough space remaining to put src." );
}
while( src.hasRemaining() ) {
this->put( src.get() );
}
return *this;
}
DECAF_CATCH_RETHROW( BufferOverflowException )
DECAF_CATCH_RETHROW( ReadOnlyBufferException )
DECAF_CATCH_RETHROW( IllegalArgumentException )
DECAF_CATCH_EXCEPTION_CONVERT( Exception, BufferOverflowException )
DECAF_CATCHALL_THROW( BufferOverflowException )
}
////////////////////////////////////////////////////////////////////////////////
FloatBuffer& FloatBuffer::put( const float* buffer, int size, int offset, int length ) {
try{
if( length == 0 ) {
return *this;
}
if( this->isReadOnly() ) {
throw ReadOnlyBufferException(
__FILE__, __LINE__,
"FloatBuffer::put - This buffer is Read Only.");
}
if( buffer == NULL ) {
throw NullPointerException(
__FILE__, __LINE__,
"FloatBuffer::put - Passed Buffer is Null.");
}
if( size < 0 || offset < 0 || length < 0 || (long long)offset + (long long)length > (long long)size ) {
throw IndexOutOfBoundsException(
__FILE__, __LINE__, "Arguments violate array bounds." );
}
if( length > this->remaining() ) {
throw BufferOverflowException(
__FILE__, __LINE__,
"FloatBuffer::put - Not Enough space to store requested Data.");
}
// read length bytes starting from the offset
for( int ix = 0; ix < length; ++ix ) {
this->put( buffer[ix + offset] );
}
return *this;
}
DECAF_CATCH_RETHROW( BufferOverflowException )
DECAF_CATCH_RETHROW( ReadOnlyBufferException )
DECAF_CATCH_RETHROW( NullPointerException )
DECAF_CATCH_RETHROW( IndexOutOfBoundsException )
DECAF_CATCH_EXCEPTION_CONVERT( Exception, BufferOverflowException )
DECAF_CATCHALL_THROW( BufferOverflowException )
}
////////////////////////////////////////////////////////////////////////////////
FloatBuffer& FloatBuffer::put( std::vector<float>& buffer ) {
try{
if( !buffer.empty() ) {
this->put( &buffer[0], (int)buffer.size(), 0, (int)buffer.size() );
}
return *this;
}
DECAF_CATCH_RETHROW( BufferOverflowException )
DECAF_CATCH_RETHROW( ReadOnlyBufferException )
DECAF_CATCH_EXCEPTION_CONVERT( Exception, BufferOverflowException )
DECAF_CATCHALL_THROW( BufferOverflowException )
}
////////////////////////////////////////////////////////////////////////////////
int FloatBuffer::compareTo( const FloatBuffer& value ) const {
int compareRemaining = Math::min( (int)remaining(), (int)value.remaining() );
int thisPos = this->position();
int otherPos = value.position();
float thisVal, otherVal;
while( compareRemaining > 0 ) {
thisVal = get( thisPos );
otherVal = value.get( otherPos );
if( thisVal != otherVal ) {
return thisVal < otherVal ? -1 : 1;
}
thisPos++;
otherPos++;
compareRemaining--;
}
return (int)( remaining() - value.remaining() );
}
////////////////////////////////////////////////////////////////////////////////
bool FloatBuffer::equals( const FloatBuffer& value ) const {
if( &value == this ) {
return true;
}
if( this->remaining() != value.remaining() ) {
return false;
}
int myPosition = this->position();
int otherPosition = value.position();
bool equalSoFar = true;
while( equalSoFar && ( myPosition < this->limit() ) ) {
equalSoFar = get( myPosition++ ) == value.get( otherPosition++ );
}
return equalSoFar;
}
////////////////////////////////////////////////////////////////////////////////
bool FloatBuffer::operator==( const FloatBuffer& value ) const {
return this->equals( value );
}
////////////////////////////////////////////////////////////////////////////////
bool FloatBuffer::operator<( const FloatBuffer& value ) const {
return this->compareTo( value ) < 0 ? true : false;
}