02021-01-26 stream: List of tools per application in the workbench: create their command + toolbar icon & menu entry

This commit is contained in:
Suzanne Soy 2021-01-26 09:15:11 +00:00
parent cf51a13d8a
commit 3f02bb6cae
6 changed files with 95 additions and 9 deletions

View File

@ -28,5 +28,5 @@ class AppCommand():
# return false to grey out the command in the menus, toolbars etc.
return True
for appName in ExternalAppsList.apps:
def createCommands(appName):
Gui.addCommand('ExternalAppsOpen' + appName + 'Command', AppCommand(appName))

32
AppTools.py Normal file
View File

@ -0,0 +1,32 @@
import os
import FreeCAD
import FreeCADGui as Gui
import PySide
from PySide import QtGui
from PySide import QtCore
import ExternalAppsList
import Embed
class ToolCommand():
def __init__(self, appName, toolName):
self.Tool = ExternalAppsList.apps[appName].Tools[toolName]
def GetResources(self):
return {
'Pixmap': self.Tool.Icon,
#'Accel': "Shit+T",
'MenuText': self.Tool.ToolName,
'ToolTip': "Runs the " + self.Tool.ToolName + " tool from " + self.Tool.AppName + "\n\n" + self.Tool.ToolTip,
}
def Activated(self):
print("tool " + self.Tool.ToolName + " of " + self.Tool.AppName + " was activated with xforms" + str(self.Tool.XForms))
def IsActive(self):
# return false to grey out the command in the menus, toolbars etc.
return True
def createCommands(appName):
for toolName in ExternalAppsList.apps[appName].Tools:
Gui.addCommand('ExternalAppsTool' + appName + toolName + 'Command', ToolCommand(appName, toolName))

View File

@ -106,6 +106,7 @@ def try_pipe_lines(commandAndArguments):
except:
return []
# TODO: this is just a quick & dirty way to attach a field to the FreeCad object
class ExternalApps():
def __init__(self):
setattr(FreeCAD, 'ExternalApps', self)

View File

@ -9,34 +9,71 @@ from PySide import QtCore
from MyX11Utils import *
class Tool():
def __init__(self, *, appName, toolName, xForms, toolTip, icon, extendedDescription, openHelpFile):
self.AppName = appName
self.ToolName = toolName
self.XForms = xForms
self.ToolTip = toolTip
self.Icon = icon
self.ExtendedDescription = extendedDescription
self.OpenHelpFile = openHelpFile
@staticmethod
def fromXForms(*, appName, xForms):
# TODO: implement a tool cache which avoids parsing the XML and memorizes the name and icon
return Tool(appName=appName,
toolName = "from XForms … TODO",
xForms = xForms,
toolTip = "from XForms … TODO",
# TODO: get the icon from the XForms file
icon = os.path.dirname(__file__) + '/icons/' + appName + '.svg',
extendedDescription = "from XForms … TODO",
openHelpFile = None)
class ToolsClass():
def __init__(self, tools):
# TODO: make this private
self.AllTools = {tool.ToolName: tool for tool in tools}
def __getitem__(self, k):
return self.AllTools[k]
def __iter__(self):
return self.AllTools.__iter__()
class App():
def __init__(self, name, *, start_command_and_args, xwininfo_filter_re, extra_xprop_filter):
def __init__(self, name, *, start_command_and_args, xwininfo_filter_re, extra_xprop_filter, tools):
self.name = name
self.Icon = os.path.dirname(__file__) + '/icons/' + self.name + '.svg'
self.start_command_and_args = start_command_and_args
self.xwininfo_filter_re = re.compile(xwininfo_filter_re)
self.extra_xprop_filter = extra_xprop_filter
self.Tools = ToolsClass([Tool.fromXForms(appName=self.name, xForms=t) for t in tools])
class Apps():
def __init__(self, *apps):
# TODO: make this private
self.apps = {app.name: app for app in apps}
self.AllApps = {app.name: app for app in apps}
def __getitem__(self, k):
return self.apps[k]
return self.AllApps[k]
def __iter__(self):
return self.apps.__iter__()
return self.AllApps.__iter__()
# app-specific infos:
apps = Apps(
App('Mousepad',
start_command_and_args = ['mousepad', '--disable-server'],
xwininfo_filter_re = r'mousepad',
extra_xprop_filter = lambda processId, windowId, i: True),
extra_xprop_filter = lambda processId, windowId, i: True,
tools = []),
App('Inkscape',
start_command_and_args = ['inkscape'],
xwininfo_filter_re = r'inkscape',
extra_xprop_filter = lambda processId, windowId, i: x11prop(windowId, 'WM_STATE', 'WM_STATE') is not None),
extra_xprop_filter = lambda processId, windowId, i: x11prop(windowId, 'WM_STATE', 'WM_STATE') is not None,
tools = [
"myTool.xforms"
]),
App('GIMP',
start_command_and_args = ['env', '-i', 'DISPLAY=:0', '/home/suzanne/perso/dotfiles/nix/result/bin/gimp', '--new-instance'],
xwininfo_filter_re = r'gimp',
extra_xprop_filter = lambda processId, windowId, i: x11prop(windowId, 'WM_STATE', 'WM_STATE') is not None))
extra_xprop_filter = lambda processId, windowId, i: x11prop(windowId, 'WM_STATE', 'WM_STATE') is not None,
tools = []))

View File

@ -52,10 +52,20 @@ class XternalAppsWorkbench(Workbench):
super(XternalAppsWorkbench, self).__init__()
def Initialize(self):
# Load commands
import AppCommand
import AppTools
import Embed
Embed.ExternalApps()
self.list = ['ExternalAppsOpen' + self.appName + 'Command']
AppCommand.createCommands(self.appName)
AppTools.createCommands(self.appName)
# List of commands for this workbench
self.list = ['ExternalAppsOpen' + self.appName + 'Command'] \
+ ['ExternalAppsTool' + self.appName + toolName + 'Command'
for toolName in ExternalAppsList.apps[self.appName].Tools]
# Create menus and toolbars
self.appendMenu("ExternalApplications", self.list)
self.appendToolbar("ExternalApplications", self.list)

6
myTool.py Executable file
View File

@ -0,0 +1,6 @@
#!/usr/bin/env python
import sys
for arg in sys.argv:
print(str(arg)