sapling/hgext/traceprof.pyx
Jun Wu cd91de7c43 codemod: use byte strings in cython files
Summary:
For some reason, buck cython build starts to treat unprefixed strings as
unicode strings. That breaks Mercurial where everything should be bytes.

Therefore add the b prefix to make them byte strings explicitly.

Reviewed By: DurhamG, ryanmce

Differential Revision: D9015176

fbshipit-source-id: 7a3ef9d735362e3ae02208ec19d0551bf0adaaa4
2018-07-26 09:53:23 -07:00

76 lines
2.0 KiB
Cython

# distutils: language = c++
# traceprof.pyx - C++ to Python bridge for the traceprof Mercurial extension
#
# Copyright 2017 Facebook, Inc.
#
# This software may be used and distributed according to the terms of the
# GNU General Public License version 2 or any later version.
"""accurate callgraph profiling
lsprof's high precision, plus statprof's intuitive output format.
Config::
[traceprof]
# whether to disable Python GC before profiling
disablegc = no
# minimal microseconds to show a function
timethreshold = 2000
# minimal call count to show "(N times)"
countthreshold = 2
# frame de-duplication (slower to print outputs)
framededup = yes
"""
from libc.stdio cimport FILE
from cpython.object cimport PyObject
import contextlib
import gc
cdef extern from "hgext/extlib/traceprofimpl.cpp":
void enable()
void disable()
IF UNAME_SYSNAME == "Windows":
void report()
ELSE:
void report(FILE *)
void settimethreshold(double)
void setcountthreshold(size_t)
void setdedup(int)
void clear()
cdef extern from "Python.h":
FILE* PyFile_AsFile(PyObject *p)
@contextlib.contextmanager
def profile(ui, fp):
if ui is not None:
if ui.configbool(b'traceprof', b'disablegc'):
gc.disable() # slightly more predictable
microseconds = ui.configint(b'traceprof', b'timethreshold')
if microseconds is not None:
settimethreshold((<double>microseconds) / 1000.0)
count = ui.configint(b'traceprof', b'countthreshold')
if count is not None:
setcountthreshold(count)
dedup = ui.configbool(b'traceprof', b'framededup', True)
setdedup(<int>dedup)
enable()
try:
yield
finally:
disable()
IF UNAME_SYSNAME == "Windows":
# On Windows, "FILE*" could be incompatible between Python.exe and
# traceimpl.exp. Use stderr from traceimpl.exp conservatively.
report()
ELSE:
report(PyFile_AsFile(<PyObject *>fp))
clear()