[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@18.116.13.192: ~ $
# -*- coding: utf-8 -*-
# Copyright (C) 2010, 2011, 2012 Sebastian Wiesner <lunaryorn@googlemail.com>

# This library is free software; you can redistribute it and/or modify it
# under the terms of the GNU Lesser General Public License as published by the
# Free Software Foundation; either version 2.1 of the License, or (at your
# option) any later version.

# This library is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public License
# for more details.

# You should have received a copy of the GNU Lesser General Public License
# along with this library; if not, write to the Free Software Foundation,
# Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA


"""
    pyudev._util
    ============

    Internal utilities

    .. moduleauthor::  Sebastian Wiesner  <lunaryorn@googlemail.com>
"""


from __future__ import (print_function, division, unicode_literals,
                        absolute_import)

import os
import sys
import stat
import errno


if sys.version_info[0] == 2:
    from pyudev._py2util import *
else:
    from pyudev._py3util import *


def ensure_byte_string(value):
    """
    Return the given ``value`` as bytestring.

    If the given ``value`` is not a byte string, but a real unicode string, it
    is encoded with the filesystem encoding (as in
    :func:`sys.getfilesystemencoding()`).
    """
    if not isinstance(value, bytes):
        value = value.encode(sys.getfilesystemencoding())
    return value


def ensure_unicode_string(value):
    """
    Return the given ``value`` as unicode string.

    If the given ``value`` is not a unicode string, but a byte string, it is
    decoded with the filesystem encoding (as in
    :func:`sys.getfilesystemencoding()`).
    """
    if not isinstance(value, unicode):
        value = value.decode(sys.getfilesystemencoding())
    return value


def property_value_to_bytes(value):
    """
    Return a byte string, which represents the given ``value`` in a way
    suitable as raw value of an udev property.

    If ``value`` is a boolean object, it is converted to ``'1'`` or ``'0'``,
    depending on whether ``value`` is ``True`` or ``False``.  If ``value`` is a
    byte string already, it is returned unchanged.  Anything else is simply
    converted to a unicode string, and then passed to
    :func:`ensure_byte_string`.
    """
    # udev represents boolean values as 1 or 0, therefore an explicit
    # conversion to int is required for boolean values
    if isinstance(value, bool):
        value = int(value)
    if isinstance(value, bytes):
        return value
    else:
        return ensure_byte_string(unicode(value))


def string_to_bool(value):
    """
    Convert the given unicode string ``value`` to a boolean object.

    If ``value`` is ``'1'``, ``True`` is returned.  If ``value`` is ``'0'``,
    ``False`` is returned.  Any other value raises a
    :exc:`~exceptions.ValueError`.
    """
    if value not in ('1', '0'):
        raise ValueError('Not a boolean value: {0!r}'.format(value))
    return value == '1'


def udev_list_iterate(libudev, entry):
    """
    Iteration helper for udev list entry objects.

    Yield a tuple ``(name, value)``.  ``name`` and ``value`` are bytestrings
    containing the name and the value of the list entry.  The exact contents
    depend on the list iterated over.
    """
    while entry:
        name = libudev.udev_list_entry_get_name(entry)
        value = libudev.udev_list_entry_get_value(entry)
        yield (name, value)
        entry = libudev.udev_list_entry_get_next(entry)


# for the sake of readability
_is_char_device = stat.S_ISCHR
_is_block_device = stat.S_ISBLK


def get_device_type(filename):
    """
    Get the device type of a device file.

    ``filename`` is a string containing the path of a device file.

    Return ``'char'`` if ``filename`` is a character device, or ``'block'`` if
    ``filename`` is a block device.  Raise :exc:`~exceptions.ValueError` if
    ``filename`` is no device file at all.  Raise
    :exc:`~exceptions.EnvironmentError` if ``filename`` does not exist or if
    its metadata was inaccessible.

    .. versionadded:: 0.15
    """
    mode = os.stat(filename).st_mode
    if _is_char_device(mode):
        return 'char'
    elif _is_block_device(mode):
        return 'block'
    else:
        raise ValueError('not a device file: {0!r}'.format(filename))


def eintr_retry_call(func, *args, **kwargs):
    """
    Handle interruptions to an interruptible system call.

    Run an interruptible system call in a loop and retry if it raises EINTR.
    The signal calls that may raise EINTR prior to Python 3.5 are listed in
    PEP 0475.  Any calls to these functions must be wrapped in eintr_retry_call
    in order to handle EINTR returns in older versions of Python.

    This function is safe to use under Python 3.5 and newer since the wrapped
    function will simply return without raising EINTR.

    This function is based on _eintr_retry_call in python's subprocess.py.
    """

    # select.error inherits from Exception instead of OSError in Python 2
    import select

    while True:
        try:
            return func(*args, **kwargs)
        except (OSError, IOError, select.error) as e:
            # If this is not an IOError or OSError, it's the old select.error
            # type, which means that the errno is only accessible via subscript
            if isinstance(e, (OSError, IOError)):
                error_code = e.errno
            else:
                error_code = e.args[0]

            if error_code == errno.EINTR:
                continue
            raise

Filemanager

Name Type Size Permission Actions
.__init__.pyo.40009 File 1.21 KB 0644
._compat.pyo.40009 File 1019 B 0644
._libudev.pyo.40009 File 8.6 KB 0644
._py2util.pyo.40009 File 870 B 0644
._py3util.pyo.40009 File 688 B 0644
._qt_base.pyo.40009 File 2.48 KB 0644
._util.pyo.40009 File 5.3 KB 0644
.core.pyo.40009 File 14.9 KB 0644
.device.pyo.40009 File 38.74 KB 0644
.glib.pyo.40009 File 3.42 KB 0644
.monitor.pyo.40009 File 17.17 KB 0644
.pyqt4.pyo.40009 File 2.37 KB 0644
.pyside.pyo.40009 File 2.38 KB 0644
.wx.pyo.40009 File 3.7 KB 0644
__init__.py File 1.75 KB 0644
__init__.pyc File 1.21 KB 0644
__init__.pyo File 1.21 KB 0644
_compat.py File 1.44 KB 0644
_compat.pyc File 1019 B 0644
_compat.pyo File 1019 B 0644
_libudev.py File 9.9 KB 0644
_libudev.pyc File 8.6 KB 0644
_libudev.pyo File 8.6 KB 0644
_py2util.py File 1.32 KB 0644
_py2util.pyc File 870 B 0644
_py2util.pyo File 870 B 0644
_py3util.py File 1.19 KB 0644
_py3util.pyc File 688 B 0644
_py3util.pyo File 688 B 0644
_qt_base.py File 2.53 KB 0644
_qt_base.pyc File 2.48 KB 0644
_qt_base.pyo File 2.48 KB 0644
_util.py File 5.62 KB 0644
_util.pyc File 5.3 KB 0644
_util.pyo File 5.3 KB 0644
core.py File 13.66 KB 0644
core.pyc File 14.9 KB 0644
core.pyo File 14.9 KB 0644
device.py File 33.43 KB 0644
device.pyc File 38.74 KB 0644
device.pyo File 38.74 KB 0644
glib.py File 4.49 KB 0644
glib.pyc File 3.42 KB 0644
glib.pyo File 3.42 KB 0644
monitor.py File 16.91 KB 0644
monitor.pyc File 17.17 KB 0644
monitor.pyo File 17.17 KB 0644
pyqt4.py File 2.85 KB 0644
pyqt4.pyc File 2.37 KB 0644
pyqt4.pyo File 2.37 KB 0644
pyside.py File 2.83 KB 0644
pyside.pyc File 2.38 KB 0644
pyside.pyo File 2.38 KB 0644
wx.py File 3.44 KB 0644
wx.pyc File 3.7 KB 0644
wx.pyo File 3.7 KB 0644