/* === This file is part of Calamares - === * * Copyright 2014, Aurélien Gâteau * Copyright 2015, Teo Mrnjavac * Copyright 2017, Adriaan de Groot * * 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 . */ #include "PartitionIterator.h" // KPMcore #include #include #include PartitionIterator::PartitionIterator( PartitionTable* table ) : m_table( table ) {} Partition* PartitionIterator::operator*() const { return m_current; } void PartitionIterator::operator++() { if ( !m_current ) return; if ( m_current->hasChildren() ) { // Go to the first child m_current = static_cast< Partition* >( m_current->children().first() ); return; } PartitionNode* parent = m_current->parent(); Partition* successor = parent->successor( *m_current ); if ( successor ) { // Go to the next sibling m_current = successor; return; } if ( parent->isRoot() ) { // We reached the end m_current = nullptr; return; } // Try to go to the next sibling of our parent PartitionNode* grandParent = parent->parent(); Q_ASSERT( grandParent ); // If parent is not root, then it's not a PartitionTable but a // Partition, we can static_cast it. m_current = grandParent->successor( *static_cast< Partition* >( parent ) ); } bool PartitionIterator::operator==( const PartitionIterator& other ) const { return m_table == other.m_table && m_current == other.m_current; } bool PartitionIterator::operator!=( const PartitionIterator& other ) const { return ! ( *this == other ); } PartitionIterator PartitionIterator::begin( Device* device ) { if ( !device ) return PartitionIterator( nullptr ); Q_ASSERT(device); PartitionTable* table = device->partitionTable(); if ( !table ) return PartitionIterator( nullptr ); return PartitionIterator::begin( table ); } PartitionIterator PartitionIterator::begin( PartitionTable* table ) { auto it = PartitionIterator( table ); QList< Partition* > children = table->children(); // Does not usually happen, but it did happen on a tiny (10MiB) disk with an MBR // partition table. if ( children.isEmpty() ) return it; it.m_current = children.first(); return it; } PartitionIterator PartitionIterator::end( Device* device ) { if ( !device ) return PartitionIterator( nullptr ); PartitionTable* table = device->partitionTable(); if ( !table ) return PartitionIterator( nullptr ); return PartitionIterator::end( table ); } PartitionIterator PartitionIterator::end( PartitionTable* table ) { return PartitionIterator( table ); }