This file is indexed.

/usr/lib/python2.7/dist-packages/woo/system.py is in python-woo 1.0+dfsg1-1+b4.

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
# coding: utf-8
# 2009 © Václav Šmilauer <eudoxos@arcig.cz>

"""
Functions for accessing woo's internals; only used internally.
"""
import sys
from woo._customConverters import *
from woo import runtime
from woo import config
import woo.core

def childClasses(base,recurse=True,includeBase=False):
	"""Enumerate classes deriving from given base (as string), recursively by default. Returns set."""
	if isinstance(base,str): ret=set(woo.master.childClassesNonrecursive(base));
	else: ret=set(base.__subclasses__())
	ret2=set();
	if includeBase: ret|=set([base])
	if not recurse: return ret
	for bb in ret:
		ret2|=childClasses(bb)
	return ret | ret2

_allSerializables=[c.__name__ for c in woo.core.Object._derivedCxxClasses]
## set of classes for which the proxies were created
_proxiedClasses=set()

if 0:
	def updateScripts(scripts):
		## Thanks goes to http://code.activestate.com/recipes/81330-single-pass-multiple-replace/
		from UserDict import UserDict
		import re,os
		class Xlator(UserDict):
			"An all-in-one multiple string substitution class; adapted to match only whole words"
			def _make_regex(self): 
				"Build a regular expression object based on the keys of the current dictionary"
				return re.compile(r"(\b%s\b)" % "|".join(self.keys()))  ## adapted here 
			def __call__(self, mo): 
				"This handler will be invoked for each regex match"
				# Count substitutions
				self.count += 1 # Look-up string
				return self[mo.string[mo.start():mo.end()]]
			def xlat(self, text):
				"Translate text, returns the modified text."
				# Reset substitution counter
				self.count = 0 
				# Process text
				return self._make_regex().sub(self, text)
		# use the _deprecated dictionary for translation, but only when matching on words boundary
		xlator=Xlator(_deprecated)
		if len(scripts)==0: print "No scripts given to --update. Nothing to do."
		for s in scripts:
			if not s.endswith('.py'): raise RuntimeError("Refusing to do --update on file '"+s+"' (not *.py)")
			txt=open(s).read()
			txt2=xlator.xlat(txt)
			if xlator.count==0: print "%s: already up-to-date."%s
			else:
				os.rename(s,s+'~')
				out=open(s,'w'); out.write(txt2); out.close()
				print "%s: %d subtitution%s made, backup in %s~"%(s,xlator.count,'s' if xlator.count>1 else '',s)


def setExitHandlers():
	"""Set exit handler to avoid gdb run if log4cxx crashes at exit."""
	# avoid backtrace at regular exit, even if we crash
	if 'log4cxx' in config.features:
		__builtins__['quit']=woo.master.exitNoBacktrace
		sys.exit=woo.master.exitNoBacktrace
	# this seems to be not needed anymore:
	#sys.excepthook=sys.__excepthook__ # apport on ubuntu overrides this, we don't need it


# consistency check
# if there are no serializables, then plugins were not loaded yet, probably
if(len(_allSerializables)==0):
	raise ImportError("No classes deriving from Object found; you must call woo.boot.initialize to load plugins before importing woo.system.")