1cd9b93a22
- point to main Calamares site in the 'part of' headers instead of to github (this is the "this file is part of Calamares" opening line for most files). - remove boilerplate from all source files, CMake modules and completions, this is the 3-paragraph summary of the GPL-3.0-or-later, which has a meaning entirely covered by the SPDX tag.
168 lines
5.3 KiB
C++
168 lines
5.3 KiB
C++
/* === This file is part of Calamares - <https://calamares.io> ===
|
|
*
|
|
* SPDX-FileCopyrightText: 2017 Kyle Robbertze <kyle@aims.ac.za>
|
|
* SPDX-FileCopyrightText: 2017 2020, Adriaan de Groot <groot@kde.org>
|
|
* SPDX-License-Identifier: GPL-3.0-or-later
|
|
*
|
|
* Calamares is Free Software: see the License-Identifier above.
|
|
*
|
|
*/
|
|
|
|
#ifndef PACKAGETREEITEM_H
|
|
#define PACKAGETREEITEM_H
|
|
|
|
#include <QList>
|
|
#include <QStandardItem>
|
|
#include <QVariant>
|
|
|
|
class PackageTreeItem : public QStandardItem
|
|
{
|
|
public:
|
|
using List = QList< PackageTreeItem* >;
|
|
|
|
///@brief A tag class to distinguish package-from-map from group-from-map
|
|
struct PackageTag
|
|
{
|
|
PackageTreeItem* parent;
|
|
};
|
|
///@brief A tag class to distinguish group-from-map from package-from-map
|
|
struct GroupTag
|
|
{
|
|
PackageTreeItem* parent;
|
|
};
|
|
|
|
///@brief A package (individual package)
|
|
explicit PackageTreeItem( const QString& packageName, PackageTreeItem* parent = nullptr );
|
|
///@brief A package (individual package with description)
|
|
explicit PackageTreeItem( const QVariantMap& packageData, PackageTag&& parent );
|
|
///@brief A group (sub-items and sub-groups are ignored)
|
|
explicit PackageTreeItem( const QVariantMap& groupData, GroupTag&& parent );
|
|
///@brief A root item, always selected, named "<root>"
|
|
explicit PackageTreeItem();
|
|
~PackageTreeItem() override;
|
|
|
|
void appendChild( PackageTreeItem* child );
|
|
PackageTreeItem* child( int row );
|
|
int childCount() const;
|
|
QVariant data( int column ) const override;
|
|
int row() const;
|
|
|
|
PackageTreeItem* parentItem();
|
|
const PackageTreeItem* parentItem() const;
|
|
|
|
QString name() const { return m_name; }
|
|
QString packageName() const { return m_packageName; }
|
|
|
|
QString description() const { return m_description; }
|
|
QString preScript() const { return m_preScript; }
|
|
QString postScript() const { return m_postScript; }
|
|
|
|
/** @brief Is this item a group-item?
|
|
*
|
|
* Groups have a (possibly empty) list of packages, and a
|
|
* (possibly empty) list of sub-groups, and can be marked
|
|
* critical, hidden, etc. Packages, on the other hand, only
|
|
* have a meaningful packageName() and selection status.
|
|
*
|
|
* Root is a group.
|
|
*/
|
|
bool isGroup() const { return m_isGroup; }
|
|
|
|
/// @brief Is this item a single package?
|
|
bool isPackage() const { return !isGroup(); }
|
|
|
|
/** @brief Is this item hidden?
|
|
*
|
|
* Hidden items (generally only groups) are maintained separately,
|
|
* not shown to the user, but do enter into the package-installation process.
|
|
*/
|
|
bool isHidden() const { return m_isHidden; }
|
|
|
|
/** @brief Is this hidden item, considered "selected"?
|
|
*
|
|
* This asserts when called on a non-hidden item.
|
|
* A hidden item has its own selected state, but really
|
|
* falls under the selectedness of the parent item.
|
|
*/
|
|
bool hiddenSelected() const;
|
|
|
|
/** @brief Is this group critical?
|
|
*
|
|
* A critical group must be successfully installed, for the Calamares
|
|
* installation to continue.
|
|
*/
|
|
bool isCritical() const { return m_isCritical; }
|
|
|
|
/** @brief Is this group expanded on start?
|
|
*
|
|
* This does not affect installation, only the UI. A group
|
|
* that expands on start is shown expanded (not collapsed)
|
|
* in the treeview when the page is loaded.
|
|
*/
|
|
bool expandOnStart() const { return m_startExpanded; }
|
|
|
|
/** @brief Is this an immutable item?
|
|
*
|
|
* Groups can be immutable: then you can't toggle the selected
|
|
* state of any of its items.
|
|
*/
|
|
bool isImmutable() const { return m_showReadOnly; }
|
|
|
|
/** @brief is this item selected?
|
|
*
|
|
* Groups may be partially selected; packages are only on or off.
|
|
*/
|
|
Qt::CheckState isSelected() const { return m_selected; }
|
|
|
|
/** @brief Turns this item into a variant for PackageOperations use
|
|
*
|
|
* For "plain" items, this is just the package name; items with
|
|
* scripts return a map. See the package module for how it's interpreted.
|
|
*/
|
|
QVariant toOperation() const;
|
|
|
|
void setSelected( Qt::CheckState isSelected );
|
|
void setChildrenSelected( Qt::CheckState isSelected );
|
|
|
|
/** @brief Update selectedness based on the children's states
|
|
*
|
|
* This only makes sense for groups, which might have packages
|
|
* or subgroups; it checks only direct children.
|
|
*/
|
|
void updateSelected();
|
|
|
|
// QStandardItem methods
|
|
int type() const override;
|
|
|
|
/** @brief Are two items equal
|
|
*
|
|
* This **disregards** parent-item and the child-items, and compares
|
|
* only the fields for the items-proper (name, .. expanded). Note
|
|
* also that *isSelected()* is a run-time state, and is **not**
|
|
* compared either.
|
|
*/
|
|
bool operator==( const PackageTreeItem& rhs ) const;
|
|
bool operator!=( const PackageTreeItem& rhs ) const { return !( *this == rhs ); }
|
|
|
|
private:
|
|
PackageTreeItem* m_parentItem;
|
|
List m_childItems;
|
|
|
|
// An entry can be a package, or a group.
|
|
QString m_name;
|
|
QString m_packageName;
|
|
Qt::CheckState m_selected = Qt::Unchecked;
|
|
|
|
// These are only useful for groups
|
|
QString m_description;
|
|
QString m_preScript;
|
|
QString m_postScript;
|
|
bool m_isGroup = false;
|
|
bool m_isCritical = false;
|
|
bool m_isHidden = false;
|
|
bool m_showReadOnly = false;
|
|
bool m_startExpanded = false;
|
|
};
|
|
|
|
#endif // PACKAGETREEITEM_H
|