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

io.vertx.reactivex.core.file.AsyncFile Maven / Gradle / Ivy

/*
 * Copyright 2014 Red Hat, Inc.
 *
 * Red Hat 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 io.vertx.reactivex.core.file;

import io.vertx.reactivex.RxHelper;
import io.vertx.reactivex.ObservableHelper;
import io.vertx.reactivex.FlowableHelper;
import io.vertx.reactivex.impl.AsyncResultMaybe;
import io.vertx.reactivex.impl.AsyncResultSingle;
import io.vertx.reactivex.impl.AsyncResultCompletable;
import io.vertx.reactivex.WriteStreamObserver;
import io.vertx.reactivex.WriteStreamSubscriber;
import java.util.Map;
import java.util.Set;
import java.util.List;
import java.util.Iterator;
import java.util.function.Function;
import java.util.function.Supplier;
import java.util.stream.Collectors;
import io.vertx.core.Handler;
import io.vertx.core.AsyncResult;
import io.vertx.core.json.JsonObject;
import io.vertx.core.json.JsonArray;
import io.vertx.lang.rx.RxGen;
import io.vertx.lang.rx.TypeArg;
import io.vertx.lang.rx.MappingIterator;

/**
 * Represents a file on the file-system which can be read from, or written to asynchronously.
 * 

* This class also implements {@link io.vertx.reactivex.core.streams.ReadStream} and * {@link io.vertx.reactivex.core.streams.WriteStream}. This allows the data to be piped to and from * other streams, e.g. an {@link io.vertx.reactivex.core.http.HttpClientRequest} instance, * using the {@link io.vertx.reactivex.core.streams.Pipe} class * *

* NOTE: This class has been automatically generated from the {@link io.vertx.core.file.AsyncFile original} non RX-ified interface using Vert.x codegen. */ @RxGen(io.vertx.core.file.AsyncFile.class) public class AsyncFile implements io.vertx.reactivex.core.streams.ReadStream, io.vertx.reactivex.core.streams.WriteStream { @Override public String toString() { return delegate.toString(); } @Override public boolean equals(Object o) { if (this == o) return true; if (o == null || getClass() != o.getClass()) return false; AsyncFile that = (AsyncFile) o; return delegate.equals(that.delegate); } @Override public int hashCode() { return delegate.hashCode(); } public static final TypeArg __TYPE_ARG = new TypeArg<>( obj -> new AsyncFile((io.vertx.core.file.AsyncFile) obj), AsyncFile::getDelegate ); private final io.vertx.core.file.AsyncFile delegate; public AsyncFile(io.vertx.core.file.AsyncFile delegate) { this.delegate = delegate; } public AsyncFile(Object delegate) { this.delegate = (io.vertx.core.file.AsyncFile)delegate; } public io.vertx.core.file.AsyncFile getDelegate() { return delegate; } private io.reactivex.Observable observable; private io.reactivex.Flowable flowable; public synchronized io.reactivex.Observable toObservable() { if (observable == null) { observable = ObservableHelper.toObservable(this.getDelegate()); } return observable; } public synchronized io.reactivex.Flowable toFlowable() { if (flowable == null) { flowable = FlowableHelper.toFlowable(this.getDelegate()); } return flowable; } private WriteStreamObserver observer; private WriteStreamSubscriber subscriber; public synchronized WriteStreamObserver toObserver() { if (observer == null) { observer = RxHelper.toObserver(getDelegate()); } return observer; } public synchronized WriteStreamSubscriber toSubscriber() { if (subscriber == null) { subscriber = RxHelper.toSubscriber(getDelegate()); } return subscriber; } private static final TypeArg TYPE_ARG_0 = new TypeArg(o1 -> io.vertx.reactivex.core.file.AsyncFileLock.newInstance((io.vertx.core.file.AsyncFileLock)o1), o1 -> o1.getDelegate()); private static final TypeArg TYPE_ARG_1 = new TypeArg(o1 -> io.vertx.reactivex.core.file.AsyncFileLock.newInstance((io.vertx.core.file.AsyncFileLock)o1), o1 -> o1.getDelegate()); /** * Pause this stream and return a to transfer the elements of this stream to a destination . *

* The stream will be resumed when the pipe will be wired to a WriteStream. * @return a pipe */ public io.vertx.reactivex.core.streams.Pipe pipe() { io.vertx.reactivex.core.streams.Pipe ret = io.vertx.reactivex.core.streams.Pipe.newInstance((io.vertx.core.streams.Pipe)delegate.pipe(), TypeArg.unknown()); return ret; } /** * Pipe this ReadStream to the WriteStream. *

* Elements emitted by this stream will be written to the write stream until this stream ends or fails. * @param dst the destination write stream * @return a future notified when the write stream will be ended with the outcome */ public io.vertx.core.Future pipeTo(io.vertx.reactivex.core.streams.WriteStream dst) { io.vertx.core.Future ret = delegate.pipeTo(dst.getDelegate()).map(val -> val); return ret; } /** * Pipe this ReadStream to the WriteStream. *

* Elements emitted by this stream will be written to the write stream until this stream ends or fails. * @param dst the destination write stream * @return a future notified when the write stream will be ended with the outcome */ public io.reactivex.Completable rxPipeTo(io.vertx.reactivex.core.streams.WriteStream dst) { return AsyncResultCompletable.toCompletable($handler -> { this.pipeTo(dst).onComplete($handler); }); } /** * Write some data to the stream. * *

The data is usually put on an internal write queue, and the write actually happens * asynchronously. To avoid running out of memory by putting too much on the write queue, * check the {@link io.vertx.reactivex.core.streams.WriteStream#writeQueueFull} method before writing. This is done automatically if * using a . * *

When the data is moved from the queue to the actual medium, the returned * will be completed with the write result, e.g the future is succeeded * when a server HTTP response buffer is written to the socket and failed if the remote * client has closed the socket while the data was still pending for write. * @param data the data to write * @return a future completed with the write result */ public io.vertx.core.Future write(io.vertx.core.buffer.Buffer data) { io.vertx.core.Future ret = delegate.write(data).map(val -> val); return ret; } /** * Write some data to the stream. * *

The data is usually put on an internal write queue, and the write actually happens * asynchronously. To avoid running out of memory by putting too much on the write queue, * check the {@link io.vertx.reactivex.core.streams.WriteStream#writeQueueFull} method before writing. This is done automatically if * using a . * *

When the data is moved from the queue to the actual medium, the returned * will be completed with the write result, e.g the future is succeeded * when a server HTTP response buffer is written to the socket and failed if the remote * client has closed the socket while the data was still pending for write. * @param data the data to write * @return a future completed with the write result */ public io.reactivex.Completable rxWrite(io.vertx.core.buffer.Buffer data) { return AsyncResultCompletable.toCompletable($handler -> { this.write(data).onComplete($handler); }); } /** * Ends the stream. *

* Once the stream has ended, it cannot be used any more. * @return a future completed with the result */ public io.vertx.core.Future end() { io.vertx.core.Future ret = delegate.end().map(val -> val); return ret; } /** * Ends the stream. *

* Once the stream has ended, it cannot be used any more. * @return a future completed with the result */ public io.reactivex.Completable rxEnd() { return AsyncResultCompletable.toCompletable($handler -> { this.end().onComplete($handler); }); } /** * Same as {@link io.vertx.reactivex.core.streams.WriteStream#end} but writes some data to the stream before ending. * @param data the data to write * @return a future completed with the result */ public io.vertx.core.Future end(io.vertx.core.buffer.Buffer data) { io.vertx.core.Future ret = delegate.end(data).map(val -> val); return ret; } /** * Same as {@link io.vertx.reactivex.core.streams.WriteStream#end} but writes some data to the stream before ending. * @param data the data to write * @return a future completed with the result */ public io.reactivex.Completable rxEnd(io.vertx.core.buffer.Buffer data) { return AsyncResultCompletable.toCompletable($handler -> { this.end(data).onComplete($handler); }); } /** * This will return true if there are more bytes in the write queue than the value set using {@link io.vertx.reactivex.core.file.AsyncFile#setWriteQueueMaxSize} * @return true if write queue is full */ public boolean writeQueueFull() { boolean ret = delegate.writeQueueFull(); return ret; } public io.vertx.reactivex.core.file.AsyncFile handler(io.vertx.core.Handler handler) { delegate.handler(handler); return this; } public io.vertx.reactivex.core.file.AsyncFile pause() { delegate.pause(); return this; } public io.vertx.reactivex.core.file.AsyncFile resume() { delegate.resume(); return this; } public io.vertx.reactivex.core.file.AsyncFile endHandler(io.vertx.core.Handler endHandler) { delegate.endHandler(endHandler); return this; } public io.vertx.reactivex.core.file.AsyncFile setWriteQueueMaxSize(int maxSize) { delegate.setWriteQueueMaxSize(maxSize); return this; } public io.vertx.reactivex.core.file.AsyncFile drainHandler(io.vertx.core.Handler handler) { delegate.drainHandler(handler); return this; } public io.vertx.reactivex.core.file.AsyncFile exceptionHandler(io.vertx.core.Handler handler) { delegate.exceptionHandler(handler); return this; } public io.vertx.reactivex.core.file.AsyncFile fetch(long amount) { delegate.fetch(amount); return this; } /** * Close the file. The actual close happens asynchronously. * @return a future completed with the result */ public io.vertx.core.Future close() { io.vertx.core.Future ret = delegate.close().map(val -> val); return ret; } /** * Close the file. The actual close happens asynchronously. * @return a future completed with the result */ public io.reactivex.Completable rxClose() { return AsyncResultCompletable.toCompletable($handler -> { this.close().onComplete($handler); }); } /** * Write a {@link io.vertx.core.buffer.Buffer} to the file at position position in the file, asynchronously. *

* If position lies outside of the current size * of the file, the file will be enlarged to encompass it. *

* When multiple writes are invoked on the same file * there are no guarantees as to order in which those writes actually occur * @param buffer the buffer to write * @param position the position in the file to write it at * @return a future notified when the write is complete */ public io.vertx.core.Future write(io.vertx.core.buffer.Buffer buffer, long position) { io.vertx.core.Future ret = delegate.write(buffer, position).map(val -> val); return ret; } /** * Write a {@link io.vertx.core.buffer.Buffer} to the file at position position in the file, asynchronously. *

* If position lies outside of the current size * of the file, the file will be enlarged to encompass it. *

* When multiple writes are invoked on the same file * there are no guarantees as to order in which those writes actually occur * @param buffer the buffer to write * @param position the position in the file to write it at * @return a future notified when the write is complete */ public io.reactivex.Completable rxWrite(io.vertx.core.buffer.Buffer buffer, long position) { return AsyncResultCompletable.toCompletable($handler -> { this.write(buffer, position).onComplete($handler); }); } /** * Reads length bytes of data from the file at position position in the file, asynchronously. *

* The read data will be written into the specified Buffer buffer at position offset. *

* If data is read past the end of the file then zero bytes will be read.

* When multiple reads are invoked on the same file there are no guarantees as to order in which those reads actually occur. * @param buffer the buffer to read into * @param offset the offset into the buffer where the data will be read * @param position the position in the file where to start reading * @param length the number of bytes to read * @return a future notified when the write is complete */ public io.vertx.core.Future read(io.vertx.core.buffer.Buffer buffer, int offset, long position, int length) { io.vertx.core.Future ret = delegate.read(buffer, offset, position, length).map(val -> val); return ret; } /** * Reads length bytes of data from the file at position position in the file, asynchronously. *

* The read data will be written into the specified Buffer buffer at position offset. *

* If data is read past the end of the file then zero bytes will be read.

* When multiple reads are invoked on the same file there are no guarantees as to order in which those reads actually occur. * @param buffer the buffer to read into * @param offset the offset into the buffer where the data will be read * @param position the position in the file where to start reading * @param length the number of bytes to read * @return a future notified when the write is complete */ public io.reactivex.Single rxRead(io.vertx.core.buffer.Buffer buffer, int offset, long position, int length) { return AsyncResultSingle.toSingle($handler -> { this.read(buffer, offset, position, length).onComplete($handler); }); } /** * Flush any writes made to this file to underlying persistent storage. *

* If the file was opened with flush set to true then calling this method will have no effect. *

* The actual flush will happen asynchronously. * @return a future completed with the result */ public io.vertx.core.Future flush() { io.vertx.core.Future ret = delegate.flush().map(val -> val); return ret; } /** * Flush any writes made to this file to underlying persistent storage. *

* If the file was opened with flush set to true then calling this method will have no effect. *

* The actual flush will happen asynchronously. * @return a future completed with the result */ public io.reactivex.Completable rxFlush() { return AsyncResultCompletable.toCompletable($handler -> { this.flush().onComplete($handler); }); } /** * Sets the position from which data will be read from when using the file as a {@link io.vertx.reactivex.core.streams.ReadStream}. * @param readPos the position in the file * @return a reference to this, so the API can be used fluently */ public io.vertx.reactivex.core.file.AsyncFile setReadPos(long readPos) { delegate.setReadPos(readPos); return this; } /** * Sets the number of bytes that will be read when using the file as a {@link io.vertx.reactivex.core.streams.ReadStream}. * @param readLength the bytes that will be read from the file * @return a reference to this, so the API can be used fluently */ public io.vertx.reactivex.core.file.AsyncFile setReadLength(long readLength) { delegate.setReadLength(readLength); return this; } /** * @return the number of bytes that will be read when using the file as a {@link io.vertx.reactivex.core.streams.ReadStream} */ public long getReadLength() { long ret = delegate.getReadLength(); return ret; } /** * Sets the position from which data will be written when using the file as a {@link io.vertx.reactivex.core.streams.WriteStream}. * @param writePos the position in the file * @return a reference to this, so the API can be used fluently */ public io.vertx.reactivex.core.file.AsyncFile setWritePos(long writePos) { delegate.setWritePos(writePos); return this; } /** * @return the current write position the file is at */ public long getWritePos() { long ret = delegate.getWritePos(); return ret; } /** * Sets the buffer size that will be used to read the data from the file. Changing this value will impact how much * the data will be read at a time from the file system. * @param readBufferSize the buffer size * @return a reference to this, so the API can be used fluently */ public io.vertx.reactivex.core.file.AsyncFile setReadBufferSize(int readBufferSize) { delegate.setReadBufferSize(readBufferSize); return this; } /** * Like {@link io.vertx.reactivex.core.file.AsyncFile#size} but blocking. * @return */ public long sizeBlocking() { long ret = delegate.sizeBlocking(); return ret; } /** * @return the size of the file */ public io.vertx.core.Future size() { io.vertx.core.Future ret = delegate.size().map(val -> val); return ret; } /** * @return the size of the file */ public io.reactivex.Single rxSize() { return AsyncResultSingle.toSingle($handler -> { this.size().onComplete($handler); }); } /** * Try to acquire a non-shared lock on the entire file. * @return the lock if it can be acquired immediately, otherwise null */ public io.vertx.reactivex.core.file.AsyncFileLock tryLock() { io.vertx.reactivex.core.file.AsyncFileLock ret = io.vertx.reactivex.core.file.AsyncFileLock.newInstance((io.vertx.core.file.AsyncFileLock)delegate.tryLock()); return ret; } /** * Try to acquire a lock on a portion of this file. * @param position where the region starts * @param size the size of the region * @param shared whether the lock should be shared * @return the lock if it can be acquired immediately, otherwise null */ public io.vertx.reactivex.core.file.AsyncFileLock tryLock(long position, long size, boolean shared) { io.vertx.reactivex.core.file.AsyncFileLock ret = io.vertx.reactivex.core.file.AsyncFileLock.newInstance((io.vertx.core.file.AsyncFileLock)delegate.tryLock(position, size, shared)); return ret; } /** * Acquire a non-shared lock on the entire file. * @return a future indicating the completion of this operation */ public io.vertx.core.Future lock() { io.vertx.core.Future ret = delegate.lock().map(val -> io.vertx.reactivex.core.file.AsyncFileLock.newInstance((io.vertx.core.file.AsyncFileLock)val)); return ret; } /** * Acquire a non-shared lock on the entire file. * @return a future indicating the completion of this operation */ public io.reactivex.Single rxLock() { return AsyncResultSingle.toSingle($handler -> { this.lock().onComplete($handler); }); } /** * Acquire a lock on a portion of this file. * @param position where the region starts * @param size the size of the region * @param shared whether the lock should be shared * @return a future indicating the completion of this operation */ public io.vertx.core.Future lock(long position, long size, boolean shared) { io.vertx.core.Future ret = delegate.lock(position, size, shared).map(val -> io.vertx.reactivex.core.file.AsyncFileLock.newInstance((io.vertx.core.file.AsyncFileLock)val)); return ret; } /** * Acquire a lock on a portion of this file. * @param position where the region starts * @param size the size of the region * @param shared whether the lock should be shared * @return a future indicating the completion of this operation */ public io.reactivex.Single rxLock(long position, long size, boolean shared) { return AsyncResultSingle.toSingle($handler -> { this.lock(position, size, shared).onComplete($handler); }); } /** * Acquire a non-shared lock on the entire file. * *

When the block is called, the lock is already acquired, it will be released when the * Future returned by the block completes. * *

When the block fails, the lock is released and the returned future is failed with the cause of the failure. * @param block the code block called after lock acquisition * @return the future returned by the block */ public io.vertx.core.Future withLock(java.util.function.Supplier> block) { io.vertx.core.Future ret = delegate.withLock(new Supplier>() { public io.vertx.core.Future get() { io.vertx.core.Future ret = block.get(); return ret.map(val -> val); } }).map(val -> (T) val); return ret; } /** * Acquire a non-shared lock on the entire file. * *

When the block is called, the lock is already acquired, it will be released when the * Future returned by the block completes. * *

When the block fails, the lock is released and the returned future is failed with the cause of the failure. * @param block the code block called after lock acquisition * @return the future returned by the block */ public io.reactivex.Single rxWithLock(java.util.function.Supplier> block) { return AsyncResultSingle.toSingle($handler -> { this.withLock(block).onComplete($handler); }); } /** * Acquire a lock on a portion of this file. * *

When the block is called, the lock is already acquired , it will be released when the * Future returned by the block completes. * *

When the block fails, the lock is released and the returned future is failed with the cause of the failure. * @param position where the region starts * @param size the size of the region * @param shared whether the lock should be shared * @param block the code block called after lock acquisition * @return the future returned by the block */ public io.vertx.core.Future withLock(long position, long size, boolean shared, java.util.function.Supplier> block) { io.vertx.core.Future ret = delegate.withLock(position, size, shared, new Supplier>() { public io.vertx.core.Future get() { io.vertx.core.Future ret = block.get(); return ret.map(val -> val); } }).map(val -> (T) val); return ret; } /** * Acquire a lock on a portion of this file. * *

When the block is called, the lock is already acquired , it will be released when the * Future returned by the block completes. * *

When the block fails, the lock is released and the returned future is failed with the cause of the failure. * @param position where the region starts * @param size the size of the region * @param shared whether the lock should be shared * @param block the code block called after lock acquisition * @return the future returned by the block */ public io.reactivex.Single rxWithLock(long position, long size, boolean shared, java.util.function.Supplier> block) { return AsyncResultSingle.toSingle($handler -> { this.withLock(position, size, shared, block).onComplete($handler); }); } public static AsyncFile newInstance(io.vertx.core.file.AsyncFile arg) { return arg != null ? new AsyncFile(arg) : null; } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy