Show More
@@ -31,8 +31,7 b' import sys' | |||
|
31 | 31 | |
|
32 | 32 | from IPython.utils import PyColorize |
|
33 | 33 | from IPython.core import ipapi |
|
34 | from IPython.utils import coloransi | |
|
35 | import IPython.utils.io | |
|
34 | from IPython.utils import coloransi, io | |
|
36 | 35 | from IPython.core.excolors import exception_colors |
|
37 | 36 | |
|
38 | 37 | # See if we can use pydb. |
@@ -171,7 +170,7 b' class Pdb(OldPdb):' | |||
|
171 | 170 | |
|
172 | 171 | # Parent constructor: |
|
173 | 172 | if has_pydb and completekey is None: |
|
174 |
OldPdb.__init__(self,stdin=stdin,stdout= |
|
|
173 | OldPdb.__init__(self,stdin=stdin,stdout=io.stdout) | |
|
175 | 174 | else: |
|
176 | 175 | OldPdb.__init__(self,completekey,stdin,stdout) |
|
177 | 176 | |
@@ -279,7 +278,7 b' class Pdb(OldPdb):' | |||
|
279 | 278 | def print_stack_entry(self,frame_lineno,prompt_prefix='\n-> ', |
|
280 | 279 | context = 3): |
|
281 | 280 | #frame, lineno = frame_lineno |
|
282 |
print >> |
|
|
281 | print >>io.stdout, self.format_stack_entry(frame_lineno, '', context) | |
|
283 | 282 | |
|
284 | 283 | # vds: >> |
|
285 | 284 | frame, lineno = frame_lineno |
@@ -419,7 +418,7 b' class Pdb(OldPdb):' | |||
|
419 | 418 | src.append(line) |
|
420 | 419 | self.lineno = lineno |
|
421 | 420 | |
|
422 |
print >> |
|
|
421 | print >>io.stdout, ''.join(src) | |
|
423 | 422 | |
|
424 | 423 | except KeyboardInterrupt: |
|
425 | 424 | pass |
@@ -26,8 +26,7 b' import __builtin__' | |||
|
26 | 26 | |
|
27 | 27 | from IPython.config.configurable import Configurable |
|
28 | 28 | from IPython.core import prompts |
|
29 | import IPython.utils.generics | |
|
30 | import IPython.utils.io | |
|
29 | from IPython.utils import io | |
|
31 | 30 | from IPython.utils.traitlets import Instance, List |
|
32 | 31 | from IPython.utils.warn import warn |
|
33 | 32 | |
@@ -178,13 +177,13 b' class DisplayHook(Configurable):' | |||
|
178 | 177 | """Write the output prompt. |
|
179 | 178 | |
|
180 | 179 | The default implementation simply writes the prompt to |
|
181 |
``io. |
|
|
180 | ``io.stdout``. | |
|
182 | 181 | """ |
|
183 | 182 | # Use write, not print which adds an extra space. |
|
184 |
|
|
|
183 | io.stdout.write(self.output_sep) | |
|
185 | 184 | outprompt = str(self.prompt_out) |
|
186 | 185 | if self.do_full_cache: |
|
187 |
|
|
|
186 | io.stdout.write(outprompt) | |
|
188 | 187 | |
|
189 | 188 | def compute_format_data(self, result): |
|
190 | 189 | """Compute format data of the object to be displayed. |
@@ -219,7 +218,7 b' class DisplayHook(Configurable):' | |||
|
219 | 218 | """Write the format data dict to the frontend. |
|
220 | 219 | |
|
221 | 220 | This default version of this method simply writes the plain text |
|
222 |
representation of the object to ``io. |
|
|
221 | representation of the object to ``io.stdout``. Subclasses should | |
|
223 | 222 | override this method to send the entire `format_dict` to the |
|
224 | 223 | frontends. |
|
225 | 224 | |
@@ -244,7 +243,7 b' class DisplayHook(Configurable):' | |||
|
244 | 243 | # But avoid extraneous empty lines. |
|
245 | 244 | result_repr = '\n' + result_repr |
|
246 | 245 | |
|
247 |
print >> |
|
|
246 | print >>io.stdout, result_repr | |
|
248 | 247 | |
|
249 | 248 | def update_user_ns(self, result): |
|
250 | 249 | """Update user_ns with various things like _, __, _1, etc.""" |
@@ -287,8 +286,8 b' class DisplayHook(Configurable):' | |||
|
287 | 286 | |
|
288 | 287 | def finish_displayhook(self): |
|
289 | 288 | """Finish up all displayhook activities.""" |
|
290 |
|
|
|
291 |
|
|
|
289 | io.stdout.write(self.output_sep2) | |
|
290 | io.stdout.flush() | |
|
292 | 291 | |
|
293 | 292 | def __call__(self, result=None): |
|
294 | 293 | """Printing with history cache management. |
@@ -98,9 +98,9 b' class DisplayPublisher(Configurable):' | |||
|
98 | 98 | the data. |
|
99 | 99 | """ |
|
100 | 100 | from IPython.utils import io |
|
101 |
# The default is to simply write the plain text data using io. |
|
|
101 | # The default is to simply write the plain text data using io.stdout. | |
|
102 | 102 | if data.has_key('text/plain'): |
|
103 |
print(data['text/plain'], file=io. |
|
|
103 | print(data['text/plain'], file=io.stdout) | |
|
104 | 104 | |
|
105 | 105 | |
|
106 | 106 | def publish_display_data(self, source, data, metadata=None): |
@@ -22,10 +22,9 b' import threading' | |||
|
22 | 22 | |
|
23 | 23 | # Our own packages |
|
24 | 24 | from IPython.config.configurable import Configurable |
|
25 | import IPython.utils.io | |
|
26 | 25 | |
|
27 | 26 | from IPython.testing import decorators as testdec |
|
28 |
from IPython.utils |
|
|
27 | from IPython.utils import io | |
|
29 | 28 | from IPython.utils.traitlets import Bool, Dict, Instance, Int, List, Unicode |
|
30 | 29 | from IPython.utils.warn import warn |
|
31 | 30 | |
@@ -630,12 +629,12 b" def magic_history(self, parameter_s = ''):" | |||
|
630 | 629 | try: |
|
631 | 630 | outfname = opts['f'] |
|
632 | 631 | except KeyError: |
|
633 |
outfile = |
|
|
632 | outfile = io.stdout # default | |
|
634 | 633 | # We don't want to close stdout at the end! |
|
635 | 634 | close_at_end = False |
|
636 | 635 | else: |
|
637 | 636 | if os.path.exists(outfname): |
|
638 | if not ask_yes_no("File %r exists. Overwrite?" % outfname): | |
|
637 | if not io.ask_yes_no("File %r exists. Overwrite?" % outfname): | |
|
639 | 638 | print('Aborting.') |
|
640 | 639 | return |
|
641 | 640 |
@@ -45,7 +45,6 b' import os, bisect' | |||
|
45 | 45 | import sys |
|
46 | 46 | |
|
47 | 47 | from IPython.core.error import TryNext |
|
48 | import IPython.utils.io | |
|
49 | 48 | |
|
50 | 49 | # List here all the default hooks. For now it's just the editor functions |
|
51 | 50 | # but over time we'll move here all the public API for user-accessible things. |
@@ -511,14 +511,13 b' class InteractiveShell(Configurable, Magic):' | |||
|
511 | 511 | def init_io(self): |
|
512 | 512 | # This will just use sys.stdout and sys.stderr. If you want to |
|
513 | 513 | # override sys.stdout and sys.stderr themselves, you need to do that |
|
514 |
# *before* instantiating this class, because |
|
|
514 | # *before* instantiating this class, because io holds onto | |
|
515 | 515 | # references to the underlying streams. |
|
516 | 516 | if sys.platform == 'win32' and self.has_readline: |
|
517 |
|
|
|
518 | cerr=self.readline._outputfile) | |
|
517 | io.stdout = io.stderr = io.IOStream(self.readline._outputfile) | |
|
519 | 518 | else: |
|
520 |
|
|
|
521 | io.Term = Term | |
|
519 | io.stdout = io.IOStream(sys.stdout) | |
|
520 | io.stderr = io.IOStream(sys.stderr) | |
|
522 | 521 | |
|
523 | 522 | def init_prompts(self): |
|
524 | 523 | # TODO: This is a pass for now because the prompts are managed inside |
@@ -1477,7 +1476,7 b' class InteractiveShell(Configurable, Magic):' | |||
|
1477 | 1476 | Subclasses may override this method to put the traceback on a different |
|
1478 | 1477 | place, like a side channel. |
|
1479 | 1478 | """ |
|
1480 |
print >> io. |
|
|
1479 | print >> io.stdout, self.InteractiveTB.stb2text(stb) | |
|
1481 | 1480 | |
|
1482 | 1481 | def showsyntaxerror(self, filename=None): |
|
1483 | 1482 | """Display the syntax error that just occurred. |
@@ -1597,7 +1596,7 b' class InteractiveShell(Configurable, Magic):' | |||
|
1597 | 1596 | include_latest=True): |
|
1598 | 1597 | if cell.strip(): # Ignore blank lines |
|
1599 | 1598 | for line in cell.splitlines(): |
|
1600 | self.readline.add_history(line.encode(stdin_encoding)) | |
|
1599 | self.readline.add_history(line.encode(stdin_encoding, 'replace')) | |
|
1601 | 1600 | |
|
1602 | 1601 | def set_next_input(self, s): |
|
1603 | 1602 | """ Sets the 'default' input string for the next command line. |
@@ -1931,7 +1930,7 b' class InteractiveShell(Configurable, Magic):' | |||
|
1931 | 1930 | # plain ascii works better w/ pyreadline, on some machines, so |
|
1932 | 1931 | # we use it and only print uncolored rewrite if we have unicode |
|
1933 | 1932 | rw = str(rw) |
|
1934 |
print >> |
|
|
1933 | print >> io.stdout, rw | |
|
1935 | 1934 | except UnicodeEncodeError: |
|
1936 | 1935 | print "------> " + cmd |
|
1937 | 1936 | |
@@ -2325,12 +2324,12 b' class InteractiveShell(Configurable, Magic):' | |||
|
2325 | 2324 | # TODO: This should be removed when Term is refactored. |
|
2326 | 2325 | def write(self,data): |
|
2327 | 2326 | """Write a string to the default output""" |
|
2328 |
io. |
|
|
2327 | io.stdout.write(data) | |
|
2329 | 2328 | |
|
2330 | 2329 | # TODO: This should be removed when Term is refactored. |
|
2331 | 2330 | def write_err(self,data): |
|
2332 | 2331 | """Write a string to the default error output""" |
|
2333 |
io. |
|
|
2332 | io.stderr.write(data) | |
|
2334 | 2333 | |
|
2335 | 2334 | def ask_yes_no(self,prompt,default=True): |
|
2336 | 2335 | if self.quiet: |
@@ -10,8 +10,6 b'' | |||
|
10 | 10 | import re |
|
11 | 11 | import sys |
|
12 | 12 | |
|
13 | import IPython.utils.io | |
|
14 | ||
|
15 | 13 | coding_declaration = re.compile(r"#\s*coding[:=]\s*([-\w.]+)") |
|
16 | 14 | |
|
17 | 15 | class Macro(object): |
@@ -53,7 +53,6 b' from IPython.lib.pylabtools import mpl_runner' | |||
|
53 | 53 | from IPython.external.Itpl import itpl, printpl |
|
54 | 54 | from IPython.testing import decorators as testdec |
|
55 | 55 | from IPython.utils.io import file_read, nlprint |
|
56 | import IPython.utils.io | |
|
57 | 56 | from IPython.utils.path import get_py_filename |
|
58 | 57 | from IPython.utils.process import arg_split, abbrev_cwd |
|
59 | 58 | from IPython.utils.terminal import set_term_title |
@@ -31,7 +31,7 b' from itertools import izip_longest' | |||
|
31 | 31 | from IPython.core import page |
|
32 | 32 | from IPython.external.Itpl import itpl |
|
33 | 33 | from IPython.utils import PyColorize |
|
34 |
|
|
|
34 | from IPython.utils import io | |
|
35 | 35 | from IPython.utils.text import indent |
|
36 | 36 | from IPython.utils.wildcard import list_namespace |
|
37 | 37 | from IPython.utils.coloransi import * |
@@ -300,7 +300,7 b' class Inspector:' | |||
|
300 | 300 | if output is None: |
|
301 | 301 | self.noinfo('definition header',oname) |
|
302 | 302 | else: |
|
303 |
print >> |
|
|
303 | print >>io.stdout, header,self.format(output), | |
|
304 | 304 | |
|
305 | 305 | def pdoc(self,obj,oname='',formatter = None): |
|
306 | 306 | """Print the docstring for any object. |
@@ -36,7 +36,7 b' from IPython.core import ipapi' | |||
|
36 | 36 | from IPython.core.error import TryNext |
|
37 | 37 | from IPython.utils.cursesimport import use_curses |
|
38 | 38 | from IPython.utils.data import chop |
|
39 |
|
|
|
39 | from IPython.utils import io | |
|
40 | 40 | from IPython.utils.process import system |
|
41 | 41 | from IPython.utils.terminal import get_terminal_size |
|
42 | 42 | |
@@ -56,18 +56,18 b' def page_dumb(strng, start=0, screen_lines=25):' | |||
|
56 | 56 | out_ln = strng.splitlines()[start:] |
|
57 | 57 | screens = chop(out_ln,screen_lines-1) |
|
58 | 58 | if len(screens) == 1: |
|
59 |
print >> |
|
|
59 | print >>io.stdout, os.linesep.join(screens[0]) | |
|
60 | 60 | else: |
|
61 | 61 | last_escape = "" |
|
62 | 62 | for scr in screens[0:-1]: |
|
63 | 63 | hunk = os.linesep.join(scr) |
|
64 |
print >> |
|
|
64 | print >>io.stdout, last_escape + hunk | |
|
65 | 65 | if not page_more(): |
|
66 | 66 | return |
|
67 | 67 | esc_list = esc_re.findall(hunk) |
|
68 | 68 | if len(esc_list) > 0: |
|
69 | 69 | last_escape = esc_list[-1] |
|
70 |
print >> |
|
|
70 | print >>io.stdout, last_escape + os.linesep.join(screens[-1]) | |
|
71 | 71 | |
|
72 | 72 | |
|
73 | 73 | def page(strng, start=0, screen_lines=0, pager_cmd=None): |
@@ -176,7 +176,7 b' def page(strng, start=0, screen_lines=0, pager_cmd=None):' | |||
|
176 | 176 | #print 'numlines',numlines,'screenlines',screen_lines # dbg |
|
177 | 177 | if numlines <= screen_lines : |
|
178 | 178 | #print '*** normal print' # dbg |
|
179 |
print >> |
|
|
179 | print >>io.stdout, str_toprint | |
|
180 | 180 | else: |
|
181 | 181 | # Try to open pager and default to internal one if that fails. |
|
182 | 182 | # All failure modes are tagged as 'retval=1', to match the return |
@@ -282,13 +282,13 b" if os.name == 'nt' and os.environ.get('TERM','dumb') != 'emacs':" | |||
|
282 | 282 | |
|
283 | 283 | @return: True if need print more lines, False if quit |
|
284 | 284 | """ |
|
285 |
|
|
|
285 | io.stdout.write('---Return to continue, q to quit--- ') | |
|
286 | 286 | ans = msvcrt.getch() |
|
287 | 287 | if ans in ("q", "Q"): |
|
288 | 288 | result = False |
|
289 | 289 | else: |
|
290 | 290 | result = True |
|
291 |
|
|
|
291 | io.stdout.write("\b"*37 + " "*37 + "\b"*37) | |
|
292 | 292 | return result |
|
293 | 293 | else: |
|
294 | 294 | def page_more(): |
@@ -37,7 +37,6 b' from IPython.core.splitinput import split_user_input' | |||
|
37 | 37 | from IPython.core import page |
|
38 | 38 | |
|
39 | 39 | from IPython.utils.traitlets import List, Int, Any, Str, CBool, Bool, Instance |
|
40 | import IPython.utils.io | |
|
41 | 40 | from IPython.utils.text import make_quoted_expr |
|
42 | 41 | from IPython.utils.autoattr import auto_attr |
|
43 | 42 |
@@ -325,8 +325,8 b' class TBTools(object):' | |||
|
325 | 325 | |
|
326 | 326 | # Output stream to write to. Note that we store the original value in |
|
327 | 327 | # a private attribute and then make the public ostream a property, so |
|
328 |
# that we can delay accessing io. |
|
|
329 |
# things are written now, the |
|
|
328 | # that we can delay accessing io.stdout until runtime. The way | |
|
329 | # things are written now, the io.stdout object is dynamically managed | |
|
330 | 330 | # so a reference to it should NEVER be stored statically. This |
|
331 | 331 | # property approach confines this detail to a single location, and all |
|
332 | 332 | # subclasses can simply access self.ostream for writing. |
@@ -349,12 +349,12 b' class TBTools(object):' | |||
|
349 | 349 | Valid values are: |
|
350 | 350 | |
|
351 | 351 | - None: the default, which means that IPython will dynamically resolve |
|
352 |
to io. |
|
|
352 | to io.stdout. This ensures compatibility with most tools, including | |
|
353 | 353 | Windows (where plain stdout doesn't recognize ANSI escapes). |
|
354 | 354 | |
|
355 | 355 | - Any object with 'write' and 'flush' attributes. |
|
356 | 356 | """ |
|
357 |
return io. |
|
|
357 | return io.stdout if self._ostream is None else self._ostream | |
|
358 | 358 | |
|
359 | 359 | def _set_ostream(self, val): |
|
360 | 360 | assert val is None or (hasattr(val, 'write') and hasattr(val, 'flush')) |
@@ -405,16 +405,18 b' IPython will show long blocks of text from many sources using a builtin pager.' | |||
|
405 | 405 | You can control where this pager appears with the ``--paging`` command-line |
|
406 | 406 | flag: |
|
407 | 407 | |
|
408 |
- default: |
|
|
409 |
to get back to the terminal (similar to how a pager such |
|
|
410 | ``more`` works). | |
|
408 | - ``inside`` [default]: the pager is overlaid on top of the main terminal. You | |
|
409 | must quit the pager to get back to the terminal (similar to how a pager such | |
|
410 | as ``less`` or ``more`` works). | |
|
411 | 411 | |
|
412 |
- |
|
|
412 | - ``vsplit``: the console is made double-tall, and the pager appears on the | |
|
413 | 413 | bottom area when needed. You can view its contents while using the terminal. |
|
414 | 414 | |
|
415 |
- |
|
|
415 | - ``hsplit``: the console is made double-wide, and the pager appears on the | |
|
416 | 416 | right area when needed. You can view its contents while using the terminal. |
|
417 | 417 | |
|
418 | - ``none``: the console never pages output. | |
|
419 | ||
|
418 | 420 | If you use the vertical or horizontal paging modes, you can navigate between |
|
419 | 421 | terminal and pager as follows: |
|
420 | 422 | |
@@ -425,7 +427,6 b' terminal and pager as follows:' | |||
|
425 | 427 | In all cases, the ``q`` or ``Escape`` keys quit the pager (when used with the |
|
426 | 428 | focus on the pager area). |
|
427 | 429 | |
|
428 | ||
|
429 | 430 | Running subprocesses |
|
430 | 431 | ==================== |
|
431 | 432 |
@@ -435,7 +435,7 b' class FrontendWidget(HistoryConsoleWidget, BaseFrontendMixin):' | |||
|
435 | 435 | """ Attempts to execute file with 'path'. If 'hidden', no output is |
|
436 | 436 | shown. |
|
437 | 437 | """ |
|
438 |
self.execute('execfile( |
|
|
438 | self.execute('execfile(%r)' % path, hidden=hidden) | |
|
439 | 439 | |
|
440 | 440 | def interrupt_kernel(self): |
|
441 | 441 | """ Attempts to interrupt the running kernel. |
@@ -8,8 +8,10 b'' | |||
|
8 | 8 | |
|
9 | 9 | # Standard library imports |
|
10 | 10 | from collections import namedtuple |
|
11 | import os.path | |
|
11 | 12 | import re |
|
12 | 13 | from subprocess import Popen |
|
14 | import sys | |
|
13 | 15 | from textwrap import dedent |
|
14 | 16 | |
|
15 | 17 | # System library imports |
@@ -233,6 +235,10 b' class IPythonWidget(FrontendWidget):' | |||
|
233 | 235 | def execute_file(self, path, hidden=False): |
|
234 | 236 | """ Reimplemented to use the 'run' magic. |
|
235 | 237 | """ |
|
238 | # Use forward slashes on Windows to avoid escaping each separator. | |
|
239 | if sys.platform == 'win32': | |
|
240 | path = os.path.normpath(path).replace('\\', '/') | |
|
241 | ||
|
236 | 242 | self.execute('%%run %s' % path, hidden=hidden) |
|
237 | 243 | |
|
238 | 244 | #--------------------------------------------------------------------------- |
@@ -176,8 +176,8 b' import shlex' | |||
|
176 | 176 | import sys |
|
177 | 177 | |
|
178 | 178 | from IPython.utils.PyColorize import Parser |
|
179 | from IPython.utils import io | |
|
179 | 180 | from IPython.utils.io import file_read, file_readlines |
|
180 | import IPython.utils.io | |
|
181 | 181 | from IPython.utils.text import marquee |
|
182 | 182 | |
|
183 | 183 | __all__ = ['Demo','IPythonDemo','LineDemo','IPythonLineDemo','DemoError'] |
@@ -319,7 +319,7 b' class Demo(object):' | |||
|
319 | 319 | |
|
320 | 320 | if index is None: |
|
321 | 321 | if self.finished: |
|
322 |
print >> |
|
|
322 | print >>io.stdout, 'Demo finished. Use <demo_name>.reset() if you want to rerun it.' | |
|
323 | 323 | return None |
|
324 | 324 | index = self.block_index |
|
325 | 325 | else: |
@@ -388,9 +388,9 b' class Demo(object):' | |||
|
388 | 388 | if index is None: |
|
389 | 389 | return |
|
390 | 390 | |
|
391 |
print >> |
|
|
391 | print >>io.stdout, self.marquee('<%s> block # %s (%s remaining)' % | |
|
392 | 392 | (self.title,index,self.nblocks-index-1)) |
|
393 |
print >> |
|
|
393 | print >>io.stdout,(self.src_blocks_colored[index]) | |
|
394 | 394 | sys.stdout.flush() |
|
395 | 395 | |
|
396 | 396 | def show_all(self): |
@@ -403,12 +403,12 b' class Demo(object):' | |||
|
403 | 403 | marquee = self.marquee |
|
404 | 404 | for index,block in enumerate(self.src_blocks_colored): |
|
405 | 405 | if silent[index]: |
|
406 |
print >> |
|
|
406 | print >>io.stdout, marquee('<%s> SILENT block # %s (%s remaining)' % | |
|
407 | 407 | (title,index,nblocks-index-1)) |
|
408 | 408 | else: |
|
409 |
print >> |
|
|
409 | print >>io.stdout, marquee('<%s> block # %s (%s remaining)' % | |
|
410 | 410 | (title,index,nblocks-index-1)) |
|
411 |
print >> |
|
|
411 | print >>io.stdout, block, | |
|
412 | 412 | sys.stdout.flush() |
|
413 | 413 | |
|
414 | 414 | def run_cell(self,source): |
@@ -433,18 +433,18 b' class Demo(object):' | |||
|
433 | 433 | next_block = self.src_blocks[index] |
|
434 | 434 | self.block_index += 1 |
|
435 | 435 | if self._silent[index]: |
|
436 |
print >> |
|
|
436 | print >>io.stdout, marquee('Executing silent block # %s (%s remaining)' % | |
|
437 | 437 | (index,self.nblocks-index-1)) |
|
438 | 438 | else: |
|
439 | 439 | self.pre_cmd() |
|
440 | 440 | self.show(index) |
|
441 | 441 | if self.auto_all or self._auto[index]: |
|
442 |
print >> |
|
|
442 | print >>io.stdout, marquee('output:') | |
|
443 | 443 | else: |
|
444 |
print >> |
|
|
444 | print >>io.stdout, marquee('Press <q> to quit, <Enter> to execute...'), | |
|
445 | 445 | ans = raw_input().strip() |
|
446 | 446 | if ans: |
|
447 |
print >> |
|
|
447 | print >>io.stdout, marquee('Block NOT executed') | |
|
448 | 448 | return |
|
449 | 449 | try: |
|
450 | 450 | save_argv = sys.argv |
@@ -462,10 +462,10 b' class Demo(object):' | |||
|
462 | 462 | if self.block_index == self.nblocks: |
|
463 | 463 | mq1 = self.marquee('END OF DEMO') |
|
464 | 464 | if mq1: |
|
465 |
# avoid spurious print >> |
|
|
466 |
print >> |
|
|
467 |
print >> |
|
|
468 |
print >> |
|
|
465 | # avoid spurious print >>io.stdout,s if empty marquees are used | |
|
466 | print >>io.stdout | |
|
467 | print >>io.stdout, mq1 | |
|
468 | print >>io.stdout, self.marquee('Use <demo_name>.reset() if you want to rerun it.') | |
|
469 | 469 | self.finished = True |
|
470 | 470 | |
|
471 | 471 | # These methods are meant to be overridden by subclasses who may wish to |
@@ -28,12 +28,33 b' from types import MethodType' | |||
|
28 | 28 | # our own |
|
29 | 29 | from . import tools |
|
30 | 30 | |
|
31 | from IPython.utils import io | |
|
31 | 32 | from IPython.frontend.terminal.interactiveshell import TerminalInteractiveShell |
|
32 | 33 | |
|
33 | 34 | #----------------------------------------------------------------------------- |
|
34 | 35 | # Functions |
|
35 | 36 | #----------------------------------------------------------------------------- |
|
36 | 37 | |
|
38 | class StreamProxy(io.IOStream): | |
|
39 | """Proxy for sys.stdout/err. This will request the stream *at call time* | |
|
40 | allowing for nose's Capture plugin's redirection of sys.stdout/err. | |
|
41 | ||
|
42 | Parameters | |
|
43 | ---------- | |
|
44 | name : str | |
|
45 | The name of the stream. This will be requested anew at every call | |
|
46 | """ | |
|
47 | ||
|
48 | def __init__(self, name): | |
|
49 | self.name=name | |
|
50 | ||
|
51 | @property | |
|
52 | def stream(self): | |
|
53 | return getattr(sys, self.name) | |
|
54 | ||
|
55 | def flush(self): | |
|
56 | self.stream.flush() | |
|
57 | ||
|
37 | 58 | # Hack to modify the %run command so we can sync the user's namespace with the |
|
38 | 59 | # test globals. Once we move over to a clean magic system, this will be done |
|
39 | 60 | # with much less ugliness. |
@@ -191,5 +212,9 b' def start_ipython():' | |||
|
191 | 212 | get_ipython = _ip.get_ipython |
|
192 | 213 | __builtin__._ip = _ip |
|
193 | 214 | __builtin__.get_ipython = get_ipython |
|
215 | ||
|
216 | # To avoid extra IPython messages during testing, suppress io.stdout/stderr | |
|
217 | io.stdout = StreamProxy('stdout') | |
|
218 | io.stderr = StreamProxy('stderr') | |
|
194 | 219 | |
|
195 | 220 | return _ip |
@@ -26,13 +26,21 b' from IPython.external.Itpl import itpl, printpl' | |||
|
26 | 26 | |
|
27 | 27 | class IOStream: |
|
28 | 28 | |
|
29 | def __init__(self,stream,fallback): | |
|
29 | def __init__(self,stream, fallback=None): | |
|
30 | 30 | if not hasattr(stream,'write') or not hasattr(stream,'flush'): |
|
31 |
|
|
|
31 | if fallback is not None: | |
|
32 | stream = fallback | |
|
33 | else: | |
|
34 | raise ValueError("fallback required, but not specified") | |
|
32 | 35 | self.stream = stream |
|
33 | 36 | self._swrite = stream.write |
|
34 | self.flush = stream.flush | |
|
35 | ||
|
37 | ||
|
38 | # clone all methods not overridden: | |
|
39 | def clone(meth): | |
|
40 | return not hasattr(self, meth) and not meth.startswith('_') | |
|
41 | for meth in filter(clone, dir(stream)): | |
|
42 | setattr(self, meth, getattr(stream, meth)) | |
|
43 | ||
|
36 | 44 | def write(self,data): |
|
37 | 45 | try: |
|
38 | 46 | self._swrite(data) |
@@ -46,11 +54,21 b' class IOStream:' | |||
|
46 | 54 | # if we get here, something is seriously broken. |
|
47 | 55 | print('ERROR - failed to write data to stream:', self.stream, |
|
48 | 56 | file=sys.stderr) |
|
57 | ||
|
58 | def writelines(self, lines): | |
|
59 | if isinstance(lines, basestring): | |
|
60 | lines = [lines] | |
|
61 | for line in lines: | |
|
62 | self.write(line) | |
|
49 | 63 | |
|
50 | 64 | # This class used to have a writeln method, but regular files and streams |
|
51 | 65 | # in Python don't have this method. We need to keep this completely |
|
52 | 66 | # compatible so we removed it. |
|
53 | 67 | |
|
68 | @property | |
|
69 | def closed(self): | |
|
70 | return self.stream.closed | |
|
71 | ||
|
54 | 72 | def close(self): |
|
55 | 73 | pass |
|
56 | 74 | |
@@ -65,10 +83,15 b' class IOTerm:' | |||
|
65 | 83 | # In the future, having IPython channel all its I/O operations through |
|
66 | 84 | # this class will make it easier to embed it into other environments which |
|
67 | 85 | # are not a normal terminal (such as a GUI-based shell) |
|
68 |
def __init__(self, |
|
|
69 |
self. |
|
|
70 |
self. |
|
|
71 |
self. |
|
|
86 | def __init__(self, stdin=None, stdout=None, stderr=None): | |
|
87 | self.stdin = IOStream(stdin, sys.stdin) | |
|
88 | self.stdout = IOStream(stdout, sys.stdout) | |
|
89 | self.stderr = IOStream(stderr, sys.stderr) | |
|
90 | ||
|
91 | # setup stdin/stdout/stderr to sys.stdin/sys.stdout/sys.stderr | |
|
92 | stdin = IOStream(sys.stdin) | |
|
93 | stdout = IOStream(sys.stdout) | |
|
94 | stderr = IOStream(sys.stderr) | |
|
72 | 95 | |
|
73 | 96 | |
|
74 | 97 | class Tee(object): |
@@ -15,6 +15,7 b'' | |||
|
15 | 15 | import sys |
|
16 | 16 | |
|
17 | 17 | from cStringIO import StringIO |
|
18 | from subprocess import Popen, PIPE | |
|
18 | 19 | |
|
19 | 20 | import nose.tools as nt |
|
20 | 21 | |
@@ -59,3 +60,12 b' class TeeTestCase(dec.ParametricTestCase):' | |||
|
59 | 60 | for chan in ['stdout', 'stderr']: |
|
60 | 61 | for check in ['close', 'del']: |
|
61 | 62 | yield self.tchan(chan, check) |
|
63 | ||
|
64 | def test_io_init(): | |
|
65 | """Test that io.stdin/out/err exist at startup""" | |
|
66 | for name in ('stdin', 'stdout', 'stderr'): | |
|
67 | p = Popen([sys.executable, '-c', "from IPython.utils import io;print io.%s.__class__"%name], | |
|
68 | stdout=PIPE) | |
|
69 | p.wait() | |
|
70 | classname = p.stdout.read().strip() | |
|
71 | nt.assert_equals(classname, 'IPython.utils.io.IOStream') |
@@ -16,7 +16,7 b" Utilities for warnings. Shoudn't we just use the built in warnings module." | |||
|
16 | 16 | |
|
17 | 17 | import sys |
|
18 | 18 | |
|
19 |
|
|
|
19 | from IPython.utils import io | |
|
20 | 20 | |
|
21 | 21 | #----------------------------------------------------------------------------- |
|
22 | 22 | # Code |
@@ -25,7 +25,7 b' import IPython.utils.io' | |||
|
25 | 25 | def warn(msg,level=2,exit_val=1): |
|
26 | 26 | """Standard warning printer. Gives formatting consistency. |
|
27 | 27 | |
|
28 |
Output is sent to |
|
|
28 | Output is sent to io.stderr (sys.stderr by default). | |
|
29 | 29 | |
|
30 | 30 | Options: |
|
31 | 31 | |
@@ -41,9 +41,9 b' def warn(msg,level=2,exit_val=1):' | |||
|
41 | 41 | |
|
42 | 42 | if level>0: |
|
43 | 43 | header = ['','','WARNING: ','ERROR: ','FATAL ERROR: '] |
|
44 |
print >> |
|
|
44 | print >> io.stderr, '%s%s' % (header[level],msg) | |
|
45 | 45 | if level == 4: |
|
46 |
print >> |
|
|
46 | print >> io.stderr,'Exiting.\n' | |
|
47 | 47 | sys.exit(exit_val) |
|
48 | 48 | |
|
49 | 49 |
@@ -481,6 +481,8 b' Message type: ``object_info_reply``::' | |||
|
481 | 481 | # can also be a string like 'Magic function' or 'System alias' |
|
482 | 482 | 'type_name' : str, |
|
483 | 483 | |
|
484 | # The string form of the object, possibly truncated for length if | |
|
485 | # detail_level is 0 | |
|
484 | 486 | 'string_form' : str, |
|
485 | 487 | |
|
486 | 488 | # For objects with a __class__ attribute this will be set |
General Comments 0
You need to be logged in to leave comments.
Login now