File: deprecated.py

package info (click to toggle)
dune-common 2.10.0-6
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 5,824 kB
  • sloc: cpp: 52,256; python: 3,979; sh: 1,658; makefile: 17
file content (22 lines) | stat: -rw-r--r-- 970 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
# SPDX-FileCopyrightInfo: Copyright © DUNE Project contributors, see file LICENSE.md in module root
# SPDX-License-Identifier: LicenseRef-GPL-2.0-only-with-DUNE-exception

import logging

class DeprecatedObject(object):
    def __init__(self, real, message):
        self.real = real
        self.logger = logging.getLogger(real.__module__)
        self.message = message

    def __call__(self, *args, **kwargs):
        object.__getattribute__(self, "logger").warning(object.__getattribute__(self, "message"))
        return object.__getattribute__(self, "real")(*args, **kwargs)

    def __getattribute__(self, name):
        object.__getattribute__(self, "logger").warning(object.__getattribute__(self, "message"))
        return getattr(object.__getattribute__(self, "real"), name)

    def __repr__(self):
        object.__getattribute__(self, "logger").warning(object.__getattribute__(self, "message"))
        return repr(object.__getattribute__(self, "real"))