[libcalamares] Move mount to the partition service
- Move mount() out of CalamaresUtils::System and into the partitioning service. - Adjust PythonJobApi (only consumer of that service).
This commit is contained in:
parent
2c399d4494
commit
d08325d3d0
@ -36,6 +36,7 @@ set( libSources
|
|||||||
locale/Lookup.cpp
|
locale/Lookup.cpp
|
||||||
|
|
||||||
# Partition service
|
# Partition service
|
||||||
|
partition/Mount.cpp
|
||||||
partition/PartitionSize.cpp
|
partition/PartitionSize.cpp
|
||||||
partition/Sync.cpp
|
partition/Sync.cpp
|
||||||
|
|
||||||
|
@ -19,14 +19,14 @@
|
|||||||
|
|
||||||
#include "PythonJobApi.h"
|
#include "PythonJobApi.h"
|
||||||
|
|
||||||
|
#include "GlobalStorage.h"
|
||||||
|
#include "JobQueue.h"
|
||||||
#include "PythonHelper.h"
|
#include "PythonHelper.h"
|
||||||
|
#include "partition/Mount.h"
|
||||||
#include "utils/Logger.h"
|
#include "utils/Logger.h"
|
||||||
#include "utils/CalamaresUtilsSystem.h"
|
#include "utils/CalamaresUtilsSystem.h"
|
||||||
#include "utils/String.h"
|
#include "utils/String.h"
|
||||||
|
|
||||||
#include "GlobalStorage.h"
|
|
||||||
#include "JobQueue.h"
|
|
||||||
|
|
||||||
#include <QCoreApplication>
|
#include <QCoreApplication>
|
||||||
#include <QDir>
|
#include <QDir>
|
||||||
#include <QStandardPaths>
|
#include <QStandardPaths>
|
||||||
@ -63,8 +63,7 @@ mount( const std::string& device_path,
|
|||||||
const std::string& filesystem_name,
|
const std::string& filesystem_name,
|
||||||
const std::string& options )
|
const std::string& options )
|
||||||
{
|
{
|
||||||
return CalamaresUtils::System::instance()->
|
return CalamaresUtils::Partition::mount( QString::fromStdString( device_path ),
|
||||||
mount( QString::fromStdString( device_path ),
|
|
||||||
QString::fromStdString( mount_point ),
|
QString::fromStdString( mount_point ),
|
||||||
QString::fromStdString( filesystem_name ),
|
QString::fromStdString( filesystem_name ),
|
||||||
QString::fromStdString( options ) );
|
QString::fromStdString( options ) );
|
||||||
|
77
src/libcalamares/partition/Mount.cpp
Normal file
77
src/libcalamares/partition/Mount.cpp
Normal file
@ -0,0 +1,77 @@
|
|||||||
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Teo Mrnjavac <teo@kde.org>
|
||||||
|
* Copyright 2017-2019, Adriaan de Groot <groot@kde.org>
|
||||||
|
*
|
||||||
|
* Calamares is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Calamares is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include "Mount.h"
|
||||||
|
|
||||||
|
#include "utils/CalamaresUtilsSystem.h"
|
||||||
|
#include "utils/Logger.h"
|
||||||
|
|
||||||
|
#include <QDir>
|
||||||
|
|
||||||
|
namespace CalamaresUtils
|
||||||
|
{
|
||||||
|
namespace Partition
|
||||||
|
{
|
||||||
|
|
||||||
|
int
|
||||||
|
mount( const QString& devicePath, const QString& mountPoint, const QString& filesystemName, const QString& options )
|
||||||
|
{
|
||||||
|
if ( devicePath.isEmpty() || mountPoint.isEmpty() )
|
||||||
|
{
|
||||||
|
if ( devicePath.isEmpty() )
|
||||||
|
{
|
||||||
|
cWarning() << "Can't mount an empty device.";
|
||||||
|
}
|
||||||
|
if ( mountPoint.isEmpty() )
|
||||||
|
{
|
||||||
|
cWarning() << "Can't mount on an empty mountpoint.";
|
||||||
|
}
|
||||||
|
|
||||||
|
return static_cast< int >( ProcessResult::Code::NoWorkingDirectory );
|
||||||
|
}
|
||||||
|
|
||||||
|
QDir mountPointDir( mountPoint );
|
||||||
|
if ( !mountPointDir.exists() )
|
||||||
|
{
|
||||||
|
bool ok = mountPointDir.mkpath( mountPoint );
|
||||||
|
if ( !ok )
|
||||||
|
{
|
||||||
|
cWarning() << "Could not create mountpoint" << mountPoint;
|
||||||
|
return static_cast< int >( ProcessResult::Code::NoWorkingDirectory );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
QStringList args = { "mount", devicePath, mountPoint };
|
||||||
|
|
||||||
|
if ( !filesystemName.isEmpty() )
|
||||||
|
{
|
||||||
|
args << "-t" << filesystemName;
|
||||||
|
}
|
||||||
|
if ( !options.isEmpty() )
|
||||||
|
{
|
||||||
|
args << "-o" << options;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto r = CalamaresUtils::System::instance()->runCommand(
|
||||||
|
CalamaresUtils::System::RunLocation::RunInHost, args, QString(), QString(), 10 );
|
||||||
|
return r.getExitCode();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace Partition
|
||||||
|
} // namespace CalamaresUtils
|
50
src/libcalamares/partition/Mount.h
Normal file
50
src/libcalamares/partition/Mount.h
Normal file
@ -0,0 +1,50 @@
|
|||||||
|
/* === This file is part of Calamares - <https://github.com/calamares> ===
|
||||||
|
*
|
||||||
|
* Copyright 2014, Teo Mrnjavac <teo@kde.org>
|
||||||
|
* Copyright 2017-2019, Adriaan de Groot <groot@kde.org>
|
||||||
|
*
|
||||||
|
* Calamares is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* Calamares is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU General Public License
|
||||||
|
* along with Calamares. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef PARTITION_MOUNT_H
|
||||||
|
#define PARTITION_MOUNT_H
|
||||||
|
|
||||||
|
#include "DllMacro.h"
|
||||||
|
|
||||||
|
#include <QString>
|
||||||
|
|
||||||
|
namespace CalamaresUtils
|
||||||
|
{
|
||||||
|
namespace Partition
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Runs the mount utility with the specified parameters.
|
||||||
|
* @param devicePath the path of the partition to mount.
|
||||||
|
* @param mountPoint the full path of the target mount point.
|
||||||
|
* @param filesystemName the name of the filesystem (optional).
|
||||||
|
* @param options any additional options as passed to mount -o (optional).
|
||||||
|
* @returns the program's exit code, or:
|
||||||
|
* Crashed = QProcess crash
|
||||||
|
* FailedToStart = QProcess cannot start
|
||||||
|
* NoWorkingDirectory = bad arguments
|
||||||
|
*/
|
||||||
|
DLLEXPORT int mount( const QString& devicePath,
|
||||||
|
const QString& mountPoint,
|
||||||
|
const QString& filesystemName = QString(),
|
||||||
|
const QString& options = QString() );
|
||||||
|
} // namespace Partition
|
||||||
|
} // namespace CalamaresUtils
|
||||||
|
|
||||||
|
#endif
|
@ -107,45 +107,6 @@ System::instance()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int
|
|
||||||
System::mount( const QString& devicePath,
|
|
||||||
const QString& mountPoint,
|
|
||||||
const QString& filesystemName,
|
|
||||||
const QString& options )
|
|
||||||
{
|
|
||||||
if ( devicePath.isEmpty() || mountPoint.isEmpty() )
|
|
||||||
{
|
|
||||||
if ( devicePath.isEmpty() )
|
|
||||||
cWarning() << "Can't mount an empty device.";
|
|
||||||
if ( mountPoint.isEmpty() )
|
|
||||||
cWarning() << "Can't mount on an empty mountpoint.";
|
|
||||||
|
|
||||||
return static_cast<int>(ProcessResult::Code::NoWorkingDirectory);
|
|
||||||
}
|
|
||||||
|
|
||||||
QDir mountPointDir( mountPoint );
|
|
||||||
if ( !mountPointDir.exists() )
|
|
||||||
{
|
|
||||||
bool ok = mountPointDir.mkpath( mountPoint );
|
|
||||||
if ( !ok )
|
|
||||||
{
|
|
||||||
cWarning() << "Could not create mountpoint" << mountPoint;
|
|
||||||
return static_cast<int>(ProcessResult::Code::NoWorkingDirectory);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
QString program( "mount" );
|
|
||||||
QStringList args = { devicePath, mountPoint };
|
|
||||||
|
|
||||||
if ( !filesystemName.isEmpty() )
|
|
||||||
args << "-t" << filesystemName;
|
|
||||||
|
|
||||||
if ( !options.isEmpty() )
|
|
||||||
args << "-o" << options;
|
|
||||||
|
|
||||||
return QProcess::execute( program, args );
|
|
||||||
}
|
|
||||||
|
|
||||||
ProcessResult
|
ProcessResult
|
||||||
System::runCommand(
|
System::runCommand(
|
||||||
System::RunLocation location,
|
System::RunLocation location,
|
||||||
|
@ -94,23 +94,6 @@ public:
|
|||||||
|
|
||||||
static System* instance();
|
static System* instance();
|
||||||
|
|
||||||
/**
|
|
||||||
* Runs the mount utility with the specified parameters.
|
|
||||||
* @param devicePath the path of the partition to mount.
|
|
||||||
* @param mountPoint the full path of the target mount point.
|
|
||||||
* @param filesystemName the name of the filesystem (optional).
|
|
||||||
* @param options any additional options as passed to mount -o (optional).
|
|
||||||
* @returns the program's exit code, or:
|
|
||||||
* Crashed = QProcess crash
|
|
||||||
* FailedToStart = QProcess cannot start
|
|
||||||
* NoWorkingDirectory = bad arguments
|
|
||||||
*/
|
|
||||||
DLLEXPORT int mount( const QString& devicePath,
|
|
||||||
const QString& mountPoint,
|
|
||||||
const QString& filesystemName = QString(),
|
|
||||||
const QString& options = QString() );
|
|
||||||
|
|
||||||
|
|
||||||
/** (Typed) Boolean describing where a particular command should be run,
|
/** (Typed) Boolean describing where a particular command should be run,
|
||||||
* whether in the host (live) system or in the (chroot) target system.
|
* whether in the host (live) system or in the (chroot) target system.
|
||||||
*/
|
*/
|
||||||
|
Loading…
Reference in New Issue
Block a user