# Copyright 2016, Tresys Technology, LLC # # SPDX-License-Identifier: LGPL-2.1-only # # from PyQt6 import QtCore import setools from .. import details from .modelroles import ModelRoles from .table import SEToolsTableModel __all__ = ("FSUseTable",) class FSUseTable(SEToolsTableModel[setools.FSUse]): """Table-based model for fs_use_*.""" headers = ["Ruletype", "FS Type", "Context"] def data(self, index: QtCore.QModelIndex, role: int = ModelRoles.DisplayRole): if not self.item_list or not index.isValid(): return None row = index.row() col = index.column() rule = self.item_list[row] match role: case ModelRoles.DisplayRole: match col: case 0: return rule.ruletype.name case 1: return rule.fs case 2: return str(rule.context) case ModelRoles.ContextMenuRole: if col == 2: return details.context_detail_action(rule.context) case ModelRoles.WhatsThisRole: match col: case 0: column_whatsthis = \ """

This is the statement type.

""" case 1: column_whatsthis = \ """

This is the type/name of the filesystem.

""" case 2: column_whatsthis = \ """

This is the context of the fs_use_*.

""" case _: column_whatsthis = "" return \ f"""

Table Representation of fs_use_*

Each part of the rule is represented as a column in the table.

{column_whatsthis} """ return super().data(index, role)