com.ait.tooling.common.server.io.NoSyncBufferedWriter Maven / Gradle / Ivy
/*
* Copyright (c) 2014,2015,2016 Ahome' Innovation Technologies. 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.
* 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 com.ait.tooling.common.server.io;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.Writer;
import java.util.Objects;
public class NoSyncBufferedWriter extends BufferedWriter
{
private final static int MINIMUM_CAPACITY = 16;
private final static int DEFAULT_CAPACITY = 4096;
private final static int BOUNDRY_CAPACITY = Integer.MAX_VALUE - MINIMUM_CAPACITY;
private static final int toMinimumCapacity(int capacity)
{
if (capacity <= MINIMUM_CAPACITY)
{
return MINIMUM_CAPACITY;
}
if (capacity >= BOUNDRY_CAPACITY)
{
capacity = capacity - DEFAULT_CAPACITY;
}
return capacity + (capacity % MINIMUM_CAPACITY);
}
private final static int less(final int a, final int b)
{
return ((a < b) ? (a) : (b));
}
private Writer m_writer;
private int m_sizeof;
private int m_nextch;
private char m_charbf[];
public NoSyncBufferedWriter(final Writer writer)
{
this(Objects.requireNonNull(writer), DEFAULT_CAPACITY);
}
public NoSyncBufferedWriter(final Writer writer, final int capacity)
{
super(Objects.requireNonNull(writer), MINIMUM_CAPACITY);
m_writer = writer;
m_sizeof = toMinimumCapacity(capacity);
m_charbf = new char[m_sizeof];
}
private void doEnsuredOpen() throws IOException
{
if (null == m_writer)
{
throw new IOException("Writer closed");
}
}
private void doFlushBuffer() throws IOException
{
doEnsuredOpen();
if (0 == m_nextch)
{
return;
}
m_writer.write(m_charbf, 0, m_nextch);
m_nextch = 0;
}
@Override
public void write(final int c) throws IOException
{
doEnsuredOpen();
if (m_nextch >= m_sizeof)
{
doFlushBuffer();
}
m_charbf[m_nextch++] = ((char) c);
}
@Override
public void write(final char buf[], final int off, final int len) throws IOException
{
doEnsuredOpen();
if ((off < 0) || (off > buf.length) || (len < 0) || ((off + len) > buf.length) || ((off + len) < 0))
{
throw new IndexOutOfBoundsException();
}
if (0 == len)
{
return;
}
if (len >= m_sizeof)
{
doFlushBuffer();
m_writer.write(buf, off, len);
return;
}
int off_sets = off;
int total_sz = (off + len);
while (off_sets < total_sz)
{
int put_size = less(m_sizeof - m_nextch, total_sz - off_sets);
System.arraycopy(buf, off_sets, m_charbf, m_nextch, put_size);
off_sets = off_sets + put_size;
m_nextch = m_nextch + put_size;
if (m_nextch >= m_sizeof)
{
doFlushBuffer();
}
}
}
@Override
public void write(final String s, final int off, final int len) throws IOException
{
doEnsuredOpen();
int off_sets = off;
int total_sz = (off + len);
while (off_sets < total_sz)
{
int put_size = less(m_sizeof - m_nextch, total_sz - off_sets);
s.getChars(off_sets, off_sets + put_size, m_charbf, m_nextch);
off_sets = off_sets + put_size;
m_nextch = m_nextch + put_size;
if (m_nextch >= m_sizeof)
{
doFlushBuffer();
}
}
}
@Override
public void newLine() throws IOException
{
super.newLine();
}
@Override
public void flush() throws IOException
{
doFlushBuffer();
m_writer.flush();
}
@Override
public void close() throws IOException
{
if (null == m_writer)
{
return;
}
try
{
doFlushBuffer();
}
finally
{
m_writer.close();
m_writer = null;
m_charbf = null;
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy