diff --git a/src/main/java/com/amazon/ion/impl/IonReaderTextRawTokensX.java b/src/main/java/com/amazon/ion/impl/IonReaderTextRawTokensX.java index 94876a285..5a2f89ba8 100644 --- a/src/main/java/com/amazon/ion/impl/IonReaderTextRawTokensX.java +++ b/src/main/java/com/amazon/ion/impl/IonReaderTextRawTokensX.java @@ -1,18 +1,5 @@ -/* - * Copyright 2007-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved. - * - * Licensed under the Apache License, Version 2.0 (the "License"). - * You may not use this file except in compliance with the License. - * A copy of the License is located at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * or in the "license" file accompanying this file. This file 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. - */ - +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 package com.amazon.ion.impl; import static com.amazon.ion.impl.IonTokenConstsX.CharacterSequence.CHAR_SEQ_ESCAPED_NEWLINE_SEQUENCE_1; @@ -1582,11 +1569,11 @@ protected IonType load_number(StringBuilder sb) throws IOException int c2 = read_char(); if (Radix.HEX.isPrefix(c2)) { sb.append((char)c); - c = loadRadixValue(sb, has_sign, c2, Radix.HEX); + c = loadRadixValue(sb, c2, Radix.HEX); return load_finish_number(sb, c, IonTokenConstsX.TOKEN_HEX); } else if (Radix.BINARY.isPrefix(c2)) { sb.append((char) c); - c = loadRadixValue(sb, has_sign, c2, Radix.BINARY); + c = loadRadixValue(sb, c2, Radix.BINARY); return load_finish_number(sb, c, IonTokenConstsX.TOKEN_BINARY); } // not a next value, back up and try again @@ -1843,7 +1830,7 @@ else if (c == '+' || c == '-') { return load_finish_number(sb, c, IonTokenConstsX.TOKEN_TIMESTAMP); } - private final int loadRadixValue(StringBuilder sb, boolean has_sign, int c2, Radix radix) + private final int loadRadixValue(StringBuilder sb, int c2, Radix radix) throws IOException { radix.assertPrefix(c2); diff --git a/src/main/java/com/amazon/ion/impl/IonTextBufferedStream.java b/src/main/java/com/amazon/ion/impl/IonTextBufferedStream.java deleted file mode 100644 index 2be9e8f4a..000000000 --- a/src/main/java/com/amazon/ion/impl/IonTextBufferedStream.java +++ /dev/null @@ -1,311 +0,0 @@ -/* - * Copyright 2007-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved. - * - * Licensed under the Apache License, Version 2.0 (the "License"). - * You may not use this file except in compliance with the License. - * A copy of the License is located at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * or in the "license" file accompanying this file. This file 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 com.amazon.ion.impl; - -import java.io.IOException; -import java.io.InputStream; - -/** - * InputStream implementations over a number of types (byte[] and String) - * that do not handle character decoding. Each byte is treated as just - * a character from 0 to 255. These are used internally to wire up some - * of the Iterator code to some of the base64 encoding (or decoding) - * routins in ion.impl. - */ -abstract class IonTextBufferedStream extends InputStream -{ - public static IonTextBufferedStream makeStream(byte[] bytes) { - return new SimpleBufferStream(bytes); - } - public static IonTextBufferedStream makeStream(byte[] bytes, int offset, int len) { - return new OffsetBufferStream(bytes, offset, len); - } - public static IonTextBufferedStream makeStream(String text) { - return new StringStream(text); - } - /*** FIXME: REMOVE OR FINISH - public static IonTextBufferedStream makeStream(InputStream stream) { - return new StreamStream(stream); - } - */ - public abstract int getByte(int pos); - public abstract int position(); - public abstract IonTextBufferedStream setPosition(int pos); - - /*** FIXME: REMOVE OR FINISH - static final class StreamStream extends IonTextBufferedStream - { - static final int DEFAULT_BUFFER_SIZE = (32*1024); - - InputStream _stream; - byte [] _buffer1; - byte [] _buffer2; - long _file_pos1; - long _file_pos2; - int _len; - int _pos; - - public StreamStream (InputStream stream) - { - _stream = stream; - _buffer1 = new byte[DEFAULT_BUFFER_SIZE]; - _buffer2 = new byte[DEFAULT_BUFFER_SIZE]; - _pos = 0; - _file_pos1 = 0; - _file_pos2 = -1; - _len = load(_buffer1); - } - int load(byte[] buffer) { - - } - - @Override - public final int getByte(int pos) { - if (pos < 0 || pos >= _len) return -1; - return _buffer[pos] & 0xff; - } - - @Override - public final int read() - throws IOException - { - if (_pos >= _len) return -1; - return _buffer[_pos++]; - } - - @Override - public final int read(byte[] bytes, int offset, int len) throws IOException - { - int copied = 0; - if (offset < 0) throw new IllegalArgumentException(); - copied = len; - if (_pos + len >= _len) copied = _len - _pos; - System.arraycopy(_buffer, _pos, bytes, offset, copied); - _pos += copied; - return copied; - } - - @Override - public final int position() { - return _pos; - } - - @Override - public final SimpleBufferStream setPosition(int pos) - { - if (_pos < 0 || _pos > _len) throw new IllegalArgumentException(); - _pos = pos; - return this; - } - - @Override - public void close() throws IOException - { - _stream.close(); - super.close(); - } - } - */ - - static final class SimpleBufferStream extends IonTextBufferedStream - { - byte [] _buffer; - int _len; - int _pos; - - public SimpleBufferStream(byte[] buffer) - { - _buffer = buffer; - _pos = 0; - _len = buffer.length; - } - - @Override - public final int getByte(int pos) { - if (pos < 0 || pos >= _len) return -1; - return _buffer[pos] & 0xff; - } - - @Override - public final int read() - throws IOException - { - if (_pos >= _len) return -1; - return _buffer[_pos++]; - } - - @Override - public final int read(byte[] bytes, int offset, int len) throws IOException - { - int copied = 0; - if (offset < 0) throw new IllegalArgumentException(); - copied = len; - if (_pos + len >= _len) copied = _len - _pos; - System.arraycopy(_buffer, _pos, bytes, offset, copied); - _pos += copied; - return copied; - } - - @Override - public final int position() { - return _pos; - } - - @Override - public final SimpleBufferStream setPosition(int pos) - { - if (_pos < 0 || _pos > _len) throw new IllegalArgumentException(); - _pos = pos; - return this; - } - - @Override - public void close() - throws IOException - { - _pos = _len; - super.close(); - } - } - - static final class StringStream extends IonTextBufferedStream - { - - String _string; - int _end; - int _pos; - - public StringStream(String text) - { - _string = text; - _pos = 0; - _end = text.length(); - } - - @Override - public final int getByte(int pos) { - if (pos < 0) return -1; - if (pos >= _end) return -1; - return _string.charAt(pos); - } - - @Override - public final int read() - throws IOException - { - if (_pos >= _end) return -1; - char c = _string.charAt(_pos++); - return c; - } - - @Override - public final int read(byte[] bytes, int offset, int len) throws IOException - { - throw new UnsupportedOperationException(); - } - - @Override - public final int position() { - return _pos; - } - - @Override - public final StringStream setPosition(int pos) - { - if (pos < 0) throw new IllegalArgumentException(); - if (pos > _end) throw new IllegalArgumentException(); - _pos = pos; - return this; - } - - @Override - public void close() - throws IOException - { - _pos = _end; - super.close(); - } - } - - static final class OffsetBufferStream extends IonTextBufferedStream - { - byte [] _buffer; - int _start; - int _end; - int _pos; - - public OffsetBufferStream(byte[] buffer, int start, int max) - { - _buffer = buffer; - _pos = start; - _start = start; - _end = start + max; - } - - @Override - public final int getByte(int pos) { - if (pos < 0) return -1; - pos += _start; - if (pos >= _end) return -1; - return _buffer[pos] & 0xff; - } - - @Override - public final int read() - throws IOException - { - int c; - if (_pos >= _end) return -1; - c = (((int)_buffer[_pos++]) & 0xFF); // trim sign extension bits - return c; - } - - @Override - public final int read(byte[] bytes, int offset, int len) throws IOException - { - int copied = 0; - if (offset < 0) throw new IllegalArgumentException(); - copied = len; - if (_pos + len >= _end) copied = _end - _pos; - System.arraycopy(_buffer, _pos, bytes, offset, copied); - _pos += copied; - return copied; - } - - @Override - public final int position() { - return _pos - _start; - } - - @Override - public final OffsetBufferStream setPosition(int pos) - { - if (pos < 0) throw new IllegalArgumentException(); - pos += _start; - if (pos > _end) throw new IllegalArgumentException(); - _pos = pos; - return this; - } - - @Override - public void close() - throws IOException - { - _pos = _end; - super.close(); - } - } -} diff --git a/src/main/java/com/amazon/ion/impl/UnifiedInputStreamX.java b/src/main/java/com/amazon/ion/impl/UnifiedInputStreamX.java index 71967f733..8356a9bee 100644 --- a/src/main/java/com/amazon/ion/impl/UnifiedInputStreamX.java +++ b/src/main/java/com/amazon/ion/impl/UnifiedInputStreamX.java @@ -1,21 +1,7 @@ -/* - * Copyright 2007-2019 Amazon.com, Inc. or its affiliates. All Rights Reserved. - * - * Licensed under the Apache License, Version 2.0 (the "License"). - * You may not use this file except in compliance with the License. - * A copy of the License is located at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * or in the "license" file accompanying this file. This file 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. - */ - +// Copyright Amazon.com, Inc. or its affiliates. All Rights Reserved. +// SPDX-License-Identifier: Apache-2.0 package com.amazon.ion.impl; -import com.amazon.ion.impl.IonReaderTextRawTokensX.IonReaderTextTokenException; import com.amazon.ion.impl.UnifiedSavePointManagerX.SavePoint; import java.io.Closeable; import java.io.IOException; @@ -383,19 +369,6 @@ public final int read(byte[] dst, int offset, int length) throws IOException } return length - remaining; } - private int read_utf8(int c) throws IOException - { - int len = IonUTF8.getUTF8LengthFromFirstByte(c); - for (int ii=1; ii