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

org.netbeans.api.extexecution.input.InputReaderTask Maven / Gradle / Ivy

There is a newer version: RELEASE240
Show 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 org.netbeans.api.extexecution.input;

import org.netbeans.modules.extexecution.input.BaseInputProcessor;
import org.netbeans.modules.extexecution.input.DelegatingInputProcessor;
import java.io.IOException;
import org.netbeans.api.annotations.common.NonNull;
import org.netbeans.api.annotations.common.NullAllowed;
import org.openide.util.Cancellable;
import org.openide.util.Parameters;

/**
 * Task consuming data from the certain reader, processing them with the given
 * processor.
 * 

* When exception occurs while running the task it is terminated. * Task is responsive to interruption. InputReader is closed on finish (includes * both cases throwing an exception and interruption). *

* The {@link #run()} method can be executed just once. *

* Task is not finished implicitly by reaching the end of the reader. * The caller has to finish it either by interruption or explicit cancellation. * Cancellation is preferred in situations where the interruption could make * cleanup operations on {@link InputProcessor} impossible to happen. * *

*

* Sample usage - reading standard output of the process (throwing the data away): *

 *     java.lang.Process process = ...
 *     java.util.concurrent.ExecutorService executorService = ...
 *     Runnable runnable = InputReaderTask.newTask(
 *         InputReaders.forStream(process.getInputStream(), Charset.defaultCharset()));
 *     executorService.submit(runnable);
 *
 *     ...
 *
 *     executorService.shutdownNow();
 * 
* Sample usage - forwarding data to standard input of the process: *
 *     java.lang.Process process = ...
 *     java.util.concurrent.ExecutorService executorService = ...
 *     Runnable runnable = InputReaderTask.newTask(
 *         InputReaders.forStream(System.in, Charset.defaultCharset()),
 *         InputProcessors.copying(new OutputStreamWriter(process.getOutputStream())));
 *     executorService.submit(runnable);
 *
 *     ...
 *
 *     executorService.shutdownNow();
 * 
*
* * @author Petr Hejl * @deprecated use {@link org.netbeans.api.extexecution.base.input.InputReaderTask} */ public final class InputReaderTask implements Runnable, Cancellable { private final org.netbeans.api.extexecution.base.input.InputReaderTask delegate; private InputReaderTask(org.netbeans.api.extexecution.base.input.InputReaderTask delegate) { this.delegate = delegate; } /** * Creates the new task. The task will read the data from reader processing * them through processor (if any) until interrupted or cancelled. *

* {@link InputReader} must be non blocking. * * @param reader data producer * @param processor processor consuming the data, may be null * @return task handling the read process */ @NonNull public static InputReaderTask newTask(@NonNull InputReader reader, @NullAllowed InputProcessor processor) { Parameters.notNull("reader", reader); return new InputReaderTask(org.netbeans.api.extexecution.base.input.InputReaderTask.newTask( new BaseInputReader(reader), processor == null ? null : new BaseInputProcessor(processor))); } /** * Creates the new task. The task will read the data from reader processing * them through processor (if any). When interrupted or cancelled task will * try to read all the remaining available data before exiting. *

* {@link InputReader} must be non blocking. * * @param reader data producer * @param processor processor consuming the data, may be null * @return task handling the read process */ @NonNull public static InputReaderTask newDrainingTask(@NonNull InputReader reader, @NullAllowed InputProcessor processor) { Parameters.notNull("reader", reader); return new InputReaderTask(org.netbeans.api.extexecution.base.input.InputReaderTask.newDrainingTask( new BaseInputReader(reader), processor == null ? null : new BaseInputProcessor(processor))); } /** * Task repeatedly reads the data from the InputReader, passing the content * to InputProcessor (if any). *

* It is not allowed to invoke run multiple times. */ public void run() { delegate.run(); } /** * Cancels the task. If the task is not running or task is already cancelled * this is noop. * * @return true if the task was successfully cancelled */ public boolean cancel() { return delegate.cancel(); } private static class BaseInputReader implements org.netbeans.api.extexecution.base.input.InputReader { private final InputReader delegate; public BaseInputReader(InputReader delegate) { this.delegate = delegate; } public int readInput(org.netbeans.api.extexecution.base.input.InputProcessor processor) throws IOException { InputProcessor p = null; if (processor != null) { if (processor instanceof BaseInputProcessor) { p = ((BaseInputProcessor) processor).getDelegate(); } else { p = new DelegatingInputProcessor(processor); } } return delegate.readInput(p); } public void close() throws IOException { delegate.close(); } } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy