##// END OF EJS Templates
allow %edit ClassName if the class was created by '%edit' (look for the source file from method objs instead of class obj). Closes #132
vivainio -
Show More
@@ -1,3272 +1,3286 b''
1 # -*- coding: utf-8 -*-
1 # -*- coding: utf-8 -*-
2 """Magic functions for InteractiveShell.
2 """Magic functions for InteractiveShell.
3
3
4 $Id: Magic.py 2899 2007-12-28 08:32:59Z fperez $"""
4 $Id: Magic.py 2917 2007-12-31 14:11:34Z vivainio $"""
5
5
6 #*****************************************************************************
6 #*****************************************************************************
7 # Copyright (C) 2001 Janko Hauser <jhauser@zscout.de> and
7 # Copyright (C) 2001 Janko Hauser <jhauser@zscout.de> and
8 # Copyright (C) 2001-2006 Fernando Perez <fperez@colorado.edu>
8 # Copyright (C) 2001-2006 Fernando Perez <fperez@colorado.edu>
9 #
9 #
10 # Distributed under the terms of the BSD License. The full license is in
10 # Distributed under the terms of the BSD License. The full license is in
11 # the file COPYING, distributed as part of this software.
11 # the file COPYING, distributed as part of this software.
12 #*****************************************************************************
12 #*****************************************************************************
13
13
14 #****************************************************************************
14 #****************************************************************************
15 # Modules and globals
15 # Modules and globals
16
16
17 from IPython import Release
17 from IPython import Release
18 __author__ = '%s <%s>\n%s <%s>' % \
18 __author__ = '%s <%s>\n%s <%s>' % \
19 ( Release.authors['Janko'] + Release.authors['Fernando'] )
19 ( Release.authors['Janko'] + Release.authors['Fernando'] )
20 __license__ = Release.license
20 __license__ = Release.license
21
21
22 # Python standard modules
22 # Python standard modules
23 import __builtin__
23 import __builtin__
24 import bdb
24 import bdb
25 import inspect
25 import inspect
26 import os
26 import os
27 import pdb
27 import pdb
28 import pydoc
28 import pydoc
29 import sys
29 import sys
30 import re
30 import re
31 import tempfile
31 import tempfile
32 import time
32 import time
33 import cPickle as pickle
33 import cPickle as pickle
34 import textwrap
34 import textwrap
35 from cStringIO import StringIO
35 from cStringIO import StringIO
36 from getopt import getopt,GetoptError
36 from getopt import getopt,GetoptError
37 from pprint import pprint, pformat
37 from pprint import pprint, pformat
38 from sets import Set
38 from sets import Set
39
39
40 # cProfile was added in Python2.5
40 # cProfile was added in Python2.5
41 try:
41 try:
42 import cProfile as profile
42 import cProfile as profile
43 import pstats
43 import pstats
44 except ImportError:
44 except ImportError:
45 # profile isn't bundled by default in Debian for license reasons
45 # profile isn't bundled by default in Debian for license reasons
46 try:
46 try:
47 import profile,pstats
47 import profile,pstats
48 except ImportError:
48 except ImportError:
49 profile = pstats = None
49 profile = pstats = None
50
50
51 # Homebrewed
51 # Homebrewed
52 import IPython
52 import IPython
53 from IPython import Debugger, OInspect, wildcard
53 from IPython import Debugger, OInspect, wildcard
54 from IPython.FakeModule import FakeModule
54 from IPython.FakeModule import FakeModule
55 from IPython.Itpl import Itpl, itpl, printpl,itplns
55 from IPython.Itpl import Itpl, itpl, printpl,itplns
56 from IPython.PyColorize import Parser
56 from IPython.PyColorize import Parser
57 from IPython.ipstruct import Struct
57 from IPython.ipstruct import Struct
58 from IPython.macro import Macro
58 from IPython.macro import Macro
59 from IPython.genutils import *
59 from IPython.genutils import *
60 from IPython import platutils
60 from IPython import platutils
61 import IPython.generics
61 import IPython.generics
62 import IPython.ipapi
62 import IPython.ipapi
63 from IPython.ipapi import UsageError
63 from IPython.ipapi import UsageError
64 #***************************************************************************
64 #***************************************************************************
65 # Utility functions
65 # Utility functions
66 def on_off(tag):
66 def on_off(tag):
67 """Return an ON/OFF string for a 1/0 input. Simple utility function."""
67 """Return an ON/OFF string for a 1/0 input. Simple utility function."""
68 return ['OFF','ON'][tag]
68 return ['OFF','ON'][tag]
69
69
70 class Bunch: pass
70 class Bunch: pass
71
71
72 def compress_dhist(dh):
72 def compress_dhist(dh):
73 head, tail = dh[:-10], dh[-10:]
73 head, tail = dh[:-10], dh[-10:]
74
74
75 newhead = []
75 newhead = []
76 done = Set()
76 done = Set()
77 for h in head:
77 for h in head:
78 if h in done:
78 if h in done:
79 continue
79 continue
80 newhead.append(h)
80 newhead.append(h)
81 done.add(h)
81 done.add(h)
82
82
83 return newhead + tail
83 return newhead + tail
84
84
85
85
86 #***************************************************************************
86 #***************************************************************************
87 # Main class implementing Magic functionality
87 # Main class implementing Magic functionality
88 class Magic:
88 class Magic:
89 """Magic functions for InteractiveShell.
89 """Magic functions for InteractiveShell.
90
90
91 Shell functions which can be reached as %function_name. All magic
91 Shell functions which can be reached as %function_name. All magic
92 functions should accept a string, which they can parse for their own
92 functions should accept a string, which they can parse for their own
93 needs. This can make some functions easier to type, eg `%cd ../`
93 needs. This can make some functions easier to type, eg `%cd ../`
94 vs. `%cd("../")`
94 vs. `%cd("../")`
95
95
96 ALL definitions MUST begin with the prefix magic_. The user won't need it
96 ALL definitions MUST begin with the prefix magic_. The user won't need it
97 at the command line, but it is is needed in the definition. """
97 at the command line, but it is is needed in the definition. """
98
98
99 # class globals
99 # class globals
100 auto_status = ['Automagic is OFF, % prefix IS needed for magic functions.',
100 auto_status = ['Automagic is OFF, % prefix IS needed for magic functions.',
101 'Automagic is ON, % prefix NOT needed for magic functions.']
101 'Automagic is ON, % prefix NOT needed for magic functions.']
102
102
103 #......................................................................
103 #......................................................................
104 # some utility functions
104 # some utility functions
105
105
106 def __init__(self,shell):
106 def __init__(self,shell):
107
107
108 self.options_table = {}
108 self.options_table = {}
109 if profile is None:
109 if profile is None:
110 self.magic_prun = self.profile_missing_notice
110 self.magic_prun = self.profile_missing_notice
111 self.shell = shell
111 self.shell = shell
112
112
113 # namespace for holding state we may need
113 # namespace for holding state we may need
114 self._magic_state = Bunch()
114 self._magic_state = Bunch()
115
115
116 def profile_missing_notice(self, *args, **kwargs):
116 def profile_missing_notice(self, *args, **kwargs):
117 error("""\
117 error("""\
118 The profile module could not be found. If you are a Debian user,
118 The profile module could not be found. If you are a Debian user,
119 it has been removed from the standard Debian package because of its non-free
119 it has been removed from the standard Debian package because of its non-free
120 license. To use profiling, please install"python2.3-profiler" from non-free.""")
120 license. To use profiling, please install"python2.3-profiler" from non-free.""")
121
121
122 def default_option(self,fn,optstr):
122 def default_option(self,fn,optstr):
123 """Make an entry in the options_table for fn, with value optstr"""
123 """Make an entry in the options_table for fn, with value optstr"""
124
124
125 if fn not in self.lsmagic():
125 if fn not in self.lsmagic():
126 error("%s is not a magic function" % fn)
126 error("%s is not a magic function" % fn)
127 self.options_table[fn] = optstr
127 self.options_table[fn] = optstr
128
128
129 def lsmagic(self):
129 def lsmagic(self):
130 """Return a list of currently available magic functions.
130 """Return a list of currently available magic functions.
131
131
132 Gives a list of the bare names after mangling (['ls','cd', ...], not
132 Gives a list of the bare names after mangling (['ls','cd', ...], not
133 ['magic_ls','magic_cd',...]"""
133 ['magic_ls','magic_cd',...]"""
134
134
135 # FIXME. This needs a cleanup, in the way the magics list is built.
135 # FIXME. This needs a cleanup, in the way the magics list is built.
136
136
137 # magics in class definition
137 # magics in class definition
138 class_magic = lambda fn: fn.startswith('magic_') and \
138 class_magic = lambda fn: fn.startswith('magic_') and \
139 callable(Magic.__dict__[fn])
139 callable(Magic.__dict__[fn])
140 # in instance namespace (run-time user additions)
140 # in instance namespace (run-time user additions)
141 inst_magic = lambda fn: fn.startswith('magic_') and \
141 inst_magic = lambda fn: fn.startswith('magic_') and \
142 callable(self.__dict__[fn])
142 callable(self.__dict__[fn])
143 # and bound magics by user (so they can access self):
143 # and bound magics by user (so they can access self):
144 inst_bound_magic = lambda fn: fn.startswith('magic_') and \
144 inst_bound_magic = lambda fn: fn.startswith('magic_') and \
145 callable(self.__class__.__dict__[fn])
145 callable(self.__class__.__dict__[fn])
146 magics = filter(class_magic,Magic.__dict__.keys()) + \
146 magics = filter(class_magic,Magic.__dict__.keys()) + \
147 filter(inst_magic,self.__dict__.keys()) + \
147 filter(inst_magic,self.__dict__.keys()) + \
148 filter(inst_bound_magic,self.__class__.__dict__.keys())
148 filter(inst_bound_magic,self.__class__.__dict__.keys())
149 out = []
149 out = []
150 for fn in magics:
150 for fn in magics:
151 out.append(fn.replace('magic_','',1))
151 out.append(fn.replace('magic_','',1))
152 out.sort()
152 out.sort()
153 return out
153 return out
154
154
155 def extract_input_slices(self,slices,raw=False):
155 def extract_input_slices(self,slices,raw=False):
156 """Return as a string a set of input history slices.
156 """Return as a string a set of input history slices.
157
157
158 Inputs:
158 Inputs:
159
159
160 - slices: the set of slices is given as a list of strings (like
160 - slices: the set of slices is given as a list of strings (like
161 ['1','4:8','9'], since this function is for use by magic functions
161 ['1','4:8','9'], since this function is for use by magic functions
162 which get their arguments as strings.
162 which get their arguments as strings.
163
163
164 Optional inputs:
164 Optional inputs:
165
165
166 - raw(False): by default, the processed input is used. If this is
166 - raw(False): by default, the processed input is used. If this is
167 true, the raw input history is used instead.
167 true, the raw input history is used instead.
168
168
169 Note that slices can be called with two notations:
169 Note that slices can be called with two notations:
170
170
171 N:M -> standard python form, means including items N...(M-1).
171 N:M -> standard python form, means including items N...(M-1).
172
172
173 N-M -> include items N..M (closed endpoint)."""
173 N-M -> include items N..M (closed endpoint)."""
174
174
175 if raw:
175 if raw:
176 hist = self.shell.input_hist_raw
176 hist = self.shell.input_hist_raw
177 else:
177 else:
178 hist = self.shell.input_hist
178 hist = self.shell.input_hist
179
179
180 cmds = []
180 cmds = []
181 for chunk in slices:
181 for chunk in slices:
182 if ':' in chunk:
182 if ':' in chunk:
183 ini,fin = map(int,chunk.split(':'))
183 ini,fin = map(int,chunk.split(':'))
184 elif '-' in chunk:
184 elif '-' in chunk:
185 ini,fin = map(int,chunk.split('-'))
185 ini,fin = map(int,chunk.split('-'))
186 fin += 1
186 fin += 1
187 else:
187 else:
188 ini = int(chunk)
188 ini = int(chunk)
189 fin = ini+1
189 fin = ini+1
190 cmds.append(hist[ini:fin])
190 cmds.append(hist[ini:fin])
191 return cmds
191 return cmds
192
192
193 def _ofind(self, oname, namespaces=None):
193 def _ofind(self, oname, namespaces=None):
194 """Find an object in the available namespaces.
194 """Find an object in the available namespaces.
195
195
196 self._ofind(oname) -> dict with keys: found,obj,ospace,ismagic
196 self._ofind(oname) -> dict with keys: found,obj,ospace,ismagic
197
197
198 Has special code to detect magic functions.
198 Has special code to detect magic functions.
199 """
199 """
200
200
201 oname = oname.strip()
201 oname = oname.strip()
202
202
203 alias_ns = None
203 alias_ns = None
204 if namespaces is None:
204 if namespaces is None:
205 # Namespaces to search in:
205 # Namespaces to search in:
206 # Put them in a list. The order is important so that we
206 # Put them in a list. The order is important so that we
207 # find things in the same order that Python finds them.
207 # find things in the same order that Python finds them.
208 namespaces = [ ('Interactive', self.shell.user_ns),
208 namespaces = [ ('Interactive', self.shell.user_ns),
209 ('IPython internal', self.shell.internal_ns),
209 ('IPython internal', self.shell.internal_ns),
210 ('Python builtin', __builtin__.__dict__),
210 ('Python builtin', __builtin__.__dict__),
211 ('Alias', self.shell.alias_table),
211 ('Alias', self.shell.alias_table),
212 ]
212 ]
213 alias_ns = self.shell.alias_table
213 alias_ns = self.shell.alias_table
214
214
215 # initialize results to 'null'
215 # initialize results to 'null'
216 found = 0; obj = None; ospace = None; ds = None;
216 found = 0; obj = None; ospace = None; ds = None;
217 ismagic = 0; isalias = 0; parent = None
217 ismagic = 0; isalias = 0; parent = None
218
218
219 # Look for the given name by splitting it in parts. If the head is
219 # Look for the given name by splitting it in parts. If the head is
220 # found, then we look for all the remaining parts as members, and only
220 # found, then we look for all the remaining parts as members, and only
221 # declare success if we can find them all.
221 # declare success if we can find them all.
222 oname_parts = oname.split('.')
222 oname_parts = oname.split('.')
223 oname_head, oname_rest = oname_parts[0],oname_parts[1:]
223 oname_head, oname_rest = oname_parts[0],oname_parts[1:]
224 for nsname,ns in namespaces:
224 for nsname,ns in namespaces:
225 try:
225 try:
226 obj = ns[oname_head]
226 obj = ns[oname_head]
227 except KeyError:
227 except KeyError:
228 continue
228 continue
229 else:
229 else:
230 #print 'oname_rest:', oname_rest # dbg
230 #print 'oname_rest:', oname_rest # dbg
231 for part in oname_rest:
231 for part in oname_rest:
232 try:
232 try:
233 parent = obj
233 parent = obj
234 obj = getattr(obj,part)
234 obj = getattr(obj,part)
235 except:
235 except:
236 # Blanket except b/c some badly implemented objects
236 # Blanket except b/c some badly implemented objects
237 # allow __getattr__ to raise exceptions other than
237 # allow __getattr__ to raise exceptions other than
238 # AttributeError, which then crashes IPython.
238 # AttributeError, which then crashes IPython.
239 break
239 break
240 else:
240 else:
241 # If we finish the for loop (no break), we got all members
241 # If we finish the for loop (no break), we got all members
242 found = 1
242 found = 1
243 ospace = nsname
243 ospace = nsname
244 if ns == alias_ns:
244 if ns == alias_ns:
245 isalias = 1
245 isalias = 1
246 break # namespace loop
246 break # namespace loop
247
247
248 # Try to see if it's magic
248 # Try to see if it's magic
249 if not found:
249 if not found:
250 if oname.startswith(self.shell.ESC_MAGIC):
250 if oname.startswith(self.shell.ESC_MAGIC):
251 oname = oname[1:]
251 oname = oname[1:]
252 obj = getattr(self,'magic_'+oname,None)
252 obj = getattr(self,'magic_'+oname,None)
253 if obj is not None:
253 if obj is not None:
254 found = 1
254 found = 1
255 ospace = 'IPython internal'
255 ospace = 'IPython internal'
256 ismagic = 1
256 ismagic = 1
257
257
258 # Last try: special-case some literals like '', [], {}, etc:
258 # Last try: special-case some literals like '', [], {}, etc:
259 if not found and oname_head in ["''",'""','[]','{}','()']:
259 if not found and oname_head in ["''",'""','[]','{}','()']:
260 obj = eval(oname_head)
260 obj = eval(oname_head)
261 found = 1
261 found = 1
262 ospace = 'Interactive'
262 ospace = 'Interactive'
263
263
264 return {'found':found, 'obj':obj, 'namespace':ospace,
264 return {'found':found, 'obj':obj, 'namespace':ospace,
265 'ismagic':ismagic, 'isalias':isalias, 'parent':parent}
265 'ismagic':ismagic, 'isalias':isalias, 'parent':parent}
266
266
267 def arg_err(self,func):
267 def arg_err(self,func):
268 """Print docstring if incorrect arguments were passed"""
268 """Print docstring if incorrect arguments were passed"""
269 print 'Error in arguments:'
269 print 'Error in arguments:'
270 print OInspect.getdoc(func)
270 print OInspect.getdoc(func)
271
271
272 def format_latex(self,strng):
272 def format_latex(self,strng):
273 """Format a string for latex inclusion."""
273 """Format a string for latex inclusion."""
274
274
275 # Characters that need to be escaped for latex:
275 # Characters that need to be escaped for latex:
276 escape_re = re.compile(r'(%|_|\$|#|&)',re.MULTILINE)
276 escape_re = re.compile(r'(%|_|\$|#|&)',re.MULTILINE)
277 # Magic command names as headers:
277 # Magic command names as headers:
278 cmd_name_re = re.compile(r'^(%s.*?):' % self.shell.ESC_MAGIC,
278 cmd_name_re = re.compile(r'^(%s.*?):' % self.shell.ESC_MAGIC,
279 re.MULTILINE)
279 re.MULTILINE)
280 # Magic commands
280 # Magic commands
281 cmd_re = re.compile(r'(?P<cmd>%s.+?\b)(?!\}\}:)' % self.shell.ESC_MAGIC,
281 cmd_re = re.compile(r'(?P<cmd>%s.+?\b)(?!\}\}:)' % self.shell.ESC_MAGIC,
282 re.MULTILINE)
282 re.MULTILINE)
283 # Paragraph continue
283 # Paragraph continue
284 par_re = re.compile(r'\\$',re.MULTILINE)
284 par_re = re.compile(r'\\$',re.MULTILINE)
285
285
286 # The "\n" symbol
286 # The "\n" symbol
287 newline_re = re.compile(r'\\n')
287 newline_re = re.compile(r'\\n')
288
288
289 # Now build the string for output:
289 # Now build the string for output:
290 #strng = cmd_name_re.sub(r'\n\\texttt{\\textsl{\\large \1}}:',strng)
290 #strng = cmd_name_re.sub(r'\n\\texttt{\\textsl{\\large \1}}:',strng)
291 strng = cmd_name_re.sub(r'\n\\bigskip\n\\texttt{\\textbf{ \1}}:',
291 strng = cmd_name_re.sub(r'\n\\bigskip\n\\texttt{\\textbf{ \1}}:',
292 strng)
292 strng)
293 strng = cmd_re.sub(r'\\texttt{\g<cmd>}',strng)
293 strng = cmd_re.sub(r'\\texttt{\g<cmd>}',strng)
294 strng = par_re.sub(r'\\\\',strng)
294 strng = par_re.sub(r'\\\\',strng)
295 strng = escape_re.sub(r'\\\1',strng)
295 strng = escape_re.sub(r'\\\1',strng)
296 strng = newline_re.sub(r'\\textbackslash{}n',strng)
296 strng = newline_re.sub(r'\\textbackslash{}n',strng)
297 return strng
297 return strng
298
298
299 def format_screen(self,strng):
299 def format_screen(self,strng):
300 """Format a string for screen printing.
300 """Format a string for screen printing.
301
301
302 This removes some latex-type format codes."""
302 This removes some latex-type format codes."""
303 # Paragraph continue
303 # Paragraph continue
304 par_re = re.compile(r'\\$',re.MULTILINE)
304 par_re = re.compile(r'\\$',re.MULTILINE)
305 strng = par_re.sub('',strng)
305 strng = par_re.sub('',strng)
306 return strng
306 return strng
307
307
308 def parse_options(self,arg_str,opt_str,*long_opts,**kw):
308 def parse_options(self,arg_str,opt_str,*long_opts,**kw):
309 """Parse options passed to an argument string.
309 """Parse options passed to an argument string.
310
310
311 The interface is similar to that of getopt(), but it returns back a
311 The interface is similar to that of getopt(), but it returns back a
312 Struct with the options as keys and the stripped argument string still
312 Struct with the options as keys and the stripped argument string still
313 as a string.
313 as a string.
314
314
315 arg_str is quoted as a true sys.argv vector by using shlex.split.
315 arg_str is quoted as a true sys.argv vector by using shlex.split.
316 This allows us to easily expand variables, glob files, quote
316 This allows us to easily expand variables, glob files, quote
317 arguments, etc.
317 arguments, etc.
318
318
319 Options:
319 Options:
320 -mode: default 'string'. If given as 'list', the argument string is
320 -mode: default 'string'. If given as 'list', the argument string is
321 returned as a list (split on whitespace) instead of a string.
321 returned as a list (split on whitespace) instead of a string.
322
322
323 -list_all: put all option values in lists. Normally only options
323 -list_all: put all option values in lists. Normally only options
324 appearing more than once are put in a list.
324 appearing more than once are put in a list.
325
325
326 -posix (True): whether to split the input line in POSIX mode or not,
326 -posix (True): whether to split the input line in POSIX mode or not,
327 as per the conventions outlined in the shlex module from the
327 as per the conventions outlined in the shlex module from the
328 standard library."""
328 standard library."""
329
329
330 # inject default options at the beginning of the input line
330 # inject default options at the beginning of the input line
331 caller = sys._getframe(1).f_code.co_name.replace('magic_','')
331 caller = sys._getframe(1).f_code.co_name.replace('magic_','')
332 arg_str = '%s %s' % (self.options_table.get(caller,''),arg_str)
332 arg_str = '%s %s' % (self.options_table.get(caller,''),arg_str)
333
333
334 mode = kw.get('mode','string')
334 mode = kw.get('mode','string')
335 if mode not in ['string','list']:
335 if mode not in ['string','list']:
336 raise ValueError,'incorrect mode given: %s' % mode
336 raise ValueError,'incorrect mode given: %s' % mode
337 # Get options
337 # Get options
338 list_all = kw.get('list_all',0)
338 list_all = kw.get('list_all',0)
339 posix = kw.get('posix',True)
339 posix = kw.get('posix',True)
340
340
341 # Check if we have more than one argument to warrant extra processing:
341 # Check if we have more than one argument to warrant extra processing:
342 odict = {} # Dictionary with options
342 odict = {} # Dictionary with options
343 args = arg_str.split()
343 args = arg_str.split()
344 if len(args) >= 1:
344 if len(args) >= 1:
345 # If the list of inputs only has 0 or 1 thing in it, there's no
345 # If the list of inputs only has 0 or 1 thing in it, there's no
346 # need to look for options
346 # need to look for options
347 argv = arg_split(arg_str,posix)
347 argv = arg_split(arg_str,posix)
348 # Do regular option processing
348 # Do regular option processing
349 try:
349 try:
350 opts,args = getopt(argv,opt_str,*long_opts)
350 opts,args = getopt(argv,opt_str,*long_opts)
351 except GetoptError,e:
351 except GetoptError,e:
352 raise UsageError('%s ( allowed: "%s" %s)' % (e.msg,opt_str,
352 raise UsageError('%s ( allowed: "%s" %s)' % (e.msg,opt_str,
353 " ".join(long_opts)))
353 " ".join(long_opts)))
354 for o,a in opts:
354 for o,a in opts:
355 if o.startswith('--'):
355 if o.startswith('--'):
356 o = o[2:]
356 o = o[2:]
357 else:
357 else:
358 o = o[1:]
358 o = o[1:]
359 try:
359 try:
360 odict[o].append(a)
360 odict[o].append(a)
361 except AttributeError:
361 except AttributeError:
362 odict[o] = [odict[o],a]
362 odict[o] = [odict[o],a]
363 except KeyError:
363 except KeyError:
364 if list_all:
364 if list_all:
365 odict[o] = [a]
365 odict[o] = [a]
366 else:
366 else:
367 odict[o] = a
367 odict[o] = a
368
368
369 # Prepare opts,args for return
369 # Prepare opts,args for return
370 opts = Struct(odict)
370 opts = Struct(odict)
371 if mode == 'string':
371 if mode == 'string':
372 args = ' '.join(args)
372 args = ' '.join(args)
373
373
374 return opts,args
374 return opts,args
375
375
376 #......................................................................
376 #......................................................................
377 # And now the actual magic functions
377 # And now the actual magic functions
378
378
379 # Functions for IPython shell work (vars,funcs, config, etc)
379 # Functions for IPython shell work (vars,funcs, config, etc)
380 def magic_lsmagic(self, parameter_s = ''):
380 def magic_lsmagic(self, parameter_s = ''):
381 """List currently available magic functions."""
381 """List currently available magic functions."""
382 mesc = self.shell.ESC_MAGIC
382 mesc = self.shell.ESC_MAGIC
383 print 'Available magic functions:\n'+mesc+\
383 print 'Available magic functions:\n'+mesc+\
384 (' '+mesc).join(self.lsmagic())
384 (' '+mesc).join(self.lsmagic())
385 print '\n' + Magic.auto_status[self.shell.rc.automagic]
385 print '\n' + Magic.auto_status[self.shell.rc.automagic]
386 return None
386 return None
387
387
388 def magic_magic(self, parameter_s = ''):
388 def magic_magic(self, parameter_s = ''):
389 """Print information about the magic function system."""
389 """Print information about the magic function system."""
390
390
391 mode = ''
391 mode = ''
392 try:
392 try:
393 if parameter_s.split()[0] == '-latex':
393 if parameter_s.split()[0] == '-latex':
394 mode = 'latex'
394 mode = 'latex'
395 if parameter_s.split()[0] == '-brief':
395 if parameter_s.split()[0] == '-brief':
396 mode = 'brief'
396 mode = 'brief'
397 except:
397 except:
398 pass
398 pass
399
399
400 magic_docs = []
400 magic_docs = []
401 for fname in self.lsmagic():
401 for fname in self.lsmagic():
402 mname = 'magic_' + fname
402 mname = 'magic_' + fname
403 for space in (Magic,self,self.__class__):
403 for space in (Magic,self,self.__class__):
404 try:
404 try:
405 fn = space.__dict__[mname]
405 fn = space.__dict__[mname]
406 except KeyError:
406 except KeyError:
407 pass
407 pass
408 else:
408 else:
409 break
409 break
410 if mode == 'brief':
410 if mode == 'brief':
411 # only first line
411 # only first line
412 fndoc = fn.__doc__.split('\n',1)[0]
412 fndoc = fn.__doc__.split('\n',1)[0]
413 else:
413 else:
414 fndoc = fn.__doc__
414 fndoc = fn.__doc__
415
415
416 magic_docs.append('%s%s:\n\t%s\n' %(self.shell.ESC_MAGIC,
416 magic_docs.append('%s%s:\n\t%s\n' %(self.shell.ESC_MAGIC,
417 fname,fndoc))
417 fname,fndoc))
418 magic_docs = ''.join(magic_docs)
418 magic_docs = ''.join(magic_docs)
419
419
420 if mode == 'latex':
420 if mode == 'latex':
421 print self.format_latex(magic_docs)
421 print self.format_latex(magic_docs)
422 return
422 return
423 else:
423 else:
424 magic_docs = self.format_screen(magic_docs)
424 magic_docs = self.format_screen(magic_docs)
425 if mode == 'brief':
425 if mode == 'brief':
426 return magic_docs
426 return magic_docs
427
427
428 outmsg = """
428 outmsg = """
429 IPython's 'magic' functions
429 IPython's 'magic' functions
430 ===========================
430 ===========================
431
431
432 The magic function system provides a series of functions which allow you to
432 The magic function system provides a series of functions which allow you to
433 control the behavior of IPython itself, plus a lot of system-type
433 control the behavior of IPython itself, plus a lot of system-type
434 features. All these functions are prefixed with a % character, but parameters
434 features. All these functions are prefixed with a % character, but parameters
435 are given without parentheses or quotes.
435 are given without parentheses or quotes.
436
436
437 NOTE: If you have 'automagic' enabled (via the command line option or with the
437 NOTE: If you have 'automagic' enabled (via the command line option or with the
438 %automagic function), you don't need to type in the % explicitly. By default,
438 %automagic function), you don't need to type in the % explicitly. By default,
439 IPython ships with automagic on, so you should only rarely need the % escape.
439 IPython ships with automagic on, so you should only rarely need the % escape.
440
440
441 Example: typing '%cd mydir' (without the quotes) changes you working directory
441 Example: typing '%cd mydir' (without the quotes) changes you working directory
442 to 'mydir', if it exists.
442 to 'mydir', if it exists.
443
443
444 You can define your own magic functions to extend the system. See the supplied
444 You can define your own magic functions to extend the system. See the supplied
445 ipythonrc and example-magic.py files for details (in your ipython
445 ipythonrc and example-magic.py files for details (in your ipython
446 configuration directory, typically $HOME/.ipython/).
446 configuration directory, typically $HOME/.ipython/).
447
447
448 You can also define your own aliased names for magic functions. In your
448 You can also define your own aliased names for magic functions. In your
449 ipythonrc file, placing a line like:
449 ipythonrc file, placing a line like:
450
450
451 execute __IPYTHON__.magic_pf = __IPYTHON__.magic_profile
451 execute __IPYTHON__.magic_pf = __IPYTHON__.magic_profile
452
452
453 will define %pf as a new name for %profile.
453 will define %pf as a new name for %profile.
454
454
455 You can also call magics in code using the ipmagic() function, which IPython
455 You can also call magics in code using the ipmagic() function, which IPython
456 automatically adds to the builtin namespace. Type 'ipmagic?' for details.
456 automatically adds to the builtin namespace. Type 'ipmagic?' for details.
457
457
458 For a list of the available magic functions, use %lsmagic. For a description
458 For a list of the available magic functions, use %lsmagic. For a description
459 of any of them, type %magic_name?, e.g. '%cd?'.
459 of any of them, type %magic_name?, e.g. '%cd?'.
460
460
461 Currently the magic system has the following functions:\n"""
461 Currently the magic system has the following functions:\n"""
462
462
463 mesc = self.shell.ESC_MAGIC
463 mesc = self.shell.ESC_MAGIC
464 outmsg = ("%s\n%s\n\nSummary of magic functions (from %slsmagic):"
464 outmsg = ("%s\n%s\n\nSummary of magic functions (from %slsmagic):"
465 "\n\n%s%s\n\n%s" % (outmsg,
465 "\n\n%s%s\n\n%s" % (outmsg,
466 magic_docs,mesc,mesc,
466 magic_docs,mesc,mesc,
467 (' '+mesc).join(self.lsmagic()),
467 (' '+mesc).join(self.lsmagic()),
468 Magic.auto_status[self.shell.rc.automagic] ) )
468 Magic.auto_status[self.shell.rc.automagic] ) )
469
469
470 page(outmsg,screen_lines=self.shell.rc.screen_length)
470 page(outmsg,screen_lines=self.shell.rc.screen_length)
471
471
472
472
473 def magic_autoindent(self, parameter_s = ''):
473 def magic_autoindent(self, parameter_s = ''):
474 """Toggle autoindent on/off (if available)."""
474 """Toggle autoindent on/off (if available)."""
475
475
476 self.shell.set_autoindent()
476 self.shell.set_autoindent()
477 print "Automatic indentation is:",['OFF','ON'][self.shell.autoindent]
477 print "Automatic indentation is:",['OFF','ON'][self.shell.autoindent]
478
478
479
479
480 def magic_automagic(self, parameter_s = ''):
480 def magic_automagic(self, parameter_s = ''):
481 """Make magic functions callable without having to type the initial %.
481 """Make magic functions callable without having to type the initial %.
482
482
483 Without argumentsl toggles on/off (when off, you must call it as
483 Without argumentsl toggles on/off (when off, you must call it as
484 %automagic, of course). With arguments it sets the value, and you can
484 %automagic, of course). With arguments it sets the value, and you can
485 use any of (case insensitive):
485 use any of (case insensitive):
486
486
487 - on,1,True: to activate
487 - on,1,True: to activate
488
488
489 - off,0,False: to deactivate.
489 - off,0,False: to deactivate.
490
490
491 Note that magic functions have lowest priority, so if there's a
491 Note that magic functions have lowest priority, so if there's a
492 variable whose name collides with that of a magic fn, automagic won't
492 variable whose name collides with that of a magic fn, automagic won't
493 work for that function (you get the variable instead). However, if you
493 work for that function (you get the variable instead). However, if you
494 delete the variable (del var), the previously shadowed magic function
494 delete the variable (del var), the previously shadowed magic function
495 becomes visible to automagic again."""
495 becomes visible to automagic again."""
496
496
497 rc = self.shell.rc
497 rc = self.shell.rc
498 arg = parameter_s.lower()
498 arg = parameter_s.lower()
499 if parameter_s in ('on','1','true'):
499 if parameter_s in ('on','1','true'):
500 rc.automagic = True
500 rc.automagic = True
501 elif parameter_s in ('off','0','false'):
501 elif parameter_s in ('off','0','false'):
502 rc.automagic = False
502 rc.automagic = False
503 else:
503 else:
504 rc.automagic = not rc.automagic
504 rc.automagic = not rc.automagic
505 print '\n' + Magic.auto_status[rc.automagic]
505 print '\n' + Magic.auto_status[rc.automagic]
506
506
507
507
508 def magic_autocall(self, parameter_s = ''):
508 def magic_autocall(self, parameter_s = ''):
509 """Make functions callable without having to type parentheses.
509 """Make functions callable without having to type parentheses.
510
510
511 Usage:
511 Usage:
512
512
513 %autocall [mode]
513 %autocall [mode]
514
514
515 The mode can be one of: 0->Off, 1->Smart, 2->Full. If not given, the
515 The mode can be one of: 0->Off, 1->Smart, 2->Full. If not given, the
516 value is toggled on and off (remembering the previous state).
516 value is toggled on and off (remembering the previous state).
517
517
518 In more detail, these values mean:
518 In more detail, these values mean:
519
519
520 0 -> fully disabled
520 0 -> fully disabled
521
521
522 1 -> active, but do not apply if there are no arguments on the line.
522 1 -> active, but do not apply if there are no arguments on the line.
523
523
524 In this mode, you get:
524 In this mode, you get:
525
525
526 In [1]: callable
526 In [1]: callable
527 Out[1]: <built-in function callable>
527 Out[1]: <built-in function callable>
528
528
529 In [2]: callable 'hello'
529 In [2]: callable 'hello'
530 ------> callable('hello')
530 ------> callable('hello')
531 Out[2]: False
531 Out[2]: False
532
532
533 2 -> Active always. Even if no arguments are present, the callable
533 2 -> Active always. Even if no arguments are present, the callable
534 object is called:
534 object is called:
535
535
536 In [4]: callable
536 In [4]: callable
537 ------> callable()
537 ------> callable()
538
538
539 Note that even with autocall off, you can still use '/' at the start of
539 Note that even with autocall off, you can still use '/' at the start of
540 a line to treat the first argument on the command line as a function
540 a line to treat the first argument on the command line as a function
541 and add parentheses to it:
541 and add parentheses to it:
542
542
543 In [8]: /str 43
543 In [8]: /str 43
544 ------> str(43)
544 ------> str(43)
545 Out[8]: '43'
545 Out[8]: '43'
546 """
546 """
547
547
548 rc = self.shell.rc
548 rc = self.shell.rc
549
549
550 if parameter_s:
550 if parameter_s:
551 arg = int(parameter_s)
551 arg = int(parameter_s)
552 else:
552 else:
553 arg = 'toggle'
553 arg = 'toggle'
554
554
555 if not arg in (0,1,2,'toggle'):
555 if not arg in (0,1,2,'toggle'):
556 error('Valid modes: (0->Off, 1->Smart, 2->Full')
556 error('Valid modes: (0->Off, 1->Smart, 2->Full')
557 return
557 return
558
558
559 if arg in (0,1,2):
559 if arg in (0,1,2):
560 rc.autocall = arg
560 rc.autocall = arg
561 else: # toggle
561 else: # toggle
562 if rc.autocall:
562 if rc.autocall:
563 self._magic_state.autocall_save = rc.autocall
563 self._magic_state.autocall_save = rc.autocall
564 rc.autocall = 0
564 rc.autocall = 0
565 else:
565 else:
566 try:
566 try:
567 rc.autocall = self._magic_state.autocall_save
567 rc.autocall = self._magic_state.autocall_save
568 except AttributeError:
568 except AttributeError:
569 rc.autocall = self._magic_state.autocall_save = 1
569 rc.autocall = self._magic_state.autocall_save = 1
570
570
571 print "Automatic calling is:",['OFF','Smart','Full'][rc.autocall]
571 print "Automatic calling is:",['OFF','Smart','Full'][rc.autocall]
572
572
573 def magic_system_verbose(self, parameter_s = ''):
573 def magic_system_verbose(self, parameter_s = ''):
574 """Set verbose printing of system calls.
574 """Set verbose printing of system calls.
575
575
576 If called without an argument, act as a toggle"""
576 If called without an argument, act as a toggle"""
577
577
578 if parameter_s:
578 if parameter_s:
579 val = bool(eval(parameter_s))
579 val = bool(eval(parameter_s))
580 else:
580 else:
581 val = None
581 val = None
582
582
583 self.shell.rc_set_toggle('system_verbose',val)
583 self.shell.rc_set_toggle('system_verbose',val)
584 print "System verbose printing is:",\
584 print "System verbose printing is:",\
585 ['OFF','ON'][self.shell.rc.system_verbose]
585 ['OFF','ON'][self.shell.rc.system_verbose]
586
586
587
587
588 def magic_page(self, parameter_s=''):
588 def magic_page(self, parameter_s=''):
589 """Pretty print the object and display it through a pager.
589 """Pretty print the object and display it through a pager.
590
590
591 %page [options] OBJECT
591 %page [options] OBJECT
592
592
593 If no object is given, use _ (last output).
593 If no object is given, use _ (last output).
594
594
595 Options:
595 Options:
596
596
597 -r: page str(object), don't pretty-print it."""
597 -r: page str(object), don't pretty-print it."""
598
598
599 # After a function contributed by Olivier Aubert, slightly modified.
599 # After a function contributed by Olivier Aubert, slightly modified.
600
600
601 # Process options/args
601 # Process options/args
602 opts,args = self.parse_options(parameter_s,'r')
602 opts,args = self.parse_options(parameter_s,'r')
603 raw = 'r' in opts
603 raw = 'r' in opts
604
604
605 oname = args and args or '_'
605 oname = args and args or '_'
606 info = self._ofind(oname)
606 info = self._ofind(oname)
607 if info['found']:
607 if info['found']:
608 txt = (raw and str or pformat)( info['obj'] )
608 txt = (raw and str or pformat)( info['obj'] )
609 page(txt)
609 page(txt)
610 else:
610 else:
611 print 'Object `%s` not found' % oname
611 print 'Object `%s` not found' % oname
612
612
613 def magic_profile(self, parameter_s=''):
613 def magic_profile(self, parameter_s=''):
614 """Print your currently active IPyhton profile."""
614 """Print your currently active IPyhton profile."""
615 if self.shell.rc.profile:
615 if self.shell.rc.profile:
616 printpl('Current IPython profile: $self.shell.rc.profile.')
616 printpl('Current IPython profile: $self.shell.rc.profile.')
617 else:
617 else:
618 print 'No profile active.'
618 print 'No profile active.'
619
619
620 def magic_pinfo(self, parameter_s='', namespaces=None):
620 def magic_pinfo(self, parameter_s='', namespaces=None):
621 """Provide detailed information about an object.
621 """Provide detailed information about an object.
622
622
623 '%pinfo object' is just a synonym for object? or ?object."""
623 '%pinfo object' is just a synonym for object? or ?object."""
624
624
625 #print 'pinfo par: <%s>' % parameter_s # dbg
625 #print 'pinfo par: <%s>' % parameter_s # dbg
626
626
627
627
628 # detail_level: 0 -> obj? , 1 -> obj??
628 # detail_level: 0 -> obj? , 1 -> obj??
629 detail_level = 0
629 detail_level = 0
630 # We need to detect if we got called as 'pinfo pinfo foo', which can
630 # We need to detect if we got called as 'pinfo pinfo foo', which can
631 # happen if the user types 'pinfo foo?' at the cmd line.
631 # happen if the user types 'pinfo foo?' at the cmd line.
632 pinfo,qmark1,oname,qmark2 = \
632 pinfo,qmark1,oname,qmark2 = \
633 re.match('(pinfo )?(\?*)(.*?)(\??$)',parameter_s).groups()
633 re.match('(pinfo )?(\?*)(.*?)(\??$)',parameter_s).groups()
634 if pinfo or qmark1 or qmark2:
634 if pinfo or qmark1 or qmark2:
635 detail_level = 1
635 detail_level = 1
636 if "*" in oname:
636 if "*" in oname:
637 self.magic_psearch(oname)
637 self.magic_psearch(oname)
638 else:
638 else:
639 self._inspect('pinfo', oname, detail_level=detail_level,
639 self._inspect('pinfo', oname, detail_level=detail_level,
640 namespaces=namespaces)
640 namespaces=namespaces)
641
641
642 def magic_pdef(self, parameter_s='', namespaces=None):
642 def magic_pdef(self, parameter_s='', namespaces=None):
643 """Print the definition header for any callable object.
643 """Print the definition header for any callable object.
644
644
645 If the object is a class, print the constructor information."""
645 If the object is a class, print the constructor information."""
646 self._inspect('pdef',parameter_s, namespaces)
646 self._inspect('pdef',parameter_s, namespaces)
647
647
648 def magic_pdoc(self, parameter_s='', namespaces=None):
648 def magic_pdoc(self, parameter_s='', namespaces=None):
649 """Print the docstring for an object.
649 """Print the docstring for an object.
650
650
651 If the given object is a class, it will print both the class and the
651 If the given object is a class, it will print both the class and the
652 constructor docstrings."""
652 constructor docstrings."""
653 self._inspect('pdoc',parameter_s, namespaces)
653 self._inspect('pdoc',parameter_s, namespaces)
654
654
655 def magic_psource(self, parameter_s='', namespaces=None):
655 def magic_psource(self, parameter_s='', namespaces=None):
656 """Print (or run through pager) the source code for an object."""
656 """Print (or run through pager) the source code for an object."""
657 self._inspect('psource',parameter_s, namespaces)
657 self._inspect('psource',parameter_s, namespaces)
658
658
659 def magic_pfile(self, parameter_s=''):
659 def magic_pfile(self, parameter_s=''):
660 """Print (or run through pager) the file where an object is defined.
660 """Print (or run through pager) the file where an object is defined.
661
661
662 The file opens at the line where the object definition begins. IPython
662 The file opens at the line where the object definition begins. IPython
663 will honor the environment variable PAGER if set, and otherwise will
663 will honor the environment variable PAGER if set, and otherwise will
664 do its best to print the file in a convenient form.
664 do its best to print the file in a convenient form.
665
665
666 If the given argument is not an object currently defined, IPython will
666 If the given argument is not an object currently defined, IPython will
667 try to interpret it as a filename (automatically adding a .py extension
667 try to interpret it as a filename (automatically adding a .py extension
668 if needed). You can thus use %pfile as a syntax highlighting code
668 if needed). You can thus use %pfile as a syntax highlighting code
669 viewer."""
669 viewer."""
670
670
671 # first interpret argument as an object name
671 # first interpret argument as an object name
672 out = self._inspect('pfile',parameter_s)
672 out = self._inspect('pfile',parameter_s)
673 # if not, try the input as a filename
673 # if not, try the input as a filename
674 if out == 'not found':
674 if out == 'not found':
675 try:
675 try:
676 filename = get_py_filename(parameter_s)
676 filename = get_py_filename(parameter_s)
677 except IOError,msg:
677 except IOError,msg:
678 print msg
678 print msg
679 return
679 return
680 page(self.shell.inspector.format(file(filename).read()))
680 page(self.shell.inspector.format(file(filename).read()))
681
681
682 def _inspect(self,meth,oname,namespaces=None,**kw):
682 def _inspect(self,meth,oname,namespaces=None,**kw):
683 """Generic interface to the inspector system.
683 """Generic interface to the inspector system.
684
684
685 This function is meant to be called by pdef, pdoc & friends."""
685 This function is meant to be called by pdef, pdoc & friends."""
686
686
687 #oname = oname.strip()
687 #oname = oname.strip()
688 #print '1- oname: <%r>' % oname # dbg
688 #print '1- oname: <%r>' % oname # dbg
689 try:
689 try:
690 oname = oname.strip().encode('ascii')
690 oname = oname.strip().encode('ascii')
691 #print '2- oname: <%r>' % oname # dbg
691 #print '2- oname: <%r>' % oname # dbg
692 except UnicodeEncodeError:
692 except UnicodeEncodeError:
693 print 'Python identifiers can only contain ascii characters.'
693 print 'Python identifiers can only contain ascii characters.'
694 return 'not found'
694 return 'not found'
695
695
696 info = Struct(self._ofind(oname, namespaces))
696 info = Struct(self._ofind(oname, namespaces))
697
697
698 if info.found:
698 if info.found:
699 try:
699 try:
700 IPython.generics.inspect_object(info.obj)
700 IPython.generics.inspect_object(info.obj)
701 return
701 return
702 except IPython.ipapi.TryNext:
702 except IPython.ipapi.TryNext:
703 pass
703 pass
704 # Get the docstring of the class property if it exists.
704 # Get the docstring of the class property if it exists.
705 path = oname.split('.')
705 path = oname.split('.')
706 root = '.'.join(path[:-1])
706 root = '.'.join(path[:-1])
707 if info.parent is not None:
707 if info.parent is not None:
708 try:
708 try:
709 target = getattr(info.parent, '__class__')
709 target = getattr(info.parent, '__class__')
710 # The object belongs to a class instance.
710 # The object belongs to a class instance.
711 try:
711 try:
712 target = getattr(target, path[-1])
712 target = getattr(target, path[-1])
713 # The class defines the object.
713 # The class defines the object.
714 if isinstance(target, property):
714 if isinstance(target, property):
715 oname = root + '.__class__.' + path[-1]
715 oname = root + '.__class__.' + path[-1]
716 info = Struct(self._ofind(oname))
716 info = Struct(self._ofind(oname))
717 except AttributeError: pass
717 except AttributeError: pass
718 except AttributeError: pass
718 except AttributeError: pass
719
719
720 pmethod = getattr(self.shell.inspector,meth)
720 pmethod = getattr(self.shell.inspector,meth)
721 formatter = info.ismagic and self.format_screen or None
721 formatter = info.ismagic and self.format_screen or None
722 if meth == 'pdoc':
722 if meth == 'pdoc':
723 pmethod(info.obj,oname,formatter)
723 pmethod(info.obj,oname,formatter)
724 elif meth == 'pinfo':
724 elif meth == 'pinfo':
725 pmethod(info.obj,oname,formatter,info,**kw)
725 pmethod(info.obj,oname,formatter,info,**kw)
726 else:
726 else:
727 pmethod(info.obj,oname)
727 pmethod(info.obj,oname)
728 else:
728 else:
729 print 'Object `%s` not found.' % oname
729 print 'Object `%s` not found.' % oname
730 return 'not found' # so callers can take other action
730 return 'not found' # so callers can take other action
731
731
732 def magic_psearch(self, parameter_s=''):
732 def magic_psearch(self, parameter_s=''):
733 """Search for object in namespaces by wildcard.
733 """Search for object in namespaces by wildcard.
734
734
735 %psearch [options] PATTERN [OBJECT TYPE]
735 %psearch [options] PATTERN [OBJECT TYPE]
736
736
737 Note: ? can be used as a synonym for %psearch, at the beginning or at
737 Note: ? can be used as a synonym for %psearch, at the beginning or at
738 the end: both a*? and ?a* are equivalent to '%psearch a*'. Still, the
738 the end: both a*? and ?a* are equivalent to '%psearch a*'. Still, the
739 rest of the command line must be unchanged (options come first), so
739 rest of the command line must be unchanged (options come first), so
740 for example the following forms are equivalent
740 for example the following forms are equivalent
741
741
742 %psearch -i a* function
742 %psearch -i a* function
743 -i a* function?
743 -i a* function?
744 ?-i a* function
744 ?-i a* function
745
745
746 Arguments:
746 Arguments:
747
747
748 PATTERN
748 PATTERN
749
749
750 where PATTERN is a string containing * as a wildcard similar to its
750 where PATTERN is a string containing * as a wildcard similar to its
751 use in a shell. The pattern is matched in all namespaces on the
751 use in a shell. The pattern is matched in all namespaces on the
752 search path. By default objects starting with a single _ are not
752 search path. By default objects starting with a single _ are not
753 matched, many IPython generated objects have a single
753 matched, many IPython generated objects have a single
754 underscore. The default is case insensitive matching. Matching is
754 underscore. The default is case insensitive matching. Matching is
755 also done on the attributes of objects and not only on the objects
755 also done on the attributes of objects and not only on the objects
756 in a module.
756 in a module.
757
757
758 [OBJECT TYPE]
758 [OBJECT TYPE]
759
759
760 Is the name of a python type from the types module. The name is
760 Is the name of a python type from the types module. The name is
761 given in lowercase without the ending type, ex. StringType is
761 given in lowercase without the ending type, ex. StringType is
762 written string. By adding a type here only objects matching the
762 written string. By adding a type here only objects matching the
763 given type are matched. Using all here makes the pattern match all
763 given type are matched. Using all here makes the pattern match all
764 types (this is the default).
764 types (this is the default).
765
765
766 Options:
766 Options:
767
767
768 -a: makes the pattern match even objects whose names start with a
768 -a: makes the pattern match even objects whose names start with a
769 single underscore. These names are normally ommitted from the
769 single underscore. These names are normally ommitted from the
770 search.
770 search.
771
771
772 -i/-c: make the pattern case insensitive/sensitive. If neither of
772 -i/-c: make the pattern case insensitive/sensitive. If neither of
773 these options is given, the default is read from your ipythonrc
773 these options is given, the default is read from your ipythonrc
774 file. The option name which sets this value is
774 file. The option name which sets this value is
775 'wildcards_case_sensitive'. If this option is not specified in your
775 'wildcards_case_sensitive'. If this option is not specified in your
776 ipythonrc file, IPython's internal default is to do a case sensitive
776 ipythonrc file, IPython's internal default is to do a case sensitive
777 search.
777 search.
778
778
779 -e/-s NAMESPACE: exclude/search a given namespace. The pattern you
779 -e/-s NAMESPACE: exclude/search a given namespace. The pattern you
780 specifiy can be searched in any of the following namespaces:
780 specifiy can be searched in any of the following namespaces:
781 'builtin', 'user', 'user_global','internal', 'alias', where
781 'builtin', 'user', 'user_global','internal', 'alias', where
782 'builtin' and 'user' are the search defaults. Note that you should
782 'builtin' and 'user' are the search defaults. Note that you should
783 not use quotes when specifying namespaces.
783 not use quotes when specifying namespaces.
784
784
785 'Builtin' contains the python module builtin, 'user' contains all
785 'Builtin' contains the python module builtin, 'user' contains all
786 user data, 'alias' only contain the shell aliases and no python
786 user data, 'alias' only contain the shell aliases and no python
787 objects, 'internal' contains objects used by IPython. The
787 objects, 'internal' contains objects used by IPython. The
788 'user_global' namespace is only used by embedded IPython instances,
788 'user_global' namespace is only used by embedded IPython instances,
789 and it contains module-level globals. You can add namespaces to the
789 and it contains module-level globals. You can add namespaces to the
790 search with -s or exclude them with -e (these options can be given
790 search with -s or exclude them with -e (these options can be given
791 more than once).
791 more than once).
792
792
793 Examples:
793 Examples:
794
794
795 %psearch a* -> objects beginning with an a
795 %psearch a* -> objects beginning with an a
796 %psearch -e builtin a* -> objects NOT in the builtin space starting in a
796 %psearch -e builtin a* -> objects NOT in the builtin space starting in a
797 %psearch a* function -> all functions beginning with an a
797 %psearch a* function -> all functions beginning with an a
798 %psearch re.e* -> objects beginning with an e in module re
798 %psearch re.e* -> objects beginning with an e in module re
799 %psearch r*.e* -> objects that start with e in modules starting in r
799 %psearch r*.e* -> objects that start with e in modules starting in r
800 %psearch r*.* string -> all strings in modules beginning with r
800 %psearch r*.* string -> all strings in modules beginning with r
801
801
802 Case sensitve search:
802 Case sensitve search:
803
803
804 %psearch -c a* list all object beginning with lower case a
804 %psearch -c a* list all object beginning with lower case a
805
805
806 Show objects beginning with a single _:
806 Show objects beginning with a single _:
807
807
808 %psearch -a _* list objects beginning with a single underscore"""
808 %psearch -a _* list objects beginning with a single underscore"""
809 try:
809 try:
810 parameter_s = parameter_s.encode('ascii')
810 parameter_s = parameter_s.encode('ascii')
811 except UnicodeEncodeError:
811 except UnicodeEncodeError:
812 print 'Python identifiers can only contain ascii characters.'
812 print 'Python identifiers can only contain ascii characters.'
813 return
813 return
814
814
815 # default namespaces to be searched
815 # default namespaces to be searched
816 def_search = ['user','builtin']
816 def_search = ['user','builtin']
817
817
818 # Process options/args
818 # Process options/args
819 opts,args = self.parse_options(parameter_s,'cias:e:',list_all=True)
819 opts,args = self.parse_options(parameter_s,'cias:e:',list_all=True)
820 opt = opts.get
820 opt = opts.get
821 shell = self.shell
821 shell = self.shell
822 psearch = shell.inspector.psearch
822 psearch = shell.inspector.psearch
823
823
824 # select case options
824 # select case options
825 if opts.has_key('i'):
825 if opts.has_key('i'):
826 ignore_case = True
826 ignore_case = True
827 elif opts.has_key('c'):
827 elif opts.has_key('c'):
828 ignore_case = False
828 ignore_case = False
829 else:
829 else:
830 ignore_case = not shell.rc.wildcards_case_sensitive
830 ignore_case = not shell.rc.wildcards_case_sensitive
831
831
832 # Build list of namespaces to search from user options
832 # Build list of namespaces to search from user options
833 def_search.extend(opt('s',[]))
833 def_search.extend(opt('s',[]))
834 ns_exclude = ns_exclude=opt('e',[])
834 ns_exclude = ns_exclude=opt('e',[])
835 ns_search = [nm for nm in def_search if nm not in ns_exclude]
835 ns_search = [nm for nm in def_search if nm not in ns_exclude]
836
836
837 # Call the actual search
837 # Call the actual search
838 try:
838 try:
839 psearch(args,shell.ns_table,ns_search,
839 psearch(args,shell.ns_table,ns_search,
840 show_all=opt('a'),ignore_case=ignore_case)
840 show_all=opt('a'),ignore_case=ignore_case)
841 except:
841 except:
842 shell.showtraceback()
842 shell.showtraceback()
843
843
844 def magic_who_ls(self, parameter_s=''):
844 def magic_who_ls(self, parameter_s=''):
845 """Return a sorted list of all interactive variables.
845 """Return a sorted list of all interactive variables.
846
846
847 If arguments are given, only variables of types matching these
847 If arguments are given, only variables of types matching these
848 arguments are returned."""
848 arguments are returned."""
849
849
850 user_ns = self.shell.user_ns
850 user_ns = self.shell.user_ns
851 internal_ns = self.shell.internal_ns
851 internal_ns = self.shell.internal_ns
852 user_config_ns = self.shell.user_config_ns
852 user_config_ns = self.shell.user_config_ns
853 out = []
853 out = []
854 typelist = parameter_s.split()
854 typelist = parameter_s.split()
855
855
856 for i in user_ns:
856 for i in user_ns:
857 if not (i.startswith('_') or i.startswith('_i')) \
857 if not (i.startswith('_') or i.startswith('_i')) \
858 and not (i in internal_ns or i in user_config_ns):
858 and not (i in internal_ns or i in user_config_ns):
859 if typelist:
859 if typelist:
860 if type(user_ns[i]).__name__ in typelist:
860 if type(user_ns[i]).__name__ in typelist:
861 out.append(i)
861 out.append(i)
862 else:
862 else:
863 out.append(i)
863 out.append(i)
864 out.sort()
864 out.sort()
865 return out
865 return out
866
866
867 def magic_who(self, parameter_s=''):
867 def magic_who(self, parameter_s=''):
868 """Print all interactive variables, with some minimal formatting.
868 """Print all interactive variables, with some minimal formatting.
869
869
870 If any arguments are given, only variables whose type matches one of
870 If any arguments are given, only variables whose type matches one of
871 these are printed. For example:
871 these are printed. For example:
872
872
873 %who function str
873 %who function str
874
874
875 will only list functions and strings, excluding all other types of
875 will only list functions and strings, excluding all other types of
876 variables. To find the proper type names, simply use type(var) at a
876 variables. To find the proper type names, simply use type(var) at a
877 command line to see how python prints type names. For example:
877 command line to see how python prints type names. For example:
878
878
879 In [1]: type('hello')\\
879 In [1]: type('hello')\\
880 Out[1]: <type 'str'>
880 Out[1]: <type 'str'>
881
881
882 indicates that the type name for strings is 'str'.
882 indicates that the type name for strings is 'str'.
883
883
884 %who always excludes executed names loaded through your configuration
884 %who always excludes executed names loaded through your configuration
885 file and things which are internal to IPython.
885 file and things which are internal to IPython.
886
886
887 This is deliberate, as typically you may load many modules and the
887 This is deliberate, as typically you may load many modules and the
888 purpose of %who is to show you only what you've manually defined."""
888 purpose of %who is to show you only what you've manually defined."""
889
889
890 varlist = self.magic_who_ls(parameter_s)
890 varlist = self.magic_who_ls(parameter_s)
891 if not varlist:
891 if not varlist:
892 if parameter_s:
892 if parameter_s:
893 print 'No variables match your requested type.'
893 print 'No variables match your requested type.'
894 else:
894 else:
895 print 'Interactive namespace is empty.'
895 print 'Interactive namespace is empty.'
896 return
896 return
897
897
898 # if we have variables, move on...
898 # if we have variables, move on...
899 count = 0
899 count = 0
900 for i in varlist:
900 for i in varlist:
901 print i+'\t',
901 print i+'\t',
902 count += 1
902 count += 1
903 if count > 8:
903 if count > 8:
904 count = 0
904 count = 0
905 print
905 print
906 print
906 print
907
907
908 def magic_whos(self, parameter_s=''):
908 def magic_whos(self, parameter_s=''):
909 """Like %who, but gives some extra information about each variable.
909 """Like %who, but gives some extra information about each variable.
910
910
911 The same type filtering of %who can be applied here.
911 The same type filtering of %who can be applied here.
912
912
913 For all variables, the type is printed. Additionally it prints:
913 For all variables, the type is printed. Additionally it prints:
914
914
915 - For {},[],(): their length.
915 - For {},[],(): their length.
916
916
917 - For numpy and Numeric arrays, a summary with shape, number of
917 - For numpy and Numeric arrays, a summary with shape, number of
918 elements, typecode and size in memory.
918 elements, typecode and size in memory.
919
919
920 - Everything else: a string representation, snipping their middle if
920 - Everything else: a string representation, snipping their middle if
921 too long."""
921 too long."""
922
922
923 varnames = self.magic_who_ls(parameter_s)
923 varnames = self.magic_who_ls(parameter_s)
924 if not varnames:
924 if not varnames:
925 if parameter_s:
925 if parameter_s:
926 print 'No variables match your requested type.'
926 print 'No variables match your requested type.'
927 else:
927 else:
928 print 'Interactive namespace is empty.'
928 print 'Interactive namespace is empty.'
929 return
929 return
930
930
931 # if we have variables, move on...
931 # if we have variables, move on...
932
932
933 # for these types, show len() instead of data:
933 # for these types, show len() instead of data:
934 seq_types = [types.DictType,types.ListType,types.TupleType]
934 seq_types = [types.DictType,types.ListType,types.TupleType]
935
935
936 # for numpy/Numeric arrays, display summary info
936 # for numpy/Numeric arrays, display summary info
937 try:
937 try:
938 import numpy
938 import numpy
939 except ImportError:
939 except ImportError:
940 ndarray_type = None
940 ndarray_type = None
941 else:
941 else:
942 ndarray_type = numpy.ndarray.__name__
942 ndarray_type = numpy.ndarray.__name__
943 try:
943 try:
944 import Numeric
944 import Numeric
945 except ImportError:
945 except ImportError:
946 array_type = None
946 array_type = None
947 else:
947 else:
948 array_type = Numeric.ArrayType.__name__
948 array_type = Numeric.ArrayType.__name__
949
949
950 # Find all variable names and types so we can figure out column sizes
950 # Find all variable names and types so we can figure out column sizes
951 def get_vars(i):
951 def get_vars(i):
952 return self.shell.user_ns[i]
952 return self.shell.user_ns[i]
953
953
954 # some types are well known and can be shorter
954 # some types are well known and can be shorter
955 abbrevs = {'IPython.macro.Macro' : 'Macro'}
955 abbrevs = {'IPython.macro.Macro' : 'Macro'}
956 def type_name(v):
956 def type_name(v):
957 tn = type(v).__name__
957 tn = type(v).__name__
958 return abbrevs.get(tn,tn)
958 return abbrevs.get(tn,tn)
959
959
960 varlist = map(get_vars,varnames)
960 varlist = map(get_vars,varnames)
961
961
962 typelist = []
962 typelist = []
963 for vv in varlist:
963 for vv in varlist:
964 tt = type_name(vv)
964 tt = type_name(vv)
965
965
966 if tt=='instance':
966 if tt=='instance':
967 typelist.append( abbrevs.get(str(vv.__class__),
967 typelist.append( abbrevs.get(str(vv.__class__),
968 str(vv.__class__)))
968 str(vv.__class__)))
969 else:
969 else:
970 typelist.append(tt)
970 typelist.append(tt)
971
971
972 # column labels and # of spaces as separator
972 # column labels and # of spaces as separator
973 varlabel = 'Variable'
973 varlabel = 'Variable'
974 typelabel = 'Type'
974 typelabel = 'Type'
975 datalabel = 'Data/Info'
975 datalabel = 'Data/Info'
976 colsep = 3
976 colsep = 3
977 # variable format strings
977 # variable format strings
978 vformat = "$vname.ljust(varwidth)$vtype.ljust(typewidth)"
978 vformat = "$vname.ljust(varwidth)$vtype.ljust(typewidth)"
979 vfmt_short = '$vstr[:25]<...>$vstr[-25:]'
979 vfmt_short = '$vstr[:25]<...>$vstr[-25:]'
980 aformat = "%s: %s elems, type `%s`, %s bytes"
980 aformat = "%s: %s elems, type `%s`, %s bytes"
981 # find the size of the columns to format the output nicely
981 # find the size of the columns to format the output nicely
982 varwidth = max(max(map(len,varnames)), len(varlabel)) + colsep
982 varwidth = max(max(map(len,varnames)), len(varlabel)) + colsep
983 typewidth = max(max(map(len,typelist)), len(typelabel)) + colsep
983 typewidth = max(max(map(len,typelist)), len(typelabel)) + colsep
984 # table header
984 # table header
985 print varlabel.ljust(varwidth) + typelabel.ljust(typewidth) + \
985 print varlabel.ljust(varwidth) + typelabel.ljust(typewidth) + \
986 ' '+datalabel+'\n' + '-'*(varwidth+typewidth+len(datalabel)+1)
986 ' '+datalabel+'\n' + '-'*(varwidth+typewidth+len(datalabel)+1)
987 # and the table itself
987 # and the table itself
988 kb = 1024
988 kb = 1024
989 Mb = 1048576 # kb**2
989 Mb = 1048576 # kb**2
990 for vname,var,vtype in zip(varnames,varlist,typelist):
990 for vname,var,vtype in zip(varnames,varlist,typelist):
991 print itpl(vformat),
991 print itpl(vformat),
992 if vtype in seq_types:
992 if vtype in seq_types:
993 print len(var)
993 print len(var)
994 elif vtype in [array_type,ndarray_type]:
994 elif vtype in [array_type,ndarray_type]:
995 vshape = str(var.shape).replace(',','').replace(' ','x')[1:-1]
995 vshape = str(var.shape).replace(',','').replace(' ','x')[1:-1]
996 if vtype==ndarray_type:
996 if vtype==ndarray_type:
997 # numpy
997 # numpy
998 vsize = var.size
998 vsize = var.size
999 vbytes = vsize*var.itemsize
999 vbytes = vsize*var.itemsize
1000 vdtype = var.dtype
1000 vdtype = var.dtype
1001 else:
1001 else:
1002 # Numeric
1002 # Numeric
1003 vsize = Numeric.size(var)
1003 vsize = Numeric.size(var)
1004 vbytes = vsize*var.itemsize()
1004 vbytes = vsize*var.itemsize()
1005 vdtype = var.typecode()
1005 vdtype = var.typecode()
1006
1006
1007 if vbytes < 100000:
1007 if vbytes < 100000:
1008 print aformat % (vshape,vsize,vdtype,vbytes)
1008 print aformat % (vshape,vsize,vdtype,vbytes)
1009 else:
1009 else:
1010 print aformat % (vshape,vsize,vdtype,vbytes),
1010 print aformat % (vshape,vsize,vdtype,vbytes),
1011 if vbytes < Mb:
1011 if vbytes < Mb:
1012 print '(%s kb)' % (vbytes/kb,)
1012 print '(%s kb)' % (vbytes/kb,)
1013 else:
1013 else:
1014 print '(%s Mb)' % (vbytes/Mb,)
1014 print '(%s Mb)' % (vbytes/Mb,)
1015 else:
1015 else:
1016 try:
1016 try:
1017 vstr = str(var)
1017 vstr = str(var)
1018 except UnicodeEncodeError:
1018 except UnicodeEncodeError:
1019 vstr = unicode(var).encode(sys.getdefaultencoding(),
1019 vstr = unicode(var).encode(sys.getdefaultencoding(),
1020 'backslashreplace')
1020 'backslashreplace')
1021 vstr = vstr.replace('\n','\\n')
1021 vstr = vstr.replace('\n','\\n')
1022 if len(vstr) < 50:
1022 if len(vstr) < 50:
1023 print vstr
1023 print vstr
1024 else:
1024 else:
1025 printpl(vfmt_short)
1025 printpl(vfmt_short)
1026
1026
1027 def magic_reset(self, parameter_s=''):
1027 def magic_reset(self, parameter_s=''):
1028 """Resets the namespace by removing all names defined by the user.
1028 """Resets the namespace by removing all names defined by the user.
1029
1029
1030 Input/Output history are left around in case you need them."""
1030 Input/Output history are left around in case you need them."""
1031
1031
1032 ans = self.shell.ask_yes_no(
1032 ans = self.shell.ask_yes_no(
1033 "Once deleted, variables cannot be recovered. Proceed (y/[n])? ")
1033 "Once deleted, variables cannot be recovered. Proceed (y/[n])? ")
1034 if not ans:
1034 if not ans:
1035 print 'Nothing done.'
1035 print 'Nothing done.'
1036 return
1036 return
1037 user_ns = self.shell.user_ns
1037 user_ns = self.shell.user_ns
1038 for i in self.magic_who_ls():
1038 for i in self.magic_who_ls():
1039 del(user_ns[i])
1039 del(user_ns[i])
1040
1040
1041 # Also flush the private list of module references kept for script
1041 # Also flush the private list of module references kept for script
1042 # execution protection
1042 # execution protection
1043 self.shell._user_main_modules[:] = []
1043 self.shell._user_main_modules[:] = []
1044
1044
1045 def magic_logstart(self,parameter_s=''):
1045 def magic_logstart(self,parameter_s=''):
1046 """Start logging anywhere in a session.
1046 """Start logging anywhere in a session.
1047
1047
1048 %logstart [-o|-r|-t] [log_name [log_mode]]
1048 %logstart [-o|-r|-t] [log_name [log_mode]]
1049
1049
1050 If no name is given, it defaults to a file named 'ipython_log.py' in your
1050 If no name is given, it defaults to a file named 'ipython_log.py' in your
1051 current directory, in 'rotate' mode (see below).
1051 current directory, in 'rotate' mode (see below).
1052
1052
1053 '%logstart name' saves to file 'name' in 'backup' mode. It saves your
1053 '%logstart name' saves to file 'name' in 'backup' mode. It saves your
1054 history up to that point and then continues logging.
1054 history up to that point and then continues logging.
1055
1055
1056 %logstart takes a second optional parameter: logging mode. This can be one
1056 %logstart takes a second optional parameter: logging mode. This can be one
1057 of (note that the modes are given unquoted):\\
1057 of (note that the modes are given unquoted):\\
1058 append: well, that says it.\\
1058 append: well, that says it.\\
1059 backup: rename (if exists) to name~ and start name.\\
1059 backup: rename (if exists) to name~ and start name.\\
1060 global: single logfile in your home dir, appended to.\\
1060 global: single logfile in your home dir, appended to.\\
1061 over : overwrite existing log.\\
1061 over : overwrite existing log.\\
1062 rotate: create rotating logs name.1~, name.2~, etc.
1062 rotate: create rotating logs name.1~, name.2~, etc.
1063
1063
1064 Options:
1064 Options:
1065
1065
1066 -o: log also IPython's output. In this mode, all commands which
1066 -o: log also IPython's output. In this mode, all commands which
1067 generate an Out[NN] prompt are recorded to the logfile, right after
1067 generate an Out[NN] prompt are recorded to the logfile, right after
1068 their corresponding input line. The output lines are always
1068 their corresponding input line. The output lines are always
1069 prepended with a '#[Out]# ' marker, so that the log remains valid
1069 prepended with a '#[Out]# ' marker, so that the log remains valid
1070 Python code.
1070 Python code.
1071
1071
1072 Since this marker is always the same, filtering only the output from
1072 Since this marker is always the same, filtering only the output from
1073 a log is very easy, using for example a simple awk call:
1073 a log is very easy, using for example a simple awk call:
1074
1074
1075 awk -F'#\\[Out\\]# ' '{if($2) {print $2}}' ipython_log.py
1075 awk -F'#\\[Out\\]# ' '{if($2) {print $2}}' ipython_log.py
1076
1076
1077 -r: log 'raw' input. Normally, IPython's logs contain the processed
1077 -r: log 'raw' input. Normally, IPython's logs contain the processed
1078 input, so that user lines are logged in their final form, converted
1078 input, so that user lines are logged in their final form, converted
1079 into valid Python. For example, %Exit is logged as
1079 into valid Python. For example, %Exit is logged as
1080 '_ip.magic("Exit"). If the -r flag is given, all input is logged
1080 '_ip.magic("Exit"). If the -r flag is given, all input is logged
1081 exactly as typed, with no transformations applied.
1081 exactly as typed, with no transformations applied.
1082
1082
1083 -t: put timestamps before each input line logged (these are put in
1083 -t: put timestamps before each input line logged (these are put in
1084 comments)."""
1084 comments)."""
1085
1085
1086 opts,par = self.parse_options(parameter_s,'ort')
1086 opts,par = self.parse_options(parameter_s,'ort')
1087 log_output = 'o' in opts
1087 log_output = 'o' in opts
1088 log_raw_input = 'r' in opts
1088 log_raw_input = 'r' in opts
1089 timestamp = 't' in opts
1089 timestamp = 't' in opts
1090
1090
1091 rc = self.shell.rc
1091 rc = self.shell.rc
1092 logger = self.shell.logger
1092 logger = self.shell.logger
1093
1093
1094 # if no args are given, the defaults set in the logger constructor by
1094 # if no args are given, the defaults set in the logger constructor by
1095 # ipytohn remain valid
1095 # ipytohn remain valid
1096 if par:
1096 if par:
1097 try:
1097 try:
1098 logfname,logmode = par.split()
1098 logfname,logmode = par.split()
1099 except:
1099 except:
1100 logfname = par
1100 logfname = par
1101 logmode = 'backup'
1101 logmode = 'backup'
1102 else:
1102 else:
1103 logfname = logger.logfname
1103 logfname = logger.logfname
1104 logmode = logger.logmode
1104 logmode = logger.logmode
1105 # put logfname into rc struct as if it had been called on the command
1105 # put logfname into rc struct as if it had been called on the command
1106 # line, so it ends up saved in the log header Save it in case we need
1106 # line, so it ends up saved in the log header Save it in case we need
1107 # to restore it...
1107 # to restore it...
1108 old_logfile = rc.opts.get('logfile','')
1108 old_logfile = rc.opts.get('logfile','')
1109 if logfname:
1109 if logfname:
1110 logfname = os.path.expanduser(logfname)
1110 logfname = os.path.expanduser(logfname)
1111 rc.opts.logfile = logfname
1111 rc.opts.logfile = logfname
1112 loghead = self.shell.loghead_tpl % (rc.opts,rc.args)
1112 loghead = self.shell.loghead_tpl % (rc.opts,rc.args)
1113 try:
1113 try:
1114 started = logger.logstart(logfname,loghead,logmode,
1114 started = logger.logstart(logfname,loghead,logmode,
1115 log_output,timestamp,log_raw_input)
1115 log_output,timestamp,log_raw_input)
1116 except:
1116 except:
1117 rc.opts.logfile = old_logfile
1117 rc.opts.logfile = old_logfile
1118 warn("Couldn't start log: %s" % sys.exc_info()[1])
1118 warn("Couldn't start log: %s" % sys.exc_info()[1])
1119 else:
1119 else:
1120 # log input history up to this point, optionally interleaving
1120 # log input history up to this point, optionally interleaving
1121 # output if requested
1121 # output if requested
1122
1122
1123 if timestamp:
1123 if timestamp:
1124 # disable timestamping for the previous history, since we've
1124 # disable timestamping for the previous history, since we've
1125 # lost those already (no time machine here).
1125 # lost those already (no time machine here).
1126 logger.timestamp = False
1126 logger.timestamp = False
1127
1127
1128 if log_raw_input:
1128 if log_raw_input:
1129 input_hist = self.shell.input_hist_raw
1129 input_hist = self.shell.input_hist_raw
1130 else:
1130 else:
1131 input_hist = self.shell.input_hist
1131 input_hist = self.shell.input_hist
1132
1132
1133 if log_output:
1133 if log_output:
1134 log_write = logger.log_write
1134 log_write = logger.log_write
1135 output_hist = self.shell.output_hist
1135 output_hist = self.shell.output_hist
1136 for n in range(1,len(input_hist)-1):
1136 for n in range(1,len(input_hist)-1):
1137 log_write(input_hist[n].rstrip())
1137 log_write(input_hist[n].rstrip())
1138 if n in output_hist:
1138 if n in output_hist:
1139 log_write(repr(output_hist[n]),'output')
1139 log_write(repr(output_hist[n]),'output')
1140 else:
1140 else:
1141 logger.log_write(input_hist[1:])
1141 logger.log_write(input_hist[1:])
1142 if timestamp:
1142 if timestamp:
1143 # re-enable timestamping
1143 # re-enable timestamping
1144 logger.timestamp = True
1144 logger.timestamp = True
1145
1145
1146 print ('Activating auto-logging. '
1146 print ('Activating auto-logging. '
1147 'Current session state plus future input saved.')
1147 'Current session state plus future input saved.')
1148 logger.logstate()
1148 logger.logstate()
1149
1149
1150 def magic_logstop(self,parameter_s=''):
1150 def magic_logstop(self,parameter_s=''):
1151 """Fully stop logging and close log file.
1151 """Fully stop logging and close log file.
1152
1152
1153 In order to start logging again, a new %logstart call needs to be made,
1153 In order to start logging again, a new %logstart call needs to be made,
1154 possibly (though not necessarily) with a new filename, mode and other
1154 possibly (though not necessarily) with a new filename, mode and other
1155 options."""
1155 options."""
1156 self.logger.logstop()
1156 self.logger.logstop()
1157
1157
1158 def magic_logoff(self,parameter_s=''):
1158 def magic_logoff(self,parameter_s=''):
1159 """Temporarily stop logging.
1159 """Temporarily stop logging.
1160
1160
1161 You must have previously started logging."""
1161 You must have previously started logging."""
1162 self.shell.logger.switch_log(0)
1162 self.shell.logger.switch_log(0)
1163
1163
1164 def magic_logon(self,parameter_s=''):
1164 def magic_logon(self,parameter_s=''):
1165 """Restart logging.
1165 """Restart logging.
1166
1166
1167 This function is for restarting logging which you've temporarily
1167 This function is for restarting logging which you've temporarily
1168 stopped with %logoff. For starting logging for the first time, you
1168 stopped with %logoff. For starting logging for the first time, you
1169 must use the %logstart function, which allows you to specify an
1169 must use the %logstart function, which allows you to specify an
1170 optional log filename."""
1170 optional log filename."""
1171
1171
1172 self.shell.logger.switch_log(1)
1172 self.shell.logger.switch_log(1)
1173
1173
1174 def magic_logstate(self,parameter_s=''):
1174 def magic_logstate(self,parameter_s=''):
1175 """Print the status of the logging system."""
1175 """Print the status of the logging system."""
1176
1176
1177 self.shell.logger.logstate()
1177 self.shell.logger.logstate()
1178
1178
1179 def magic_pdb(self, parameter_s=''):
1179 def magic_pdb(self, parameter_s=''):
1180 """Control the automatic calling of the pdb interactive debugger.
1180 """Control the automatic calling of the pdb interactive debugger.
1181
1181
1182 Call as '%pdb on', '%pdb 1', '%pdb off' or '%pdb 0'. If called without
1182 Call as '%pdb on', '%pdb 1', '%pdb off' or '%pdb 0'. If called without
1183 argument it works as a toggle.
1183 argument it works as a toggle.
1184
1184
1185 When an exception is triggered, IPython can optionally call the
1185 When an exception is triggered, IPython can optionally call the
1186 interactive pdb debugger after the traceback printout. %pdb toggles
1186 interactive pdb debugger after the traceback printout. %pdb toggles
1187 this feature on and off.
1187 this feature on and off.
1188
1188
1189 The initial state of this feature is set in your ipythonrc
1189 The initial state of this feature is set in your ipythonrc
1190 configuration file (the variable is called 'pdb').
1190 configuration file (the variable is called 'pdb').
1191
1191
1192 If you want to just activate the debugger AFTER an exception has fired,
1192 If you want to just activate the debugger AFTER an exception has fired,
1193 without having to type '%pdb on' and rerunning your code, you can use
1193 without having to type '%pdb on' and rerunning your code, you can use
1194 the %debug magic."""
1194 the %debug magic."""
1195
1195
1196 par = parameter_s.strip().lower()
1196 par = parameter_s.strip().lower()
1197
1197
1198 if par:
1198 if par:
1199 try:
1199 try:
1200 new_pdb = {'off':0,'0':0,'on':1,'1':1}[par]
1200 new_pdb = {'off':0,'0':0,'on':1,'1':1}[par]
1201 except KeyError:
1201 except KeyError:
1202 print ('Incorrect argument. Use on/1, off/0, '
1202 print ('Incorrect argument. Use on/1, off/0, '
1203 'or nothing for a toggle.')
1203 'or nothing for a toggle.')
1204 return
1204 return
1205 else:
1205 else:
1206 # toggle
1206 # toggle
1207 new_pdb = not self.shell.call_pdb
1207 new_pdb = not self.shell.call_pdb
1208
1208
1209 # set on the shell
1209 # set on the shell
1210 self.shell.call_pdb = new_pdb
1210 self.shell.call_pdb = new_pdb
1211 print 'Automatic pdb calling has been turned',on_off(new_pdb)
1211 print 'Automatic pdb calling has been turned',on_off(new_pdb)
1212
1212
1213 def magic_debug(self, parameter_s=''):
1213 def magic_debug(self, parameter_s=''):
1214 """Activate the interactive debugger in post-mortem mode.
1214 """Activate the interactive debugger in post-mortem mode.
1215
1215
1216 If an exception has just occurred, this lets you inspect its stack
1216 If an exception has just occurred, this lets you inspect its stack
1217 frames interactively. Note that this will always work only on the last
1217 frames interactively. Note that this will always work only on the last
1218 traceback that occurred, so you must call this quickly after an
1218 traceback that occurred, so you must call this quickly after an
1219 exception that you wish to inspect has fired, because if another one
1219 exception that you wish to inspect has fired, because if another one
1220 occurs, it clobbers the previous one.
1220 occurs, it clobbers the previous one.
1221
1221
1222 If you want IPython to automatically do this on every exception, see
1222 If you want IPython to automatically do this on every exception, see
1223 the %pdb magic for more details.
1223 the %pdb magic for more details.
1224 """
1224 """
1225
1225
1226 self.shell.debugger(force=True)
1226 self.shell.debugger(force=True)
1227
1227
1228 def magic_prun(self, parameter_s ='',user_mode=1,
1228 def magic_prun(self, parameter_s ='',user_mode=1,
1229 opts=None,arg_lst=None,prog_ns=None):
1229 opts=None,arg_lst=None,prog_ns=None):
1230
1230
1231 """Run a statement through the python code profiler.
1231 """Run a statement through the python code profiler.
1232
1232
1233 Usage:\\
1233 Usage:\\
1234 %prun [options] statement
1234 %prun [options] statement
1235
1235
1236 The given statement (which doesn't require quote marks) is run via the
1236 The given statement (which doesn't require quote marks) is run via the
1237 python profiler in a manner similar to the profile.run() function.
1237 python profiler in a manner similar to the profile.run() function.
1238 Namespaces are internally managed to work correctly; profile.run
1238 Namespaces are internally managed to work correctly; profile.run
1239 cannot be used in IPython because it makes certain assumptions about
1239 cannot be used in IPython because it makes certain assumptions about
1240 namespaces which do not hold under IPython.
1240 namespaces which do not hold under IPython.
1241
1241
1242 Options:
1242 Options:
1243
1243
1244 -l <limit>: you can place restrictions on what or how much of the
1244 -l <limit>: you can place restrictions on what or how much of the
1245 profile gets printed. The limit value can be:
1245 profile gets printed. The limit value can be:
1246
1246
1247 * A string: only information for function names containing this string
1247 * A string: only information for function names containing this string
1248 is printed.
1248 is printed.
1249
1249
1250 * An integer: only these many lines are printed.
1250 * An integer: only these many lines are printed.
1251
1251
1252 * A float (between 0 and 1): this fraction of the report is printed
1252 * A float (between 0 and 1): this fraction of the report is printed
1253 (for example, use a limit of 0.4 to see the topmost 40% only).
1253 (for example, use a limit of 0.4 to see the topmost 40% only).
1254
1254
1255 You can combine several limits with repeated use of the option. For
1255 You can combine several limits with repeated use of the option. For
1256 example, '-l __init__ -l 5' will print only the topmost 5 lines of
1256 example, '-l __init__ -l 5' will print only the topmost 5 lines of
1257 information about class constructors.
1257 information about class constructors.
1258
1258
1259 -r: return the pstats.Stats object generated by the profiling. This
1259 -r: return the pstats.Stats object generated by the profiling. This
1260 object has all the information about the profile in it, and you can
1260 object has all the information about the profile in it, and you can
1261 later use it for further analysis or in other functions.
1261 later use it for further analysis or in other functions.
1262
1262
1263 -s <key>: sort profile by given key. You can provide more than one key
1263 -s <key>: sort profile by given key. You can provide more than one key
1264 by using the option several times: '-s key1 -s key2 -s key3...'. The
1264 by using the option several times: '-s key1 -s key2 -s key3...'. The
1265 default sorting key is 'time'.
1265 default sorting key is 'time'.
1266
1266
1267 The following is copied verbatim from the profile documentation
1267 The following is copied verbatim from the profile documentation
1268 referenced below:
1268 referenced below:
1269
1269
1270 When more than one key is provided, additional keys are used as
1270 When more than one key is provided, additional keys are used as
1271 secondary criteria when the there is equality in all keys selected
1271 secondary criteria when the there is equality in all keys selected
1272 before them.
1272 before them.
1273
1273
1274 Abbreviations can be used for any key names, as long as the
1274 Abbreviations can be used for any key names, as long as the
1275 abbreviation is unambiguous. The following are the keys currently
1275 abbreviation is unambiguous. The following are the keys currently
1276 defined:
1276 defined:
1277
1277
1278 Valid Arg Meaning\\
1278 Valid Arg Meaning\\
1279 "calls" call count\\
1279 "calls" call count\\
1280 "cumulative" cumulative time\\
1280 "cumulative" cumulative time\\
1281 "file" file name\\
1281 "file" file name\\
1282 "module" file name\\
1282 "module" file name\\
1283 "pcalls" primitive call count\\
1283 "pcalls" primitive call count\\
1284 "line" line number\\
1284 "line" line number\\
1285 "name" function name\\
1285 "name" function name\\
1286 "nfl" name/file/line\\
1286 "nfl" name/file/line\\
1287 "stdname" standard name\\
1287 "stdname" standard name\\
1288 "time" internal time
1288 "time" internal time
1289
1289
1290 Note that all sorts on statistics are in descending order (placing
1290 Note that all sorts on statistics are in descending order (placing
1291 most time consuming items first), where as name, file, and line number
1291 most time consuming items first), where as name, file, and line number
1292 searches are in ascending order (i.e., alphabetical). The subtle
1292 searches are in ascending order (i.e., alphabetical). The subtle
1293 distinction between "nfl" and "stdname" is that the standard name is a
1293 distinction between "nfl" and "stdname" is that the standard name is a
1294 sort of the name as printed, which means that the embedded line
1294 sort of the name as printed, which means that the embedded line
1295 numbers get compared in an odd way. For example, lines 3, 20, and 40
1295 numbers get compared in an odd way. For example, lines 3, 20, and 40
1296 would (if the file names were the same) appear in the string order
1296 would (if the file names were the same) appear in the string order
1297 "20" "3" and "40". In contrast, "nfl" does a numeric compare of the
1297 "20" "3" and "40". In contrast, "nfl" does a numeric compare of the
1298 line numbers. In fact, sort_stats("nfl") is the same as
1298 line numbers. In fact, sort_stats("nfl") is the same as
1299 sort_stats("name", "file", "line").
1299 sort_stats("name", "file", "line").
1300
1300
1301 -T <filename>: save profile results as shown on screen to a text
1301 -T <filename>: save profile results as shown on screen to a text
1302 file. The profile is still shown on screen.
1302 file. The profile is still shown on screen.
1303
1303
1304 -D <filename>: save (via dump_stats) profile statistics to given
1304 -D <filename>: save (via dump_stats) profile statistics to given
1305 filename. This data is in a format understod by the pstats module, and
1305 filename. This data is in a format understod by the pstats module, and
1306 is generated by a call to the dump_stats() method of profile
1306 is generated by a call to the dump_stats() method of profile
1307 objects. The profile is still shown on screen.
1307 objects. The profile is still shown on screen.
1308
1308
1309 If you want to run complete programs under the profiler's control, use
1309 If you want to run complete programs under the profiler's control, use
1310 '%run -p [prof_opts] filename.py [args to program]' where prof_opts
1310 '%run -p [prof_opts] filename.py [args to program]' where prof_opts
1311 contains profiler specific options as described here.
1311 contains profiler specific options as described here.
1312
1312
1313 You can read the complete documentation for the profile module with:\\
1313 You can read the complete documentation for the profile module with:\\
1314 In [1]: import profile; profile.help() """
1314 In [1]: import profile; profile.help() """
1315
1315
1316 opts_def = Struct(D=[''],l=[],s=['time'],T=[''])
1316 opts_def = Struct(D=[''],l=[],s=['time'],T=[''])
1317 # protect user quote marks
1317 # protect user quote marks
1318 parameter_s = parameter_s.replace('"',r'\"').replace("'",r"\'")
1318 parameter_s = parameter_s.replace('"',r'\"').replace("'",r"\'")
1319
1319
1320 if user_mode: # regular user call
1320 if user_mode: # regular user call
1321 opts,arg_str = self.parse_options(parameter_s,'D:l:rs:T:',
1321 opts,arg_str = self.parse_options(parameter_s,'D:l:rs:T:',
1322 list_all=1)
1322 list_all=1)
1323 namespace = self.shell.user_ns
1323 namespace = self.shell.user_ns
1324 else: # called to run a program by %run -p
1324 else: # called to run a program by %run -p
1325 try:
1325 try:
1326 filename = get_py_filename(arg_lst[0])
1326 filename = get_py_filename(arg_lst[0])
1327 except IOError,msg:
1327 except IOError,msg:
1328 error(msg)
1328 error(msg)
1329 return
1329 return
1330
1330
1331 arg_str = 'execfile(filename,prog_ns)'
1331 arg_str = 'execfile(filename,prog_ns)'
1332 namespace = locals()
1332 namespace = locals()
1333
1333
1334 opts.merge(opts_def)
1334 opts.merge(opts_def)
1335
1335
1336 prof = profile.Profile()
1336 prof = profile.Profile()
1337 try:
1337 try:
1338 prof = prof.runctx(arg_str,namespace,namespace)
1338 prof = prof.runctx(arg_str,namespace,namespace)
1339 sys_exit = ''
1339 sys_exit = ''
1340 except SystemExit:
1340 except SystemExit:
1341 sys_exit = """*** SystemExit exception caught in code being profiled."""
1341 sys_exit = """*** SystemExit exception caught in code being profiled."""
1342
1342
1343 stats = pstats.Stats(prof).strip_dirs().sort_stats(*opts.s)
1343 stats = pstats.Stats(prof).strip_dirs().sort_stats(*opts.s)
1344
1344
1345 lims = opts.l
1345 lims = opts.l
1346 if lims:
1346 if lims:
1347 lims = [] # rebuild lims with ints/floats/strings
1347 lims = [] # rebuild lims with ints/floats/strings
1348 for lim in opts.l:
1348 for lim in opts.l:
1349 try:
1349 try:
1350 lims.append(int(lim))
1350 lims.append(int(lim))
1351 except ValueError:
1351 except ValueError:
1352 try:
1352 try:
1353 lims.append(float(lim))
1353 lims.append(float(lim))
1354 except ValueError:
1354 except ValueError:
1355 lims.append(lim)
1355 lims.append(lim)
1356
1356
1357 # Trap output.
1357 # Trap output.
1358 stdout_trap = StringIO()
1358 stdout_trap = StringIO()
1359
1359
1360 if hasattr(stats,'stream'):
1360 if hasattr(stats,'stream'):
1361 # In newer versions of python, the stats object has a 'stream'
1361 # In newer versions of python, the stats object has a 'stream'
1362 # attribute to write into.
1362 # attribute to write into.
1363 stats.stream = stdout_trap
1363 stats.stream = stdout_trap
1364 stats.print_stats(*lims)
1364 stats.print_stats(*lims)
1365 else:
1365 else:
1366 # For older versions, we manually redirect stdout during printing
1366 # For older versions, we manually redirect stdout during printing
1367 sys_stdout = sys.stdout
1367 sys_stdout = sys.stdout
1368 try:
1368 try:
1369 sys.stdout = stdout_trap
1369 sys.stdout = stdout_trap
1370 stats.print_stats(*lims)
1370 stats.print_stats(*lims)
1371 finally:
1371 finally:
1372 sys.stdout = sys_stdout
1372 sys.stdout = sys_stdout
1373
1373
1374 output = stdout_trap.getvalue()
1374 output = stdout_trap.getvalue()
1375 output = output.rstrip()
1375 output = output.rstrip()
1376
1376
1377 page(output,screen_lines=self.shell.rc.screen_length)
1377 page(output,screen_lines=self.shell.rc.screen_length)
1378 print sys_exit,
1378 print sys_exit,
1379
1379
1380 dump_file = opts.D[0]
1380 dump_file = opts.D[0]
1381 text_file = opts.T[0]
1381 text_file = opts.T[0]
1382 if dump_file:
1382 if dump_file:
1383 prof.dump_stats(dump_file)
1383 prof.dump_stats(dump_file)
1384 print '\n*** Profile stats marshalled to file',\
1384 print '\n*** Profile stats marshalled to file',\
1385 `dump_file`+'.',sys_exit
1385 `dump_file`+'.',sys_exit
1386 if text_file:
1386 if text_file:
1387 pfile = file(text_file,'w')
1387 pfile = file(text_file,'w')
1388 pfile.write(output)
1388 pfile.write(output)
1389 pfile.close()
1389 pfile.close()
1390 print '\n*** Profile printout saved to text file',\
1390 print '\n*** Profile printout saved to text file',\
1391 `text_file`+'.',sys_exit
1391 `text_file`+'.',sys_exit
1392
1392
1393 if opts.has_key('r'):
1393 if opts.has_key('r'):
1394 return stats
1394 return stats
1395 else:
1395 else:
1396 return None
1396 return None
1397
1397
1398 def magic_run(self, parameter_s ='',runner=None):
1398 def magic_run(self, parameter_s ='',runner=None):
1399 """Run the named file inside IPython as a program.
1399 """Run the named file inside IPython as a program.
1400
1400
1401 Usage:\\
1401 Usage:\\
1402 %run [-n -i -t [-N<N>] -d [-b<N>] -p [profile options]] file [args]
1402 %run [-n -i -t [-N<N>] -d [-b<N>] -p [profile options]] file [args]
1403
1403
1404 Parameters after the filename are passed as command-line arguments to
1404 Parameters after the filename are passed as command-line arguments to
1405 the program (put in sys.argv). Then, control returns to IPython's
1405 the program (put in sys.argv). Then, control returns to IPython's
1406 prompt.
1406 prompt.
1407
1407
1408 This is similar to running at a system prompt:\\
1408 This is similar to running at a system prompt:\\
1409 $ python file args\\
1409 $ python file args\\
1410 but with the advantage of giving you IPython's tracebacks, and of
1410 but with the advantage of giving you IPython's tracebacks, and of
1411 loading all variables into your interactive namespace for further use
1411 loading all variables into your interactive namespace for further use
1412 (unless -p is used, see below).
1412 (unless -p is used, see below).
1413
1413
1414 The file is executed in a namespace initially consisting only of
1414 The file is executed in a namespace initially consisting only of
1415 __name__=='__main__' and sys.argv constructed as indicated. It thus
1415 __name__=='__main__' and sys.argv constructed as indicated. It thus
1416 sees its environment as if it were being run as a stand-alone program
1416 sees its environment as if it were being run as a stand-alone program
1417 (except for sharing global objects such as previously imported
1417 (except for sharing global objects such as previously imported
1418 modules). But after execution, the IPython interactive namespace gets
1418 modules). But after execution, the IPython interactive namespace gets
1419 updated with all variables defined in the program (except for __name__
1419 updated with all variables defined in the program (except for __name__
1420 and sys.argv). This allows for very convenient loading of code for
1420 and sys.argv). This allows for very convenient loading of code for
1421 interactive work, while giving each program a 'clean sheet' to run in.
1421 interactive work, while giving each program a 'clean sheet' to run in.
1422
1422
1423 Options:
1423 Options:
1424
1424
1425 -n: __name__ is NOT set to '__main__', but to the running file's name
1425 -n: __name__ is NOT set to '__main__', but to the running file's name
1426 without extension (as python does under import). This allows running
1426 without extension (as python does under import). This allows running
1427 scripts and reloading the definitions in them without calling code
1427 scripts and reloading the definitions in them without calling code
1428 protected by an ' if __name__ == "__main__" ' clause.
1428 protected by an ' if __name__ == "__main__" ' clause.
1429
1429
1430 -i: run the file in IPython's namespace instead of an empty one. This
1430 -i: run the file in IPython's namespace instead of an empty one. This
1431 is useful if you are experimenting with code written in a text editor
1431 is useful if you are experimenting with code written in a text editor
1432 which depends on variables defined interactively.
1432 which depends on variables defined interactively.
1433
1433
1434 -e: ignore sys.exit() calls or SystemExit exceptions in the script
1434 -e: ignore sys.exit() calls or SystemExit exceptions in the script
1435 being run. This is particularly useful if IPython is being used to
1435 being run. This is particularly useful if IPython is being used to
1436 run unittests, which always exit with a sys.exit() call. In such
1436 run unittests, which always exit with a sys.exit() call. In such
1437 cases you are interested in the output of the test results, not in
1437 cases you are interested in the output of the test results, not in
1438 seeing a traceback of the unittest module.
1438 seeing a traceback of the unittest module.
1439
1439
1440 -t: print timing information at the end of the run. IPython will give
1440 -t: print timing information at the end of the run. IPython will give
1441 you an estimated CPU time consumption for your script, which under
1441 you an estimated CPU time consumption for your script, which under
1442 Unix uses the resource module to avoid the wraparound problems of
1442 Unix uses the resource module to avoid the wraparound problems of
1443 time.clock(). Under Unix, an estimate of time spent on system tasks
1443 time.clock(). Under Unix, an estimate of time spent on system tasks
1444 is also given (for Windows platforms this is reported as 0.0).
1444 is also given (for Windows platforms this is reported as 0.0).
1445
1445
1446 If -t is given, an additional -N<N> option can be given, where <N>
1446 If -t is given, an additional -N<N> option can be given, where <N>
1447 must be an integer indicating how many times you want the script to
1447 must be an integer indicating how many times you want the script to
1448 run. The final timing report will include total and per run results.
1448 run. The final timing report will include total and per run results.
1449
1449
1450 For example (testing the script uniq_stable.py):
1450 For example (testing the script uniq_stable.py):
1451
1451
1452 In [1]: run -t uniq_stable
1452 In [1]: run -t uniq_stable
1453
1453
1454 IPython CPU timings (estimated):\\
1454 IPython CPU timings (estimated):\\
1455 User : 0.19597 s.\\
1455 User : 0.19597 s.\\
1456 System: 0.0 s.\\
1456 System: 0.0 s.\\
1457
1457
1458 In [2]: run -t -N5 uniq_stable
1458 In [2]: run -t -N5 uniq_stable
1459
1459
1460 IPython CPU timings (estimated):\\
1460 IPython CPU timings (estimated):\\
1461 Total runs performed: 5\\
1461 Total runs performed: 5\\
1462 Times : Total Per run\\
1462 Times : Total Per run\\
1463 User : 0.910862 s, 0.1821724 s.\\
1463 User : 0.910862 s, 0.1821724 s.\\
1464 System: 0.0 s, 0.0 s.
1464 System: 0.0 s, 0.0 s.
1465
1465
1466 -d: run your program under the control of pdb, the Python debugger.
1466 -d: run your program under the control of pdb, the Python debugger.
1467 This allows you to execute your program step by step, watch variables,
1467 This allows you to execute your program step by step, watch variables,
1468 etc. Internally, what IPython does is similar to calling:
1468 etc. Internally, what IPython does is similar to calling:
1469
1469
1470 pdb.run('execfile("YOURFILENAME")')
1470 pdb.run('execfile("YOURFILENAME")')
1471
1471
1472 with a breakpoint set on line 1 of your file. You can change the line
1472 with a breakpoint set on line 1 of your file. You can change the line
1473 number for this automatic breakpoint to be <N> by using the -bN option
1473 number for this automatic breakpoint to be <N> by using the -bN option
1474 (where N must be an integer). For example:
1474 (where N must be an integer). For example:
1475
1475
1476 %run -d -b40 myscript
1476 %run -d -b40 myscript
1477
1477
1478 will set the first breakpoint at line 40 in myscript.py. Note that
1478 will set the first breakpoint at line 40 in myscript.py. Note that
1479 the first breakpoint must be set on a line which actually does
1479 the first breakpoint must be set on a line which actually does
1480 something (not a comment or docstring) for it to stop execution.
1480 something (not a comment or docstring) for it to stop execution.
1481
1481
1482 When the pdb debugger starts, you will see a (Pdb) prompt. You must
1482 When the pdb debugger starts, you will see a (Pdb) prompt. You must
1483 first enter 'c' (without qoutes) to start execution up to the first
1483 first enter 'c' (without qoutes) to start execution up to the first
1484 breakpoint.
1484 breakpoint.
1485
1485
1486 Entering 'help' gives information about the use of the debugger. You
1486 Entering 'help' gives information about the use of the debugger. You
1487 can easily see pdb's full documentation with "import pdb;pdb.help()"
1487 can easily see pdb's full documentation with "import pdb;pdb.help()"
1488 at a prompt.
1488 at a prompt.
1489
1489
1490 -p: run program under the control of the Python profiler module (which
1490 -p: run program under the control of the Python profiler module (which
1491 prints a detailed report of execution times, function calls, etc).
1491 prints a detailed report of execution times, function calls, etc).
1492
1492
1493 You can pass other options after -p which affect the behavior of the
1493 You can pass other options after -p which affect the behavior of the
1494 profiler itself. See the docs for %prun for details.
1494 profiler itself. See the docs for %prun for details.
1495
1495
1496 In this mode, the program's variables do NOT propagate back to the
1496 In this mode, the program's variables do NOT propagate back to the
1497 IPython interactive namespace (because they remain in the namespace
1497 IPython interactive namespace (because they remain in the namespace
1498 where the profiler executes them).
1498 where the profiler executes them).
1499
1499
1500 Internally this triggers a call to %prun, see its documentation for
1500 Internally this triggers a call to %prun, see its documentation for
1501 details on the options available specifically for profiling.
1501 details on the options available specifically for profiling.
1502
1502
1503 There is one special usage for which the text above doesn't apply:
1503 There is one special usage for which the text above doesn't apply:
1504 if the filename ends with .ipy, the file is run as ipython script,
1504 if the filename ends with .ipy, the file is run as ipython script,
1505 just as if the commands were written on IPython prompt.
1505 just as if the commands were written on IPython prompt.
1506 """
1506 """
1507
1507
1508 # get arguments and set sys.argv for program to be run.
1508 # get arguments and set sys.argv for program to be run.
1509 opts,arg_lst = self.parse_options(parameter_s,'nidtN:b:pD:l:rs:T:e',
1509 opts,arg_lst = self.parse_options(parameter_s,'nidtN:b:pD:l:rs:T:e',
1510 mode='list',list_all=1)
1510 mode='list',list_all=1)
1511
1511
1512 try:
1512 try:
1513 filename = get_py_filename(arg_lst[0])
1513 filename = get_py_filename(arg_lst[0])
1514 except IndexError:
1514 except IndexError:
1515 warn('you must provide at least a filename.')
1515 warn('you must provide at least a filename.')
1516 print '\n%run:\n',OInspect.getdoc(self.magic_run)
1516 print '\n%run:\n',OInspect.getdoc(self.magic_run)
1517 return
1517 return
1518 except IOError,msg:
1518 except IOError,msg:
1519 error(msg)
1519 error(msg)
1520 return
1520 return
1521
1521
1522 if filename.lower().endswith('.ipy'):
1522 if filename.lower().endswith('.ipy'):
1523 self.api.runlines(open(filename).read())
1523 self.api.runlines(open(filename).read())
1524 return
1524 return
1525
1525
1526 # Control the response to exit() calls made by the script being run
1526 # Control the response to exit() calls made by the script being run
1527 exit_ignore = opts.has_key('e')
1527 exit_ignore = opts.has_key('e')
1528
1528
1529 # Make sure that the running script gets a proper sys.argv as if it
1529 # Make sure that the running script gets a proper sys.argv as if it
1530 # were run from a system shell.
1530 # were run from a system shell.
1531 save_argv = sys.argv # save it for later restoring
1531 save_argv = sys.argv # save it for later restoring
1532 sys.argv = [filename]+ arg_lst[1:] # put in the proper filename
1532 sys.argv = [filename]+ arg_lst[1:] # put in the proper filename
1533
1533
1534 if opts.has_key('i'):
1534 if opts.has_key('i'):
1535 # Run in user's interactive namespace
1535 # Run in user's interactive namespace
1536 prog_ns = self.shell.user_ns
1536 prog_ns = self.shell.user_ns
1537 __name__save = self.shell.user_ns['__name__']
1537 __name__save = self.shell.user_ns['__name__']
1538 prog_ns['__name__'] = '__main__'
1538 prog_ns['__name__'] = '__main__'
1539 main_mod = FakeModule(prog_ns)
1539 main_mod = FakeModule(prog_ns)
1540 else:
1540 else:
1541 # Run in a fresh, empty namespace
1541 # Run in a fresh, empty namespace
1542 if opts.has_key('n'):
1542 if opts.has_key('n'):
1543 name = os.path.splitext(os.path.basename(filename))[0]
1543 name = os.path.splitext(os.path.basename(filename))[0]
1544 else:
1544 else:
1545 name = '__main__'
1545 name = '__main__'
1546 main_mod = FakeModule()
1546 main_mod = FakeModule()
1547 prog_ns = main_mod.__dict__
1547 prog_ns = main_mod.__dict__
1548 prog_ns['__name__'] = name
1548 prog_ns['__name__'] = name
1549 # The shell MUST hold a reference to main_mod so after %run exits,
1549 # The shell MUST hold a reference to main_mod so after %run exits,
1550 # the python deletion mechanism doesn't zero it out (leaving
1550 # the python deletion mechanism doesn't zero it out (leaving
1551 # dangling references)
1551 # dangling references)
1552 self.shell._user_main_modules.append(main_mod)
1552 self.shell._user_main_modules.append(main_mod)
1553
1553
1554 # Since '%run foo' emulates 'python foo.py' at the cmd line, we must
1554 # Since '%run foo' emulates 'python foo.py' at the cmd line, we must
1555 # set the __file__ global in the script's namespace
1555 # set the __file__ global in the script's namespace
1556 prog_ns['__file__'] = filename
1556 prog_ns['__file__'] = filename
1557
1557
1558 # pickle fix. See iplib for an explanation. But we need to make sure
1558 # pickle fix. See iplib for an explanation. But we need to make sure
1559 # that, if we overwrite __main__, we replace it at the end
1559 # that, if we overwrite __main__, we replace it at the end
1560 if prog_ns['__name__'] == '__main__':
1560 if prog_ns['__name__'] == '__main__':
1561 restore_main = sys.modules['__main__']
1561 restore_main = sys.modules['__main__']
1562 else:
1562 else:
1563 restore_main = False
1563 restore_main = False
1564
1564
1565 sys.modules[prog_ns['__name__']] = main_mod
1565 sys.modules[prog_ns['__name__']] = main_mod
1566
1566
1567 stats = None
1567 stats = None
1568 try:
1568 try:
1569 self.shell.savehist()
1569 self.shell.savehist()
1570
1570
1571 if opts.has_key('p'):
1571 if opts.has_key('p'):
1572 stats = self.magic_prun('',0,opts,arg_lst,prog_ns)
1572 stats = self.magic_prun('',0,opts,arg_lst,prog_ns)
1573 else:
1573 else:
1574 if opts.has_key('d'):
1574 if opts.has_key('d'):
1575 deb = Debugger.Pdb(self.shell.rc.colors)
1575 deb = Debugger.Pdb(self.shell.rc.colors)
1576 # reset Breakpoint state, which is moronically kept
1576 # reset Breakpoint state, which is moronically kept
1577 # in a class
1577 # in a class
1578 bdb.Breakpoint.next = 1
1578 bdb.Breakpoint.next = 1
1579 bdb.Breakpoint.bplist = {}
1579 bdb.Breakpoint.bplist = {}
1580 bdb.Breakpoint.bpbynumber = [None]
1580 bdb.Breakpoint.bpbynumber = [None]
1581 # Set an initial breakpoint to stop execution
1581 # Set an initial breakpoint to stop execution
1582 maxtries = 10
1582 maxtries = 10
1583 bp = int(opts.get('b',[1])[0])
1583 bp = int(opts.get('b',[1])[0])
1584 checkline = deb.checkline(filename,bp)
1584 checkline = deb.checkline(filename,bp)
1585 if not checkline:
1585 if not checkline:
1586 for bp in range(bp+1,bp+maxtries+1):
1586 for bp in range(bp+1,bp+maxtries+1):
1587 if deb.checkline(filename,bp):
1587 if deb.checkline(filename,bp):
1588 break
1588 break
1589 else:
1589 else:
1590 msg = ("\nI failed to find a valid line to set "
1590 msg = ("\nI failed to find a valid line to set "
1591 "a breakpoint\n"
1591 "a breakpoint\n"
1592 "after trying up to line: %s.\n"
1592 "after trying up to line: %s.\n"
1593 "Please set a valid breakpoint manually "
1593 "Please set a valid breakpoint manually "
1594 "with the -b option." % bp)
1594 "with the -b option." % bp)
1595 error(msg)
1595 error(msg)
1596 return
1596 return
1597 # if we find a good linenumber, set the breakpoint
1597 # if we find a good linenumber, set the breakpoint
1598 deb.do_break('%s:%s' % (filename,bp))
1598 deb.do_break('%s:%s' % (filename,bp))
1599 # Start file run
1599 # Start file run
1600 print "NOTE: Enter 'c' at the",
1600 print "NOTE: Enter 'c' at the",
1601 print "%s prompt to start your script." % deb.prompt
1601 print "%s prompt to start your script." % deb.prompt
1602 try:
1602 try:
1603 deb.run('execfile("%s")' % filename,prog_ns)
1603 deb.run('execfile("%s")' % filename,prog_ns)
1604
1604
1605 except:
1605 except:
1606 etype, value, tb = sys.exc_info()
1606 etype, value, tb = sys.exc_info()
1607 # Skip three frames in the traceback: the %run one,
1607 # Skip three frames in the traceback: the %run one,
1608 # one inside bdb.py, and the command-line typed by the
1608 # one inside bdb.py, and the command-line typed by the
1609 # user (run by exec in pdb itself).
1609 # user (run by exec in pdb itself).
1610 self.shell.InteractiveTB(etype,value,tb,tb_offset=3)
1610 self.shell.InteractiveTB(etype,value,tb,tb_offset=3)
1611 else:
1611 else:
1612 if runner is None:
1612 if runner is None:
1613 runner = self.shell.safe_execfile
1613 runner = self.shell.safe_execfile
1614 if opts.has_key('t'):
1614 if opts.has_key('t'):
1615 # timed execution
1615 # timed execution
1616 try:
1616 try:
1617 nruns = int(opts['N'][0])
1617 nruns = int(opts['N'][0])
1618 if nruns < 1:
1618 if nruns < 1:
1619 error('Number of runs must be >=1')
1619 error('Number of runs must be >=1')
1620 return
1620 return
1621 except (KeyError):
1621 except (KeyError):
1622 nruns = 1
1622 nruns = 1
1623 if nruns == 1:
1623 if nruns == 1:
1624 t0 = clock2()
1624 t0 = clock2()
1625 runner(filename,prog_ns,prog_ns,
1625 runner(filename,prog_ns,prog_ns,
1626 exit_ignore=exit_ignore)
1626 exit_ignore=exit_ignore)
1627 t1 = clock2()
1627 t1 = clock2()
1628 t_usr = t1[0]-t0[0]
1628 t_usr = t1[0]-t0[0]
1629 t_sys = t1[1]-t1[1]
1629 t_sys = t1[1]-t1[1]
1630 print "\nIPython CPU timings (estimated):"
1630 print "\nIPython CPU timings (estimated):"
1631 print " User : %10s s." % t_usr
1631 print " User : %10s s." % t_usr
1632 print " System: %10s s." % t_sys
1632 print " System: %10s s." % t_sys
1633 else:
1633 else:
1634 runs = range(nruns)
1634 runs = range(nruns)
1635 t0 = clock2()
1635 t0 = clock2()
1636 for nr in runs:
1636 for nr in runs:
1637 runner(filename,prog_ns,prog_ns,
1637 runner(filename,prog_ns,prog_ns,
1638 exit_ignore=exit_ignore)
1638 exit_ignore=exit_ignore)
1639 t1 = clock2()
1639 t1 = clock2()
1640 t_usr = t1[0]-t0[0]
1640 t_usr = t1[0]-t0[0]
1641 t_sys = t1[1]-t1[1]
1641 t_sys = t1[1]-t1[1]
1642 print "\nIPython CPU timings (estimated):"
1642 print "\nIPython CPU timings (estimated):"
1643 print "Total runs performed:",nruns
1643 print "Total runs performed:",nruns
1644 print " Times : %10s %10s" % ('Total','Per run')
1644 print " Times : %10s %10s" % ('Total','Per run')
1645 print " User : %10s s, %10s s." % (t_usr,t_usr/nruns)
1645 print " User : %10s s, %10s s." % (t_usr,t_usr/nruns)
1646 print " System: %10s s, %10s s." % (t_sys,t_sys/nruns)
1646 print " System: %10s s, %10s s." % (t_sys,t_sys/nruns)
1647
1647
1648 else:
1648 else:
1649 # regular execution
1649 # regular execution
1650 runner(filename,prog_ns,prog_ns,exit_ignore=exit_ignore)
1650 runner(filename,prog_ns,prog_ns,exit_ignore=exit_ignore)
1651 if opts.has_key('i'):
1651 if opts.has_key('i'):
1652 self.shell.user_ns['__name__'] = __name__save
1652 self.shell.user_ns['__name__'] = __name__save
1653 else:
1653 else:
1654 # update IPython interactive namespace
1654 # update IPython interactive namespace
1655 del prog_ns['__name__']
1655 del prog_ns['__name__']
1656 self.shell.user_ns.update(prog_ns)
1656 self.shell.user_ns.update(prog_ns)
1657 finally:
1657 finally:
1658 sys.argv = save_argv
1658 sys.argv = save_argv
1659 if restore_main:
1659 if restore_main:
1660 sys.modules['__main__'] = restore_main
1660 sys.modules['__main__'] = restore_main
1661 self.shell.reloadhist()
1661 self.shell.reloadhist()
1662
1662
1663 return stats
1663 return stats
1664
1664
1665 def magic_runlog(self, parameter_s =''):
1665 def magic_runlog(self, parameter_s =''):
1666 """Run files as logs.
1666 """Run files as logs.
1667
1667
1668 Usage:\\
1668 Usage:\\
1669 %runlog file1 file2 ...
1669 %runlog file1 file2 ...
1670
1670
1671 Run the named files (treating them as log files) in sequence inside
1671 Run the named files (treating them as log files) in sequence inside
1672 the interpreter, and return to the prompt. This is much slower than
1672 the interpreter, and return to the prompt. This is much slower than
1673 %run because each line is executed in a try/except block, but it
1673 %run because each line is executed in a try/except block, but it
1674 allows running files with syntax errors in them.
1674 allows running files with syntax errors in them.
1675
1675
1676 Normally IPython will guess when a file is one of its own logfiles, so
1676 Normally IPython will guess when a file is one of its own logfiles, so
1677 you can typically use %run even for logs. This shorthand allows you to
1677 you can typically use %run even for logs. This shorthand allows you to
1678 force any file to be treated as a log file."""
1678 force any file to be treated as a log file."""
1679
1679
1680 for f in parameter_s.split():
1680 for f in parameter_s.split():
1681 self.shell.safe_execfile(f,self.shell.user_ns,
1681 self.shell.safe_execfile(f,self.shell.user_ns,
1682 self.shell.user_ns,islog=1)
1682 self.shell.user_ns,islog=1)
1683
1683
1684 def magic_timeit(self, parameter_s =''):
1684 def magic_timeit(self, parameter_s =''):
1685 """Time execution of a Python statement or expression
1685 """Time execution of a Python statement or expression
1686
1686
1687 Usage:\\
1687 Usage:\\
1688 %timeit [-n<N> -r<R> [-t|-c]] statement
1688 %timeit [-n<N> -r<R> [-t|-c]] statement
1689
1689
1690 Time execution of a Python statement or expression using the timeit
1690 Time execution of a Python statement or expression using the timeit
1691 module.
1691 module.
1692
1692
1693 Options:
1693 Options:
1694 -n<N>: execute the given statement <N> times in a loop. If this value
1694 -n<N>: execute the given statement <N> times in a loop. If this value
1695 is not given, a fitting value is chosen.
1695 is not given, a fitting value is chosen.
1696
1696
1697 -r<R>: repeat the loop iteration <R> times and take the best result.
1697 -r<R>: repeat the loop iteration <R> times and take the best result.
1698 Default: 3
1698 Default: 3
1699
1699
1700 -t: use time.time to measure the time, which is the default on Unix.
1700 -t: use time.time to measure the time, which is the default on Unix.
1701 This function measures wall time.
1701 This function measures wall time.
1702
1702
1703 -c: use time.clock to measure the time, which is the default on
1703 -c: use time.clock to measure the time, which is the default on
1704 Windows and measures wall time. On Unix, resource.getrusage is used
1704 Windows and measures wall time. On Unix, resource.getrusage is used
1705 instead and returns the CPU user time.
1705 instead and returns the CPU user time.
1706
1706
1707 -p<P>: use a precision of <P> digits to display the timing result.
1707 -p<P>: use a precision of <P> digits to display the timing result.
1708 Default: 3
1708 Default: 3
1709
1709
1710
1710
1711 Examples:\\
1711 Examples:\\
1712 In [1]: %timeit pass
1712 In [1]: %timeit pass
1713 10000000 loops, best of 3: 53.3 ns per loop
1713 10000000 loops, best of 3: 53.3 ns per loop
1714
1714
1715 In [2]: u = None
1715 In [2]: u = None
1716
1716
1717 In [3]: %timeit u is None
1717 In [3]: %timeit u is None
1718 10000000 loops, best of 3: 184 ns per loop
1718 10000000 loops, best of 3: 184 ns per loop
1719
1719
1720 In [4]: %timeit -r 4 u == None
1720 In [4]: %timeit -r 4 u == None
1721 1000000 loops, best of 4: 242 ns per loop
1721 1000000 loops, best of 4: 242 ns per loop
1722
1722
1723 In [5]: import time
1723 In [5]: import time
1724
1724
1725 In [6]: %timeit -n1 time.sleep(2)
1725 In [6]: %timeit -n1 time.sleep(2)
1726 1 loops, best of 3: 2 s per loop
1726 1 loops, best of 3: 2 s per loop
1727
1727
1728
1728
1729 The times reported by %timeit will be slightly higher than those
1729 The times reported by %timeit will be slightly higher than those
1730 reported by the timeit.py script when variables are accessed. This is
1730 reported by the timeit.py script when variables are accessed. This is
1731 due to the fact that %timeit executes the statement in the namespace
1731 due to the fact that %timeit executes the statement in the namespace
1732 of the shell, compared with timeit.py, which uses a single setup
1732 of the shell, compared with timeit.py, which uses a single setup
1733 statement to import function or create variables. Generally, the bias
1733 statement to import function or create variables. Generally, the bias
1734 does not matter as long as results from timeit.py are not mixed with
1734 does not matter as long as results from timeit.py are not mixed with
1735 those from %timeit."""
1735 those from %timeit."""
1736
1736
1737 import timeit
1737 import timeit
1738 import math
1738 import math
1739
1739
1740 units = ["s", "ms", "\xc2\xb5s", "ns"]
1740 units = ["s", "ms", "\xc2\xb5s", "ns"]
1741 scaling = [1, 1e3, 1e6, 1e9]
1741 scaling = [1, 1e3, 1e6, 1e9]
1742
1742
1743 opts, stmt = self.parse_options(parameter_s,'n:r:tcp:',
1743 opts, stmt = self.parse_options(parameter_s,'n:r:tcp:',
1744 posix=False)
1744 posix=False)
1745 if stmt == "":
1745 if stmt == "":
1746 return
1746 return
1747 timefunc = timeit.default_timer
1747 timefunc = timeit.default_timer
1748 number = int(getattr(opts, "n", 0))
1748 number = int(getattr(opts, "n", 0))
1749 repeat = int(getattr(opts, "r", timeit.default_repeat))
1749 repeat = int(getattr(opts, "r", timeit.default_repeat))
1750 precision = int(getattr(opts, "p", 3))
1750 precision = int(getattr(opts, "p", 3))
1751 if hasattr(opts, "t"):
1751 if hasattr(opts, "t"):
1752 timefunc = time.time
1752 timefunc = time.time
1753 if hasattr(opts, "c"):
1753 if hasattr(opts, "c"):
1754 timefunc = clock
1754 timefunc = clock
1755
1755
1756 timer = timeit.Timer(timer=timefunc)
1756 timer = timeit.Timer(timer=timefunc)
1757 # this code has tight coupling to the inner workings of timeit.Timer,
1757 # this code has tight coupling to the inner workings of timeit.Timer,
1758 # but is there a better way to achieve that the code stmt has access
1758 # but is there a better way to achieve that the code stmt has access
1759 # to the shell namespace?
1759 # to the shell namespace?
1760
1760
1761 src = timeit.template % {'stmt': timeit.reindent(stmt, 8),
1761 src = timeit.template % {'stmt': timeit.reindent(stmt, 8),
1762 'setup': "pass"}
1762 'setup': "pass"}
1763 # Track compilation time so it can be reported if too long
1763 # Track compilation time so it can be reported if too long
1764 # Minimum time above which compilation time will be reported
1764 # Minimum time above which compilation time will be reported
1765 tc_min = 0.1
1765 tc_min = 0.1
1766
1766
1767 t0 = clock()
1767 t0 = clock()
1768 code = compile(src, "<magic-timeit>", "exec")
1768 code = compile(src, "<magic-timeit>", "exec")
1769 tc = clock()-t0
1769 tc = clock()-t0
1770
1770
1771 ns = {}
1771 ns = {}
1772 exec code in self.shell.user_ns, ns
1772 exec code in self.shell.user_ns, ns
1773 timer.inner = ns["inner"]
1773 timer.inner = ns["inner"]
1774
1774
1775 if number == 0:
1775 if number == 0:
1776 # determine number so that 0.2 <= total time < 2.0
1776 # determine number so that 0.2 <= total time < 2.0
1777 number = 1
1777 number = 1
1778 for i in range(1, 10):
1778 for i in range(1, 10):
1779 number *= 10
1779 number *= 10
1780 if timer.timeit(number) >= 0.2:
1780 if timer.timeit(number) >= 0.2:
1781 break
1781 break
1782
1782
1783 best = min(timer.repeat(repeat, number)) / number
1783 best = min(timer.repeat(repeat, number)) / number
1784
1784
1785 if best > 0.0:
1785 if best > 0.0:
1786 order = min(-int(math.floor(math.log10(best)) // 3), 3)
1786 order = min(-int(math.floor(math.log10(best)) // 3), 3)
1787 else:
1787 else:
1788 order = 3
1788 order = 3
1789 print "%d loops, best of %d: %.*g %s per loop" % (number, repeat,
1789 print "%d loops, best of %d: %.*g %s per loop" % (number, repeat,
1790 precision,
1790 precision,
1791 best * scaling[order],
1791 best * scaling[order],
1792 units[order])
1792 units[order])
1793 if tc > tc_min:
1793 if tc > tc_min:
1794 print "Compiler time: %.2f s" % tc
1794 print "Compiler time: %.2f s" % tc
1795
1795
1796 def magic_time(self,parameter_s = ''):
1796 def magic_time(self,parameter_s = ''):
1797 """Time execution of a Python statement or expression.
1797 """Time execution of a Python statement or expression.
1798
1798
1799 The CPU and wall clock times are printed, and the value of the
1799 The CPU and wall clock times are printed, and the value of the
1800 expression (if any) is returned. Note that under Win32, system time
1800 expression (if any) is returned. Note that under Win32, system time
1801 is always reported as 0, since it can not be measured.
1801 is always reported as 0, since it can not be measured.
1802
1802
1803 This function provides very basic timing functionality. In Python
1803 This function provides very basic timing functionality. In Python
1804 2.3, the timeit module offers more control and sophistication, so this
1804 2.3, the timeit module offers more control and sophistication, so this
1805 could be rewritten to use it (patches welcome).
1805 could be rewritten to use it (patches welcome).
1806
1806
1807 Some examples:
1807 Some examples:
1808
1808
1809 In [1]: time 2**128
1809 In [1]: time 2**128
1810 CPU times: user 0.00 s, sys: 0.00 s, total: 0.00 s
1810 CPU times: user 0.00 s, sys: 0.00 s, total: 0.00 s
1811 Wall time: 0.00
1811 Wall time: 0.00
1812 Out[1]: 340282366920938463463374607431768211456L
1812 Out[1]: 340282366920938463463374607431768211456L
1813
1813
1814 In [2]: n = 1000000
1814 In [2]: n = 1000000
1815
1815
1816 In [3]: time sum(range(n))
1816 In [3]: time sum(range(n))
1817 CPU times: user 1.20 s, sys: 0.05 s, total: 1.25 s
1817 CPU times: user 1.20 s, sys: 0.05 s, total: 1.25 s
1818 Wall time: 1.37
1818 Wall time: 1.37
1819 Out[3]: 499999500000L
1819 Out[3]: 499999500000L
1820
1820
1821 In [4]: time print 'hello world'
1821 In [4]: time print 'hello world'
1822 hello world
1822 hello world
1823 CPU times: user 0.00 s, sys: 0.00 s, total: 0.00 s
1823 CPU times: user 0.00 s, sys: 0.00 s, total: 0.00 s
1824 Wall time: 0.00
1824 Wall time: 0.00
1825
1825
1826 Note that the time needed by Python to compile the given expression
1826 Note that the time needed by Python to compile the given expression
1827 will be reported if it is more than 0.1s. In this example, the
1827 will be reported if it is more than 0.1s. In this example, the
1828 actual exponentiation is done by Python at compilation time, so while
1828 actual exponentiation is done by Python at compilation time, so while
1829 the expression can take a noticeable amount of time to compute, that
1829 the expression can take a noticeable amount of time to compute, that
1830 time is purely due to the compilation:
1830 time is purely due to the compilation:
1831
1831
1832 In [5]: time 3**9999;
1832 In [5]: time 3**9999;
1833 CPU times: user 0.00 s, sys: 0.00 s, total: 0.00 s
1833 CPU times: user 0.00 s, sys: 0.00 s, total: 0.00 s
1834 Wall time: 0.00 s
1834 Wall time: 0.00 s
1835
1835
1836 In [6]: time 3**999999;
1836 In [6]: time 3**999999;
1837 CPU times: user 0.00 s, sys: 0.00 s, total: 0.00 s
1837 CPU times: user 0.00 s, sys: 0.00 s, total: 0.00 s
1838 Wall time: 0.00 s
1838 Wall time: 0.00 s
1839 Compiler : 0.78 s
1839 Compiler : 0.78 s
1840 """
1840 """
1841
1841
1842 # fail immediately if the given expression can't be compiled
1842 # fail immediately if the given expression can't be compiled
1843
1843
1844 expr = self.shell.prefilter(parameter_s,False)
1844 expr = self.shell.prefilter(parameter_s,False)
1845
1845
1846 # Minimum time above which compilation time will be reported
1846 # Minimum time above which compilation time will be reported
1847 tc_min = 0.1
1847 tc_min = 0.1
1848
1848
1849 try:
1849 try:
1850 mode = 'eval'
1850 mode = 'eval'
1851 t0 = clock()
1851 t0 = clock()
1852 code = compile(expr,'<timed eval>',mode)
1852 code = compile(expr,'<timed eval>',mode)
1853 tc = clock()-t0
1853 tc = clock()-t0
1854 except SyntaxError:
1854 except SyntaxError:
1855 mode = 'exec'
1855 mode = 'exec'
1856 t0 = clock()
1856 t0 = clock()
1857 code = compile(expr,'<timed exec>',mode)
1857 code = compile(expr,'<timed exec>',mode)
1858 tc = clock()-t0
1858 tc = clock()-t0
1859 # skew measurement as little as possible
1859 # skew measurement as little as possible
1860 glob = self.shell.user_ns
1860 glob = self.shell.user_ns
1861 clk = clock2
1861 clk = clock2
1862 wtime = time.time
1862 wtime = time.time
1863 # time execution
1863 # time execution
1864 wall_st = wtime()
1864 wall_st = wtime()
1865 if mode=='eval':
1865 if mode=='eval':
1866 st = clk()
1866 st = clk()
1867 out = eval(code,glob)
1867 out = eval(code,glob)
1868 end = clk()
1868 end = clk()
1869 else:
1869 else:
1870 st = clk()
1870 st = clk()
1871 exec code in glob
1871 exec code in glob
1872 end = clk()
1872 end = clk()
1873 out = None
1873 out = None
1874 wall_end = wtime()
1874 wall_end = wtime()
1875 # Compute actual times and report
1875 # Compute actual times and report
1876 wall_time = wall_end-wall_st
1876 wall_time = wall_end-wall_st
1877 cpu_user = end[0]-st[0]
1877 cpu_user = end[0]-st[0]
1878 cpu_sys = end[1]-st[1]
1878 cpu_sys = end[1]-st[1]
1879 cpu_tot = cpu_user+cpu_sys
1879 cpu_tot = cpu_user+cpu_sys
1880 print "CPU times: user %.2f s, sys: %.2f s, total: %.2f s" % \
1880 print "CPU times: user %.2f s, sys: %.2f s, total: %.2f s" % \
1881 (cpu_user,cpu_sys,cpu_tot)
1881 (cpu_user,cpu_sys,cpu_tot)
1882 print "Wall time: %.2f s" % wall_time
1882 print "Wall time: %.2f s" % wall_time
1883 if tc > tc_min:
1883 if tc > tc_min:
1884 print "Compiler : %.2f s" % tc
1884 print "Compiler : %.2f s" % tc
1885 return out
1885 return out
1886
1886
1887 def magic_macro(self,parameter_s = ''):
1887 def magic_macro(self,parameter_s = ''):
1888 """Define a set of input lines as a macro for future re-execution.
1888 """Define a set of input lines as a macro for future re-execution.
1889
1889
1890 Usage:\\
1890 Usage:\\
1891 %macro [options] name n1-n2 n3-n4 ... n5 .. n6 ...
1891 %macro [options] name n1-n2 n3-n4 ... n5 .. n6 ...
1892
1892
1893 Options:
1893 Options:
1894
1894
1895 -r: use 'raw' input. By default, the 'processed' history is used,
1895 -r: use 'raw' input. By default, the 'processed' history is used,
1896 so that magics are loaded in their transformed version to valid
1896 so that magics are loaded in their transformed version to valid
1897 Python. If this option is given, the raw input as typed as the
1897 Python. If this option is given, the raw input as typed as the
1898 command line is used instead.
1898 command line is used instead.
1899
1899
1900 This will define a global variable called `name` which is a string
1900 This will define a global variable called `name` which is a string
1901 made of joining the slices and lines you specify (n1,n2,... numbers
1901 made of joining the slices and lines you specify (n1,n2,... numbers
1902 above) from your input history into a single string. This variable
1902 above) from your input history into a single string. This variable
1903 acts like an automatic function which re-executes those lines as if
1903 acts like an automatic function which re-executes those lines as if
1904 you had typed them. You just type 'name' at the prompt and the code
1904 you had typed them. You just type 'name' at the prompt and the code
1905 executes.
1905 executes.
1906
1906
1907 The notation for indicating number ranges is: n1-n2 means 'use line
1907 The notation for indicating number ranges is: n1-n2 means 'use line
1908 numbers n1,...n2' (the endpoint is included). That is, '5-7' means
1908 numbers n1,...n2' (the endpoint is included). That is, '5-7' means
1909 using the lines numbered 5,6 and 7.
1909 using the lines numbered 5,6 and 7.
1910
1910
1911 Note: as a 'hidden' feature, you can also use traditional python slice
1911 Note: as a 'hidden' feature, you can also use traditional python slice
1912 notation, where N:M means numbers N through M-1.
1912 notation, where N:M means numbers N through M-1.
1913
1913
1914 For example, if your history contains (%hist prints it):
1914 For example, if your history contains (%hist prints it):
1915
1915
1916 44: x=1\\
1916 44: x=1\\
1917 45: y=3\\
1917 45: y=3\\
1918 46: z=x+y\\
1918 46: z=x+y\\
1919 47: print x\\
1919 47: print x\\
1920 48: a=5\\
1920 48: a=5\\
1921 49: print 'x',x,'y',y\\
1921 49: print 'x',x,'y',y\\
1922
1922
1923 you can create a macro with lines 44 through 47 (included) and line 49
1923 you can create a macro with lines 44 through 47 (included) and line 49
1924 called my_macro with:
1924 called my_macro with:
1925
1925
1926 In [51]: %macro my_macro 44-47 49
1926 In [51]: %macro my_macro 44-47 49
1927
1927
1928 Now, typing `my_macro` (without quotes) will re-execute all this code
1928 Now, typing `my_macro` (without quotes) will re-execute all this code
1929 in one pass.
1929 in one pass.
1930
1930
1931 You don't need to give the line-numbers in order, and any given line
1931 You don't need to give the line-numbers in order, and any given line
1932 number can appear multiple times. You can assemble macros with any
1932 number can appear multiple times. You can assemble macros with any
1933 lines from your input history in any order.
1933 lines from your input history in any order.
1934
1934
1935 The macro is a simple object which holds its value in an attribute,
1935 The macro is a simple object which holds its value in an attribute,
1936 but IPython's display system checks for macros and executes them as
1936 but IPython's display system checks for macros and executes them as
1937 code instead of printing them when you type their name.
1937 code instead of printing them when you type their name.
1938
1938
1939 You can view a macro's contents by explicitly printing it with:
1939 You can view a macro's contents by explicitly printing it with:
1940
1940
1941 'print macro_name'.
1941 'print macro_name'.
1942
1942
1943 For one-off cases which DON'T contain magic function calls in them you
1943 For one-off cases which DON'T contain magic function calls in them you
1944 can obtain similar results by explicitly executing slices from your
1944 can obtain similar results by explicitly executing slices from your
1945 input history with:
1945 input history with:
1946
1946
1947 In [60]: exec In[44:48]+In[49]"""
1947 In [60]: exec In[44:48]+In[49]"""
1948
1948
1949 opts,args = self.parse_options(parameter_s,'r',mode='list')
1949 opts,args = self.parse_options(parameter_s,'r',mode='list')
1950 if not args:
1950 if not args:
1951 macs = [k for k,v in self.shell.user_ns.items() if isinstance(v, Macro)]
1951 macs = [k for k,v in self.shell.user_ns.items() if isinstance(v, Macro)]
1952 macs.sort()
1952 macs.sort()
1953 return macs
1953 return macs
1954 if len(args) == 1:
1954 if len(args) == 1:
1955 raise UsageError(
1955 raise UsageError(
1956 "%macro insufficient args; usage '%macro name n1-n2 n3-4...")
1956 "%macro insufficient args; usage '%macro name n1-n2 n3-4...")
1957 name,ranges = args[0], args[1:]
1957 name,ranges = args[0], args[1:]
1958
1958
1959 #print 'rng',ranges # dbg
1959 #print 'rng',ranges # dbg
1960 lines = self.extract_input_slices(ranges,opts.has_key('r'))
1960 lines = self.extract_input_slices(ranges,opts.has_key('r'))
1961 macro = Macro(lines)
1961 macro = Macro(lines)
1962 self.shell.user_ns.update({name:macro})
1962 self.shell.user_ns.update({name:macro})
1963 print 'Macro `%s` created. To execute, type its name (without quotes).' % name
1963 print 'Macro `%s` created. To execute, type its name (without quotes).' % name
1964 print 'Macro contents:'
1964 print 'Macro contents:'
1965 print macro,
1965 print macro,
1966
1966
1967 def magic_save(self,parameter_s = ''):
1967 def magic_save(self,parameter_s = ''):
1968 """Save a set of lines to a given filename.
1968 """Save a set of lines to a given filename.
1969
1969
1970 Usage:\\
1970 Usage:\\
1971 %save [options] filename n1-n2 n3-n4 ... n5 .. n6 ...
1971 %save [options] filename n1-n2 n3-n4 ... n5 .. n6 ...
1972
1972
1973 Options:
1973 Options:
1974
1974
1975 -r: use 'raw' input. By default, the 'processed' history is used,
1975 -r: use 'raw' input. By default, the 'processed' history is used,
1976 so that magics are loaded in their transformed version to valid
1976 so that magics are loaded in their transformed version to valid
1977 Python. If this option is given, the raw input as typed as the
1977 Python. If this option is given, the raw input as typed as the
1978 command line is used instead.
1978 command line is used instead.
1979
1979
1980 This function uses the same syntax as %macro for line extraction, but
1980 This function uses the same syntax as %macro for line extraction, but
1981 instead of creating a macro it saves the resulting string to the
1981 instead of creating a macro it saves the resulting string to the
1982 filename you specify.
1982 filename you specify.
1983
1983
1984 It adds a '.py' extension to the file if you don't do so yourself, and
1984 It adds a '.py' extension to the file if you don't do so yourself, and
1985 it asks for confirmation before overwriting existing files."""
1985 it asks for confirmation before overwriting existing files."""
1986
1986
1987 opts,args = self.parse_options(parameter_s,'r',mode='list')
1987 opts,args = self.parse_options(parameter_s,'r',mode='list')
1988 fname,ranges = args[0], args[1:]
1988 fname,ranges = args[0], args[1:]
1989 if not fname.endswith('.py'):
1989 if not fname.endswith('.py'):
1990 fname += '.py'
1990 fname += '.py'
1991 if os.path.isfile(fname):
1991 if os.path.isfile(fname):
1992 ans = raw_input('File `%s` exists. Overwrite (y/[N])? ' % fname)
1992 ans = raw_input('File `%s` exists. Overwrite (y/[N])? ' % fname)
1993 if ans.lower() not in ['y','yes']:
1993 if ans.lower() not in ['y','yes']:
1994 print 'Operation cancelled.'
1994 print 'Operation cancelled.'
1995 return
1995 return
1996 cmds = ''.join(self.extract_input_slices(ranges,opts.has_key('r')))
1996 cmds = ''.join(self.extract_input_slices(ranges,opts.has_key('r')))
1997 f = file(fname,'w')
1997 f = file(fname,'w')
1998 f.write(cmds)
1998 f.write(cmds)
1999 f.close()
1999 f.close()
2000 print 'The following commands were written to file `%s`:' % fname
2000 print 'The following commands were written to file `%s`:' % fname
2001 print cmds
2001 print cmds
2002
2002
2003 def _edit_macro(self,mname,macro):
2003 def _edit_macro(self,mname,macro):
2004 """open an editor with the macro data in a file"""
2004 """open an editor with the macro data in a file"""
2005 filename = self.shell.mktempfile(macro.value)
2005 filename = self.shell.mktempfile(macro.value)
2006 self.shell.hooks.editor(filename)
2006 self.shell.hooks.editor(filename)
2007
2007
2008 # and make a new macro object, to replace the old one
2008 # and make a new macro object, to replace the old one
2009 mfile = open(filename)
2009 mfile = open(filename)
2010 mvalue = mfile.read()
2010 mvalue = mfile.read()
2011 mfile.close()
2011 mfile.close()
2012 self.shell.user_ns[mname] = Macro(mvalue)
2012 self.shell.user_ns[mname] = Macro(mvalue)
2013
2013
2014 def magic_ed(self,parameter_s=''):
2014 def magic_ed(self,parameter_s=''):
2015 """Alias to %edit."""
2015 """Alias to %edit."""
2016 return self.magic_edit(parameter_s)
2016 return self.magic_edit(parameter_s)
2017
2017
2018 def magic_edit(self,parameter_s='',last_call=['','']):
2018 def magic_edit(self,parameter_s='',last_call=['','']):
2019 """Bring up an editor and execute the resulting code.
2019 """Bring up an editor and execute the resulting code.
2020
2020
2021 Usage:
2021 Usage:
2022 %edit [options] [args]
2022 %edit [options] [args]
2023
2023
2024 %edit runs IPython's editor hook. The default version of this hook is
2024 %edit runs IPython's editor hook. The default version of this hook is
2025 set to call the __IPYTHON__.rc.editor command. This is read from your
2025 set to call the __IPYTHON__.rc.editor command. This is read from your
2026 environment variable $EDITOR. If this isn't found, it will default to
2026 environment variable $EDITOR. If this isn't found, it will default to
2027 vi under Linux/Unix and to notepad under Windows. See the end of this
2027 vi under Linux/Unix and to notepad under Windows. See the end of this
2028 docstring for how to change the editor hook.
2028 docstring for how to change the editor hook.
2029
2029
2030 You can also set the value of this editor via the command line option
2030 You can also set the value of this editor via the command line option
2031 '-editor' or in your ipythonrc file. This is useful if you wish to use
2031 '-editor' or in your ipythonrc file. This is useful if you wish to use
2032 specifically for IPython an editor different from your typical default
2032 specifically for IPython an editor different from your typical default
2033 (and for Windows users who typically don't set environment variables).
2033 (and for Windows users who typically don't set environment variables).
2034
2034
2035 This command allows you to conveniently edit multi-line code right in
2035 This command allows you to conveniently edit multi-line code right in
2036 your IPython session.
2036 your IPython session.
2037
2037
2038 If called without arguments, %edit opens up an empty editor with a
2038 If called without arguments, %edit opens up an empty editor with a
2039 temporary file and will execute the contents of this file when you
2039 temporary file and will execute the contents of this file when you
2040 close it (don't forget to save it!).
2040 close it (don't forget to save it!).
2041
2041
2042
2042
2043 Options:
2043 Options:
2044
2044
2045 -n <number>: open the editor at a specified line number. By default,
2045 -n <number>: open the editor at a specified line number. By default,
2046 the IPython editor hook uses the unix syntax 'editor +N filename', but
2046 the IPython editor hook uses the unix syntax 'editor +N filename', but
2047 you can configure this by providing your own modified hook if your
2047 you can configure this by providing your own modified hook if your
2048 favorite editor supports line-number specifications with a different
2048 favorite editor supports line-number specifications with a different
2049 syntax.
2049 syntax.
2050
2050
2051 -p: this will call the editor with the same data as the previous time
2051 -p: this will call the editor with the same data as the previous time
2052 it was used, regardless of how long ago (in your current session) it
2052 it was used, regardless of how long ago (in your current session) it
2053 was.
2053 was.
2054
2054
2055 -r: use 'raw' input. This option only applies to input taken from the
2055 -r: use 'raw' input. This option only applies to input taken from the
2056 user's history. By default, the 'processed' history is used, so that
2056 user's history. By default, the 'processed' history is used, so that
2057 magics are loaded in their transformed version to valid Python. If
2057 magics are loaded in their transformed version to valid Python. If
2058 this option is given, the raw input as typed as the command line is
2058 this option is given, the raw input as typed as the command line is
2059 used instead. When you exit the editor, it will be executed by
2059 used instead. When you exit the editor, it will be executed by
2060 IPython's own processor.
2060 IPython's own processor.
2061
2061
2062 -x: do not execute the edited code immediately upon exit. This is
2062 -x: do not execute the edited code immediately upon exit. This is
2063 mainly useful if you are editing programs which need to be called with
2063 mainly useful if you are editing programs which need to be called with
2064 command line arguments, which you can then do using %run.
2064 command line arguments, which you can then do using %run.
2065
2065
2066
2066
2067 Arguments:
2067 Arguments:
2068
2068
2069 If arguments are given, the following possibilites exist:
2069 If arguments are given, the following possibilites exist:
2070
2070
2071 - The arguments are numbers or pairs of colon-separated numbers (like
2071 - The arguments are numbers or pairs of colon-separated numbers (like
2072 1 4:8 9). These are interpreted as lines of previous input to be
2072 1 4:8 9). These are interpreted as lines of previous input to be
2073 loaded into the editor. The syntax is the same of the %macro command.
2073 loaded into the editor. The syntax is the same of the %macro command.
2074
2074
2075 - If the argument doesn't start with a number, it is evaluated as a
2075 - If the argument doesn't start with a number, it is evaluated as a
2076 variable and its contents loaded into the editor. You can thus edit
2076 variable and its contents loaded into the editor. You can thus edit
2077 any string which contains python code (including the result of
2077 any string which contains python code (including the result of
2078 previous edits).
2078 previous edits).
2079
2079
2080 - If the argument is the name of an object (other than a string),
2080 - If the argument is the name of an object (other than a string),
2081 IPython will try to locate the file where it was defined and open the
2081 IPython will try to locate the file where it was defined and open the
2082 editor at the point where it is defined. You can use `%edit function`
2082 editor at the point where it is defined. You can use `%edit function`
2083 to load an editor exactly at the point where 'function' is defined,
2083 to load an editor exactly at the point where 'function' is defined,
2084 edit it and have the file be executed automatically.
2084 edit it and have the file be executed automatically.
2085
2085
2086 If the object is a macro (see %macro for details), this opens up your
2086 If the object is a macro (see %macro for details), this opens up your
2087 specified editor with a temporary file containing the macro's data.
2087 specified editor with a temporary file containing the macro's data.
2088 Upon exit, the macro is reloaded with the contents of the file.
2088 Upon exit, the macro is reloaded with the contents of the file.
2089
2089
2090 Note: opening at an exact line is only supported under Unix, and some
2090 Note: opening at an exact line is only supported under Unix, and some
2091 editors (like kedit and gedit up to Gnome 2.8) do not understand the
2091 editors (like kedit and gedit up to Gnome 2.8) do not understand the
2092 '+NUMBER' parameter necessary for this feature. Good editors like
2092 '+NUMBER' parameter necessary for this feature. Good editors like
2093 (X)Emacs, vi, jed, pico and joe all do.
2093 (X)Emacs, vi, jed, pico and joe all do.
2094
2094
2095 - If the argument is not found as a variable, IPython will look for a
2095 - If the argument is not found as a variable, IPython will look for a
2096 file with that name (adding .py if necessary) and load it into the
2096 file with that name (adding .py if necessary) and load it into the
2097 editor. It will execute its contents with execfile() when you exit,
2097 editor. It will execute its contents with execfile() when you exit,
2098 loading any code in the file into your interactive namespace.
2098 loading any code in the file into your interactive namespace.
2099
2099
2100 After executing your code, %edit will return as output the code you
2100 After executing your code, %edit will return as output the code you
2101 typed in the editor (except when it was an existing file). This way
2101 typed in the editor (except when it was an existing file). This way
2102 you can reload the code in further invocations of %edit as a variable,
2102 you can reload the code in further invocations of %edit as a variable,
2103 via _<NUMBER> or Out[<NUMBER>], where <NUMBER> is the prompt number of
2103 via _<NUMBER> or Out[<NUMBER>], where <NUMBER> is the prompt number of
2104 the output.
2104 the output.
2105
2105
2106 Note that %edit is also available through the alias %ed.
2106 Note that %edit is also available through the alias %ed.
2107
2107
2108 This is an example of creating a simple function inside the editor and
2108 This is an example of creating a simple function inside the editor and
2109 then modifying it. First, start up the editor:
2109 then modifying it. First, start up the editor:
2110
2110
2111 In [1]: ed\\
2111 In [1]: ed\\
2112 Editing... done. Executing edited code...\\
2112 Editing... done. Executing edited code...\\
2113 Out[1]: 'def foo():\\n print "foo() was defined in an editing session"\\n'
2113 Out[1]: 'def foo():\\n print "foo() was defined in an editing session"\\n'
2114
2114
2115 We can then call the function foo():
2115 We can then call the function foo():
2116
2116
2117 In [2]: foo()\\
2117 In [2]: foo()\\
2118 foo() was defined in an editing session
2118 foo() was defined in an editing session
2119
2119
2120 Now we edit foo. IPython automatically loads the editor with the
2120 Now we edit foo. IPython automatically loads the editor with the
2121 (temporary) file where foo() was previously defined:
2121 (temporary) file where foo() was previously defined:
2122
2122
2123 In [3]: ed foo\\
2123 In [3]: ed foo\\
2124 Editing... done. Executing edited code...
2124 Editing... done. Executing edited code...
2125
2125
2126 And if we call foo() again we get the modified version:
2126 And if we call foo() again we get the modified version:
2127
2127
2128 In [4]: foo()\\
2128 In [4]: foo()\\
2129 foo() has now been changed!
2129 foo() has now been changed!
2130
2130
2131 Here is an example of how to edit a code snippet successive
2131 Here is an example of how to edit a code snippet successive
2132 times. First we call the editor:
2132 times. First we call the editor:
2133
2133
2134 In [8]: ed\\
2134 In [8]: ed\\
2135 Editing... done. Executing edited code...\\
2135 Editing... done. Executing edited code...\\
2136 hello\\
2136 hello\\
2137 Out[8]: "print 'hello'\\n"
2137 Out[8]: "print 'hello'\\n"
2138
2138
2139 Now we call it again with the previous output (stored in _):
2139 Now we call it again with the previous output (stored in _):
2140
2140
2141 In [9]: ed _\\
2141 In [9]: ed _\\
2142 Editing... done. Executing edited code...\\
2142 Editing... done. Executing edited code...\\
2143 hello world\\
2143 hello world\\
2144 Out[9]: "print 'hello world'\\n"
2144 Out[9]: "print 'hello world'\\n"
2145
2145
2146 Now we call it with the output #8 (stored in _8, also as Out[8]):
2146 Now we call it with the output #8 (stored in _8, also as Out[8]):
2147
2147
2148 In [10]: ed _8\\
2148 In [10]: ed _8\\
2149 Editing... done. Executing edited code...\\
2149 Editing... done. Executing edited code...\\
2150 hello again\\
2150 hello again\\
2151 Out[10]: "print 'hello again'\\n"
2151 Out[10]: "print 'hello again'\\n"
2152
2152
2153
2153
2154 Changing the default editor hook:
2154 Changing the default editor hook:
2155
2155
2156 If you wish to write your own editor hook, you can put it in a
2156 If you wish to write your own editor hook, you can put it in a
2157 configuration file which you load at startup time. The default hook
2157 configuration file which you load at startup time. The default hook
2158 is defined in the IPython.hooks module, and you can use that as a
2158 is defined in the IPython.hooks module, and you can use that as a
2159 starting example for further modifications. That file also has
2159 starting example for further modifications. That file also has
2160 general instructions on how to set a new hook for use once you've
2160 general instructions on how to set a new hook for use once you've
2161 defined it."""
2161 defined it."""
2162
2162
2163 # FIXME: This function has become a convoluted mess. It needs a
2163 # FIXME: This function has become a convoluted mess. It needs a
2164 # ground-up rewrite with clean, simple logic.
2164 # ground-up rewrite with clean, simple logic.
2165
2165
2166 def make_filename(arg):
2166 def make_filename(arg):
2167 "Make a filename from the given args"
2167 "Make a filename from the given args"
2168 try:
2168 try:
2169 filename = get_py_filename(arg)
2169 filename = get_py_filename(arg)
2170 except IOError:
2170 except IOError:
2171 if args.endswith('.py'):
2171 if args.endswith('.py'):
2172 filename = arg
2172 filename = arg
2173 else:
2173 else:
2174 filename = None
2174 filename = None
2175 return filename
2175 return filename
2176
2176
2177 # custom exceptions
2177 # custom exceptions
2178 class DataIsObject(Exception): pass
2178 class DataIsObject(Exception): pass
2179
2179
2180 opts,args = self.parse_options(parameter_s,'prxn:')
2180 opts,args = self.parse_options(parameter_s,'prxn:')
2181 # Set a few locals from the options for convenience:
2181 # Set a few locals from the options for convenience:
2182 opts_p = opts.has_key('p')
2182 opts_p = opts.has_key('p')
2183 opts_r = opts.has_key('r')
2183 opts_r = opts.has_key('r')
2184
2184
2185 # Default line number value
2185 # Default line number value
2186 lineno = opts.get('n',None)
2186 lineno = opts.get('n',None)
2187
2187
2188 if opts_p:
2188 if opts_p:
2189 args = '_%s' % last_call[0]
2189 args = '_%s' % last_call[0]
2190 if not self.shell.user_ns.has_key(args):
2190 if not self.shell.user_ns.has_key(args):
2191 args = last_call[1]
2191 args = last_call[1]
2192
2192
2193 # use last_call to remember the state of the previous call, but don't
2193 # use last_call to remember the state of the previous call, but don't
2194 # let it be clobbered by successive '-p' calls.
2194 # let it be clobbered by successive '-p' calls.
2195 try:
2195 try:
2196 last_call[0] = self.shell.outputcache.prompt_count
2196 last_call[0] = self.shell.outputcache.prompt_count
2197 if not opts_p:
2197 if not opts_p:
2198 last_call[1] = parameter_s
2198 last_call[1] = parameter_s
2199 except:
2199 except:
2200 pass
2200 pass
2201
2201
2202 # by default this is done with temp files, except when the given
2202 # by default this is done with temp files, except when the given
2203 # arg is a filename
2203 # arg is a filename
2204 use_temp = 1
2204 use_temp = 1
2205
2205
2206 if re.match(r'\d',args):
2206 if re.match(r'\d',args):
2207 # Mode where user specifies ranges of lines, like in %macro.
2207 # Mode where user specifies ranges of lines, like in %macro.
2208 # This means that you can't edit files whose names begin with
2208 # This means that you can't edit files whose names begin with
2209 # numbers this way. Tough.
2209 # numbers this way. Tough.
2210 ranges = args.split()
2210 ranges = args.split()
2211 data = ''.join(self.extract_input_slices(ranges,opts_r))
2211 data = ''.join(self.extract_input_slices(ranges,opts_r))
2212 elif args.endswith('.py'):
2212 elif args.endswith('.py'):
2213 filename = make_filename(args)
2213 filename = make_filename(args)
2214 data = ''
2214 data = ''
2215 use_temp = 0
2215 use_temp = 0
2216 elif args:
2216 elif args:
2217 try:
2217 try:
2218 # Load the parameter given as a variable. If not a string,
2218 # Load the parameter given as a variable. If not a string,
2219 # process it as an object instead (below)
2219 # process it as an object instead (below)
2220
2220
2221 #print '*** args',args,'type',type(args) # dbg
2221 #print '*** args',args,'type',type(args) # dbg
2222 data = eval(args,self.shell.user_ns)
2222 data = eval(args,self.shell.user_ns)
2223 if not type(data) in StringTypes:
2223 if not type(data) in StringTypes:
2224 raise DataIsObject
2224 raise DataIsObject
2225
2225
2226 except (NameError,SyntaxError):
2226 except (NameError,SyntaxError):
2227 # given argument is not a variable, try as a filename
2227 # given argument is not a variable, try as a filename
2228 filename = make_filename(args)
2228 filename = make_filename(args)
2229 if filename is None:
2229 if filename is None:
2230 warn("Argument given (%s) can't be found as a variable "
2230 warn("Argument given (%s) can't be found as a variable "
2231 "or as a filename." % args)
2231 "or as a filename." % args)
2232 return
2232 return
2233
2233
2234 data = ''
2234 data = ''
2235 use_temp = 0
2235 use_temp = 0
2236 except DataIsObject:
2236 except DataIsObject:
2237
2237
2238 # macros have a special edit function
2238 # macros have a special edit function
2239 if isinstance(data,Macro):
2239 if isinstance(data,Macro):
2240 self._edit_macro(args,data)
2240 self._edit_macro(args,data)
2241 return
2241 return
2242
2242
2243 # For objects, try to edit the file where they are defined
2243 # For objects, try to edit the file where they are defined
2244 try:
2244 try:
2245 filename = inspect.getabsfile(data)
2245 filename = inspect.getabsfile(data)
2246 if 'fakemodule' in filename.lower() and inspect.isclass(data):
2247 # class created by %edit? Try to find source
2248 # by looking for method definitions instead, the
2249 # __module__ in those classes is FakeModule.
2250 attrs = [getattr(data, aname) for aname in dir(data)]
2251 for attr in attrs:
2252 if not inspect.ismethod(attr):
2253 continue
2254 filename = inspect.getabsfile(attr)
2255 if filename and 'fakemodule' not in filename.lower():
2256 # change the attribute to be the edit target instead
2257 data = attr
2258 break
2259
2246 datafile = 1
2260 datafile = 1
2247 except TypeError:
2261 except TypeError:
2248 filename = make_filename(args)
2262 filename = make_filename(args)
2249 datafile = 1
2263 datafile = 1
2250 warn('Could not find file where `%s` is defined.\n'
2264 warn('Could not find file where `%s` is defined.\n'
2251 'Opening a file named `%s`' % (args,filename))
2265 'Opening a file named `%s`' % (args,filename))
2252 # Now, make sure we can actually read the source (if it was in
2266 # Now, make sure we can actually read the source (if it was in
2253 # a temp file it's gone by now).
2267 # a temp file it's gone by now).
2254 if datafile:
2268 if datafile:
2255 try:
2269 try:
2256 if lineno is None:
2270 if lineno is None:
2257 lineno = inspect.getsourcelines(data)[1]
2271 lineno = inspect.getsourcelines(data)[1]
2258 except IOError:
2272 except IOError:
2259 filename = make_filename(args)
2273 filename = make_filename(args)
2260 if filename is None:
2274 if filename is None:
2261 warn('The file `%s` where `%s` was defined cannot '
2275 warn('The file `%s` where `%s` was defined cannot '
2262 'be read.' % (filename,data))
2276 'be read.' % (filename,data))
2263 return
2277 return
2264 use_temp = 0
2278 use_temp = 0
2265 else:
2279 else:
2266 data = ''
2280 data = ''
2267
2281
2268 if use_temp:
2282 if use_temp:
2269 filename = self.shell.mktempfile(data)
2283 filename = self.shell.mktempfile(data)
2270 print 'IPython will make a temporary file named:',filename
2284 print 'IPython will make a temporary file named:',filename
2271
2285
2272 # do actual editing here
2286 # do actual editing here
2273 print 'Editing...',
2287 print 'Editing...',
2274 sys.stdout.flush()
2288 sys.stdout.flush()
2275 self.shell.hooks.editor(filename,lineno)
2289 self.shell.hooks.editor(filename,lineno)
2276 if opts.has_key('x'): # -x prevents actual execution
2290 if opts.has_key('x'): # -x prevents actual execution
2277 print
2291 print
2278 else:
2292 else:
2279 print 'done. Executing edited code...'
2293 print 'done. Executing edited code...'
2280 if opts_r:
2294 if opts_r:
2281 self.shell.runlines(file_read(filename))
2295 self.shell.runlines(file_read(filename))
2282 else:
2296 else:
2283 self.shell.safe_execfile(filename,self.shell.user_ns,
2297 self.shell.safe_execfile(filename,self.shell.user_ns,
2284 self.shell.user_ns)
2298 self.shell.user_ns)
2285 if use_temp:
2299 if use_temp:
2286 try:
2300 try:
2287 return open(filename).read()
2301 return open(filename).read()
2288 except IOError,msg:
2302 except IOError,msg:
2289 if msg.filename == filename:
2303 if msg.filename == filename:
2290 warn('File not found. Did you forget to save?')
2304 warn('File not found. Did you forget to save?')
2291 return
2305 return
2292 else:
2306 else:
2293 self.shell.showtraceback()
2307 self.shell.showtraceback()
2294
2308
2295 def magic_xmode(self,parameter_s = ''):
2309 def magic_xmode(self,parameter_s = ''):
2296 """Switch modes for the exception handlers.
2310 """Switch modes for the exception handlers.
2297
2311
2298 Valid modes: Plain, Context and Verbose.
2312 Valid modes: Plain, Context and Verbose.
2299
2313
2300 If called without arguments, acts as a toggle."""
2314 If called without arguments, acts as a toggle."""
2301
2315
2302 def xmode_switch_err(name):
2316 def xmode_switch_err(name):
2303 warn('Error changing %s exception modes.\n%s' %
2317 warn('Error changing %s exception modes.\n%s' %
2304 (name,sys.exc_info()[1]))
2318 (name,sys.exc_info()[1]))
2305
2319
2306 shell = self.shell
2320 shell = self.shell
2307 new_mode = parameter_s.strip().capitalize()
2321 new_mode = parameter_s.strip().capitalize()
2308 try:
2322 try:
2309 shell.InteractiveTB.set_mode(mode=new_mode)
2323 shell.InteractiveTB.set_mode(mode=new_mode)
2310 print 'Exception reporting mode:',shell.InteractiveTB.mode
2324 print 'Exception reporting mode:',shell.InteractiveTB.mode
2311 except:
2325 except:
2312 xmode_switch_err('user')
2326 xmode_switch_err('user')
2313
2327
2314 # threaded shells use a special handler in sys.excepthook
2328 # threaded shells use a special handler in sys.excepthook
2315 if shell.isthreaded:
2329 if shell.isthreaded:
2316 try:
2330 try:
2317 shell.sys_excepthook.set_mode(mode=new_mode)
2331 shell.sys_excepthook.set_mode(mode=new_mode)
2318 except:
2332 except:
2319 xmode_switch_err('threaded')
2333 xmode_switch_err('threaded')
2320
2334
2321 def magic_colors(self,parameter_s = ''):
2335 def magic_colors(self,parameter_s = ''):
2322 """Switch color scheme for prompts, info system and exception handlers.
2336 """Switch color scheme for prompts, info system and exception handlers.
2323
2337
2324 Currently implemented schemes: NoColor, Linux, LightBG.
2338 Currently implemented schemes: NoColor, Linux, LightBG.
2325
2339
2326 Color scheme names are not case-sensitive."""
2340 Color scheme names are not case-sensitive."""
2327
2341
2328 def color_switch_err(name):
2342 def color_switch_err(name):
2329 warn('Error changing %s color schemes.\n%s' %
2343 warn('Error changing %s color schemes.\n%s' %
2330 (name,sys.exc_info()[1]))
2344 (name,sys.exc_info()[1]))
2331
2345
2332
2346
2333 new_scheme = parameter_s.strip()
2347 new_scheme = parameter_s.strip()
2334 if not new_scheme:
2348 if not new_scheme:
2335 raise UsageError(
2349 raise UsageError(
2336 "%colors: you must specify a color scheme. See '%colors?'")
2350 "%colors: you must specify a color scheme. See '%colors?'")
2337 return
2351 return
2338 # local shortcut
2352 # local shortcut
2339 shell = self.shell
2353 shell = self.shell
2340
2354
2341 import IPython.rlineimpl as readline
2355 import IPython.rlineimpl as readline
2342
2356
2343 if not readline.have_readline and sys.platform == "win32":
2357 if not readline.have_readline and sys.platform == "win32":
2344 msg = """\
2358 msg = """\
2345 Proper color support under MS Windows requires the pyreadline library.
2359 Proper color support under MS Windows requires the pyreadline library.
2346 You can find it at:
2360 You can find it at:
2347 http://ipython.scipy.org/moin/PyReadline/Intro
2361 http://ipython.scipy.org/moin/PyReadline/Intro
2348 Gary's readline needs the ctypes module, from:
2362 Gary's readline needs the ctypes module, from:
2349 http://starship.python.net/crew/theller/ctypes
2363 http://starship.python.net/crew/theller/ctypes
2350 (Note that ctypes is already part of Python versions 2.5 and newer).
2364 (Note that ctypes is already part of Python versions 2.5 and newer).
2351
2365
2352 Defaulting color scheme to 'NoColor'"""
2366 Defaulting color scheme to 'NoColor'"""
2353 new_scheme = 'NoColor'
2367 new_scheme = 'NoColor'
2354 warn(msg)
2368 warn(msg)
2355
2369
2356 # readline option is 0
2370 # readline option is 0
2357 if not shell.has_readline:
2371 if not shell.has_readline:
2358 new_scheme = 'NoColor'
2372 new_scheme = 'NoColor'
2359
2373
2360 # Set prompt colors
2374 # Set prompt colors
2361 try:
2375 try:
2362 shell.outputcache.set_colors(new_scheme)
2376 shell.outputcache.set_colors(new_scheme)
2363 except:
2377 except:
2364 color_switch_err('prompt')
2378 color_switch_err('prompt')
2365 else:
2379 else:
2366 shell.rc.colors = \
2380 shell.rc.colors = \
2367 shell.outputcache.color_table.active_scheme_name
2381 shell.outputcache.color_table.active_scheme_name
2368 # Set exception colors
2382 # Set exception colors
2369 try:
2383 try:
2370 shell.InteractiveTB.set_colors(scheme = new_scheme)
2384 shell.InteractiveTB.set_colors(scheme = new_scheme)
2371 shell.SyntaxTB.set_colors(scheme = new_scheme)
2385 shell.SyntaxTB.set_colors(scheme = new_scheme)
2372 except:
2386 except:
2373 color_switch_err('exception')
2387 color_switch_err('exception')
2374
2388
2375 # threaded shells use a verbose traceback in sys.excepthook
2389 # threaded shells use a verbose traceback in sys.excepthook
2376 if shell.isthreaded:
2390 if shell.isthreaded:
2377 try:
2391 try:
2378 shell.sys_excepthook.set_colors(scheme=new_scheme)
2392 shell.sys_excepthook.set_colors(scheme=new_scheme)
2379 except:
2393 except:
2380 color_switch_err('system exception handler')
2394 color_switch_err('system exception handler')
2381
2395
2382 # Set info (for 'object?') colors
2396 # Set info (for 'object?') colors
2383 if shell.rc.color_info:
2397 if shell.rc.color_info:
2384 try:
2398 try:
2385 shell.inspector.set_active_scheme(new_scheme)
2399 shell.inspector.set_active_scheme(new_scheme)
2386 except:
2400 except:
2387 color_switch_err('object inspector')
2401 color_switch_err('object inspector')
2388 else:
2402 else:
2389 shell.inspector.set_active_scheme('NoColor')
2403 shell.inspector.set_active_scheme('NoColor')
2390
2404
2391 def magic_color_info(self,parameter_s = ''):
2405 def magic_color_info(self,parameter_s = ''):
2392 """Toggle color_info.
2406 """Toggle color_info.
2393
2407
2394 The color_info configuration parameter controls whether colors are
2408 The color_info configuration parameter controls whether colors are
2395 used for displaying object details (by things like %psource, %pfile or
2409 used for displaying object details (by things like %psource, %pfile or
2396 the '?' system). This function toggles this value with each call.
2410 the '?' system). This function toggles this value with each call.
2397
2411
2398 Note that unless you have a fairly recent pager (less works better
2412 Note that unless you have a fairly recent pager (less works better
2399 than more) in your system, using colored object information displays
2413 than more) in your system, using colored object information displays
2400 will not work properly. Test it and see."""
2414 will not work properly. Test it and see."""
2401
2415
2402 self.shell.rc.color_info = 1 - self.shell.rc.color_info
2416 self.shell.rc.color_info = 1 - self.shell.rc.color_info
2403 self.magic_colors(self.shell.rc.colors)
2417 self.magic_colors(self.shell.rc.colors)
2404 print 'Object introspection functions have now coloring:',
2418 print 'Object introspection functions have now coloring:',
2405 print ['OFF','ON'][self.shell.rc.color_info]
2419 print ['OFF','ON'][self.shell.rc.color_info]
2406
2420
2407 def magic_Pprint(self, parameter_s=''):
2421 def magic_Pprint(self, parameter_s=''):
2408 """Toggle pretty printing on/off."""
2422 """Toggle pretty printing on/off."""
2409
2423
2410 self.shell.rc.pprint = 1 - self.shell.rc.pprint
2424 self.shell.rc.pprint = 1 - self.shell.rc.pprint
2411 print 'Pretty printing has been turned', \
2425 print 'Pretty printing has been turned', \
2412 ['OFF','ON'][self.shell.rc.pprint]
2426 ['OFF','ON'][self.shell.rc.pprint]
2413
2427
2414 def magic_exit(self, parameter_s=''):
2428 def magic_exit(self, parameter_s=''):
2415 """Exit IPython, confirming if configured to do so.
2429 """Exit IPython, confirming if configured to do so.
2416
2430
2417 You can configure whether IPython asks for confirmation upon exit by
2431 You can configure whether IPython asks for confirmation upon exit by
2418 setting the confirm_exit flag in the ipythonrc file."""
2432 setting the confirm_exit flag in the ipythonrc file."""
2419
2433
2420 self.shell.exit()
2434 self.shell.exit()
2421
2435
2422 def magic_quit(self, parameter_s=''):
2436 def magic_quit(self, parameter_s=''):
2423 """Exit IPython, confirming if configured to do so (like %exit)"""
2437 """Exit IPython, confirming if configured to do so (like %exit)"""
2424
2438
2425 self.shell.exit()
2439 self.shell.exit()
2426
2440
2427 def magic_Exit(self, parameter_s=''):
2441 def magic_Exit(self, parameter_s=''):
2428 """Exit IPython without confirmation."""
2442 """Exit IPython without confirmation."""
2429
2443
2430 self.shell.exit_now = True
2444 self.shell.exit_now = True
2431
2445
2432 #......................................................................
2446 #......................................................................
2433 # Functions to implement unix shell-type things
2447 # Functions to implement unix shell-type things
2434
2448
2435 def magic_alias(self, parameter_s = ''):
2449 def magic_alias(self, parameter_s = ''):
2436 """Define an alias for a system command.
2450 """Define an alias for a system command.
2437
2451
2438 '%alias alias_name cmd' defines 'alias_name' as an alias for 'cmd'
2452 '%alias alias_name cmd' defines 'alias_name' as an alias for 'cmd'
2439
2453
2440 Then, typing 'alias_name params' will execute the system command 'cmd
2454 Then, typing 'alias_name params' will execute the system command 'cmd
2441 params' (from your underlying operating system).
2455 params' (from your underlying operating system).
2442
2456
2443 Aliases have lower precedence than magic functions and Python normal
2457 Aliases have lower precedence than magic functions and Python normal
2444 variables, so if 'foo' is both a Python variable and an alias, the
2458 variables, so if 'foo' is both a Python variable and an alias, the
2445 alias can not be executed until 'del foo' removes the Python variable.
2459 alias can not be executed until 'del foo' removes the Python variable.
2446
2460
2447 You can use the %l specifier in an alias definition to represent the
2461 You can use the %l specifier in an alias definition to represent the
2448 whole line when the alias is called. For example:
2462 whole line when the alias is called. For example:
2449
2463
2450 In [2]: alias all echo "Input in brackets: <%l>"\\
2464 In [2]: alias all echo "Input in brackets: <%l>"\\
2451 In [3]: all hello world\\
2465 In [3]: all hello world\\
2452 Input in brackets: <hello world>
2466 Input in brackets: <hello world>
2453
2467
2454 You can also define aliases with parameters using %s specifiers (one
2468 You can also define aliases with parameters using %s specifiers (one
2455 per parameter):
2469 per parameter):
2456
2470
2457 In [1]: alias parts echo first %s second %s\\
2471 In [1]: alias parts echo first %s second %s\\
2458 In [2]: %parts A B\\
2472 In [2]: %parts A B\\
2459 first A second B\\
2473 first A second B\\
2460 In [3]: %parts A\\
2474 In [3]: %parts A\\
2461 Incorrect number of arguments: 2 expected.\\
2475 Incorrect number of arguments: 2 expected.\\
2462 parts is an alias to: 'echo first %s second %s'
2476 parts is an alias to: 'echo first %s second %s'
2463
2477
2464 Note that %l and %s are mutually exclusive. You can only use one or
2478 Note that %l and %s are mutually exclusive. You can only use one or
2465 the other in your aliases.
2479 the other in your aliases.
2466
2480
2467 Aliases expand Python variables just like system calls using ! or !!
2481 Aliases expand Python variables just like system calls using ! or !!
2468 do: all expressions prefixed with '$' get expanded. For details of
2482 do: all expressions prefixed with '$' get expanded. For details of
2469 the semantic rules, see PEP-215:
2483 the semantic rules, see PEP-215:
2470 http://www.python.org/peps/pep-0215.html. This is the library used by
2484 http://www.python.org/peps/pep-0215.html. This is the library used by
2471 IPython for variable expansion. If you want to access a true shell
2485 IPython for variable expansion. If you want to access a true shell
2472 variable, an extra $ is necessary to prevent its expansion by IPython:
2486 variable, an extra $ is necessary to prevent its expansion by IPython:
2473
2487
2474 In [6]: alias show echo\\
2488 In [6]: alias show echo\\
2475 In [7]: PATH='A Python string'\\
2489 In [7]: PATH='A Python string'\\
2476 In [8]: show $PATH\\
2490 In [8]: show $PATH\\
2477 A Python string\\
2491 A Python string\\
2478 In [9]: show $$PATH\\
2492 In [9]: show $$PATH\\
2479 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
2493 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
2480
2494
2481 You can use the alias facility to acess all of $PATH. See the %rehash
2495 You can use the alias facility to acess all of $PATH. See the %rehash
2482 and %rehashx functions, which automatically create aliases for the
2496 and %rehashx functions, which automatically create aliases for the
2483 contents of your $PATH.
2497 contents of your $PATH.
2484
2498
2485 If called with no parameters, %alias prints the current alias table."""
2499 If called with no parameters, %alias prints the current alias table."""
2486
2500
2487 par = parameter_s.strip()
2501 par = parameter_s.strip()
2488 if not par:
2502 if not par:
2489 stored = self.db.get('stored_aliases', {} )
2503 stored = self.db.get('stored_aliases', {} )
2490 atab = self.shell.alias_table
2504 atab = self.shell.alias_table
2491 aliases = atab.keys()
2505 aliases = atab.keys()
2492 aliases.sort()
2506 aliases.sort()
2493 res = []
2507 res = []
2494 showlast = []
2508 showlast = []
2495 for alias in aliases:
2509 for alias in aliases:
2496 special = False
2510 special = False
2497 try:
2511 try:
2498 tgt = atab[alias][1]
2512 tgt = atab[alias][1]
2499 except (TypeError, AttributeError):
2513 except (TypeError, AttributeError):
2500 # unsubscriptable? probably a callable
2514 # unsubscriptable? probably a callable
2501 tgt = atab[alias]
2515 tgt = atab[alias]
2502 special = True
2516 special = True
2503 # 'interesting' aliases
2517 # 'interesting' aliases
2504 if (alias in stored or
2518 if (alias in stored or
2505 special or
2519 special or
2506 alias.lower() != os.path.splitext(tgt)[0].lower() or
2520 alias.lower() != os.path.splitext(tgt)[0].lower() or
2507 ' ' in tgt):
2521 ' ' in tgt):
2508 showlast.append((alias, tgt))
2522 showlast.append((alias, tgt))
2509 else:
2523 else:
2510 res.append((alias, tgt ))
2524 res.append((alias, tgt ))
2511
2525
2512 # show most interesting aliases last
2526 # show most interesting aliases last
2513 res.extend(showlast)
2527 res.extend(showlast)
2514 print "Total number of aliases:",len(aliases)
2528 print "Total number of aliases:",len(aliases)
2515 return res
2529 return res
2516 try:
2530 try:
2517 alias,cmd = par.split(None,1)
2531 alias,cmd = par.split(None,1)
2518 except:
2532 except:
2519 print OInspect.getdoc(self.magic_alias)
2533 print OInspect.getdoc(self.magic_alias)
2520 else:
2534 else:
2521 nargs = cmd.count('%s')
2535 nargs = cmd.count('%s')
2522 if nargs>0 and cmd.find('%l')>=0:
2536 if nargs>0 and cmd.find('%l')>=0:
2523 error('The %s and %l specifiers are mutually exclusive '
2537 error('The %s and %l specifiers are mutually exclusive '
2524 'in alias definitions.')
2538 'in alias definitions.')
2525 else: # all looks OK
2539 else: # all looks OK
2526 self.shell.alias_table[alias] = (nargs,cmd)
2540 self.shell.alias_table[alias] = (nargs,cmd)
2527 self.shell.alias_table_validate(verbose=0)
2541 self.shell.alias_table_validate(verbose=0)
2528 # end magic_alias
2542 # end magic_alias
2529
2543
2530 def magic_unalias(self, parameter_s = ''):
2544 def magic_unalias(self, parameter_s = ''):
2531 """Remove an alias"""
2545 """Remove an alias"""
2532
2546
2533 aname = parameter_s.strip()
2547 aname = parameter_s.strip()
2534 if aname in self.shell.alias_table:
2548 if aname in self.shell.alias_table:
2535 del self.shell.alias_table[aname]
2549 del self.shell.alias_table[aname]
2536 stored = self.db.get('stored_aliases', {} )
2550 stored = self.db.get('stored_aliases', {} )
2537 if aname in stored:
2551 if aname in stored:
2538 print "Removing %stored alias",aname
2552 print "Removing %stored alias",aname
2539 del stored[aname]
2553 del stored[aname]
2540 self.db['stored_aliases'] = stored
2554 self.db['stored_aliases'] = stored
2541
2555
2542
2556
2543 def magic_rehashx(self, parameter_s = ''):
2557 def magic_rehashx(self, parameter_s = ''):
2544 """Update the alias table with all executable files in $PATH.
2558 """Update the alias table with all executable files in $PATH.
2545
2559
2546 This version explicitly checks that every entry in $PATH is a file
2560 This version explicitly checks that every entry in $PATH is a file
2547 with execute access (os.X_OK), so it is much slower than %rehash.
2561 with execute access (os.X_OK), so it is much slower than %rehash.
2548
2562
2549 Under Windows, it checks executability as a match agains a
2563 Under Windows, it checks executability as a match agains a
2550 '|'-separated string of extensions, stored in the IPython config
2564 '|'-separated string of extensions, stored in the IPython config
2551 variable win_exec_ext. This defaults to 'exe|com|bat'.
2565 variable win_exec_ext. This defaults to 'exe|com|bat'.
2552
2566
2553 This function also resets the root module cache of module completer,
2567 This function also resets the root module cache of module completer,
2554 used on slow filesystems.
2568 used on slow filesystems.
2555 """
2569 """
2556
2570
2557
2571
2558 ip = self.api
2572 ip = self.api
2559
2573
2560 # for the benefit of module completer in ipy_completers.py
2574 # for the benefit of module completer in ipy_completers.py
2561 del ip.db['rootmodules']
2575 del ip.db['rootmodules']
2562
2576
2563 path = [os.path.abspath(os.path.expanduser(p)) for p in
2577 path = [os.path.abspath(os.path.expanduser(p)) for p in
2564 os.environ.get('PATH','').split(os.pathsep)]
2578 os.environ.get('PATH','').split(os.pathsep)]
2565 path = filter(os.path.isdir,path)
2579 path = filter(os.path.isdir,path)
2566
2580
2567 alias_table = self.shell.alias_table
2581 alias_table = self.shell.alias_table
2568 syscmdlist = []
2582 syscmdlist = []
2569 if os.name == 'posix':
2583 if os.name == 'posix':
2570 isexec = lambda fname:os.path.isfile(fname) and \
2584 isexec = lambda fname:os.path.isfile(fname) and \
2571 os.access(fname,os.X_OK)
2585 os.access(fname,os.X_OK)
2572 else:
2586 else:
2573
2587
2574 try:
2588 try:
2575 winext = os.environ['pathext'].replace(';','|').replace('.','')
2589 winext = os.environ['pathext'].replace(';','|').replace('.','')
2576 except KeyError:
2590 except KeyError:
2577 winext = 'exe|com|bat|py'
2591 winext = 'exe|com|bat|py'
2578 if 'py' not in winext:
2592 if 'py' not in winext:
2579 winext += '|py'
2593 winext += '|py'
2580 execre = re.compile(r'(.*)\.(%s)$' % winext,re.IGNORECASE)
2594 execre = re.compile(r'(.*)\.(%s)$' % winext,re.IGNORECASE)
2581 isexec = lambda fname:os.path.isfile(fname) and execre.match(fname)
2595 isexec = lambda fname:os.path.isfile(fname) and execre.match(fname)
2582 savedir = os.getcwd()
2596 savedir = os.getcwd()
2583 try:
2597 try:
2584 # write the whole loop for posix/Windows so we don't have an if in
2598 # write the whole loop for posix/Windows so we don't have an if in
2585 # the innermost part
2599 # the innermost part
2586 if os.name == 'posix':
2600 if os.name == 'posix':
2587 for pdir in path:
2601 for pdir in path:
2588 os.chdir(pdir)
2602 os.chdir(pdir)
2589 for ff in os.listdir(pdir):
2603 for ff in os.listdir(pdir):
2590 if isexec(ff) and ff not in self.shell.no_alias:
2604 if isexec(ff) and ff not in self.shell.no_alias:
2591 # each entry in the alias table must be (N,name),
2605 # each entry in the alias table must be (N,name),
2592 # where N is the number of positional arguments of the
2606 # where N is the number of positional arguments of the
2593 # alias.
2607 # alias.
2594 alias_table[ff] = (0,ff)
2608 alias_table[ff] = (0,ff)
2595 syscmdlist.append(ff)
2609 syscmdlist.append(ff)
2596 else:
2610 else:
2597 for pdir in path:
2611 for pdir in path:
2598 os.chdir(pdir)
2612 os.chdir(pdir)
2599 for ff in os.listdir(pdir):
2613 for ff in os.listdir(pdir):
2600 base, ext = os.path.splitext(ff)
2614 base, ext = os.path.splitext(ff)
2601 if isexec(ff) and base not in self.shell.no_alias:
2615 if isexec(ff) and base not in self.shell.no_alias:
2602 if ext.lower() == '.exe':
2616 if ext.lower() == '.exe':
2603 ff = base
2617 ff = base
2604 alias_table[base.lower()] = (0,ff)
2618 alias_table[base.lower()] = (0,ff)
2605 syscmdlist.append(ff)
2619 syscmdlist.append(ff)
2606 # Make sure the alias table doesn't contain keywords or builtins
2620 # Make sure the alias table doesn't contain keywords or builtins
2607 self.shell.alias_table_validate()
2621 self.shell.alias_table_validate()
2608 # Call again init_auto_alias() so we get 'rm -i' and other
2622 # Call again init_auto_alias() so we get 'rm -i' and other
2609 # modified aliases since %rehashx will probably clobber them
2623 # modified aliases since %rehashx will probably clobber them
2610
2624
2611 # no, we don't want them. if %rehashx clobbers them, good,
2625 # no, we don't want them. if %rehashx clobbers them, good,
2612 # we'll probably get better versions
2626 # we'll probably get better versions
2613 # self.shell.init_auto_alias()
2627 # self.shell.init_auto_alias()
2614 db = ip.db
2628 db = ip.db
2615 db['syscmdlist'] = syscmdlist
2629 db['syscmdlist'] = syscmdlist
2616 finally:
2630 finally:
2617 os.chdir(savedir)
2631 os.chdir(savedir)
2618
2632
2619 def magic_pwd(self, parameter_s = ''):
2633 def magic_pwd(self, parameter_s = ''):
2620 """Return the current working directory path."""
2634 """Return the current working directory path."""
2621 return os.getcwd()
2635 return os.getcwd()
2622
2636
2623 def magic_cd(self, parameter_s=''):
2637 def magic_cd(self, parameter_s=''):
2624 """Change the current working directory.
2638 """Change the current working directory.
2625
2639
2626 This command automatically maintains an internal list of directories
2640 This command automatically maintains an internal list of directories
2627 you visit during your IPython session, in the variable _dh. The
2641 you visit during your IPython session, in the variable _dh. The
2628 command %dhist shows this history nicely formatted. You can also
2642 command %dhist shows this history nicely formatted. You can also
2629 do 'cd -<tab>' to see directory history conveniently.
2643 do 'cd -<tab>' to see directory history conveniently.
2630
2644
2631 Usage:
2645 Usage:
2632
2646
2633 cd 'dir': changes to directory 'dir'.
2647 cd 'dir': changes to directory 'dir'.
2634
2648
2635 cd -: changes to the last visited directory.
2649 cd -: changes to the last visited directory.
2636
2650
2637 cd -<n>: changes to the n-th directory in the directory history.
2651 cd -<n>: changes to the n-th directory in the directory history.
2638
2652
2639 cd -b <bookmark_name>: jump to a bookmark set by %bookmark
2653 cd -b <bookmark_name>: jump to a bookmark set by %bookmark
2640 (note: cd <bookmark_name> is enough if there is no
2654 (note: cd <bookmark_name> is enough if there is no
2641 directory <bookmark_name>, but a bookmark with the name exists.)
2655 directory <bookmark_name>, but a bookmark with the name exists.)
2642 'cd -b <tab>' allows you to tab-complete bookmark names.
2656 'cd -b <tab>' allows you to tab-complete bookmark names.
2643
2657
2644 Options:
2658 Options:
2645
2659
2646 -q: quiet. Do not print the working directory after the cd command is
2660 -q: quiet. Do not print the working directory after the cd command is
2647 executed. By default IPython's cd command does print this directory,
2661 executed. By default IPython's cd command does print this directory,
2648 since the default prompts do not display path information.
2662 since the default prompts do not display path information.
2649
2663
2650 Note that !cd doesn't work for this purpose because the shell where
2664 Note that !cd doesn't work for this purpose because the shell where
2651 !command runs is immediately discarded after executing 'command'."""
2665 !command runs is immediately discarded after executing 'command'."""
2652
2666
2653 parameter_s = parameter_s.strip()
2667 parameter_s = parameter_s.strip()
2654 #bkms = self.shell.persist.get("bookmarks",{})
2668 #bkms = self.shell.persist.get("bookmarks",{})
2655
2669
2656 numcd = re.match(r'(-)(\d+)$',parameter_s)
2670 numcd = re.match(r'(-)(\d+)$',parameter_s)
2657 # jump in directory history by number
2671 # jump in directory history by number
2658 if numcd:
2672 if numcd:
2659 nn = int(numcd.group(2))
2673 nn = int(numcd.group(2))
2660 try:
2674 try:
2661 ps = self.shell.user_ns['_dh'][nn]
2675 ps = self.shell.user_ns['_dh'][nn]
2662 except IndexError:
2676 except IndexError:
2663 print 'The requested directory does not exist in history.'
2677 print 'The requested directory does not exist in history.'
2664 return
2678 return
2665 else:
2679 else:
2666 opts = {}
2680 opts = {}
2667 else:
2681 else:
2668 #turn all non-space-escaping backslashes to slashes,
2682 #turn all non-space-escaping backslashes to slashes,
2669 # for c:\windows\directory\names\
2683 # for c:\windows\directory\names\
2670 parameter_s = re.sub(r'\\(?! )','/', parameter_s)
2684 parameter_s = re.sub(r'\\(?! )','/', parameter_s)
2671 opts,ps = self.parse_options(parameter_s,'qb',mode='string')
2685 opts,ps = self.parse_options(parameter_s,'qb',mode='string')
2672 # jump to previous
2686 # jump to previous
2673 if ps == '-':
2687 if ps == '-':
2674 try:
2688 try:
2675 ps = self.shell.user_ns['_dh'][-2]
2689 ps = self.shell.user_ns['_dh'][-2]
2676 except IndexError:
2690 except IndexError:
2677 raise UsageError('%cd -: No previous directory to change to.')
2691 raise UsageError('%cd -: No previous directory to change to.')
2678 # jump to bookmark if needed
2692 # jump to bookmark if needed
2679 else:
2693 else:
2680 if not os.path.isdir(ps) or opts.has_key('b'):
2694 if not os.path.isdir(ps) or opts.has_key('b'):
2681 bkms = self.db.get('bookmarks', {})
2695 bkms = self.db.get('bookmarks', {})
2682
2696
2683 if bkms.has_key(ps):
2697 if bkms.has_key(ps):
2684 target = bkms[ps]
2698 target = bkms[ps]
2685 print '(bookmark:%s) -> %s' % (ps,target)
2699 print '(bookmark:%s) -> %s' % (ps,target)
2686 ps = target
2700 ps = target
2687 else:
2701 else:
2688 if opts.has_key('b'):
2702 if opts.has_key('b'):
2689 raise UsageError("Bookmark '%s' not found. "
2703 raise UsageError("Bookmark '%s' not found. "
2690 "Use '%%bookmark -l' to see your bookmarks." % ps)
2704 "Use '%%bookmark -l' to see your bookmarks." % ps)
2691
2705
2692 # at this point ps should point to the target dir
2706 # at this point ps should point to the target dir
2693 if ps:
2707 if ps:
2694 try:
2708 try:
2695 os.chdir(os.path.expanduser(ps))
2709 os.chdir(os.path.expanduser(ps))
2696 if self.shell.rc.term_title:
2710 if self.shell.rc.term_title:
2697 #print 'set term title:',self.shell.rc.term_title # dbg
2711 #print 'set term title:',self.shell.rc.term_title # dbg
2698 ttitle = 'IPy ' + abbrev_cwd()
2712 ttitle = 'IPy ' + abbrev_cwd()
2699 platutils.set_term_title(ttitle)
2713 platutils.set_term_title(ttitle)
2700 except OSError:
2714 except OSError:
2701 print sys.exc_info()[1]
2715 print sys.exc_info()[1]
2702 else:
2716 else:
2703 cwd = os.getcwd()
2717 cwd = os.getcwd()
2704 dhist = self.shell.user_ns['_dh']
2718 dhist = self.shell.user_ns['_dh']
2705 dhist.append(cwd)
2719 dhist.append(cwd)
2706 self.db['dhist'] = compress_dhist(dhist)[-100:]
2720 self.db['dhist'] = compress_dhist(dhist)[-100:]
2707
2721
2708 else:
2722 else:
2709 os.chdir(self.shell.home_dir)
2723 os.chdir(self.shell.home_dir)
2710 if self.shell.rc.term_title:
2724 if self.shell.rc.term_title:
2711 platutils.set_term_title("IPy ~")
2725 platutils.set_term_title("IPy ~")
2712 cwd = os.getcwd()
2726 cwd = os.getcwd()
2713 dhist = self.shell.user_ns['_dh']
2727 dhist = self.shell.user_ns['_dh']
2714 dhist.append(cwd)
2728 dhist.append(cwd)
2715 self.db['dhist'] = compress_dhist(dhist)[-100:]
2729 self.db['dhist'] = compress_dhist(dhist)[-100:]
2716 if not 'q' in opts and self.shell.user_ns['_dh']:
2730 if not 'q' in opts and self.shell.user_ns['_dh']:
2717 print self.shell.user_ns['_dh'][-1]
2731 print self.shell.user_ns['_dh'][-1]
2718
2732
2719
2733
2720 def magic_env(self, parameter_s=''):
2734 def magic_env(self, parameter_s=''):
2721 """List environment variables."""
2735 """List environment variables."""
2722
2736
2723 return os.environ.data
2737 return os.environ.data
2724
2738
2725 def magic_pushd(self, parameter_s=''):
2739 def magic_pushd(self, parameter_s=''):
2726 """Place the current dir on stack and change directory.
2740 """Place the current dir on stack and change directory.
2727
2741
2728 Usage:\\
2742 Usage:\\
2729 %pushd ['dirname']
2743 %pushd ['dirname']
2730 """
2744 """
2731
2745
2732 dir_s = self.shell.dir_stack
2746 dir_s = self.shell.dir_stack
2733 tgt = os.path.expanduser(parameter_s)
2747 tgt = os.path.expanduser(parameter_s)
2734 cwd = os.getcwd().replace(self.home_dir,'~')
2748 cwd = os.getcwd().replace(self.home_dir,'~')
2735 if tgt:
2749 if tgt:
2736 self.magic_cd(parameter_s)
2750 self.magic_cd(parameter_s)
2737 dir_s.insert(0,cwd)
2751 dir_s.insert(0,cwd)
2738 return self.magic_dirs()
2752 return self.magic_dirs()
2739
2753
2740 def magic_popd(self, parameter_s=''):
2754 def magic_popd(self, parameter_s=''):
2741 """Change to directory popped off the top of the stack.
2755 """Change to directory popped off the top of the stack.
2742 """
2756 """
2743 if not self.shell.dir_stack:
2757 if not self.shell.dir_stack:
2744 raise UsageError("%popd on empty stack")
2758 raise UsageError("%popd on empty stack")
2745 top = self.shell.dir_stack.pop(0)
2759 top = self.shell.dir_stack.pop(0)
2746 self.magic_cd(top)
2760 self.magic_cd(top)
2747 print "popd ->",top
2761 print "popd ->",top
2748
2762
2749 def magic_dirs(self, parameter_s=''):
2763 def magic_dirs(self, parameter_s=''):
2750 """Return the current directory stack."""
2764 """Return the current directory stack."""
2751
2765
2752 return self.shell.dir_stack
2766 return self.shell.dir_stack
2753
2767
2754 def magic_dhist(self, parameter_s=''):
2768 def magic_dhist(self, parameter_s=''):
2755 """Print your history of visited directories.
2769 """Print your history of visited directories.
2756
2770
2757 %dhist -> print full history\\
2771 %dhist -> print full history\\
2758 %dhist n -> print last n entries only\\
2772 %dhist n -> print last n entries only\\
2759 %dhist n1 n2 -> print entries between n1 and n2 (n1 not included)\\
2773 %dhist n1 n2 -> print entries between n1 and n2 (n1 not included)\\
2760
2774
2761 This history is automatically maintained by the %cd command, and
2775 This history is automatically maintained by the %cd command, and
2762 always available as the global list variable _dh. You can use %cd -<n>
2776 always available as the global list variable _dh. You can use %cd -<n>
2763 to go to directory number <n>.
2777 to go to directory number <n>.
2764
2778
2765 Note that most of time, you should view directory history by entering
2779 Note that most of time, you should view directory history by entering
2766 cd -<TAB>.
2780 cd -<TAB>.
2767
2781
2768 """
2782 """
2769
2783
2770 dh = self.shell.user_ns['_dh']
2784 dh = self.shell.user_ns['_dh']
2771 if parameter_s:
2785 if parameter_s:
2772 try:
2786 try:
2773 args = map(int,parameter_s.split())
2787 args = map(int,parameter_s.split())
2774 except:
2788 except:
2775 self.arg_err(Magic.magic_dhist)
2789 self.arg_err(Magic.magic_dhist)
2776 return
2790 return
2777 if len(args) == 1:
2791 if len(args) == 1:
2778 ini,fin = max(len(dh)-(args[0]),0),len(dh)
2792 ini,fin = max(len(dh)-(args[0]),0),len(dh)
2779 elif len(args) == 2:
2793 elif len(args) == 2:
2780 ini,fin = args
2794 ini,fin = args
2781 else:
2795 else:
2782 self.arg_err(Magic.magic_dhist)
2796 self.arg_err(Magic.magic_dhist)
2783 return
2797 return
2784 else:
2798 else:
2785 ini,fin = 0,len(dh)
2799 ini,fin = 0,len(dh)
2786 nlprint(dh,
2800 nlprint(dh,
2787 header = 'Directory history (kept in _dh)',
2801 header = 'Directory history (kept in _dh)',
2788 start=ini,stop=fin)
2802 start=ini,stop=fin)
2789
2803
2790
2804
2791 def magic_sc(self, parameter_s=''):
2805 def magic_sc(self, parameter_s=''):
2792 """Shell capture - execute a shell command and capture its output.
2806 """Shell capture - execute a shell command and capture its output.
2793
2807
2794 DEPRECATED. Suboptimal, retained for backwards compatibility.
2808 DEPRECATED. Suboptimal, retained for backwards compatibility.
2795
2809
2796 You should use the form 'var = !command' instead. Example:
2810 You should use the form 'var = !command' instead. Example:
2797
2811
2798 "%sc -l myfiles = ls ~" should now be written as
2812 "%sc -l myfiles = ls ~" should now be written as
2799
2813
2800 "myfiles = !ls ~"
2814 "myfiles = !ls ~"
2801
2815
2802 myfiles.s, myfiles.l and myfiles.n still apply as documented
2816 myfiles.s, myfiles.l and myfiles.n still apply as documented
2803 below.
2817 below.
2804
2818
2805 --
2819 --
2806 %sc [options] varname=command
2820 %sc [options] varname=command
2807
2821
2808 IPython will run the given command using commands.getoutput(), and
2822 IPython will run the given command using commands.getoutput(), and
2809 will then update the user's interactive namespace with a variable
2823 will then update the user's interactive namespace with a variable
2810 called varname, containing the value of the call. Your command can
2824 called varname, containing the value of the call. Your command can
2811 contain shell wildcards, pipes, etc.
2825 contain shell wildcards, pipes, etc.
2812
2826
2813 The '=' sign in the syntax is mandatory, and the variable name you
2827 The '=' sign in the syntax is mandatory, and the variable name you
2814 supply must follow Python's standard conventions for valid names.
2828 supply must follow Python's standard conventions for valid names.
2815
2829
2816 (A special format without variable name exists for internal use)
2830 (A special format without variable name exists for internal use)
2817
2831
2818 Options:
2832 Options:
2819
2833
2820 -l: list output. Split the output on newlines into a list before
2834 -l: list output. Split the output on newlines into a list before
2821 assigning it to the given variable. By default the output is stored
2835 assigning it to the given variable. By default the output is stored
2822 as a single string.
2836 as a single string.
2823
2837
2824 -v: verbose. Print the contents of the variable.
2838 -v: verbose. Print the contents of the variable.
2825
2839
2826 In most cases you should not need to split as a list, because the
2840 In most cases you should not need to split as a list, because the
2827 returned value is a special type of string which can automatically
2841 returned value is a special type of string which can automatically
2828 provide its contents either as a list (split on newlines) or as a
2842 provide its contents either as a list (split on newlines) or as a
2829 space-separated string. These are convenient, respectively, either
2843 space-separated string. These are convenient, respectively, either
2830 for sequential processing or to be passed to a shell command.
2844 for sequential processing or to be passed to a shell command.
2831
2845
2832 For example:
2846 For example:
2833
2847
2834 # Capture into variable a
2848 # Capture into variable a
2835 In [9]: sc a=ls *py
2849 In [9]: sc a=ls *py
2836
2850
2837 # a is a string with embedded newlines
2851 # a is a string with embedded newlines
2838 In [10]: a
2852 In [10]: a
2839 Out[10]: 'setup.py\nwin32_manual_post_install.py'
2853 Out[10]: 'setup.py\nwin32_manual_post_install.py'
2840
2854
2841 # which can be seen as a list:
2855 # which can be seen as a list:
2842 In [11]: a.l
2856 In [11]: a.l
2843 Out[11]: ['setup.py', 'win32_manual_post_install.py']
2857 Out[11]: ['setup.py', 'win32_manual_post_install.py']
2844
2858
2845 # or as a whitespace-separated string:
2859 # or as a whitespace-separated string:
2846 In [12]: a.s
2860 In [12]: a.s
2847 Out[12]: 'setup.py win32_manual_post_install.py'
2861 Out[12]: 'setup.py win32_manual_post_install.py'
2848
2862
2849 # a.s is useful to pass as a single command line:
2863 # a.s is useful to pass as a single command line:
2850 In [13]: !wc -l $a.s
2864 In [13]: !wc -l $a.s
2851 146 setup.py
2865 146 setup.py
2852 130 win32_manual_post_install.py
2866 130 win32_manual_post_install.py
2853 276 total
2867 276 total
2854
2868
2855 # while the list form is useful to loop over:
2869 # while the list form is useful to loop over:
2856 In [14]: for f in a.l:
2870 In [14]: for f in a.l:
2857 ....: !wc -l $f
2871 ....: !wc -l $f
2858 ....:
2872 ....:
2859 146 setup.py
2873 146 setup.py
2860 130 win32_manual_post_install.py
2874 130 win32_manual_post_install.py
2861
2875
2862 Similiarly, the lists returned by the -l option are also special, in
2876 Similiarly, the lists returned by the -l option are also special, in
2863 the sense that you can equally invoke the .s attribute on them to
2877 the sense that you can equally invoke the .s attribute on them to
2864 automatically get a whitespace-separated string from their contents:
2878 automatically get a whitespace-separated string from their contents:
2865
2879
2866 In [1]: sc -l b=ls *py
2880 In [1]: sc -l b=ls *py
2867
2881
2868 In [2]: b
2882 In [2]: b
2869 Out[2]: ['setup.py', 'win32_manual_post_install.py']
2883 Out[2]: ['setup.py', 'win32_manual_post_install.py']
2870
2884
2871 In [3]: b.s
2885 In [3]: b.s
2872 Out[3]: 'setup.py win32_manual_post_install.py'
2886 Out[3]: 'setup.py win32_manual_post_install.py'
2873
2887
2874 In summary, both the lists and strings used for ouptut capture have
2888 In summary, both the lists and strings used for ouptut capture have
2875 the following special attributes:
2889 the following special attributes:
2876
2890
2877 .l (or .list) : value as list.
2891 .l (or .list) : value as list.
2878 .n (or .nlstr): value as newline-separated string.
2892 .n (or .nlstr): value as newline-separated string.
2879 .s (or .spstr): value as space-separated string.
2893 .s (or .spstr): value as space-separated string.
2880 """
2894 """
2881
2895
2882 opts,args = self.parse_options(parameter_s,'lv')
2896 opts,args = self.parse_options(parameter_s,'lv')
2883 # Try to get a variable name and command to run
2897 # Try to get a variable name and command to run
2884 try:
2898 try:
2885 # the variable name must be obtained from the parse_options
2899 # the variable name must be obtained from the parse_options
2886 # output, which uses shlex.split to strip options out.
2900 # output, which uses shlex.split to strip options out.
2887 var,_ = args.split('=',1)
2901 var,_ = args.split('=',1)
2888 var = var.strip()
2902 var = var.strip()
2889 # But the the command has to be extracted from the original input
2903 # But the the command has to be extracted from the original input
2890 # parameter_s, not on what parse_options returns, to avoid the
2904 # parameter_s, not on what parse_options returns, to avoid the
2891 # quote stripping which shlex.split performs on it.
2905 # quote stripping which shlex.split performs on it.
2892 _,cmd = parameter_s.split('=',1)
2906 _,cmd = parameter_s.split('=',1)
2893 except ValueError:
2907 except ValueError:
2894 var,cmd = '',''
2908 var,cmd = '',''
2895 # If all looks ok, proceed
2909 # If all looks ok, proceed
2896 out,err = self.shell.getoutputerror(cmd)
2910 out,err = self.shell.getoutputerror(cmd)
2897 if err:
2911 if err:
2898 print >> Term.cerr,err
2912 print >> Term.cerr,err
2899 if opts.has_key('l'):
2913 if opts.has_key('l'):
2900 out = SList(out.split('\n'))
2914 out = SList(out.split('\n'))
2901 else:
2915 else:
2902 out = LSString(out)
2916 out = LSString(out)
2903 if opts.has_key('v'):
2917 if opts.has_key('v'):
2904 print '%s ==\n%s' % (var,pformat(out))
2918 print '%s ==\n%s' % (var,pformat(out))
2905 if var:
2919 if var:
2906 self.shell.user_ns.update({var:out})
2920 self.shell.user_ns.update({var:out})
2907 else:
2921 else:
2908 return out
2922 return out
2909
2923
2910 def magic_sx(self, parameter_s=''):
2924 def magic_sx(self, parameter_s=''):
2911 """Shell execute - run a shell command and capture its output.
2925 """Shell execute - run a shell command and capture its output.
2912
2926
2913 %sx command
2927 %sx command
2914
2928
2915 IPython will run the given command using commands.getoutput(), and
2929 IPython will run the given command using commands.getoutput(), and
2916 return the result formatted as a list (split on '\\n'). Since the
2930 return the result formatted as a list (split on '\\n'). Since the
2917 output is _returned_, it will be stored in ipython's regular output
2931 output is _returned_, it will be stored in ipython's regular output
2918 cache Out[N] and in the '_N' automatic variables.
2932 cache Out[N] and in the '_N' automatic variables.
2919
2933
2920 Notes:
2934 Notes:
2921
2935
2922 1) If an input line begins with '!!', then %sx is automatically
2936 1) If an input line begins with '!!', then %sx is automatically
2923 invoked. That is, while:
2937 invoked. That is, while:
2924 !ls
2938 !ls
2925 causes ipython to simply issue system('ls'), typing
2939 causes ipython to simply issue system('ls'), typing
2926 !!ls
2940 !!ls
2927 is a shorthand equivalent to:
2941 is a shorthand equivalent to:
2928 %sx ls
2942 %sx ls
2929
2943
2930 2) %sx differs from %sc in that %sx automatically splits into a list,
2944 2) %sx differs from %sc in that %sx automatically splits into a list,
2931 like '%sc -l'. The reason for this is to make it as easy as possible
2945 like '%sc -l'. The reason for this is to make it as easy as possible
2932 to process line-oriented shell output via further python commands.
2946 to process line-oriented shell output via further python commands.
2933 %sc is meant to provide much finer control, but requires more
2947 %sc is meant to provide much finer control, but requires more
2934 typing.
2948 typing.
2935
2949
2936 3) Just like %sc -l, this is a list with special attributes:
2950 3) Just like %sc -l, this is a list with special attributes:
2937
2951
2938 .l (or .list) : value as list.
2952 .l (or .list) : value as list.
2939 .n (or .nlstr): value as newline-separated string.
2953 .n (or .nlstr): value as newline-separated string.
2940 .s (or .spstr): value as whitespace-separated string.
2954 .s (or .spstr): value as whitespace-separated string.
2941
2955
2942 This is very useful when trying to use such lists as arguments to
2956 This is very useful when trying to use such lists as arguments to
2943 system commands."""
2957 system commands."""
2944
2958
2945 if parameter_s:
2959 if parameter_s:
2946 out,err = self.shell.getoutputerror(parameter_s)
2960 out,err = self.shell.getoutputerror(parameter_s)
2947 if err:
2961 if err:
2948 print >> Term.cerr,err
2962 print >> Term.cerr,err
2949 return SList(out.split('\n'))
2963 return SList(out.split('\n'))
2950
2964
2951 def magic_bg(self, parameter_s=''):
2965 def magic_bg(self, parameter_s=''):
2952 """Run a job in the background, in a separate thread.
2966 """Run a job in the background, in a separate thread.
2953
2967
2954 For example,
2968 For example,
2955
2969
2956 %bg myfunc(x,y,z=1)
2970 %bg myfunc(x,y,z=1)
2957
2971
2958 will execute 'myfunc(x,y,z=1)' in a background thread. As soon as the
2972 will execute 'myfunc(x,y,z=1)' in a background thread. As soon as the
2959 execution starts, a message will be printed indicating the job
2973 execution starts, a message will be printed indicating the job
2960 number. If your job number is 5, you can use
2974 number. If your job number is 5, you can use
2961
2975
2962 myvar = jobs.result(5) or myvar = jobs[5].result
2976 myvar = jobs.result(5) or myvar = jobs[5].result
2963
2977
2964 to assign this result to variable 'myvar'.
2978 to assign this result to variable 'myvar'.
2965
2979
2966 IPython has a job manager, accessible via the 'jobs' object. You can
2980 IPython has a job manager, accessible via the 'jobs' object. You can
2967 type jobs? to get more information about it, and use jobs.<TAB> to see
2981 type jobs? to get more information about it, and use jobs.<TAB> to see
2968 its attributes. All attributes not starting with an underscore are
2982 its attributes. All attributes not starting with an underscore are
2969 meant for public use.
2983 meant for public use.
2970
2984
2971 In particular, look at the jobs.new() method, which is used to create
2985 In particular, look at the jobs.new() method, which is used to create
2972 new jobs. This magic %bg function is just a convenience wrapper
2986 new jobs. This magic %bg function is just a convenience wrapper
2973 around jobs.new(), for expression-based jobs. If you want to create a
2987 around jobs.new(), for expression-based jobs. If you want to create a
2974 new job with an explicit function object and arguments, you must call
2988 new job with an explicit function object and arguments, you must call
2975 jobs.new() directly.
2989 jobs.new() directly.
2976
2990
2977 The jobs.new docstring also describes in detail several important
2991 The jobs.new docstring also describes in detail several important
2978 caveats associated with a thread-based model for background job
2992 caveats associated with a thread-based model for background job
2979 execution. Type jobs.new? for details.
2993 execution. Type jobs.new? for details.
2980
2994
2981 You can check the status of all jobs with jobs.status().
2995 You can check the status of all jobs with jobs.status().
2982
2996
2983 The jobs variable is set by IPython into the Python builtin namespace.
2997 The jobs variable is set by IPython into the Python builtin namespace.
2984 If you ever declare a variable named 'jobs', you will shadow this
2998 If you ever declare a variable named 'jobs', you will shadow this
2985 name. You can either delete your global jobs variable to regain
2999 name. You can either delete your global jobs variable to regain
2986 access to the job manager, or make a new name and assign it manually
3000 access to the job manager, or make a new name and assign it manually
2987 to the manager (stored in IPython's namespace). For example, to
3001 to the manager (stored in IPython's namespace). For example, to
2988 assign the job manager to the Jobs name, use:
3002 assign the job manager to the Jobs name, use:
2989
3003
2990 Jobs = __builtins__.jobs"""
3004 Jobs = __builtins__.jobs"""
2991
3005
2992 self.shell.jobs.new(parameter_s,self.shell.user_ns)
3006 self.shell.jobs.new(parameter_s,self.shell.user_ns)
2993
3007
2994 def magic_r(self, parameter_s=''):
3008 def magic_r(self, parameter_s=''):
2995 """Repeat previous input.
3009 """Repeat previous input.
2996
3010
2997 Note: Consider using the more powerfull %rep instead!
3011 Note: Consider using the more powerfull %rep instead!
2998
3012
2999 If given an argument, repeats the previous command which starts with
3013 If given an argument, repeats the previous command which starts with
3000 the same string, otherwise it just repeats the previous input.
3014 the same string, otherwise it just repeats the previous input.
3001
3015
3002 Shell escaped commands (with ! as first character) are not recognized
3016 Shell escaped commands (with ! as first character) are not recognized
3003 by this system, only pure python code and magic commands.
3017 by this system, only pure python code and magic commands.
3004 """
3018 """
3005
3019
3006 start = parameter_s.strip()
3020 start = parameter_s.strip()
3007 esc_magic = self.shell.ESC_MAGIC
3021 esc_magic = self.shell.ESC_MAGIC
3008 # Identify magic commands even if automagic is on (which means
3022 # Identify magic commands even if automagic is on (which means
3009 # the in-memory version is different from that typed by the user).
3023 # the in-memory version is different from that typed by the user).
3010 if self.shell.rc.automagic:
3024 if self.shell.rc.automagic:
3011 start_magic = esc_magic+start
3025 start_magic = esc_magic+start
3012 else:
3026 else:
3013 start_magic = start
3027 start_magic = start
3014 # Look through the input history in reverse
3028 # Look through the input history in reverse
3015 for n in range(len(self.shell.input_hist)-2,0,-1):
3029 for n in range(len(self.shell.input_hist)-2,0,-1):
3016 input = self.shell.input_hist[n]
3030 input = self.shell.input_hist[n]
3017 # skip plain 'r' lines so we don't recurse to infinity
3031 # skip plain 'r' lines so we don't recurse to infinity
3018 if input != '_ip.magic("r")\n' and \
3032 if input != '_ip.magic("r")\n' and \
3019 (input.startswith(start) or input.startswith(start_magic)):
3033 (input.startswith(start) or input.startswith(start_magic)):
3020 #print 'match',`input` # dbg
3034 #print 'match',`input` # dbg
3021 print 'Executing:',input,
3035 print 'Executing:',input,
3022 self.shell.runlines(input)
3036 self.shell.runlines(input)
3023 return
3037 return
3024 print 'No previous input matching `%s` found.' % start
3038 print 'No previous input matching `%s` found.' % start
3025
3039
3026
3040
3027 def magic_bookmark(self, parameter_s=''):
3041 def magic_bookmark(self, parameter_s=''):
3028 """Manage IPython's bookmark system.
3042 """Manage IPython's bookmark system.
3029
3043
3030 %bookmark <name> - set bookmark to current dir
3044 %bookmark <name> - set bookmark to current dir
3031 %bookmark <name> <dir> - set bookmark to <dir>
3045 %bookmark <name> <dir> - set bookmark to <dir>
3032 %bookmark -l - list all bookmarks
3046 %bookmark -l - list all bookmarks
3033 %bookmark -d <name> - remove bookmark
3047 %bookmark -d <name> - remove bookmark
3034 %bookmark -r - remove all bookmarks
3048 %bookmark -r - remove all bookmarks
3035
3049
3036 You can later on access a bookmarked folder with:
3050 You can later on access a bookmarked folder with:
3037 %cd -b <name>
3051 %cd -b <name>
3038 or simply '%cd <name>' if there is no directory called <name> AND
3052 or simply '%cd <name>' if there is no directory called <name> AND
3039 there is such a bookmark defined.
3053 there is such a bookmark defined.
3040
3054
3041 Your bookmarks persist through IPython sessions, but they are
3055 Your bookmarks persist through IPython sessions, but they are
3042 associated with each profile."""
3056 associated with each profile."""
3043
3057
3044 opts,args = self.parse_options(parameter_s,'drl',mode='list')
3058 opts,args = self.parse_options(parameter_s,'drl',mode='list')
3045 if len(args) > 2:
3059 if len(args) > 2:
3046 raise UsageError("%bookmark: too many arguments")
3060 raise UsageError("%bookmark: too many arguments")
3047
3061
3048 bkms = self.db.get('bookmarks',{})
3062 bkms = self.db.get('bookmarks',{})
3049
3063
3050 if opts.has_key('d'):
3064 if opts.has_key('d'):
3051 try:
3065 try:
3052 todel = args[0]
3066 todel = args[0]
3053 except IndexError:
3067 except IndexError:
3054 raise UsageError(
3068 raise UsageError(
3055 "%bookmark -d: must provide a bookmark to delete")
3069 "%bookmark -d: must provide a bookmark to delete")
3056 else:
3070 else:
3057 try:
3071 try:
3058 del bkms[todel]
3072 del bkms[todel]
3059 except KeyError:
3073 except KeyError:
3060 raise UsageError(
3074 raise UsageError(
3061 "%%bookmark -d: Can't delete bookmark '%s'" % todel)
3075 "%%bookmark -d: Can't delete bookmark '%s'" % todel)
3062
3076
3063 elif opts.has_key('r'):
3077 elif opts.has_key('r'):
3064 bkms = {}
3078 bkms = {}
3065 elif opts.has_key('l'):
3079 elif opts.has_key('l'):
3066 bks = bkms.keys()
3080 bks = bkms.keys()
3067 bks.sort()
3081 bks.sort()
3068 if bks:
3082 if bks:
3069 size = max(map(len,bks))
3083 size = max(map(len,bks))
3070 else:
3084 else:
3071 size = 0
3085 size = 0
3072 fmt = '%-'+str(size)+'s -> %s'
3086 fmt = '%-'+str(size)+'s -> %s'
3073 print 'Current bookmarks:'
3087 print 'Current bookmarks:'
3074 for bk in bks:
3088 for bk in bks:
3075 print fmt % (bk,bkms[bk])
3089 print fmt % (bk,bkms[bk])
3076 else:
3090 else:
3077 if not args:
3091 if not args:
3078 raise UsageError("%bookmark: You must specify the bookmark name")
3092 raise UsageError("%bookmark: You must specify the bookmark name")
3079 elif len(args)==1:
3093 elif len(args)==1:
3080 bkms[args[0]] = os.getcwd()
3094 bkms[args[0]] = os.getcwd()
3081 elif len(args)==2:
3095 elif len(args)==2:
3082 bkms[args[0]] = args[1]
3096 bkms[args[0]] = args[1]
3083 self.db['bookmarks'] = bkms
3097 self.db['bookmarks'] = bkms
3084
3098
3085 def magic_pycat(self, parameter_s=''):
3099 def magic_pycat(self, parameter_s=''):
3086 """Show a syntax-highlighted file through a pager.
3100 """Show a syntax-highlighted file through a pager.
3087
3101
3088 This magic is similar to the cat utility, but it will assume the file
3102 This magic is similar to the cat utility, but it will assume the file
3089 to be Python source and will show it with syntax highlighting. """
3103 to be Python source and will show it with syntax highlighting. """
3090
3104
3091 try:
3105 try:
3092 filename = get_py_filename(parameter_s)
3106 filename = get_py_filename(parameter_s)
3093 cont = file_read(filename)
3107 cont = file_read(filename)
3094 except IOError:
3108 except IOError:
3095 try:
3109 try:
3096 cont = eval(parameter_s,self.user_ns)
3110 cont = eval(parameter_s,self.user_ns)
3097 except NameError:
3111 except NameError:
3098 cont = None
3112 cont = None
3099 if cont is None:
3113 if cont is None:
3100 print "Error: no such file or variable"
3114 print "Error: no such file or variable"
3101 return
3115 return
3102
3116
3103 page(self.shell.pycolorize(cont),
3117 page(self.shell.pycolorize(cont),
3104 screen_lines=self.shell.rc.screen_length)
3118 screen_lines=self.shell.rc.screen_length)
3105
3119
3106 def magic_cpaste(self, parameter_s=''):
3120 def magic_cpaste(self, parameter_s=''):
3107 """Allows you to paste & execute a pre-formatted code block from clipboard
3121 """Allows you to paste & execute a pre-formatted code block from clipboard
3108
3122
3109 You must terminate the block with '--' (two minus-signs) alone on the
3123 You must terminate the block with '--' (two minus-signs) alone on the
3110 line. You can also provide your own sentinel with '%paste -s %%' ('%%'
3124 line. You can also provide your own sentinel with '%paste -s %%' ('%%'
3111 is the new sentinel for this operation)
3125 is the new sentinel for this operation)
3112
3126
3113 The block is dedented prior to execution to enable execution of method
3127 The block is dedented prior to execution to enable execution of method
3114 definitions. '>' and '+' characters at the beginning of a line are
3128 definitions. '>' and '+' characters at the beginning of a line are
3115 ignored, to allow pasting directly from e-mails or diff files. The
3129 ignored, to allow pasting directly from e-mails or diff files. The
3116 executed block is also assigned to variable named 'pasted_block' for
3130 executed block is also assigned to variable named 'pasted_block' for
3117 later editing with '%edit pasted_block'.
3131 later editing with '%edit pasted_block'.
3118
3132
3119 You can also pass a variable name as an argument, e.g. '%cpaste foo'.
3133 You can also pass a variable name as an argument, e.g. '%cpaste foo'.
3120 This assigns the pasted block to variable 'foo' as string, without
3134 This assigns the pasted block to variable 'foo' as string, without
3121 dedenting or executing it.
3135 dedenting or executing it.
3122
3136
3123 Do not be alarmed by garbled output on Windows (it's a readline bug).
3137 Do not be alarmed by garbled output on Windows (it's a readline bug).
3124 Just press enter and type -- (and press enter again) and the block
3138 Just press enter and type -- (and press enter again) and the block
3125 will be what was just pasted.
3139 will be what was just pasted.
3126
3140
3127 IPython statements (magics, shell escapes) are not supported (yet).
3141 IPython statements (magics, shell escapes) are not supported (yet).
3128 """
3142 """
3129 opts,args = self.parse_options(parameter_s,'s:',mode='string')
3143 opts,args = self.parse_options(parameter_s,'s:',mode='string')
3130 par = args.strip()
3144 par = args.strip()
3131 sentinel = opts.get('s','--')
3145 sentinel = opts.get('s','--')
3132
3146
3133 from IPython import iplib
3147 from IPython import iplib
3134 lines = []
3148 lines = []
3135 print "Pasting code; enter '%s' alone on the line to stop." % sentinel
3149 print "Pasting code; enter '%s' alone on the line to stop." % sentinel
3136 while 1:
3150 while 1:
3137 l = iplib.raw_input_original(':')
3151 l = iplib.raw_input_original(':')
3138 if l ==sentinel:
3152 if l ==sentinel:
3139 break
3153 break
3140 lines.append(l.lstrip('>').lstrip('+'))
3154 lines.append(l.lstrip('>').lstrip('+'))
3141 block = "\n".join(lines) + '\n'
3155 block = "\n".join(lines) + '\n'
3142 #print "block:\n",block
3156 #print "block:\n",block
3143 if not par:
3157 if not par:
3144 b = textwrap.dedent(block)
3158 b = textwrap.dedent(block)
3145 exec b in self.user_ns
3159 exec b in self.user_ns
3146 self.user_ns['pasted_block'] = b
3160 self.user_ns['pasted_block'] = b
3147 else:
3161 else:
3148 self.user_ns[par] = block
3162 self.user_ns[par] = block
3149 print "Block assigned to '%s'" % par
3163 print "Block assigned to '%s'" % par
3150
3164
3151 def magic_quickref(self,arg):
3165 def magic_quickref(self,arg):
3152 """ Show a quick reference sheet """
3166 """ Show a quick reference sheet """
3153 import IPython.usage
3167 import IPython.usage
3154 qr = IPython.usage.quick_reference + self.magic_magic('-brief')
3168 qr = IPython.usage.quick_reference + self.magic_magic('-brief')
3155
3169
3156 page(qr)
3170 page(qr)
3157
3171
3158 def magic_upgrade(self,arg):
3172 def magic_upgrade(self,arg):
3159 """ Upgrade your IPython installation
3173 """ Upgrade your IPython installation
3160
3174
3161 This will copy the config files that don't yet exist in your
3175 This will copy the config files that don't yet exist in your
3162 ipython dir from the system config dir. Use this after upgrading
3176 ipython dir from the system config dir. Use this after upgrading
3163 IPython if you don't wish to delete your .ipython dir.
3177 IPython if you don't wish to delete your .ipython dir.
3164
3178
3165 Call with -nolegacy to get rid of ipythonrc* files (recommended for
3179 Call with -nolegacy to get rid of ipythonrc* files (recommended for
3166 new users)
3180 new users)
3167
3181
3168 """
3182 """
3169 ip = self.getapi()
3183 ip = self.getapi()
3170 ipinstallation = path(IPython.__file__).dirname()
3184 ipinstallation = path(IPython.__file__).dirname()
3171 upgrade_script = '%s "%s"' % (sys.executable,ipinstallation / 'upgrade_dir.py')
3185 upgrade_script = '%s "%s"' % (sys.executable,ipinstallation / 'upgrade_dir.py')
3172 src_config = ipinstallation / 'UserConfig'
3186 src_config = ipinstallation / 'UserConfig'
3173 userdir = path(ip.options.ipythondir)
3187 userdir = path(ip.options.ipythondir)
3174 cmd = '%s "%s" "%s"' % (upgrade_script, src_config, userdir)
3188 cmd = '%s "%s" "%s"' % (upgrade_script, src_config, userdir)
3175 print ">",cmd
3189 print ">",cmd
3176 shell(cmd)
3190 shell(cmd)
3177 if arg == '-nolegacy':
3191 if arg == '-nolegacy':
3178 legacy = userdir.files('ipythonrc*')
3192 legacy = userdir.files('ipythonrc*')
3179 print "Nuking legacy files:",legacy
3193 print "Nuking legacy files:",legacy
3180
3194
3181 [p.remove() for p in legacy]
3195 [p.remove() for p in legacy]
3182 suffix = (sys.platform == 'win32' and '.ini' or '')
3196 suffix = (sys.platform == 'win32' and '.ini' or '')
3183 (userdir / ('ipythonrc' + suffix)).write_text('# Empty, see ipy_user_conf.py\n')
3197 (userdir / ('ipythonrc' + suffix)).write_text('# Empty, see ipy_user_conf.py\n')
3184
3198
3185
3199
3186 def magic_doctest_mode(self,parameter_s=''):
3200 def magic_doctest_mode(self,parameter_s=''):
3187 """Toggle doctest mode on and off.
3201 """Toggle doctest mode on and off.
3188
3202
3189 This mode allows you to toggle the prompt behavior between normal
3203 This mode allows you to toggle the prompt behavior between normal
3190 IPython prompts and ones that are as similar to the default IPython
3204 IPython prompts and ones that are as similar to the default IPython
3191 interpreter as possible.
3205 interpreter as possible.
3192
3206
3193 It also supports the pasting of code snippets that have leading '>>>'
3207 It also supports the pasting of code snippets that have leading '>>>'
3194 and '...' prompts in them. This means that you can paste doctests from
3208 and '...' prompts in them. This means that you can paste doctests from
3195 files or docstrings (even if they have leading whitespace), and the
3209 files or docstrings (even if they have leading whitespace), and the
3196 code will execute correctly. You can then use '%history -tn' to see
3210 code will execute correctly. You can then use '%history -tn' to see
3197 the translated history without line numbers; this will give you the
3211 the translated history without line numbers; this will give you the
3198 input after removal of all the leading prompts and whitespace, which
3212 input after removal of all the leading prompts and whitespace, which
3199 can be pasted back into an editor.
3213 can be pasted back into an editor.
3200
3214
3201 With these features, you can switch into this mode easily whenever you
3215 With these features, you can switch into this mode easily whenever you
3202 need to do testing and changes to doctests, without having to leave
3216 need to do testing and changes to doctests, without having to leave
3203 your existing IPython session.
3217 your existing IPython session.
3204 """
3218 """
3205
3219
3206 # XXX - Fix this to have cleaner activate/deactivate calls.
3220 # XXX - Fix this to have cleaner activate/deactivate calls.
3207 from IPython.Extensions import InterpreterPasteInput as ipaste
3221 from IPython.Extensions import InterpreterPasteInput as ipaste
3208 from IPython.ipstruct import Struct
3222 from IPython.ipstruct import Struct
3209
3223
3210 # Shorthands
3224 # Shorthands
3211 shell = self.shell
3225 shell = self.shell
3212 oc = shell.outputcache
3226 oc = shell.outputcache
3213 rc = shell.rc
3227 rc = shell.rc
3214 meta = shell.meta
3228 meta = shell.meta
3215 # dstore is a data store kept in the instance metadata bag to track any
3229 # dstore is a data store kept in the instance metadata bag to track any
3216 # changes we make, so we can undo them later.
3230 # changes we make, so we can undo them later.
3217 dstore = meta.setdefault('doctest_mode',Struct())
3231 dstore = meta.setdefault('doctest_mode',Struct())
3218 save_dstore = dstore.setdefault
3232 save_dstore = dstore.setdefault
3219
3233
3220 # save a few values we'll need to recover later
3234 # save a few values we'll need to recover later
3221 mode = save_dstore('mode',False)
3235 mode = save_dstore('mode',False)
3222 save_dstore('rc_pprint',rc.pprint)
3236 save_dstore('rc_pprint',rc.pprint)
3223 save_dstore('xmode',shell.InteractiveTB.mode)
3237 save_dstore('xmode',shell.InteractiveTB.mode)
3224 save_dstore('rc_separate_in',rc.separate_in)
3238 save_dstore('rc_separate_in',rc.separate_in)
3225 save_dstore('rc_separate_out',rc.separate_out)
3239 save_dstore('rc_separate_out',rc.separate_out)
3226 save_dstore('rc_separate_out2',rc.separate_out2)
3240 save_dstore('rc_separate_out2',rc.separate_out2)
3227 save_dstore('rc_prompts_pad_left',rc.prompts_pad_left)
3241 save_dstore('rc_prompts_pad_left',rc.prompts_pad_left)
3228
3242
3229 if mode == False:
3243 if mode == False:
3230 # turn on
3244 # turn on
3231 ipaste.activate_prefilter()
3245 ipaste.activate_prefilter()
3232
3246
3233 oc.prompt1.p_template = '>>> '
3247 oc.prompt1.p_template = '>>> '
3234 oc.prompt2.p_template = '... '
3248 oc.prompt2.p_template = '... '
3235 oc.prompt_out.p_template = ''
3249 oc.prompt_out.p_template = ''
3236
3250
3237 oc.prompt1.sep = '\n'
3251 oc.prompt1.sep = '\n'
3238 oc.output_sep = ''
3252 oc.output_sep = ''
3239 oc.output_sep2 = ''
3253 oc.output_sep2 = ''
3240
3254
3241 oc.prompt1.pad_left = oc.prompt2.pad_left = \
3255 oc.prompt1.pad_left = oc.prompt2.pad_left = \
3242 oc.prompt_out.pad_left = False
3256 oc.prompt_out.pad_left = False
3243
3257
3244 rc.pprint = False
3258 rc.pprint = False
3245
3259
3246 shell.magic_xmode('Plain')
3260 shell.magic_xmode('Plain')
3247
3261
3248 else:
3262 else:
3249 # turn off
3263 # turn off
3250 ipaste.deactivate_prefilter()
3264 ipaste.deactivate_prefilter()
3251
3265
3252 oc.prompt1.p_template = rc.prompt_in1
3266 oc.prompt1.p_template = rc.prompt_in1
3253 oc.prompt2.p_template = rc.prompt_in2
3267 oc.prompt2.p_template = rc.prompt_in2
3254 oc.prompt_out.p_template = rc.prompt_out
3268 oc.prompt_out.p_template = rc.prompt_out
3255
3269
3256 oc.prompt1.sep = dstore.rc_separate_in
3270 oc.prompt1.sep = dstore.rc_separate_in
3257 oc.output_sep = dstore.rc_separate_out
3271 oc.output_sep = dstore.rc_separate_out
3258 oc.output_sep2 = dstore.rc_separate_out2
3272 oc.output_sep2 = dstore.rc_separate_out2
3259
3273
3260 oc.prompt1.pad_left = oc.prompt2.pad_left = \
3274 oc.prompt1.pad_left = oc.prompt2.pad_left = \
3261 oc.prompt_out.pad_left = dstore.rc_prompts_pad_left
3275 oc.prompt_out.pad_left = dstore.rc_prompts_pad_left
3262
3276
3263 rc.pprint = dstore.rc_pprint
3277 rc.pprint = dstore.rc_pprint
3264
3278
3265 shell.magic_xmode(dstore.xmode)
3279 shell.magic_xmode(dstore.xmode)
3266
3280
3267 # Store new mode and inform
3281 # Store new mode and inform
3268 dstore.mode = bool(1-int(mode))
3282 dstore.mode = bool(1-int(mode))
3269 print 'Doctest mode is:',
3283 print 'Doctest mode is:',
3270 print ['OFF','ON'][dstore.mode]
3284 print ['OFF','ON'][dstore.mode]
3271
3285
3272 # end Magic
3286 # end Magic
General Comments 0
You need to be logged in to leave comments. Login now