activemq-cpp-3.8.2
ShortArrayBuffer.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_SHORTARRAYBUFFER_H_
19 #define _DECAF_INTERNAL_NIO_SHORTARRAYBUFFER_H_
20 
21 #include <decaf/nio/ShortBuffer.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  // The length of the sub-array, or limit
47  int length;
48 
49  // Read / Write flag
50  bool readOnly;
51 
52  public:
53 
66  ShortArrayBuffer( int size, bool readOnly = false );
67 
86  ShortArrayBuffer( short* array, int size, int offset, int length, bool readOnly = false );
87 
105  ShortArrayBuffer( const decaf::lang::Pointer<ByteArrayAdapter>& array, int offset, int length,
106  bool readOnly = false );
107 
116  ShortArrayBuffer( const ShortArrayBuffer& other );
117 
118  virtual ~ShortArrayBuffer();
119 
120  public:
121 
125  virtual short* array();
126 
130  virtual int arrayOffset();
131 
135  virtual ShortBuffer* asReadOnlyBuffer() const;
136 
140  virtual ShortBuffer& compact();
141 
145  virtual ShortBuffer* duplicate();
146 
150  virtual short get();
151 
155  virtual short 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 ShortBuffer& put( short value );
173 
177  virtual ShortBuffer& put( int index, short value );
178 
182  virtual ShortBuffer* 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_SHORTARRAYBUFFER_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: ShortArrayBuffer.h:165
virtual void setReadOnly(bool value)
Sets this ShortArrayBuffer as Read-Only.
Definition: ShortArrayBuffer.h:192
Definition: ShortArrayBuffer.h:37
This class defines four categories of operations upon short buffers:
Definition: ShortBuffer.h:50
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
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
virtual bool hasArray() const
Tells whether or not this buffer is backed by an accessible short array.If this method returns true t...
Definition: ShortArrayBuffer.h:160
Licensed to the Apache Software Foundation (ASF) under one or more contributor license agreements...
Definition: AprPool.h:25