/**************************************************************************** ** ** Copyright (C) 2019 The Qt Company Ltd. ** Contact: https://www.qt.io/licensing/ ** ** This file is part of the QtCore module of the Qt Toolkit. ** ** $QT_BEGIN_LICENSE:LGPL$ ** Commercial License Usage ** Licensees holding valid commercial Qt licenses may use this file in ** accordance with the commercial license agreement provided with the ** Software or, alternatively, in accordance with the terms contained in ** a written agreement between you and The Qt Company. For licensing terms ** and conditions see https://www.qt.io/terms-conditions. For further ** information use the contact form at https://www.qt.io/contact-us. ** ** GNU Lesser General Public License Usage ** Alternatively, this file may be used under the terms of the GNU Lesser ** General Public License version 3 as published by the Free Software ** Foundation and appearing in the file LICENSE.LGPL3 included in the ** packaging of this file. Please review the following information to ** ensure the GNU Lesser General Public License version 3 requirements ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html. ** ** GNU General Public License Usage ** Alternatively, this file may be used under the terms of the GNU ** General Public License version 2.0 or (at your option) the GNU General ** Public license version 3 or any later version approved by the KDE Free ** Qt Foundation. The licenses are as published by the Free Software ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3 ** included in the packaging of this file. Please review the following ** information to ensure the GNU General Public License requirements will ** be met: https://www.gnu.org/licenses/gpl-2.0.html and ** https://www.gnu.org/licenses/gpl-3.0.html. ** ** $QT_END_LICENSE$ ** ****************************************************************************/ #include "qplatformdefs.h" #include "qfilesystemengine_p.h" #include "qfile.h" #include "qurl.h" #include #include QT_BEGIN_NAMESPACE /* This implementation does not enable the "put back" option in Finder for the trashed object. The only way to get this is to use Finder automation, which would query the user for permission to access Finder using a modal, blocking dialog - which we definitely can't have in a console application. Using Finder would also play the trash sound, which we don't want either in such a core API; applications that want that can play the sound themselves. */ //static bool QFileSystemEngine::moveFileToTrash(const QFileSystemEntry &source, QFileSystemEntry &newLocation, QSystemError &error) { #ifdef Q_OS_MACOS // desktop macOS has a trash can QMacAutoReleasePool pool; QFileInfo info(source.filePath()); NSString *filepath = info.filePath().toNSString(); NSURL *fileurl = [NSURL fileURLWithPath:filepath isDirectory:info.isDir()]; NSURL *resultingUrl = nil; NSError *nserror = nil; NSFileManager *fm = [NSFileManager defaultManager]; if ([fm trashItemAtURL:fileurl resultingItemURL:&resultingUrl error:&nserror] != YES) { error = QSystemError(nserror.code, QSystemError::NativeError); return false; } newLocation = QFileSystemEntry(QUrl::fromNSURL(resultingUrl).path()); return true; #else // watch, tv, iOS don't have a trash can Q_UNUSED(source); Q_UNUSED(newLocation); Q_UNUSED(error); return false; #endif } QT_END_NAMESPACE