org.netbeans.api.extexecution.input.InputReaders 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 org.netbeans.api.extexecution.input;
import org.netbeans.modules.extexecution.input.BaseInputProcessor;
import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.Reader;
import java.nio.charset.Charset;
import java.util.concurrent.atomic.AtomicReference;
import org.netbeans.api.annotations.common.CheckForNull;
import org.netbeans.api.annotations.common.NonNull;
import org.netbeans.api.extexecution.base.input.InputProcessor;
import org.openide.util.Parameters;
/**
* Factory methods for {@link InputReader} classes.
*
* @author Petr Hejl
* @deprecated use {@link org.netbeans.api.extexecution.base.input.InputReaders}
*/
public final class InputReaders {
private InputReaders() {
super();
}
/**
* Returns the input reader backed by the given reader.
*
* The client should not use the reader passed as argument anymore. When
* the returned input reader is closed reader passed as argument is closed
* respectively.
*
* Returned reader will never call reset on {@link InputProcessor} while
* reading.
*
* Returned reader is not thread safe so it can't be used in
* multiple instances of {@link InputReaderTask}.
*
* @param reader real source of the data
* @return input reader backed by the given reader
*/
@NonNull
public static InputReader forReader(@NonNull Reader reader) {
final org.netbeans.api.extexecution.base.input.InputReader delegate = org.netbeans.api.extexecution.base.input.InputReaders.forReader(reader);
return new InputReader() {
@Override
public int readInput(org.netbeans.api.extexecution.input.InputProcessor processor) throws IOException {
return delegate.readInput(processor == null ? null : new BaseInputProcessor(processor));
}
@Override
public void close() throws IOException {
delegate.close();
}
};
}
/**
* Returns the input reader backed by the given stream. To convert read
* bytes to characters specified charset is used.
*
* The client should not use the stream passed as argument anymore. When
* the returned input reader is closed stream is closed respectively.
*
* Returned reader will never call reset on {@link InputProcessor} while
* reading.
*
* Returned reader is not thread safe so it can't be used in
* multiple instances of {@link InputReaderTask}.
*
* @param stream real source of the data
* @param charset bytes to characters conversion charset
* @return input reader backed by the given stream
*/
@NonNull
public static InputReader forStream(@NonNull InputStream stream, @NonNull Charset charset) {
Parameters.notNull("stream", stream);
return forReader(new InputStreamReader(stream, charset));
}
/**
* Returns the input reader for the given file. To convert read bytes
* to characters specified charset is used.
*
* Returned reader will never call reset on {@link InputProcessor} while
* reading.
*
* Returned reader is not thread safe so it can't be used in
* multiple instances of {@link InputReaderTask}.
*
* @param file file to read from
* @param charset bytes to characters conversion charset
* @return input reader for the given file
*/
@NonNull
public static InputReader forFile(@NonNull File file, @NonNull Charset charset) {
Parameters.notNull("file", file);
Parameters.notNull("charset", charset);
final FileInput fileInput = new FileInput(file, charset);
return forFileInputProvider(new FileInput.Provider() {
public FileInput getFileInput() {
return fileInput;
}
});
}
/**
* Returns the input reader reading data from the given provider.
*
* This means that the actual file (and the corresponding charset) used
* can change during the processing. This is specifically useful for
* rotating log files.
*
* Before each read cycle reader invokes {@link FileInput.Provider#getFileInput()}
* to determine the actual file to read.
*
* When processing the input {@link InputProcessor#reset()} is called on
* each file change (when provided file input differs from the previous one).
*
* Returned reader is not thread safe so it can't be used in
* multiple instances of {@link InputReaderTask}.
*
* @param fileProvider provider used to get the file to process
* @return input reader for the given provider
*/
@NonNull
public static InputReader forFileInputProvider(@NonNull final FileInput.Provider fileProvider) {
Parameters.notNull("fileProvider", fileProvider);
final org.netbeans.api.extexecution.base.input.InputReader delegate = org.netbeans.api.extexecution.base.input.InputReaders.forFileInputProvider(new org.netbeans.api.extexecution.base.input.InputReaders.FileInput.Provider() {
private org.netbeans.api.extexecution.base.input.InputReaders.FileInput proxy;
private FileInput input;
@Override
public org.netbeans.api.extexecution.base.input.InputReaders.FileInput getFileInput() {
FileInput fresh = fileProvider.getFileInput();
if (input != fresh && (input == null || !input.equals(fresh))) {
input = fresh;
proxy = new org.netbeans.api.extexecution.base.input.InputReaders.FileInput(
input.getFile(), input.getCharset());
}
return proxy;
}
});
return new InputReader() {
@Override
public int readInput(org.netbeans.api.extexecution.input.InputProcessor processor) throws IOException {
return delegate.readInput(processor == null ? null : new BaseInputProcessor(processor));
}
@Override
public void close() throws IOException {
delegate.close();
}
};
}
/**
* Represents the file with associated charset for reading from it.
*
* This class is immutable.
*/
public static final class FileInput {
private final File file;
private final Charset charset;
/**
* Creates the new input representing the given file.
*
* @param file file to represent
* @param charset associated charset
*/
public FileInput(@NonNull File file, @NonNull Charset charset) {
Parameters.notNull("file", file);
Parameters.notNull("charset", charset);
this.file = file;
this.charset = charset;
}
/**
* Returns the charset for reading the file.
*
* @return the charset for reading the file
*/
@NonNull
public Charset getCharset() {
return charset;
}
/**
* Returns the file represented by this input.
*
* @return the file represented by this input
*/
@NonNull
public File getFile() {
return file;
}
/**
* Provides the file input.
*
* @see InputReaders#forFileInputProvider(org.netbeans.api.extexecution.input.InputReaders.FileInput.Provider)
*/
public interface Provider {
/**
* Returns the file input to use or null
if there is
* no file to read currently.
*
* @return the file input to use or null
if there is
* no file to read currently
*/
@CheckForNull
FileInput getFileInput();
}
}
}