Skip to content

Commit

Permalink
Merge pull request #3 from ViToni/feature/move_to_PyQT6
Browse files Browse the repository at this point in the history
Move from PyQT5 to PyQT6
  • Loading branch information
glowinthedark authored Jul 28, 2024
2 parents d40d8b6 + caf332d commit b577360
Show file tree
Hide file tree
Showing 2 changed files with 62 additions and 62 deletions.
4 changes: 2 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,8 @@ MacOS launchd/launchctl GUI
To run the app the following dependencies are needed (assuming [homebrew](https://brew.sh/) is already installed):

- python3 — normally, already present on modern macos versions, a user-managed version can be installed with `brew install python`
- qt5 - install with `brew install qt5`
- pyqt5 - install with `pip3 install pyqt5`
- qt6 - install with `brew install qt6`
- pyqt6 - install with `pip3 install pyqt6`

## Usage

Expand Down
120 changes: 60 additions & 60 deletions pylaunchd_gui.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@
from pathlib import Path

# import launchd
from PyQt5 import QtCore
from PyQt5 import QtGui
from PyQt5 import QtWidgets
from PyQt5.QtWidgets import QLineEdit
from PyQt6 import QtCore
from PyQt6 import QtGui
from PyQt6 import QtWidgets
from PyQt6.QtWidgets import QLineEdit

"""
Expand Down Expand Up @@ -86,7 +86,7 @@
"""

APPNAME = 'pyLaunchd'
VERSION = '22.2221 (pyqt5)'
VERSION = '22.2221 (pyqt6)'

LAUNCHD_DOMAINS = ["User", "System", "GUI"]
DEFAULT_DOMAIN = LAUNCHD_DOMAINS[2]
Expand All @@ -104,7 +104,7 @@ def __init__(self):
self.is_toolbar_hidden = False
self.read_settings()

self.iconSwitch = self.style().standardIcon(QtWidgets.QStyle.SP_MediaSkipForward)
self.iconSwitch = self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_MediaSkipForward)
self.setWindowIcon(self.iconSwitch)

self.setGeometry(100, 150, 500, 660)
Expand Down Expand Up @@ -214,71 +214,71 @@ def on_refresh(self, which):

def createActions(self):

self.actionOpenFile = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_ArrowRight),
self.actionOpenFile = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_ArrowRight),
"&Open...", self,
shortcut=QtGui.QKeySequence.Forward,
shortcut=QtGui.QKeySequence.StandardKey.Forward,
statusTip="Open associated plist file",
triggered=self.on_open_linked_file)

self.actionToggleToolbar = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_DialogCloseButton),
self.actionToggleToolbar = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_DialogCloseButton),
"Hide toolbar...", self,
shortcut=QtGui.QKeySequence.Bold,
shortcut=QtGui.QKeySequence.StandardKey.Bold,
statusTip="Show or hide toolbar",
triggered=self.on_toggle_toolbar)

self.actionSetEditor = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_FileDialogDetailedView),
self.actionSetEditor = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_FileDialogDetailedView),
"Set editor...", self,
statusTip="Set editor app for viewing plist files",
triggered=self.on_editor_config,
checkable=True)

self.actionQuit = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_BrowserStop),
self.actionQuit = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_BrowserStop),
"&Quit",
self,
statusTip="Quit the application", triggered=self.close)

self.actionAbout = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_FileDialogInfoView),
self.actionAbout = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_FileDialogInfoView),
"About", self,
statusTip="Show the About box",
triggered=self.on_about)

self.actionStart = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_MediaPlay),
self.actionStart = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_MediaPlay),
"Start", self,
statusTip="Start job",
triggered=self.on_start_job)

self.actionStop = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_MediaStop),
self.actionStop = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_MediaStop),
"Stop", self,
statusTip="Stop job",
triggered=self.on_stop_job)

self.actionEnable = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_DialogApplyButton),
self.actionEnable = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_DialogApplyButton),
"Start +w", self,
statusTip="Enable job",
triggered=self.on_enable_job)

self.actionDisable = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_DialogCancelButton),
self.actionDisable = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_DialogCancelButton),
"Stop -w", self,
statusTip="Disable job",
triggered=self.on_disable_job)

self.actionShowInFinder = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_DirIcon),
self.actionShowInFinder = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_DirIcon),
"Show in Finder", self,
statusTip="Show plist file in finder",
triggered=self.on_show_in_finder)

self.actionRefresh = QtWidgets.QAction(
self.style().standardIcon(QtWidgets.QStyle.SP_BrowserReload),
self.actionRefresh = QtGui.QAction(
self.style().standardIcon(QtWidgets.QStyle.StandardPixmap.SP_BrowserReload),
"Refresh", self,
statusTip="Refresh",
triggered=self.on_refresh)
Expand Down Expand Up @@ -337,7 +337,7 @@ def createMenus(self):

def createToolBars(self):
self.toolBar = self.addToolBar("&File")
self.toolBar.setToolButtonStyle(QtCore.Qt.ToolButtonTextUnderIcon)
self.toolBar.setToolButtonStyle(QtCore.Qt.ToolButtonStyle.ToolButtonTextUnderIcon)
self.comboBoxDomain = QtWidgets.QComboBox()
self.comboBoxDomain.insertItems(1, LAUNCHD_DOMAINS)
self.comboBoxDomain.setCurrentIndex(self.domain_id)
Expand Down Expand Up @@ -389,11 +389,11 @@ def load_data_launchctl(self, domain_id=0):

def createDockWindows(self):
self.topDock = QtWidgets.QDockWidget(self)
self.topDock.setFeatures(QtWidgets.QDockWidget.DockWidgetMovable | QtWidgets.QDockWidget.DockWidgetFloatable)
self.topDock.setAllowedAreas(QtCore.Qt.LeftDockWidgetArea
| QtCore.Qt.RightDockWidgetArea
| QtCore.Qt.TopDockWidgetArea
| QtCore.Qt.BottomDockWidgetArea)
self.topDock.setFeatures(QtWidgets.QDockWidget.DockWidgetFeature.DockWidgetMovable | QtWidgets.QDockWidget.DockWidgetFeature.DockWidgetFloatable)
self.topDock.setAllowedAreas(QtCore.Qt.DockWidgetArea.LeftDockWidgetArea
| QtCore.Qt.DockWidgetArea.RightDockWidgetArea
| QtCore.Qt.DockWidgetArea.TopDockWidgetArea
| QtCore.Qt.DockWidgetArea.BottomDockWidgetArea)

self.tableView = CustomTableView(self.data)
self.tableView.addAction(self.actionOpenFile)
Expand All @@ -404,24 +404,24 @@ def createDockWindows(self):
self.tableView.addAction(self.actionShowInFinder)
self.tableView.setAppWindowHandle(self)

self.tableView.setSelectionMode(QtWidgets.QTableView.SingleSelection)
self.tableView.setSelectionMode(QtWidgets.QTableView.SelectionMode.SingleSelection)
self.topDock.setWindowTitle("registered services")

self.topDock.setWidget(self.tableView)
self.tableView.selectionModel().selectionChanged.connect(self.onListItemSelect)
self.tableView.doubleClicked.connect(self.onListItemDoubleClick)

self.addDockWidget(QtCore.Qt.TopDockWidgetArea, self.topDock)
self.addDockWidget(QtCore.Qt.DockWidgetArea.TopDockWidgetArea, self.topDock)

self.bottomDock = QtWidgets.QDockWidget("", self)
self.bottomDock.setFeatures(QtWidgets.QDockWidget.DockWidgetVerticalTitleBar)
self.bottomDock.setFeatures(QtWidgets.QDockWidget.DockWidgetFeature.DockWidgetVerticalTitleBar)
self.bottomDock.setTitleBarWidget(QtWidgets.QWidget(self.bottomDock))
# self.bottomDock.setFeatures(QtWidgets.QDockWidget.DockWidgetClosable)
self.bottomDock.setAllowedAreas(QtCore.Qt.BottomDockWidgetArea | QtCore.Qt.RightDockWidgetArea)
self.bottomDock.setAllowedAreas(QtCore.Qt.DockWidgetArea.BottomDockWidgetArea | QtCore.Qt.DockWidgetArea.RightDockWidgetArea)

## hide initially
self.bottomDock.hide()
self.addDockWidget(QtCore.Qt.BottomDockWidgetArea, self.bottomDock)
self.addDockWidget(QtCore.Qt.DockWidgetArea.BottomDockWidgetArea, self.bottomDock)

# def restore_column_sort_mode(self):
# if len(tableview_data):
Expand Down Expand Up @@ -488,7 +488,7 @@ def start_file(self, filepath):
self.exec(('open', '-a', self.editor, filepath))

def read_settings(self):
self.settings = QtCore.QSettings(QtCore.QSettings.IniFormat, QtCore.QSettings.UserScope, "xh", APPNAME)
self.settings = QtCore.QSettings(QtCore.QSettings.Format.IniFormat, QtCore.QSettings.Scope.UserScope, "xh", APPNAME)
pos = self.settings.value("pos", QtCore.QPoint(200, 200))
size = self.settings.value("size", QtCore.QSize(600, 400))
self.resize(size)
Expand All @@ -505,7 +505,7 @@ def read_settings(self):
"editor", type=str) or DEFAULT_EDITOR

def write_settings(self):
settings = QtCore.QSettings(QtCore.QSettings.IniFormat, QtCore.QSettings.UserScope, "xh", APPNAME)
settings = QtCore.QSettings(QtCore.QSettings.Format.IniFormat, QtCore.QSettings.Scope.UserScope, "xh", APPNAME)
settings.setValue("pos", self.pos())
settings.setValue("size", self.size())
# settings.setValue("last_saved_sort_column", self.last_saved_sort_column)
Expand Down Expand Up @@ -537,7 +537,7 @@ def __init__(self, table_data, *args):
QtWidgets.QTableView.__init__(self, *args)
self.tableModel = CustomTableModel(table_data, self)
self.setModel(self.tableModel)
self.setContextMenuPolicy(QtCore.Qt.ActionsContextMenu)
self.setContextMenuPolicy(QtCore.Qt.ContextMenuPolicy.ActionsContextMenu)

def setAppWindowHandle(self, mainWindowHandle):
self.mainWindow = mainWindowHandle
Expand All @@ -546,20 +546,20 @@ def configureTableView(self):
self.setShowGrid(False)
self.horizontalHeader().setStretchLastSection(True)
self.verticalHeader().setVisible(False)
self.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectRows)
self.setSelectionBehavior(QtWidgets.QAbstractItemView.SelectionBehavior.SelectRows)
self.setTabKeyNavigation(False)

# disable row editing
self.setEditTriggers(QtWidgets.QAbstractItemView.NoEditTriggers)
self.setEditTriggers(QtWidgets.QAbstractItemView.EditTrigger.NoEditTriggers)

# disable bold column headers
horizontalHeader = self.horizontalHeader()
horizontalHeader.setHighlightSections(False)

self.style().pixelMetric(QtWidgets.QStyle.PM_ScrollBarExtent)
self.style().pixelMetric(QtWidgets.QStyle.PixelMetric.PM_ScrollBarExtent)
self.setWordWrap(True)
self.setSortingEnabled(True)
self.setSizeAdjustPolicy(QtWidgets.QAbstractScrollArea.AdjustToContents)
self.setSizeAdjustPolicy(QtWidgets.QAbstractScrollArea.SizeAdjustPolicy.AdjustToContents)
self.resizeColumnsToContents()


Expand All @@ -583,19 +583,19 @@ def data(self, qModelIndex, role):
# index is a QModelIndex type
if not qModelIndex.isValid():
return QtCore.QVariant()
elif role != QtCore.Qt.DisplayRole:
elif role != QtCore.Qt.ItemDataRole.DisplayRole:
return QtCore.QVariant()
elif role == QtCore.Qt.TextAlignmentRole:
return QtCore.Qt.AlignLeft
elif qModelIndex.isValid() and role == QtCore.Qt.DecorationRole:
elif role == QtCore.Qt.ItemDataRole.TextAlignmentRole:
return QtCore.Qt.AlignmentFlag.AlignLeft
elif qModelIndex.isValid() and role == QtCore.Qt.ItemDataRole.DecorationRole:
row = qModelIndex.row()
column = qModelIndex.column()
value = None
try:
value = self.arraydata[row][column]
except IndexError:
return
elif qModelIndex.isValid() and role == QtCore.Qt.DisplayRole:
elif qModelIndex.isValid() and role == QtCore.Qt.ItemDataRole.DisplayRole:
row = qModelIndex.row()
column = qModelIndex.column()
try:
Expand All @@ -606,8 +606,8 @@ def data(self, qModelIndex, role):

return QtCore.QVariant(self.arraydata[qModelIndex.row()][qModelIndex.column()])

def setData(self, index, value, role=QtCore.Qt.EditRole):
if role == QtCore.Qt.EditRole:
def setData(self, index, value, role=QtCore.Qt.ItemDataRole.EditRole):
if role == QtCore.Qt.ItemDataRole.EditRole:
self.arraydata[index.row()] = value
self.dataChanged.emit(index, index)
return True
Expand All @@ -621,8 +621,8 @@ def sendSignalLayoutChanged(self):
self.endResetModel()
self.layoutChanged.emit()

def headerData(self, section, orientation, role=QtCore.Qt.DisplayRole):
if role == QtCore.Qt.DisplayRole and orientation == QtCore.Qt.Horizontal:
def headerData(self, section, orientation, role=QtCore.Qt.ItemDataRole.DisplayRole):
if role == QtCore.Qt.ItemDataRole.DisplayRole and orientation == QtCore.Qt.Orientation.Horizontal:
return self.header_labels[section]
return QtCore.QAbstractTableModel.headerData(self, section, orientation, role)

Expand All @@ -639,14 +639,14 @@ def sort(self, ncol, order):
"""
self.sendSignalLayoutAboutToBeChanged()

sorted_data = sorted(self.arraydata, key=operator.itemgetter(ncol), reverse=order)
sorted_data = sorted(self.arraydata, key=operator.itemgetter(ncol), reverse=(order == QtCore.Qt.SortOrder.DescendingOrder) )
self.arraydata[:] = sorted_data[:]
self.sendSignalLayoutChanged()
self.last_saved_sort_column = ncol
self.last_saved_sort_order = order

def flags(self, index):
return QtCore.Qt.ItemIsEnabled | QtCore.Qt.ItemIsEditable | QtCore.Qt.ItemIsSelectable
return QtCore.Qt.ItemFlag.ItemIsEnabled | QtCore.Qt.ItemFlag.ItemIsEditable | QtCore.Qt.ItemFlag.ItemIsSelectable


def show_gui_error(msg, error_text=''):
Expand All @@ -658,7 +658,7 @@ def main():
mainWin = MainWindow()
mainWin.show()
mainWin.raise_()
sys.exit(app.exec_())
sys.exit(app.exec())


if __name__ == '__main__':
Expand Down

0 comments on commit b577360

Please sign in to comment.