/usr/share/pyshared/mayavi/components/cutter.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 | """A simple wrapper for `tvtk.Cutter`.
"""
# Author: Prabhu Ramachandran <prabhu_r@users.sf.net>
# Copyright (c) 2005-2008, Enthought, Inc.
# License: BSD Style.
# Enthought library imports.
from traits.api import Instance, Property
from traitsui.api import View, Group, Item
from tvtk.api import tvtk
# Local imports.
from mayavi.core.component import Component
######################################################################
# `Cutter` class.
######################################################################
class Cutter(Component):
# The version of this class. Used for persistence.
__version__ = 0
# The mapper.
cutter = Instance(tvtk.Cutter, args=())
# The cut function. This should be a delegate but due to a bug in
# traits that does not work.
cut_function = Property
########################################
# View related traits.
view = View(Group(Item(name='cutter',
style='custom',
resizable=True),
show_labels=False),
resizable=True)
######################################################################
# `Component` interface
######################################################################
def update_pipeline(self):
"""Override this method so that it *updates* the tvtk pipeline
when data upstream is known to have changed.
This method is invoked (automatically) when the input fires a
`pipeline_changed` event.
"""
if (len(self.inputs) == 0) or (len(self.inputs[0].outputs) == 0):
return
c = self.cutter
c.input = self.inputs[0].outputs[0]
self.outputs = [c.output]
def update_data(self):
"""Override this method to do what is necessary when upstream
data changes.
This method is invoked (automatically) when any of the inputs
sends a `data_changed` event.
"""
self.data_changed = True
######################################################################
# `Cutter` interface
######################################################################
def _get_cut_function(self):
return self.cutter.cut_function
def _set_cut_function(self, val):
old = self.cutter.cut_function
self.cutter.cut_function = val
self.trait_property_changed('cut_function', old, val)
|