/usr/share/pyshared/matplotlib/_pylab_helpers.py is in python-matplotlib 1.1.1~rc1+git20120423-0ubuntu1.
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 | """
Manage figures for pyplot interface.
"""
import sys, gc
import atexit
import traceback
def error_msg(msg):
print >>sys.stderr, msg
class Gcf(object):
"""
Manage a set of integer-numbered figures.
This class is never instantiated; it consists of two class
attributes (a list and a dictionary), and a set of static
methods that operate on those attributes, accessing them
directly as class attributes.
Attributes:
*figs*:
dictionary of the form {*num*: *manager*, ...}
*_activeQue*:
list of *managers*, with active one at the end
"""
_activeQue = []
figs = {}
@staticmethod
def get_fig_manager(num):
"""
If figure manager *num* exists, make it the active
figure and return the manager; otherwise return *None*.
"""
manager = Gcf.figs.get(num, None)
if manager is not None:
Gcf.set_active(manager)
return manager
@staticmethod
def destroy(num):
"""
Try to remove all traces of figure *num*.
In the interactive backends, this is bound to the
window "destroy" and "delete" events.
"""
if not Gcf.has_fignum(num): return
manager = Gcf.figs[num]
manager.canvas.mpl_disconnect(manager._cidgcf)
# There must be a good reason for the following careful
# rebuilding of the activeQue; what is it?
oldQue = Gcf._activeQue[:]
Gcf._activeQue = []
for f in oldQue:
if f != manager:
Gcf._activeQue.append(f)
del Gcf.figs[num]
#print len(Gcf.figs.keys()), len(Gcf._activeQue)
manager.destroy()
gc.collect()
@staticmethod
def destroy_fig(fig):
"*fig* is a Figure instance"
for manager in Gcf.figs.values():
if manager.canvas.figure == fig:
Gcf.destroy(manager.num)
@staticmethod
def destroy_all():
for manager in Gcf.figs.values():
manager.canvas.mpl_disconnect(manager._cidgcf)
manager.destroy()
Gcf._activeQue = []
Gcf.figs.clear()
gc.collect()
@staticmethod
def has_fignum(num):
"""
Return *True* if figure *num* exists.
"""
return num in Gcf.figs
@staticmethod
def get_all_fig_managers():
"""
Return a list of figure managers.
"""
return Gcf.figs.values()
@staticmethod
def get_num_fig_managers():
"""
Return the number of figures being managed.
"""
return len(Gcf.figs.values())
@staticmethod
def get_active():
"""
Return the manager of the active figure, or *None*.
"""
if len(Gcf._activeQue)==0:
return None
else: return Gcf._activeQue[-1]
@staticmethod
def set_active(manager):
"""
Make the figure corresponding to *manager* the active one.
"""
oldQue = Gcf._activeQue[:]
Gcf._activeQue = []
for m in oldQue:
if m != manager: Gcf._activeQue.append(m)
Gcf._activeQue.append(manager)
Gcf.figs[manager.num] = manager
atexit.register(Gcf.destroy_all)
|