/usr/share/pyshared/mayavi/plugins/app.py is in mayavi2 4.0.0-3build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 | """The Mayavi Envisage application.
"""
# Author: Prabhu Ramachandran <prabhu_r@users.sf.net>
# Copyright (c) 2008, Enthought, Inc.
# License: BSD Style.
# Standard library imports.
import sys
import os.path
import logging
# Enthought library imports.
from apptools.logger.api import LogFileHandler, FORMATTER
from traits.etsconfig.api import ETSConfig
from traits.api import (HasTraits, Instance, Int,
on_trait_change, Bool)
# Local imports.
from mayavi_workbench_application import MayaviWorkbenchApplication
from mayavi.preferences.api import preference_manager
from mayavi.core.customize import get_custom_plugins
# GLOBALS
logger = logging.getLogger()
######################################################################
# Useful functions.
######################################################################
def setup_logger(logger, fname, stream=True, mode=logging.ERROR):
"""Setup a log file and the logger. If the given file name is not
absolute, put the log file in `ETSConfig.application_home`, if not
it will create it where desired.
Parameters:
-----------
fname -- file name the logger should use. If this is an absolute
path it will create the log file as specified, if not it will put it
in `ETSConfig.application_home`.
stream -- Add a stream handler.
mode -- the logging mode of the stream handler.
"""
if not os.path.isabs(fname):
path = os.path.join(ETSConfig.application_home, fname)
else:
path = fname
# Check if we have already added a logger (can happen when the app
# is started multiple number of times from ipython say).
handlers = logger.handlers
if len(handlers) > 1:
h = handlers[0]
if isinstance(h, LogFileHandler) and h.baseFilename == path:
logger.info('Logging handlers already set! Not duplicating.')
return
logger.setLevel(logging.DEBUG)
handler = LogFileHandler(path)
handler.setLevel(logging.DEBUG)
logger.addHandler(handler)
if stream:
s = logging.StreamHandler()
s.setFormatter(FORMATTER)
s.setLevel(mode)
logger.addHandler(s)
logger.info("*"*80)
logger.info("logfile is: '%s'", os.path.abspath(path))
logger.info("*"*80)
def get_non_gui_plugin_classes():
"""Get list of basic mayavi plugin classes that do not add any views or
actions."""
from envisage.core_plugin import CorePlugin
from envisage.ui.workbench.workbench_plugin import WorkbenchPlugin
from tvtk.plugins.scene.scene_plugin import ScenePlugin
from mayavi.plugins.mayavi_plugin import MayaviPlugin
plugins = [CorePlugin,
WorkbenchPlugin,
MayaviPlugin,
ScenePlugin,
]
return plugins
def get_non_gui_plugins():
"""Get list of basic mayavi plugins that do not add any views or
actions."""
return [cls() for cls in get_non_gui_plugin_classes()]
def get_plugin_classes():
"""Get list of default plugin classes to use for Mayavi."""
# Force the selection of a toolkit:
from traitsui.api import toolkit
toolkit()
from traits.etsconfig.api import ETSConfig
try_use_ipython = preference_manager.root.use_ipython
use_ipython = False
if ETSConfig.toolkit == 'wx' and try_use_ipython:
try:
# If the right versions of IPython, EnvisagePlugins and
# Pyface are not installed, this import will fail.
from envisage.plugins.ipython_shell.view.ipython_shell_view \
import IPythonShellView
use_ipython = True
except: pass
if use_ipython:
from envisage.plugins.ipython_shell.ipython_shell_plugin import \
IPythonShellPlugin
PythonShellPlugin = IPythonShellPlugin
else:
from envisage.plugins.python_shell.python_shell_plugin import PythonShellPlugin
from envisage.plugins.text_editor.text_editor_plugin import TextEditorPlugin
from apptools.logger.plugin.logger_plugin import LoggerPlugin
from tvtk.plugins.scene.ui.scene_ui_plugin import SceneUIPlugin
from mayavi.plugins.mayavi_ui_plugin import MayaviUIPlugin
plugins = get_non_gui_plugin_classes()
plugins.extend([
LoggerPlugin,
MayaviUIPlugin,
SceneUIPlugin,
PythonShellPlugin,
TextEditorPlugin,
])
return plugins
def get_plugins():
"""Get list of default plugins to use for Mayavi."""
return [cls() for cls in get_plugin_classes()]
###########################################################################
# `Mayavi` class.
###########################################################################
class Mayavi(HasTraits):
"""The Mayavi application class.
This class may be easily subclassed to do something different.
For example, one way to script MayaVi (as a standalone application
and not interactively) is to subclass this and do the needful.
"""
# The main envisage application.
application = Instance('envisage.ui.workbench.api.WorkbenchApplication')
# Turn this off if you don't want the workbench to start the GUI
# event loop.
start_gui_event_loop = Bool(True, desc='start a GUI event loop')
# The MayaVi Script instance.
script = Instance('mayavi.plugins.script.Script')
# The logging mode.
log_mode = Int(logging.ERROR, desc='the logging mode to use')
def main(self, argv=None, plugins=None):
"""The main application is created and launched here.
Parameters
----------
argv : list of strings
The list of command line arguments. The default is `None`
where no command line arguments are parsed. To support
command line arguments you can pass `sys.argv[1:]`.
plugins : list of Plugin objects
List of plugins to start. If none is provided it defaults to
something meaningful.
log_mode :
The logging mode to use.
"""
# Parse any cmd line args.
if argv is None:
argv = []
self.parse_command_line(argv)
if plugins is None:
plugins = get_plugins()
plugins += get_custom_plugins()
# Create the application
prefs = preference_manager.preferences
app = MayaviWorkbenchApplication(plugins=plugins,
preferences=prefs,
start_gui_event_loop=self.start_gui_event_loop)
self.application = app
# Setup the logger.
self.setup_logger()
# Start the application.
app.run()
def setup_logger(self):
"""Setup logging for the application."""
setup_logger(logger, 'mayavi.log', mode=self.log_mode)
def parse_command_line(self, argv):
"""Parse command line options.
Parameters
----------
- argv : `list` of `strings`
The list of command line arguments.
"""
from optparse import OptionParser
usage = "usage: %prog [options]"
parser = OptionParser(usage)
(options, args) = parser.parse_args(argv)
def run(self):
"""This function is called after the GUI has started.
Override this to do whatever you want to do as a MayaVi
script. If this is not overridden then an empty MayaVi
application will be started.
*Make sure all other MayaVi specific imports are made here!*
If you import MayaVi related code earlier you will run into
difficulties. Use 'self.script' to script the mayavi engine.
"""
pass
######################################################################
# Non-public interface.
######################################################################
@on_trait_change('application.gui:started')
def _on_application_gui_started(self, obj, trait_name, old, new):
"""This is called as soon as the Envisage GUI starts up. The
method is responsible for setting our script instance.
"""
if trait_name != 'started' or not new:
return
app = self.application
from mayavi.plugins.script import Script
window = app.workbench.active_window
# Set our script instance.
self.script = window.get_service(Script)
# Call self.run from the GUI thread.
app.gui.invoke_later(self.run)
def main(argv=None):
"""Simple helper to start up the mayavi application. This returns
the running application."""
m = Mayavi()
m.main(argv)
return m
if __name__ == '__main__':
main(sys.argv[1:])
|