io.qt.core.QScopedArrayPointer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of qtjambi Show documentation
Show all versions of qtjambi Show documentation
QtJambi base module containing QtCore, QtGui and QtWidgets.
/****************************************************************************
**
** Copyright (C) 2009-2024 Dr. Peter Droste, Omix Visualization GmbH & Co. KG. All rights reserved.
**
** This file is part of Qt Jambi.
**
** $BEGIN_LICENSE$
** GNU Lesser General Public License Usage
** This file may be used under the terms of the GNU Lesser
** General Public License version 2.1 as published by the Free Software
** Foundation and appearing in the file LICENSE.LGPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU Lesser General Public License version 2.1 requirements
** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** GNU General Public License Usage
** Alternatively, this file may be used under the terms of the GNU
** General Public License version 3.0 as published by the Free Software
** Foundation and appearing in the file LICENSE.GPL included in the
** packaging of this file. Please review the following information to
** ensure the GNU General Public License version 3.0 requirements will be
** met: http://www.gnu.org/copyleft/gpl.html.
** $END_LICENSE$
**
** This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE
** WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
**
****************************************************************************/
package io.qt.core;
import java.util.Arrays;
import java.util.Objects;
import java.util.function.Consumer;
import java.util.function.Function;
import java.util.function.ToDoubleFunction;
import java.util.function.ToIntFunction;
import java.util.function.ToLongFunction;
import java.util.logging.Level;
import io.qt.QtUninvokable;
import io.qt.StrictNonNull;
import io.qt.InternalAccess.Cleanable;
import io.qt.NonNull;
import io.qt.Nullable;
import io.qt.QtObjectInterface;
/**
* Java wrapper for Qt class QScopedArrayPointer
* to be used inside a try-with-resource block.
* Example:
*
* try(var pointer = QScopedArrayPointer.disposing(new QDialog(), new QColor())){
* QDialog dialog = pointer.get(0);
* dialog.exec();
* }
* // dialog is disposed
*
*
*/
public final class QScopedArrayPointer implements AutoCloseable {
private static class Data{
private O[] data;
private Consumer cleanup;
private Cleanable cleanable;
@QtUninvokable
void close(){
if(cleanup!=null) {
try{
if(data!=null) {
for(O o : data) {
try{
cleanup.accept(o);
} catch (Throwable e) {
QScopedPointer.logger.log(Level.WARNING, "QScopedArrayPointer cleanup", e);
}
}
}
}finally{
cleanup = null;
}
}
data = null;
}
}
private final Data data = new Data<>();
private QScopedArrayPointer(O[] data, Consumer cleanup) {
this.data.data = data;
this.data.cleanup = Objects.requireNonNull(cleanup, "Argument 'cleanup': null not expected.");
this.data.cleanable = QtJambi_LibraryUtilities.internal.registerCleaner(this, this.data::close);
}
/**
* Returns the array stored by this scoped pointer
* @return data
*/
@QtUninvokable
public O @Nullable[] data() {
return data.data==null ? null : Arrays.copyOf(data.data, data.data.length);
}
/**
* @see #data()
*/
@QtUninvokable
public O @Nullable[] get() {
return data();
}
/**
* Returns the object at index i in the array stored by this scoped pointer
* See QScopedPointer::operator[](qsizetype i)const.
* @param i index
* @return data
*/
@QtUninvokable
public O data(int i) {
return data.data==null ? null : data.data[i];
}
/**
* @see #data(int)
*/
@QtUninvokable
public O get(int i) {
return data(i);
}
@QtUninvokable
public O @Nullable[] take() {
if(data.data==null)
return null;
O[] oldData = data.data;
data.data = null;
return oldData;
}
/**
* Removes and returns the array stored by this scoped pointer without cleanup
* @return data
*/
@QtUninvokable
public O take(int i) {
if(data.data==null)
return null;
O oldData = data.data[i];
data.data[i] = null;
return oldData;
}
/**
* performs cleanup operation on all objects of the contained array and sets new array.
*/
@QtUninvokable
@SafeVarargs
public final void reset(O... other) {
if(data.cleanup!=null) {
O[] oldData = data.data;
data.data = other;
if(oldData!=null) {
for(O o : oldData) {
data.cleanup.accept(o);
}
}
}
}
/**
* checks if the array is null
*/
@QtUninvokable
public boolean isNull(){
return data.data==null;
}
@QtUninvokable
public void swap(@StrictNonNull QScopedArrayPointer other){
O[] oldData = data.data;
Consumer oldCleanup = data.cleanup;
this.data.data = other.data.data;
this.data.cleanup = other.data.cleanup;
other.data.data = oldData;
other.data.cleanup = oldCleanup;
}
/**
* performs the cleanup operation
*/
@Override
@QtUninvokable
public void close(){
data.close();
if(this.data.cleanable!=null) {
this.data.cleanable.clean();
this.data.cleanable = null;
}
}
@QtUninvokable
private static void dispose(QtObjectInterface data) {
if(QtJambi_LibraryUtilities.internal.nativeId(data)!=0)
data.dispose();
}
@QtUninvokable
private static void disposeLater(QObject data) {
if(QtJambi_LibraryUtilities.internal.nativeId(data)!=0)
data.disposeLater();
}
/**
* Creates a scoped pointer for the given objects performing {@link QtObjectInterface#dispose()} on each object at cleanup.
* @param data the contained objects
* @return scoped pointer
*/
@SafeVarargs
@QtUninvokable
public static @NonNull QScopedArrayPointer disposing(O @Nullable... data){
return new QScopedArrayPointer<>(data, QScopedArrayPointer::dispose);
}
/**
* Creates a scoped pointer for the given objects performing {@link QObject#disposeLater()} on each object at cleanup.
* @param data the contained objects
* @return scoped pointer
*/
@SafeVarargs
@QtUninvokable
public static @NonNull QScopedArrayPointer disposingLater(O @Nullable... data){
return new QScopedArrayPointer<>(data, QScopedArrayPointer::disposeLater);
}
/**
* Creates a scoped array pointer for the given objects performing the given operation on each object at cleanup.
* @param cleanup operation performed at cleanup
* @param data the contained objects
* @return scoped pointer
*/
@SafeVarargs
@QtUninvokable
public static @NonNull QScopedArrayPointer cleanup(@StrictNonNull Consumer cleanup, O @Nullable... data){
return new QScopedArrayPointer<>(data, cleanup);
}
/**
* Performs an action on resources which will be disposes subsequently.
*
* @param data multiple resources
* @param action the action
*/
@SafeVarargs
@QtUninvokable
public static void performAndDispose(Consumer action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposing(data)){
action.accept(ptr.get());
}
}
/**
* Performs an action on multiple {@link QObject} resources which will be called {@link QObject#disposeLater()} subsequently.
*
* @param data multiple resources
* @param action the action
*/
@SafeVarargs
@QtUninvokable
public static void performAndDisposeLater(Consumer action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposingLater(data)){
action.accept(ptr.get());
}
}
/**
* Performs an action on resources which will be cleaned up subsequently.
*
* @param data multiple resources
* @param action the action
*/
@SafeVarargs
@QtUninvokable
public static void performAndCleanup(Consumer cleanup, Consumer action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.cleanup(cleanup, data)){
action.accept(ptr.get());
}
}
/**
* Performs an action on resources which will be disposes subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@SafeVarargs
@QtUninvokable
public static R performAndDispose(Function action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposing(data)){
return action.apply(ptr.get());
}
}
/**
* Performs an action on a {@link QObject} resource which will be called {@link QObject#disposeLater()} subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static R performAndDisposeLater(Function action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposingLater(data)){
return action.apply(ptr.get());
}
}
/**
* Performs an action on resources which will be cleaned up subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static R performAndCleanup(Consumer cleanup, Function action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.cleanup(cleanup, data)){
return action.apply(ptr.get());
}
}
/**
* Performs an action on resources which will be disposes subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static int performAndDispose(ToIntFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposing(data)){
return action.applyAsInt(ptr.get());
}
}
/**
* Performs an action on a {@link QObject} resource which will be called {@link QObject#disposeLater()} subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static int performAndDisposeLater(ToIntFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposingLater(data)){
return action.applyAsInt(ptr.get());
}
}
/**
* Performs an action on resources which will be cleaned up subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static int performAndCleanup(Consumer cleanup, ToIntFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.cleanup(cleanup, data)){
return action.applyAsInt(ptr.get());
}
}
/**
* Performs an action on resources which will be disposes subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static double performAndDispose(ToDoubleFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposing(data)){
return action.applyAsDouble(ptr.get());
}
}
/**
* Performs an action on a {@link QObject} resource which will be called {@link QObject#disposeLater()} subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static double performAndDisposeLater(ToDoubleFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposingLater(data)){
return action.applyAsDouble(ptr.get());
}
}
/**
* Performs an action on resources which will be cleaned up subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static double performAndCleanup(Consumer cleanup, ToDoubleFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.cleanup(cleanup, data)){
return action.applyAsDouble(ptr.get());
}
}
/**
* Performs an action on resources which will be disposes subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static long performAndDispose(ToLongFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposing(data)){
return action.applyAsLong(ptr.get());
}
}
/**
* Performs an action on a {@link QObject} resource which will be called {@link QObject#disposeLater()} subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static long performAndDisposeLater(ToLongFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.disposingLater(data)){
return action.applyAsLong(ptr.get());
}
}
/**
* Performs an action on resources which will be cleaned up subsequently.
*
* @param data multiple resources
* @param action the action
* @return result
*/
@QtUninvokable
@SafeVarargs
public static long performAndCleanup(Consumer cleanup, ToLongFunction action, O... data){
try(QScopedArrayPointer ptr = QScopedArrayPointer.cleanup(cleanup, data)){
return action.applyAsLong(ptr.get());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy