本文整理汇总了Python中sys.getprofile方法的典型用法代码示例。如果您正苦于以下问题:Python sys.getprofile方法的具体用法?Python sys.getprofile怎么用?Python sys.getprofile使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类sys
的用法示例。
在下文中一共展示了sys.getprofile方法的10个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的Python代码示例。
示例1: restore_profiler
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def restore_profiler():
"""If a typechecking profiler is active, e.g. created by
pytypes.set_global_typechecked_profiler(), such a profiler
must be restored whenever a TypeCheckError is caught.
The call must stem from the thread that raised the error.
Otherwise the typechecking profiler is implicitly disabled.
Alternatively one can turn pytypes into warning mode. In that
mode no calls to this function are required (unless one uses
filterwarnings("error") or likewise).
"""
idn = threading.current_thread().ident
if not sys.getprofile() is None:
warn("restore_profiler: Current profile is not None!")
if not idn in _saved_profilers:
warn("restore_profiler: No saved profiler for calling thread!")
else:
sys.setprofile(_saved_profilers[idn])
del _saved_profilers[idn]
示例2: run
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def run(self):
if sys.getprofile() is not None:
# NOTE: There's no threading.getprofile().
# The profiling function will be stored at threading._profile_hook
# but it's not documented.
raise RuntimeError('Another profiler already registered')
with deferral() as defer:
self._times_entered.clear()
self.overhead = 0.0
sys.setprofile(self._profile)
defer(sys.setprofile, None)
threading.setprofile(self._profile)
defer(threading.setprofile, None)
self.timer.start(self)
defer(self.timer.stop)
yield
示例3: start
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def start(self):
if self._active:
raise RuntimeError('type checker already running')
elif self._pending:
raise RuntimeError('type checker already starting up')
self._pending = True
# Install this instance as the current profiler
self._previous_profiler = sys.getprofile()
self._set_caller_level_shift(0)
sys.setprofile(self)
# If requested, set this instance as the default profiler for all future threads
# (does not affect existing threads)
if self.all_threads:
self._previous_thread_profiler = threading._profile_hook
threading.setprofile(self)
self._active, self._pending = True, False
示例4: stop
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def stop(self):
if self._active and not self._pending:
self._pending = True
if sys.getprofile() is self:
sys.setprofile(self._previous_profiler)
if not self._previous_profiler is None and \
isinstance(self._previous_profiler, TypeAgent):
self._previous_profiler._set_caller_level_shift(0)
else:
if sys.getprofile() is not None or not self._cleared:
warn('the system profiling hook has changed unexpectedly')
if self.all_threads:
if threading._profile_hook is self:
threading.setprofile(self._previous_thread_profiler)
else: # pragma: no cover
warn('the threading profiling hook has changed unexpectedly')
self._active, self._pending = False, False
示例5: test_empty
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def test_empty(self):
self.assertIsNone(sys.getprofile())
示例6: test_setget
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def test_setget(self):
def fn(*args):
pass
sys.setprofile(fn)
self.assertIs(sys.getprofile(), fn)
示例7: test_setprofile
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def test_setprofile():
profiler = TracingProfiler()
assert sys.getprofile() is None
with profiler:
assert sys.getprofile() == profiler._profile
assert sys.getprofile() is None
sys.setprofile(lambda *x: x)
with pytest.raises(RuntimeError):
profiler.start()
sys.setprofile(None)
示例8: stop
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def stop(self):
"""
Removes the module profiler globally and from future threads.
"""
if sys.getprofile() != self.profiler:
logger.warning(
"ModuleProfiler: The currently enabled profile function was not ours - unbinding anyways"
)
threading.setprofile(None)
sys.setprofile(None)
示例9: test_empty
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def test_empty(self):
assert sys.getprofile() == None
示例10: test_setget
# 需要导入模块: import sys [as 别名]
# 或者: from sys import getprofile [as 别名]
def test_setget(self):
def fn(*args):
pass
sys.setprofile(fn)
assert sys.getprofile() == fn