All Downloads are FREE. Search and download functionalities are using the official Maven repository.

java.nio.ShortToByteBufferAdapter Maven / Gradle / Ivy

The newest version!
/* 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.
 */

package java.nio;

//import org.apache.harmony.nio.internal.DirectBuffer;
//import org.apache.harmony.luni.platform.PlatformAddress;

/** This class wraps a byte buffer to be a short buffer.
 * 

* Implementation notice: *

    *
  • After a byte buffer instance is wrapped, it becomes privately owned by the adapter. It must NOT be accessed outside the * adapter any more.
  • *
  • The byte buffer's position and limit are NOT linked with the adapter. The adapter extends Buffer, thus has its own position * and limit.
  • *
*

*/ final class ShortToByteBufferAdapter extends ShortBuffer implements ByteBufferWrapper { // implements DirectBuffer { static ShortBuffer wrap (ByteBuffer byteBuffer) { return new ShortToByteBufferAdapter(byteBuffer.slice()); } private final ByteBuffer byteBuffer; ShortToByteBufferAdapter (ByteBuffer byteBuffer) { super((byteBuffer.capacity() >> 1)); this.byteBuffer = byteBuffer; this.byteBuffer.clear(); } // public int getByteCapacity() { // if (byteBuffer instanceof DirectBuffer) { // return ((DirectBuffer) byteBuffer).getByteCapacity(); // } // assert false : byteBuffer; // return -1; // } // // public PlatformAddress getEffectiveAddress() { // if (byteBuffer instanceof DirectBuffer) { // return ((DirectBuffer) byteBuffer).getEffectiveAddress(); // } // assert false : byteBuffer; // return null; // } // // public PlatformAddress getBaseAddress() { // if (byteBuffer instanceof DirectBuffer) { // return ((DirectBuffer) byteBuffer).getBaseAddress(); // } // assert false : byteBuffer; // return null; // } // // public boolean isAddressValid() { // if (byteBuffer instanceof DirectBuffer) { // return ((DirectBuffer) byteBuffer).isAddressValid(); // } // assert false : byteBuffer; // return false; // } // // public void addressValidityCheck() { // if (byteBuffer instanceof DirectBuffer) { // ((DirectBuffer) byteBuffer).addressValidityCheck(); // } else { // assert false : byteBuffer; // } // } // // public void free() { // if (byteBuffer instanceof DirectBuffer) { // ((DirectBuffer) byteBuffer).free(); // } else { // assert false : byteBuffer; // } // } @Override public ShortBuffer asReadOnlyBuffer () { ShortToByteBufferAdapter buf = new ShortToByteBufferAdapter(byteBuffer.asReadOnlyBuffer()); buf.limit = limit; buf.position = position; buf.mark = mark; return buf; } @Override public ShortBuffer compact () { if (byteBuffer.isReadOnly()) { throw new ReadOnlyBufferException(); } byteBuffer.limit(limit << 1); byteBuffer.position(position << 1); byteBuffer.compact(); byteBuffer.clear(); position = limit - position; limit = capacity; mark = UNSET_MARK; return this; } @Override public ShortBuffer duplicate () { ShortToByteBufferAdapter buf = new ShortToByteBufferAdapter(byteBuffer.duplicate()); buf.limit = limit; buf.position = position; buf.mark = mark; return buf; } @Override public short get () { if (position == limit) { throw new BufferUnderflowException(); } return byteBuffer.getShort(position++ << 1); } @Override public short get (int index) { if (index < 0 || index >= limit) { throw new IndexOutOfBoundsException(); } return byteBuffer.getShort(index << 1); } @Override public boolean isDirect () { return byteBuffer.isDirect(); } @Override public boolean isReadOnly () { return byteBuffer.isReadOnly(); } @Override public ByteOrder order () { return byteBuffer.order(); } @Override protected short[] protectedArray () { throw new UnsupportedOperationException(); } @Override protected int protectedArrayOffset () { throw new UnsupportedOperationException(); } @Override protected boolean protectedHasArray () { return false; } @Override public ShortBuffer put (short c) { if (position == limit) { throw new BufferOverflowException(); } byteBuffer.putShort(position++ << 1, c); return this; } @Override public ShortBuffer put (int index, short c) { if (index < 0 || index >= limit) { throw new IndexOutOfBoundsException(); } byteBuffer.putShort(index << 1, c); return this; } @Override public ShortBuffer slice () { byteBuffer.limit(limit << 1); byteBuffer.position(position << 1); ShortBuffer result = new ShortToByteBufferAdapter(byteBuffer.slice()); byteBuffer.clear(); return result; } public ByteBuffer getByteBuffer () { return byteBuffer; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy