/************************************************************************* * Copyright (C) 2016 by Chantara Tith * * Copyright (C) 2016 by Andrius Štikonas * * * * This program 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. * * * * This program 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 this program. If not, see .* *************************************************************************/ #include "jobs/createvolumegroupjob.h" #include "core/lvmdevice.h" #include "util/report.h" #include /** Creates a new CreateVolumeGroupJob * @param vgName LVM Volume Group name * @param pvList List of LVM Physical Volumes used to create Volume Group * @param peSize LVM Physical Extent size in MiB */ CreateVolumeGroupJob::CreateVolumeGroupJob(const QString& vgName, const QList& pvList, const qint32 peSize) : Job(), m_vgName(vgName), m_pvList(pvList), m_PESize(peSize) { } bool CreateVolumeGroupJob::run(Report& parent) { bool rval = false; Report* report = jobStarted(parent); rval = LvmDevice::createVG(*report, vgName(), pvList(), peSize()); jobFinished(*report, rval); return rval; } QString CreateVolumeGroupJob::description() const { QString tmp = QString(); for (const auto &p : pvList()) { tmp += p->deviceNode() + QStringLiteral(", "); } tmp.chop(2); return xi18nc("@info/plain", "Create a new Volume Group: %1 with PV: %2", vgName(), tmp); }