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

java.nio.CharSequenceAdapter Maven / Gradle / Ivy

/*
 *  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;

/**
 * This class wraps a char sequence to be a char buffer.
 * 

* Implementation notice: *

    *
  • Char sequence based buffer is always readonly.
  • *
*

* */ final class CharSequenceAdapter extends CharBuffer { static CharSequenceAdapter copy(CharSequenceAdapter other) { CharSequenceAdapter buf = new CharSequenceAdapter(other.sequence); buf.limit = other.limit; buf.position = other.position; buf.mark = other.mark; return buf; } final CharSequence sequence; CharSequenceAdapter(CharSequence chseq) { super(chseq.length()); sequence = chseq; } public CharBuffer asReadOnlyBuffer() { return duplicate(); } public CharBuffer compact() { throw new ReadOnlyBufferException(); } public CharBuffer duplicate() { return copy(this); } public char get() { if (position == limit) { throw new BufferUnderflowException(); } return sequence.charAt(position++); } public char get(int index) { if (index < 0 || index >= limit) { throw new IndexOutOfBoundsException(); } return sequence.charAt(index); } public final CharBuffer get(char[] dest, int off, int len) { int length = dest.length; if ((off < 0 ) || (len < 0) || off + len > length) { throw new IndexOutOfBoundsException(); } if (len > remaining()) { throw new BufferUnderflowException(); } int newPosition = position + len; sequence.toString().getChars(position, newPosition, dest, off); position = newPosition; return this; } public boolean isDirect() { return false; } public boolean isReadOnly() { return true; } public ByteOrder order() { return ByteOrder.nativeOrder(); } protected char[] protectedArray() { throw new UnsupportedOperationException(); } protected int protectedArrayOffset() { throw new UnsupportedOperationException(); } protected boolean protectedHasArray() { return false; } public CharBuffer put(char c) { throw new ReadOnlyBufferException(); } public CharBuffer put(int index, char c) { throw new ReadOnlyBufferException(); } public final CharBuffer put(char[] src, int off, int len) { if ((off < 0 ) || (len < 0) || off + len > src.length) { throw new IndexOutOfBoundsException(); } if (len > remaining()) { throw new BufferOverflowException(); } throw new ReadOnlyBufferException(); } public CharBuffer put(String src, int start, int end) { if ((start < 0 ) || (end < 0) || start + end > src.length()) { throw new IndexOutOfBoundsException(); } throw new ReadOnlyBufferException(); } public CharBuffer slice() { return new CharSequenceAdapter(sequence.subSequence(position, limit)); } public CharSequence subSequence(int start, int end) { if (end < start || start < 0 || end > remaining()) { throw new IndexOutOfBoundsException(); } CharSequenceAdapter result = copy(this); result.position = position + start; result.limit = position + end; return result; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy