/* * Copyright (C) 2005-2006 Alfresco, Inc. * * Licensed under the Mozilla Public License version 1.1 * with a permitted attribution clause. You may obtain a * copy of the License at * * http://www.alfresco.org/legal/license.txt * * 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. */ #ifndef _ByteArray_H #define _ByteArray_H // Includes #include #include #include "util\Types.h" // Classes defined in this header file namespace Alfresco { class ByteArray; typedef std::auto_ptr PTR_ByteArray; } /** * Byte Array Class * * Provides a byte array object similar to Javas byte[]. */ class Alfresco::ByteArray { public: // Constructors ByteArray( BUFLEN len = 0, bool clearMem = false); ByteArray( CBUFPTR data, BUFLEN len); ByteArray( const char* data, BUFLEN len); // Copy constructor ByteArray( const ByteArray& byts); // Class destructor ~ByteArray(); // Return the data/length inline CBUFPTR getData( void) const { return m_data; } inline BUFPTR getData( void) { return m_data; } inline BUFLEN getLength( void) const { return m_length; } // Set the array length void setLength( BUFLEN len, bool clearMem = false); // Set a byte void setByte( unsigned int idx, unsigned char val); // Subscript operator unsigned char& operator[](const unsigned int idx); // Assignment operator ByteArray& operator=( const ByteArray& byts); ByteArray& operator=( std::string& byts); // Equality operator bool operator== ( const ByteArray& byts); // Return the start address of the byte array operator const unsigned char* ( void) { return m_data; } protected: // Set the byte array and length void setData( CBUFPTR data, BUFLEN len); private: // Instance variables // // Byte data and length BUFPTR m_data; BUFLEN m_length; }; #endif