summaryrefslogtreecommitdiff
path: root/silx/utils/decorators.py
diff options
context:
space:
mode:
authorPicca Frédéric-Emmanuel <picca@debian.org>2017-10-07 07:59:01 +0200
committerPicca Frédéric-Emmanuel <picca@debian.org>2017-10-07 07:59:01 +0200
commitbfa4dba15485b4192f8bbe13345e9658c97ecf76 (patch)
treefb9c6e5860881fbde902f7cbdbd41dc4a3a9fb5d /silx/utils/decorators.py
parentf7bdc2acff3c13a6d632c28c4569690ab106eed7 (diff)
New upstream version 0.6.0+dfsg
Diffstat (limited to 'silx/utils/decorators.py')
-rw-r--r--silx/utils/decorators.py71
1 files changed, 0 insertions, 71 deletions
diff --git a/silx/utils/decorators.py b/silx/utils/decorators.py
deleted file mode 100644
index ff70e38..0000000
--- a/silx/utils/decorators.py
+++ /dev/null
@@ -1,71 +0,0 @@
-# coding: utf-8
-# /*##########################################################################
-#
-# Copyright (c) 2016-2017 European Synchrotron Radiation Facility
-#
-# Permission is hereby granted, free of charge, to any person obtaining a copy
-# of this software and associated documentation files (the "Software"), to deal
-# in the Software without restriction, including without limitation the rights
-# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-# copies of the Software, and to permit persons to whom the Software is
-# furnished to do so, subject to the following conditions:
-#
-# The above copyright notice and this permission notice shall be included in
-# all copies or substantial portions of the Software.
-#
-# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-# THE SOFTWARE.
-#
-# ###########################################################################*/
-"""Bunch of useful decorators"""
-
-from __future__ import absolute_import, print_function, division
-
-__authors__ = ["Jerome Kieffer"]
-__license__ = "MIT"
-__date__ = "01/03/2017"
-
-import os
-import sys
-import traceback
-import logging
-import functools
-
-
-depreclog = logging.getLogger("DEPRECATION")
-
-
-def deprecated(func=None, reason=None, replacement=None, since_version=None):
- """
- Decorator that deprecates the use of a function
-
- :param str reason: Reason for deprecating this function
- (e.g. "feature no longer provided",
- :param str replacement: Name of replacement function (if the reason for
- deprecating was to rename the function)
- :param str since_version: First *silx* version for which the function was
- deprecated (e.g. "0.5.0").
- """
- def decorator(func):
- @functools.wraps(func)
- def wrapper(*args, **kwargs):
- name = func.func_name if sys.version_info[0] < 3 else func.__name__
- msg = "%s is deprecated"
- if since_version is not None:
- msg += " since silx version %s" % since_version
- msg += "!"
- if reason is not None:
- msg += " Reason: %s." % reason
- if replacement is not None:
- msg += " Use '%s' instead." % replacement
- depreclog.warning(msg + " %s", name, os.linesep.join([""] + traceback.format_stack()[:-1]))
- return func(*args, **kwargs)
- return wrapper
- if func is not None:
- return decorator(func)
- return decorator