404

[ Avaa Bypassed ]




Upload:

Command:

botdev@18.227.114.67: ~ $
# Copyright 2010, 2011  Lars Wirzenius
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program 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 General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program.  If not, see <http://www.gnu.org/licenses/>.


import time

import ttystatus


class Messager(object):

    '''Manages messages to the terminal.

    This includes disabling messages, allowing notifications, and
    becalming the flow of messages to avoid writing too fast. The
    speed is a performance thing: writing too much message text can
    slow an application down a lot (too much work for terminal
    emulators), and doesn't actually help the user in any way.

    '''

    def __init__(self, period=None, _terminal=None):
        self._period = 1.0 if period is None else period

        self.enabled = True

        self._cached_message = None  # The latest message from caller.
        self._displayed_message = None  # The latest message displayed.
        self._previous_write_at = 0  # When the latest message was written.

        self._terminal = _terminal or ttystatus.PhysicalTerminal()
        try:
            self._terminal.open_tty()
        except IOError:
            self.enabled = False

        if not self._terminal.has_capabilities():
            self.enabled = False

        self._area = ttystatus.AreaManager()
        self._area.set_terminal(self._terminal)

    def disable(self):
        '''Disable all output except notifications.'''
        self.enabled = False

    def enable(self):
        '''Enable output to happen.'''
        self.enabled = True

    def time_to_write(self):
        '''Is it time to write now?'''
        return self._now() - self._previous_write_at >= self._period

    def _now(self):
        '''Return current time.'''
        # This is a wrapper around time.time(), for testing.
        return time.time()

    def get_terminal_size(self):
        '''Return terminal width, height.'''
        return self._terminal.get_size()

    def get_max_line_length(self):
        return self._area.get_max_line_length()

    def write(self, message, force=False):
        '''Write message to terminal.

        Message may be multiple lines.

        '''

        if self.enabled and (force or self.time_to_write()):
            if self._displayed_message is not None:
                self._area.prepare_to_overwrite(self._displayed_message)
            num_lines = len(message.split('\n'))
            self._area.make_space(num_lines)
            self._area.display(message)
            self._displayed_message = message
            self._previous_write_at = self._now()
        self._cached_message = message

    def clear(self):
        '''Remove currently displayed message from terminal, if any.'''

        if self._displayed_message is not None:
            num_lines = len(self._displayed_message.split('\n'))
            self._area.clear_area(num_lines)
            self._displayed_message = None
            self._cached_message = None
            self._previous_write_at = 0  # Next .write() should display.

    def notify(self, message, f, force=False):
        '''Show a notification message string to the user.

        Notifications are meant for error messages and other things
        that do not belong in, say, progress bars. Whatever is currently
        on the terminal is wiped, then the notification message is shown,
        a new line is started, and the old message is restored.

        Notifications are written even when the output is not going
        to a terminal.

        '''

        if self.enabled or force:
            self.clear()
            try:
                f.write(message)
                f.write('\n')
                f.flush()
            except IOError:
                # We ignore these. No point in crashing if terminal is bad.
                pass
            if self._cached_message is not None:
                self.write(self._cached_message)

    def finish(self):
        '''Finalize output.'''
        if self.enabled and self._cached_message is not None:
            self.write(self._cached_message)
            if self._cached_message:
                self._terminal.write('\n')

Filemanager

Name Type Size Permission Actions
__init__.py File 1.29 KB 0644
__init__.pyc File 1.25 KB 0644
area.py File 3.41 KB 0644
area.pyc File 3.9 KB 0644
bytesize.py File 1.39 KB 0644
bytesize.pyc File 1.37 KB 0644
bytesize_tests.py File 1.95 KB 0644
bytesize_tests.pyc File 3.11 KB 0644
bytespeed.py File 2.26 KB 0644
bytespeed.pyc File 2.17 KB 0644
bytespeed_tests.py File 2.54 KB 0644
bytespeed_tests.pyc File 4.77 KB 0644
counter.py File 1.1 KB 0644
counter.pyc File 1.13 KB 0644
counter_tests.py File 1.42 KB 0644
counter_tests.pyc File 1.97 KB 0644
elapsed.py File 1.35 KB 0644
elapsed.pyc File 1.43 KB 0644
elapsed_tests.py File 1.38 KB 0644
elapsed_tests.pyc File 2.14 KB 0644
fmt.py File 2.15 KB 0644
fmt.pyc File 1.74 KB 0644
fmt_tests.py File 2.39 KB 0644
fmt_tests.pyc File 2.78 KB 0644
index.py File 1.25 KB 0644
index.pyc File 1.24 KB 0644
index_tests.py File 1.27 KB 0644
index_tests.pyc File 1.7 KB 0644
integer.py File 1.06 KB 0644
integer.pyc File 1.12 KB 0644
integer_tests.py File 1.22 KB 0644
integer_tests.pyc File 1.64 KB 0644
literal.py File 877 B 0644
literal.pyc File 791 B 0644
literal_tests.py File 984 B 0644
literal_tests.pyc File 1.09 KB 0644
messager.py File 4.52 KB 0644
messager.pyc File 4.61 KB 0644
pathname.py File 1.07 KB 0644
pathname.pyc File 1.12 KB 0644
pathname_tests.py File 1.36 KB 0644
pathname_tests.pyc File 1.92 KB 0644
percent.py File 1.4 KB 0644
percent.pyc File 1.35 KB 0644
percent_tests.py File 1.42 KB 0644
percent_tests.pyc File 2 KB 0644
progressbar.py File 1.46 KB 0644
progressbar.pyc File 1.41 KB 0644
progressbar_tests.py File 2.33 KB 0644
progressbar_tests.pyc File 3.77 KB 0644
remtime.py File 1.89 KB 0644
remtime.pyc File 1.81 KB 0644
remtime_tests.py File 2.08 KB 0644
remtime_tests.pyc File 3.26 KB 0644
speed.py File 1.94 KB 0644
speed.pyc File 1.83 KB 0644
speed_tests.py File 1001 B 0644
speed_tests.pyc File 1.1 KB 0644
status.py File 6.15 KB 0644
status.pyc File 8.2 KB 0644
status_tests.py File 5.18 KB 0644
status_tests.pyc File 8.97 KB 0644
string.py File 998 B 0644
string.pyc File 1.02 KB 0644
string_tests.py File 1.2 KB 0644
string_tests.pyc File 1.61 KB 0644
tty.py File 2.87 KB 0644
tty.pyc File 3.33 KB 0644
version.py File 48 B 0644
version.pyc File 225 B 0644
widget.py File 2.22 KB 0644
widget.pyc File 2.13 KB 0644