summaryrefslogtreecommitdiffstats
path: root/contrib/tools/cython/Cython/Debugger/DebugWriter.py
diff options
context:
space:
mode:
authorAnton Samokhvalov <[email protected]>2022-02-10 16:45:17 +0300
committerDaniil Cherednik <[email protected]>2022-02-10 16:45:17 +0300
commitd3a398281c6fd1d3672036cb2d63f842d2cb28c5 (patch)
treedd4bd3ca0f36b817e96812825ffaf10d645803f2 /contrib/tools/cython/Cython/Debugger/DebugWriter.py
parent72cb13b4aff9bc9cf22e49251bc8fd143f82538f (diff)
Restoring authorship annotation for Anton Samokhvalov <[email protected]>. Commit 2 of 2.
Diffstat (limited to 'contrib/tools/cython/Cython/Debugger/DebugWriter.py')
-rw-r--r--contrib/tools/cython/Cython/Debugger/DebugWriter.py126
1 files changed, 63 insertions, 63 deletions
diff --git a/contrib/tools/cython/Cython/Debugger/DebugWriter.py b/contrib/tools/cython/Cython/Debugger/DebugWriter.py
index ebf99a2f643..876a3a2169a 100644
--- a/contrib/tools/cython/Cython/Debugger/DebugWriter.py
+++ b/contrib/tools/cython/Cython/Debugger/DebugWriter.py
@@ -1,72 +1,72 @@
from __future__ import absolute_import
-
-import os
-import sys
-import errno
-
-try:
- from lxml import etree
- have_lxml = True
-except ImportError:
- have_lxml = False
- try:
- from xml.etree import cElementTree as etree
- except ImportError:
- try:
- from xml.etree import ElementTree as etree
- except ImportError:
+
+import os
+import sys
+import errno
+
+try:
+ from lxml import etree
+ have_lxml = True
+except ImportError:
+ have_lxml = False
+ try:
+ from xml.etree import cElementTree as etree
+ except ImportError:
+ try:
+ from xml.etree import ElementTree as etree
+ except ImportError:
etree = None
-
+
from ..Compiler import Errors
-
-
-class CythonDebugWriter(object):
- """
- Class to output debugging information for cygdb
-
- It writes debug information to cython_debug/cython_debug_info_<modulename>
- in the build directory.
- """
-
- def __init__(self, output_dir):
- if etree is None:
- raise Errors.NoElementTreeInstalledException()
-
+
+
+class CythonDebugWriter(object):
+ """
+ Class to output debugging information for cygdb
+
+ It writes debug information to cython_debug/cython_debug_info_<modulename>
+ in the build directory.
+ """
+
+ def __init__(self, output_dir):
+ if etree is None:
+ raise Errors.NoElementTreeInstalledException()
+
self.output_dir = os.path.join(output_dir or os.curdir, 'cython_debug')
- self.tb = etree.TreeBuilder()
- # set by Cython.Compiler.ParseTreeTransforms.DebugTransform
- self.module_name = None
- self.start('cython_debug', attrs=dict(version='1.0'))
-
- def start(self, name, attrs=None):
- self.tb.start(name, attrs or {})
-
- def end(self, name):
- self.tb.end(name)
-
+ self.tb = etree.TreeBuilder()
+ # set by Cython.Compiler.ParseTreeTransforms.DebugTransform
+ self.module_name = None
+ self.start('cython_debug', attrs=dict(version='1.0'))
+
+ def start(self, name, attrs=None):
+ self.tb.start(name, attrs or {})
+
+ def end(self, name):
+ self.tb.end(name)
+
def add_entry(self, name, **attrs):
self.tb.start(name, attrs)
self.tb.end(name)
- def serialize(self):
- self.tb.end('Module')
- self.tb.end('cython_debug')
- xml_root_element = self.tb.close()
-
- try:
- os.makedirs(self.output_dir)
+ def serialize(self):
+ self.tb.end('Module')
+ self.tb.end('cython_debug')
+ xml_root_element = self.tb.close()
+
+ try:
+ os.makedirs(self.output_dir)
except OSError as e:
- if e.errno != errno.EEXIST:
- raise
-
- et = etree.ElementTree(xml_root_element)
- kw = {}
- if have_lxml:
- kw['pretty_print'] = True
-
- fn = "cython_debug_info_" + self.module_name
- et.write(os.path.join(self.output_dir, fn), encoding="UTF-8", **kw)
-
- interpreter_path = os.path.join(self.output_dir, 'interpreter')
- with open(interpreter_path, 'w') as f:
- f.write(sys.executable)
+ if e.errno != errno.EEXIST:
+ raise
+
+ et = etree.ElementTree(xml_root_element)
+ kw = {}
+ if have_lxml:
+ kw['pretty_print'] = True
+
+ fn = "cython_debug_info_" + self.module_name
+ et.write(os.path.join(self.output_dir, fn), encoding="UTF-8", **kw)
+
+ interpreter_path = os.path.join(self.output_dir, 'interpreter')
+ with open(interpreter_path, 'w') as f:
+ f.write(sys.executable)