activemq-cpp-3.8.2
FloatArrayBuffer.h
Go to the documentation of this file.
1 /*
2  * Licensed to the Apache Software Foundation (ASF) under one or more
3  * contributor license agreements. See the NOTICE file distributed with
4  * this work for additional information regarding copyright ownership.
5  * The ASF licenses this file to You under the Apache License, Version 2.0
6  * (the "License"); you may not use this file except in compliance with
7  * the License. You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  */
17 
18 #ifndef _DECAF_INTERNAL_NIO_FLOATARRAYBUFFER_H_
19 #define _DECAF_INTERNAL_NIO_FLOATARRAYBUFFER_H_
20 
21 #include <decaf/nio/FloatBuffer.h>
28 
29 #include <decaf/lang/Pointer.h>
30 
31 namespace decaf{
32 namespace internal{
33 namespace nio{
34 
36 
38  private:
39 
40  // The reference array object that backs this buffer.
42 
43  // Offset into the array that we are to start from
44  int offset;
45 
46  // Number of bytes to read past the offset, or Limit.
47  int length;
48 
49  // Read / Write flag
50  bool readOnly;
51 
52  public:
53 
66  FloatArrayBuffer( int size, bool readOnly = false );
67 
86  FloatArrayBuffer( float* array, int size, int offset, int length, bool readOnly = false );
87 
105  FloatArrayBuffer( const decaf::lang::Pointer<ByteArrayAdapter>& array, int offset, int capacity,
106  bool readOnly = false );
107 
116  FloatArrayBuffer( const FloatArrayBuffer& other );
117 
118  virtual ~FloatArrayBuffer();
119 
120  public:
121 
125  virtual float* array();
126 
130  virtual int arrayOffset();
131 
135  virtual FloatBuffer* asReadOnlyBuffer() const;
136 
140  virtual FloatBuffer& compact();
141 
145  virtual FloatBuffer* duplicate();
146 
150  virtual float get();
151 
155  virtual float get( int index ) const;
156 
160  virtual bool hasArray() const { return true; }
161 
165  virtual bool isReadOnly() const {
166  return this->readOnly;
167  }
168 
172  virtual FloatBuffer& put( float value );
173 
177  virtual FloatBuffer& put( int index, float value );
178 
182  virtual FloatBuffer* slice() const;
183 
184  protected:
185 
192  virtual void setReadOnly( bool value ) {
193  this->readOnly = value;
194  }
195 
196  };
197 
198 }}}
199 
200 #endif /*_DECAF_INTERNAL_NIO_FLOATARRAYBUFFER_H_*/
virtual bool isReadOnly() const
Tells whether or not this buffer is read-only.true if, and only if, this buffer is read-only...
Definition: FloatArrayBuffer.h:165
This class defines four categories of operations upon float buffers:
Definition: FloatBuffer.h:50
Definition: FloatArrayBuffer.h:37
virtual bool hasArray() const
Tells whether or not this buffer is backed by an accessible float array.If this method returns true t...
Definition: FloatArrayBuffer.h:160
This class adapts primitive type arrays to a base byte array so that the classes can inter-operate on...
Definition: ByteArrayAdapter.h:43
#define DECAF_API
Definition: Config.h:29
virtual void setReadOnly(bool value)
Sets this FloatArrayBuffer as Read-Only.
Definition: FloatArrayBuffer.h:192
Decaf&#39;s implementation of a Smart Pointer that is a template on a Type and is Thread Safe if the defa...
Definition: Pointer.h:53
Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements...
Definition: AprPool.h:25