Logo Search packages:      
Sourcecode: partitionmanager version File versions  Download package


 *   Copyright (C) 2008 by Volker Lanz <vl@fidra.de>                       *
 *                                                                         *
 *   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 2 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        *
 *   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, write to the                         *
 *   Free Software Foundation, Inc.,                                       *
 *   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA            *

#include "ops/deleteoperation.h"

#include "core/partition.h"
#include "core/device.h"
#include "core/partitiontable.h"

#include "jobs/deletepartitionjob.h"
#include "jobs/deletefilesystemjob.h"

#include "util/capacity.h"

#include <QString>

#include <kdebug.h>
#include <klocale.h>

/** Creates a new DeleteOperation
      @param d the Device to delete a Partition on
      @param p pointer to the Partition to delete. May not be NULL
00040 DeleteOperation::DeleteOperation(Device& d, Partition* p) :
      m_DeleteFileSystemJob(new DeleteFileSystemJob(targetDevice(), deletedPartition())),
      m_DeletePartitionJob(new DeletePartitionJob(targetDevice(), deletedPartition()))

      if (status() != StatusPending && status() != StatusNone) // don't delete the partition if we're being merged or undone
            delete m_DeletedPartition;

00057 void DeleteOperation::preview()
      removePreviewPartition(targetDevice(), deletedPartition());
      checkAdjustLogicalNumbers(deletedPartition(), false);

00063 void DeleteOperation::undo()
      checkAdjustLogicalNumbers(deletedPartition(), true);
      insertPreviewPartition(targetDevice(), deletedPartition());

00069 QString DeleteOperation::description() const
      return QString(i18nc("@info/plain", "Delete partition <filename>%1</filename> (%2, %3)", deletedPartition().deviceNode(), Capacity(deletedPartition()).toString(), deletedPartition().fileSystem().name()));

void DeleteOperation::checkAdjustLogicalNumbers(Partition& p, bool undo)
      // If the deleted partition is a logical one, we need to adjust the numbers of the
      // other logical partitions in the extended one, if there are any, because the OS
      // will do that, too: Logicals must be numbered without gaps, i.e., a numbering like
      // sda5, sda6, sda8 (after sda7 is deleted) will become sda5, sda6, sda7
      Partition* parentPartition = dynamic_cast<Partition*>(p.parent());
      if (parentPartition && parentPartition->roles().has(PartitionRole::Extended))
            parentPartition->adjustLogicalNumbers(undo ? -1 : p.number(), undo ? p.number() : -1);

/** Can a Partition be deleted?
      @param p the Partition in question, may be NULL.
      @return true if @p p can be deleted.
00089 bool DeleteOperation::canDelete(const Partition* p)
      if (p == NULL)
            return false;
      if (p->isMounted())
            return false;

      if (p->roles().has(PartitionRole::Unallocated))
            return false;

      if (p->roles().has(PartitionRole::Extended))
            return p->children().size() == 1 && p->children()[0]->roles().has(PartitionRole::Unallocated);

      return true;

Generated by  Doxygen 1.6.0   Back to index