1
# Copyright (C) 2005 Canonical Ltd
 
 
3
# This program is free software; you can redistribute it and/or modify
 
 
4
# it under the terms of the GNU General Public License as published by
 
 
5
# the Free Software Foundation; either version 2 of the License, or
 
 
6
# (at your option) any later version.
 
 
8
# This program is distributed in the hope that it will be useful,
 
 
9
# but WITHOUT ANY WARRANTY; without even the implied warranty of
 
 
10
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
 
11
# GNU General Public License for more details.
 
 
13
# You should have received a copy of the GNU General Public License
 
 
14
# along with this program; if not, write to the Free Software
 
 
15
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
 
 
19
"""Text UI, write output to the console.
 
 
24
from bzrlib.lazy_import import lazy_import
 
 
25
lazy_import(globals(), """
 
 
34
from bzrlib.ui import CLIUIFactory
 
 
37
class TextUIFactory(CLIUIFactory):
 
 
38
    """A UI factory for Text user interefaces."""
 
 
44
        """Create a TextUIFactory.
 
 
46
        :param bar_type: The type of progress bar to create. It defaults to 
 
 
47
                         letting the bzrlib.progress.ProgressBar factory auto
 
 
50
        super(TextUIFactory, self).__init__()
 
 
51
        self._bar_type = bar_type
 
 
53
            self.stdout = sys.stdout
 
 
57
            self.stderr = sys.stderr
 
 
61
    def prompt(self, prompt):
 
 
62
        """Emit prompt on the CLI."""
 
 
63
        self.stdout.write(prompt)
 
 
65
    def nested_progress_bar(self):
 
 
66
        """Return a nested progress bar.
 
 
68
        The actual bar type returned depends on the progress module which
 
 
69
        may return a tty or dots bar depending on the terminal.
 
 
71
        if self._progress_bar_stack is None:
 
 
72
            self._progress_bar_stack = progress.ProgressBarStack(
 
 
74
        return self._progress_bar_stack.get_nested()
 
 
77
        """Prepare the terminal for output.
 
 
79
        This will, clear any progress bars, and leave the cursor at the
 
 
81
        if self._progress_bar_stack is None:
 
 
83
        overall_pb = self._progress_bar_stack.bottom()
 
 
84
        if overall_pb is not None: