##// END OF EJS Templates
SList.grep() supports optional 'field' argument
Ville M. Vainio -
Show More
@@ -1,2008 +1,2024
1 # -*- coding: utf-8 -*-
1 # -*- coding: utf-8 -*-
2 """
2 """
3 General purpose utilities.
3 General purpose utilities.
4
4
5 This is a grab-bag of stuff I find useful in most programs I write. Some of
5 This is a grab-bag of stuff I find useful in most programs I write. Some of
6 these things are also convenient when working at the command line.
6 these things are also convenient when working at the command line.
7
7
8 $Id: genutils.py 2998 2008-01-31 10:06:04Z vivainio $"""
8 $Id: genutils.py 2998 2008-01-31 10:06:04Z vivainio $"""
9
9
10 #*****************************************************************************
10 #*****************************************************************************
11 # Copyright (C) 2001-2006 Fernando Perez. <fperez@colorado.edu>
11 # Copyright (C) 2001-2006 Fernando Perez. <fperez@colorado.edu>
12 #
12 #
13 # Distributed under the terms of the BSD License. The full license is in
13 # Distributed under the terms of the BSD License. The full license is in
14 # the file COPYING, distributed as part of this software.
14 # the file COPYING, distributed as part of this software.
15 #*****************************************************************************
15 #*****************************************************************************
16
16
17 from IPython import Release
17 from IPython import Release
18 __author__ = '%s <%s>' % Release.authors['Fernando']
18 __author__ = '%s <%s>' % Release.authors['Fernando']
19 __license__ = Release.license
19 __license__ = Release.license
20
20
21 #****************************************************************************
21 #****************************************************************************
22 # required modules from the Python standard library
22 # required modules from the Python standard library
23 import __main__
23 import __main__
24 import commands
24 import commands
25 import doctest
25 import doctest
26 import os
26 import os
27 import re
27 import re
28 import shlex
28 import shlex
29 import shutil
29 import shutil
30 import sys
30 import sys
31 import tempfile
31 import tempfile
32 import time
32 import time
33 import types
33 import types
34 import warnings
34 import warnings
35
35
36 # Other IPython utilities
36 # Other IPython utilities
37 import IPython
37 import IPython
38 from IPython.Itpl import Itpl,itpl,printpl
38 from IPython.Itpl import Itpl,itpl,printpl
39 from IPython import DPyGetOpt, platutils
39 from IPython import DPyGetOpt, platutils
40 from IPython.generics import result_display
40 from IPython.generics import result_display
41 import IPython.ipapi
41 import IPython.ipapi
42 from IPython.external.path import path
42 from IPython.external.path import path
43 if os.name == "nt":
43 if os.name == "nt":
44 from IPython.winconsole import get_console_size
44 from IPython.winconsole import get_console_size
45
45
46 try:
46 try:
47 set
47 set
48 except:
48 except:
49 from sets import Set as set
49 from sets import Set as set
50
50
51
51
52 #****************************************************************************
52 #****************************************************************************
53 # Exceptions
53 # Exceptions
54 class Error(Exception):
54 class Error(Exception):
55 """Base class for exceptions in this module."""
55 """Base class for exceptions in this module."""
56 pass
56 pass
57
57
58 #----------------------------------------------------------------------------
58 #----------------------------------------------------------------------------
59 class IOStream:
59 class IOStream:
60 def __init__(self,stream,fallback):
60 def __init__(self,stream,fallback):
61 if not hasattr(stream,'write') or not hasattr(stream,'flush'):
61 if not hasattr(stream,'write') or not hasattr(stream,'flush'):
62 stream = fallback
62 stream = fallback
63 self.stream = stream
63 self.stream = stream
64 self._swrite = stream.write
64 self._swrite = stream.write
65 self.flush = stream.flush
65 self.flush = stream.flush
66
66
67 def write(self,data):
67 def write(self,data):
68 try:
68 try:
69 self._swrite(data)
69 self._swrite(data)
70 except:
70 except:
71 try:
71 try:
72 # print handles some unicode issues which may trip a plain
72 # print handles some unicode issues which may trip a plain
73 # write() call. Attempt to emulate write() by using a
73 # write() call. Attempt to emulate write() by using a
74 # trailing comma
74 # trailing comma
75 print >> self.stream, data,
75 print >> self.stream, data,
76 except:
76 except:
77 # if we get here, something is seriously broken.
77 # if we get here, something is seriously broken.
78 print >> sys.stderr, \
78 print >> sys.stderr, \
79 'ERROR - failed to write data to stream:', self.stream
79 'ERROR - failed to write data to stream:', self.stream
80
80
81 def close(self):
81 def close(self):
82 pass
82 pass
83
83
84
84
85 class IOTerm:
85 class IOTerm:
86 """ Term holds the file or file-like objects for handling I/O operations.
86 """ Term holds the file or file-like objects for handling I/O operations.
87
87
88 These are normally just sys.stdin, sys.stdout and sys.stderr but for
88 These are normally just sys.stdin, sys.stdout and sys.stderr but for
89 Windows they can can replaced to allow editing the strings before they are
89 Windows they can can replaced to allow editing the strings before they are
90 displayed."""
90 displayed."""
91
91
92 # In the future, having IPython channel all its I/O operations through
92 # In the future, having IPython channel all its I/O operations through
93 # this class will make it easier to embed it into other environments which
93 # this class will make it easier to embed it into other environments which
94 # are not a normal terminal (such as a GUI-based shell)
94 # are not a normal terminal (such as a GUI-based shell)
95 def __init__(self,cin=None,cout=None,cerr=None):
95 def __init__(self,cin=None,cout=None,cerr=None):
96 self.cin = IOStream(cin,sys.stdin)
96 self.cin = IOStream(cin,sys.stdin)
97 self.cout = IOStream(cout,sys.stdout)
97 self.cout = IOStream(cout,sys.stdout)
98 self.cerr = IOStream(cerr,sys.stderr)
98 self.cerr = IOStream(cerr,sys.stderr)
99
99
100 # Global variable to be used for all I/O
100 # Global variable to be used for all I/O
101 Term = IOTerm()
101 Term = IOTerm()
102
102
103 import IPython.rlineimpl as readline
103 import IPython.rlineimpl as readline
104 # Remake Term to use the readline i/o facilities
104 # Remake Term to use the readline i/o facilities
105 if sys.platform == 'win32' and readline.have_readline:
105 if sys.platform == 'win32' and readline.have_readline:
106
106
107 Term = IOTerm(cout=readline._outputfile,cerr=readline._outputfile)
107 Term = IOTerm(cout=readline._outputfile,cerr=readline._outputfile)
108
108
109
109
110 #****************************************************************************
110 #****************************************************************************
111 # Generic warning/error printer, used by everything else
111 # Generic warning/error printer, used by everything else
112 def warn(msg,level=2,exit_val=1):
112 def warn(msg,level=2,exit_val=1):
113 """Standard warning printer. Gives formatting consistency.
113 """Standard warning printer. Gives formatting consistency.
114
114
115 Output is sent to Term.cerr (sys.stderr by default).
115 Output is sent to Term.cerr (sys.stderr by default).
116
116
117 Options:
117 Options:
118
118
119 -level(2): allows finer control:
119 -level(2): allows finer control:
120 0 -> Do nothing, dummy function.
120 0 -> Do nothing, dummy function.
121 1 -> Print message.
121 1 -> Print message.
122 2 -> Print 'WARNING:' + message. (Default level).
122 2 -> Print 'WARNING:' + message. (Default level).
123 3 -> Print 'ERROR:' + message.
123 3 -> Print 'ERROR:' + message.
124 4 -> Print 'FATAL ERROR:' + message and trigger a sys.exit(exit_val).
124 4 -> Print 'FATAL ERROR:' + message and trigger a sys.exit(exit_val).
125
125
126 -exit_val (1): exit value returned by sys.exit() for a level 4
126 -exit_val (1): exit value returned by sys.exit() for a level 4
127 warning. Ignored for all other levels."""
127 warning. Ignored for all other levels."""
128
128
129 if level>0:
129 if level>0:
130 header = ['','','WARNING: ','ERROR: ','FATAL ERROR: ']
130 header = ['','','WARNING: ','ERROR: ','FATAL ERROR: ']
131 print >> Term.cerr, '%s%s' % (header[level],msg)
131 print >> Term.cerr, '%s%s' % (header[level],msg)
132 if level == 4:
132 if level == 4:
133 print >> Term.cerr,'Exiting.\n'
133 print >> Term.cerr,'Exiting.\n'
134 sys.exit(exit_val)
134 sys.exit(exit_val)
135
135
136 def info(msg):
136 def info(msg):
137 """Equivalent to warn(msg,level=1)."""
137 """Equivalent to warn(msg,level=1)."""
138
138
139 warn(msg,level=1)
139 warn(msg,level=1)
140
140
141 def error(msg):
141 def error(msg):
142 """Equivalent to warn(msg,level=3)."""
142 """Equivalent to warn(msg,level=3)."""
143
143
144 warn(msg,level=3)
144 warn(msg,level=3)
145
145
146 def fatal(msg,exit_val=1):
146 def fatal(msg,exit_val=1):
147 """Equivalent to warn(msg,exit_val=exit_val,level=4)."""
147 """Equivalent to warn(msg,exit_val=exit_val,level=4)."""
148
148
149 warn(msg,exit_val=exit_val,level=4)
149 warn(msg,exit_val=exit_val,level=4)
150
150
151 #---------------------------------------------------------------------------
151 #---------------------------------------------------------------------------
152 # Debugging routines
152 # Debugging routines
153 #
153 #
154 def debugx(expr,pre_msg=''):
154 def debugx(expr,pre_msg=''):
155 """Print the value of an expression from the caller's frame.
155 """Print the value of an expression from the caller's frame.
156
156
157 Takes an expression, evaluates it in the caller's frame and prints both
157 Takes an expression, evaluates it in the caller's frame and prints both
158 the given expression and the resulting value (as well as a debug mark
158 the given expression and the resulting value (as well as a debug mark
159 indicating the name of the calling function. The input must be of a form
159 indicating the name of the calling function. The input must be of a form
160 suitable for eval().
160 suitable for eval().
161
161
162 An optional message can be passed, which will be prepended to the printed
162 An optional message can be passed, which will be prepended to the printed
163 expr->value pair."""
163 expr->value pair."""
164
164
165 cf = sys._getframe(1)
165 cf = sys._getframe(1)
166 print '[DBG:%s] %s%s -> %r' % (cf.f_code.co_name,pre_msg,expr,
166 print '[DBG:%s] %s%s -> %r' % (cf.f_code.co_name,pre_msg,expr,
167 eval(expr,cf.f_globals,cf.f_locals))
167 eval(expr,cf.f_globals,cf.f_locals))
168
168
169 # deactivate it by uncommenting the following line, which makes it a no-op
169 # deactivate it by uncommenting the following line, which makes it a no-op
170 #def debugx(expr,pre_msg=''): pass
170 #def debugx(expr,pre_msg=''): pass
171
171
172 #----------------------------------------------------------------------------
172 #----------------------------------------------------------------------------
173 StringTypes = types.StringTypes
173 StringTypes = types.StringTypes
174
174
175 # Basic timing functionality
175 # Basic timing functionality
176
176
177 # If possible (Unix), use the resource module instead of time.clock()
177 # If possible (Unix), use the resource module instead of time.clock()
178 try:
178 try:
179 import resource
179 import resource
180 def clocku():
180 def clocku():
181 """clocku() -> floating point number
181 """clocku() -> floating point number
182
182
183 Return the *USER* CPU time in seconds since the start of the process.
183 Return the *USER* CPU time in seconds since the start of the process.
184 This is done via a call to resource.getrusage, so it avoids the
184 This is done via a call to resource.getrusage, so it avoids the
185 wraparound problems in time.clock()."""
185 wraparound problems in time.clock()."""
186
186
187 return resource.getrusage(resource.RUSAGE_SELF)[0]
187 return resource.getrusage(resource.RUSAGE_SELF)[0]
188
188
189 def clocks():
189 def clocks():
190 """clocks() -> floating point number
190 """clocks() -> floating point number
191
191
192 Return the *SYSTEM* CPU time in seconds since the start of the process.
192 Return the *SYSTEM* CPU time in seconds since the start of the process.
193 This is done via a call to resource.getrusage, so it avoids the
193 This is done via a call to resource.getrusage, so it avoids the
194 wraparound problems in time.clock()."""
194 wraparound problems in time.clock()."""
195
195
196 return resource.getrusage(resource.RUSAGE_SELF)[1]
196 return resource.getrusage(resource.RUSAGE_SELF)[1]
197
197
198 def clock():
198 def clock():
199 """clock() -> floating point number
199 """clock() -> floating point number
200
200
201 Return the *TOTAL USER+SYSTEM* CPU time in seconds since the start of
201 Return the *TOTAL USER+SYSTEM* CPU time in seconds since the start of
202 the process. This is done via a call to resource.getrusage, so it
202 the process. This is done via a call to resource.getrusage, so it
203 avoids the wraparound problems in time.clock()."""
203 avoids the wraparound problems in time.clock()."""
204
204
205 u,s = resource.getrusage(resource.RUSAGE_SELF)[:2]
205 u,s = resource.getrusage(resource.RUSAGE_SELF)[:2]
206 return u+s
206 return u+s
207
207
208 def clock2():
208 def clock2():
209 """clock2() -> (t_user,t_system)
209 """clock2() -> (t_user,t_system)
210
210
211 Similar to clock(), but return a tuple of user/system times."""
211 Similar to clock(), but return a tuple of user/system times."""
212 return resource.getrusage(resource.RUSAGE_SELF)[:2]
212 return resource.getrusage(resource.RUSAGE_SELF)[:2]
213
213
214 except ImportError:
214 except ImportError:
215 # There is no distinction of user/system time under windows, so we just use
215 # There is no distinction of user/system time under windows, so we just use
216 # time.clock() for everything...
216 # time.clock() for everything...
217 clocku = clocks = clock = time.clock
217 clocku = clocks = clock = time.clock
218 def clock2():
218 def clock2():
219 """Under windows, system CPU time can't be measured.
219 """Under windows, system CPU time can't be measured.
220
220
221 This just returns clock() and zero."""
221 This just returns clock() and zero."""
222 return time.clock(),0.0
222 return time.clock(),0.0
223
223
224 def timings_out(reps,func,*args,**kw):
224 def timings_out(reps,func,*args,**kw):
225 """timings_out(reps,func,*args,**kw) -> (t_total,t_per_call,output)
225 """timings_out(reps,func,*args,**kw) -> (t_total,t_per_call,output)
226
226
227 Execute a function reps times, return a tuple with the elapsed total
227 Execute a function reps times, return a tuple with the elapsed total
228 CPU time in seconds, the time per call and the function's output.
228 CPU time in seconds, the time per call and the function's output.
229
229
230 Under Unix, the return value is the sum of user+system time consumed by
230 Under Unix, the return value is the sum of user+system time consumed by
231 the process, computed via the resource module. This prevents problems
231 the process, computed via the resource module. This prevents problems
232 related to the wraparound effect which the time.clock() function has.
232 related to the wraparound effect which the time.clock() function has.
233
233
234 Under Windows the return value is in wall clock seconds. See the
234 Under Windows the return value is in wall clock seconds. See the
235 documentation for the time module for more details."""
235 documentation for the time module for more details."""
236
236
237 reps = int(reps)
237 reps = int(reps)
238 assert reps >=1, 'reps must be >= 1'
238 assert reps >=1, 'reps must be >= 1'
239 if reps==1:
239 if reps==1:
240 start = clock()
240 start = clock()
241 out = func(*args,**kw)
241 out = func(*args,**kw)
242 tot_time = clock()-start
242 tot_time = clock()-start
243 else:
243 else:
244 rng = xrange(reps-1) # the last time is executed separately to store output
244 rng = xrange(reps-1) # the last time is executed separately to store output
245 start = clock()
245 start = clock()
246 for dummy in rng: func(*args,**kw)
246 for dummy in rng: func(*args,**kw)
247 out = func(*args,**kw) # one last time
247 out = func(*args,**kw) # one last time
248 tot_time = clock()-start
248 tot_time = clock()-start
249 av_time = tot_time / reps
249 av_time = tot_time / reps
250 return tot_time,av_time,out
250 return tot_time,av_time,out
251
251
252 def timings(reps,func,*args,**kw):
252 def timings(reps,func,*args,**kw):
253 """timings(reps,func,*args,**kw) -> (t_total,t_per_call)
253 """timings(reps,func,*args,**kw) -> (t_total,t_per_call)
254
254
255 Execute a function reps times, return a tuple with the elapsed total CPU
255 Execute a function reps times, return a tuple with the elapsed total CPU
256 time in seconds and the time per call. These are just the first two values
256 time in seconds and the time per call. These are just the first two values
257 in timings_out()."""
257 in timings_out()."""
258
258
259 return timings_out(reps,func,*args,**kw)[0:2]
259 return timings_out(reps,func,*args,**kw)[0:2]
260
260
261 def timing(func,*args,**kw):
261 def timing(func,*args,**kw):
262 """timing(func,*args,**kw) -> t_total
262 """timing(func,*args,**kw) -> t_total
263
263
264 Execute a function once, return the elapsed total CPU time in
264 Execute a function once, return the elapsed total CPU time in
265 seconds. This is just the first value in timings_out()."""
265 seconds. This is just the first value in timings_out()."""
266
266
267 return timings_out(1,func,*args,**kw)[0]
267 return timings_out(1,func,*args,**kw)[0]
268
268
269 #****************************************************************************
269 #****************************************************************************
270 # file and system
270 # file and system
271
271
272 def arg_split(s,posix=False):
272 def arg_split(s,posix=False):
273 """Split a command line's arguments in a shell-like manner.
273 """Split a command line's arguments in a shell-like manner.
274
274
275 This is a modified version of the standard library's shlex.split()
275 This is a modified version of the standard library's shlex.split()
276 function, but with a default of posix=False for splitting, so that quotes
276 function, but with a default of posix=False for splitting, so that quotes
277 in inputs are respected."""
277 in inputs are respected."""
278
278
279 # XXX - there may be unicode-related problems here!!! I'm not sure that
279 # XXX - there may be unicode-related problems here!!! I'm not sure that
280 # shlex is truly unicode-safe, so it might be necessary to do
280 # shlex is truly unicode-safe, so it might be necessary to do
281 #
281 #
282 # s = s.encode(sys.stdin.encoding)
282 # s = s.encode(sys.stdin.encoding)
283 #
283 #
284 # first, to ensure that shlex gets a normal string. Input from anyone who
284 # first, to ensure that shlex gets a normal string. Input from anyone who
285 # knows more about unicode and shlex than I would be good to have here...
285 # knows more about unicode and shlex than I would be good to have here...
286 lex = shlex.shlex(s, posix=posix)
286 lex = shlex.shlex(s, posix=posix)
287 lex.whitespace_split = True
287 lex.whitespace_split = True
288 return list(lex)
288 return list(lex)
289
289
290 def system(cmd,verbose=0,debug=0,header=''):
290 def system(cmd,verbose=0,debug=0,header=''):
291 """Execute a system command, return its exit status.
291 """Execute a system command, return its exit status.
292
292
293 Options:
293 Options:
294
294
295 - verbose (0): print the command to be executed.
295 - verbose (0): print the command to be executed.
296
296
297 - debug (0): only print, do not actually execute.
297 - debug (0): only print, do not actually execute.
298
298
299 - header (''): Header to print on screen prior to the executed command (it
299 - header (''): Header to print on screen prior to the executed command (it
300 is only prepended to the command, no newlines are added).
300 is only prepended to the command, no newlines are added).
301
301
302 Note: a stateful version of this function is available through the
302 Note: a stateful version of this function is available through the
303 SystemExec class."""
303 SystemExec class."""
304
304
305 stat = 0
305 stat = 0
306 if verbose or debug: print header+cmd
306 if verbose or debug: print header+cmd
307 sys.stdout.flush()
307 sys.stdout.flush()
308 if not debug: stat = os.system(cmd)
308 if not debug: stat = os.system(cmd)
309 return stat
309 return stat
310
310
311 def abbrev_cwd():
311 def abbrev_cwd():
312 """ Return abbreviated version of cwd, e.g. d:mydir """
312 """ Return abbreviated version of cwd, e.g. d:mydir """
313 cwd = os.getcwd().replace('\\','/')
313 cwd = os.getcwd().replace('\\','/')
314 drivepart = ''
314 drivepart = ''
315 tail = cwd
315 tail = cwd
316 if sys.platform == 'win32':
316 if sys.platform == 'win32':
317 if len(cwd) < 4:
317 if len(cwd) < 4:
318 return cwd
318 return cwd
319 drivepart,tail = os.path.splitdrive(cwd)
319 drivepart,tail = os.path.splitdrive(cwd)
320
320
321
321
322 parts = tail.split('/')
322 parts = tail.split('/')
323 if len(parts) > 2:
323 if len(parts) > 2:
324 tail = '/'.join(parts[-2:])
324 tail = '/'.join(parts[-2:])
325
325
326 return (drivepart + (
326 return (drivepart + (
327 cwd == '/' and '/' or tail))
327 cwd == '/' and '/' or tail))
328
328
329
329
330 # This function is used by ipython in a lot of places to make system calls.
330 # This function is used by ipython in a lot of places to make system calls.
331 # We need it to be slightly different under win32, due to the vagaries of
331 # We need it to be slightly different under win32, due to the vagaries of
332 # 'network shares'. A win32 override is below.
332 # 'network shares'. A win32 override is below.
333
333
334 def shell(cmd,verbose=0,debug=0,header=''):
334 def shell(cmd,verbose=0,debug=0,header=''):
335 """Execute a command in the system shell, always return None.
335 """Execute a command in the system shell, always return None.
336
336
337 Options:
337 Options:
338
338
339 - verbose (0): print the command to be executed.
339 - verbose (0): print the command to be executed.
340
340
341 - debug (0): only print, do not actually execute.
341 - debug (0): only print, do not actually execute.
342
342
343 - header (''): Header to print on screen prior to the executed command (it
343 - header (''): Header to print on screen prior to the executed command (it
344 is only prepended to the command, no newlines are added).
344 is only prepended to the command, no newlines are added).
345
345
346 Note: this is similar to genutils.system(), but it returns None so it can
346 Note: this is similar to genutils.system(), but it returns None so it can
347 be conveniently used in interactive loops without getting the return value
347 be conveniently used in interactive loops without getting the return value
348 (typically 0) printed many times."""
348 (typically 0) printed many times."""
349
349
350 stat = 0
350 stat = 0
351 if verbose or debug: print header+cmd
351 if verbose or debug: print header+cmd
352 # flush stdout so we don't mangle python's buffering
352 # flush stdout so we don't mangle python's buffering
353 sys.stdout.flush()
353 sys.stdout.flush()
354
354
355 if not debug:
355 if not debug:
356 platutils.set_term_title("IPy " + cmd)
356 platutils.set_term_title("IPy " + cmd)
357 os.system(cmd)
357 os.system(cmd)
358 platutils.set_term_title("IPy " + abbrev_cwd())
358 platutils.set_term_title("IPy " + abbrev_cwd())
359
359
360 # override shell() for win32 to deal with network shares
360 # override shell() for win32 to deal with network shares
361 if os.name in ('nt','dos'):
361 if os.name in ('nt','dos'):
362
362
363 shell_ori = shell
363 shell_ori = shell
364
364
365 def shell(cmd,verbose=0,debug=0,header=''):
365 def shell(cmd,verbose=0,debug=0,header=''):
366 if os.getcwd().startswith(r"\\"):
366 if os.getcwd().startswith(r"\\"):
367 path = os.getcwd()
367 path = os.getcwd()
368 # change to c drive (cannot be on UNC-share when issuing os.system,
368 # change to c drive (cannot be on UNC-share when issuing os.system,
369 # as cmd.exe cannot handle UNC addresses)
369 # as cmd.exe cannot handle UNC addresses)
370 os.chdir("c:")
370 os.chdir("c:")
371 # issue pushd to the UNC-share and then run the command
371 # issue pushd to the UNC-share and then run the command
372 try:
372 try:
373 shell_ori('"pushd %s&&"'%path+cmd,verbose,debug,header)
373 shell_ori('"pushd %s&&"'%path+cmd,verbose,debug,header)
374 finally:
374 finally:
375 os.chdir(path)
375 os.chdir(path)
376 else:
376 else:
377 shell_ori(cmd,verbose,debug,header)
377 shell_ori(cmd,verbose,debug,header)
378
378
379 shell.__doc__ = shell_ori.__doc__
379 shell.__doc__ = shell_ori.__doc__
380
380
381 def getoutput(cmd,verbose=0,debug=0,header='',split=0):
381 def getoutput(cmd,verbose=0,debug=0,header='',split=0):
382 """Dummy substitute for perl's backquotes.
382 """Dummy substitute for perl's backquotes.
383
383
384 Executes a command and returns the output.
384 Executes a command and returns the output.
385
385
386 Accepts the same arguments as system(), plus:
386 Accepts the same arguments as system(), plus:
387
387
388 - split(0): if true, the output is returned as a list split on newlines.
388 - split(0): if true, the output is returned as a list split on newlines.
389
389
390 Note: a stateful version of this function is available through the
390 Note: a stateful version of this function is available through the
391 SystemExec class.
391 SystemExec class.
392
392
393 This is pretty much deprecated and rarely used,
393 This is pretty much deprecated and rarely used,
394 genutils.getoutputerror may be what you need.
394 genutils.getoutputerror may be what you need.
395
395
396 """
396 """
397
397
398 if verbose or debug: print header+cmd
398 if verbose or debug: print header+cmd
399 if not debug:
399 if not debug:
400 output = os.popen(cmd).read()
400 output = os.popen(cmd).read()
401 # stipping last \n is here for backwards compat.
401 # stipping last \n is here for backwards compat.
402 if output.endswith('\n'):
402 if output.endswith('\n'):
403 output = output[:-1]
403 output = output[:-1]
404 if split:
404 if split:
405 return output.split('\n')
405 return output.split('\n')
406 else:
406 else:
407 return output
407 return output
408
408
409 def getoutputerror(cmd,verbose=0,debug=0,header='',split=0):
409 def getoutputerror(cmd,verbose=0,debug=0,header='',split=0):
410 """Return (standard output,standard error) of executing cmd in a shell.
410 """Return (standard output,standard error) of executing cmd in a shell.
411
411
412 Accepts the same arguments as system(), plus:
412 Accepts the same arguments as system(), plus:
413
413
414 - split(0): if true, each of stdout/err is returned as a list split on
414 - split(0): if true, each of stdout/err is returned as a list split on
415 newlines.
415 newlines.
416
416
417 Note: a stateful version of this function is available through the
417 Note: a stateful version of this function is available through the
418 SystemExec class."""
418 SystemExec class."""
419
419
420 if verbose or debug: print header+cmd
420 if verbose or debug: print header+cmd
421 if not cmd:
421 if not cmd:
422 if split:
422 if split:
423 return [],[]
423 return [],[]
424 else:
424 else:
425 return '',''
425 return '',''
426 if not debug:
426 if not debug:
427 pin,pout,perr = os.popen3(cmd)
427 pin,pout,perr = os.popen3(cmd)
428 tout = pout.read().rstrip()
428 tout = pout.read().rstrip()
429 terr = perr.read().rstrip()
429 terr = perr.read().rstrip()
430 pin.close()
430 pin.close()
431 pout.close()
431 pout.close()
432 perr.close()
432 perr.close()
433 if split:
433 if split:
434 return tout.split('\n'),terr.split('\n')
434 return tout.split('\n'),terr.split('\n')
435 else:
435 else:
436 return tout,terr
436 return tout,terr
437
437
438 # for compatibility with older naming conventions
438 # for compatibility with older naming conventions
439 xsys = system
439 xsys = system
440 bq = getoutput
440 bq = getoutput
441
441
442 class SystemExec:
442 class SystemExec:
443 """Access the system and getoutput functions through a stateful interface.
443 """Access the system and getoutput functions through a stateful interface.
444
444
445 Note: here we refer to the system and getoutput functions from this
445 Note: here we refer to the system and getoutput functions from this
446 library, not the ones from the standard python library.
446 library, not the ones from the standard python library.
447
447
448 This class offers the system and getoutput functions as methods, but the
448 This class offers the system and getoutput functions as methods, but the
449 verbose, debug and header parameters can be set for the instance (at
449 verbose, debug and header parameters can be set for the instance (at
450 creation time or later) so that they don't need to be specified on each
450 creation time or later) so that they don't need to be specified on each
451 call.
451 call.
452
452
453 For efficiency reasons, there's no way to override the parameters on a
453 For efficiency reasons, there's no way to override the parameters on a
454 per-call basis other than by setting instance attributes. If you need
454 per-call basis other than by setting instance attributes. If you need
455 local overrides, it's best to directly call system() or getoutput().
455 local overrides, it's best to directly call system() or getoutput().
456
456
457 The following names are provided as alternate options:
457 The following names are provided as alternate options:
458 - xsys: alias to system
458 - xsys: alias to system
459 - bq: alias to getoutput
459 - bq: alias to getoutput
460
460
461 An instance can then be created as:
461 An instance can then be created as:
462 >>> sysexec = SystemExec(verbose=1,debug=0,header='Calling: ')
462 >>> sysexec = SystemExec(verbose=1,debug=0,header='Calling: ')
463
463
464 And used as:
464 And used as:
465 >>> sysexec.xsys('pwd')
465 >>> sysexec.xsys('pwd')
466 >>> dirlist = sysexec.bq('ls -l')
466 >>> dirlist = sysexec.bq('ls -l')
467 """
467 """
468
468
469 def __init__(self,verbose=0,debug=0,header='',split=0):
469 def __init__(self,verbose=0,debug=0,header='',split=0):
470 """Specify the instance's values for verbose, debug and header."""
470 """Specify the instance's values for verbose, debug and header."""
471 setattr_list(self,'verbose debug header split')
471 setattr_list(self,'verbose debug header split')
472
472
473 def system(self,cmd):
473 def system(self,cmd):
474 """Stateful interface to system(), with the same keyword parameters."""
474 """Stateful interface to system(), with the same keyword parameters."""
475
475
476 system(cmd,self.verbose,self.debug,self.header)
476 system(cmd,self.verbose,self.debug,self.header)
477
477
478 def shell(self,cmd):
478 def shell(self,cmd):
479 """Stateful interface to shell(), with the same keyword parameters."""
479 """Stateful interface to shell(), with the same keyword parameters."""
480
480
481 shell(cmd,self.verbose,self.debug,self.header)
481 shell(cmd,self.verbose,self.debug,self.header)
482
482
483 xsys = system # alias
483 xsys = system # alias
484
484
485 def getoutput(self,cmd):
485 def getoutput(self,cmd):
486 """Stateful interface to getoutput()."""
486 """Stateful interface to getoutput()."""
487
487
488 return getoutput(cmd,self.verbose,self.debug,self.header,self.split)
488 return getoutput(cmd,self.verbose,self.debug,self.header,self.split)
489
489
490 def getoutputerror(self,cmd):
490 def getoutputerror(self,cmd):
491 """Stateful interface to getoutputerror()."""
491 """Stateful interface to getoutputerror()."""
492
492
493 return getoutputerror(cmd,self.verbose,self.debug,self.header,self.split)
493 return getoutputerror(cmd,self.verbose,self.debug,self.header,self.split)
494
494
495 bq = getoutput # alias
495 bq = getoutput # alias
496
496
497 #-----------------------------------------------------------------------------
497 #-----------------------------------------------------------------------------
498 def mutex_opts(dict,ex_op):
498 def mutex_opts(dict,ex_op):
499 """Check for presence of mutually exclusive keys in a dict.
499 """Check for presence of mutually exclusive keys in a dict.
500
500
501 Call: mutex_opts(dict,[[op1a,op1b],[op2a,op2b]...]"""
501 Call: mutex_opts(dict,[[op1a,op1b],[op2a,op2b]...]"""
502 for op1,op2 in ex_op:
502 for op1,op2 in ex_op:
503 if op1 in dict and op2 in dict:
503 if op1 in dict and op2 in dict:
504 raise ValueError,'\n*** ERROR in Arguments *** '\
504 raise ValueError,'\n*** ERROR in Arguments *** '\
505 'Options '+op1+' and '+op2+' are mutually exclusive.'
505 'Options '+op1+' and '+op2+' are mutually exclusive.'
506
506
507 #-----------------------------------------------------------------------------
507 #-----------------------------------------------------------------------------
508 def get_py_filename(name):
508 def get_py_filename(name):
509 """Return a valid python filename in the current directory.
509 """Return a valid python filename in the current directory.
510
510
511 If the given name is not a file, it adds '.py' and searches again.
511 If the given name is not a file, it adds '.py' and searches again.
512 Raises IOError with an informative message if the file isn't found."""
512 Raises IOError with an informative message if the file isn't found."""
513
513
514 name = os.path.expanduser(name)
514 name = os.path.expanduser(name)
515 if not os.path.isfile(name) and not name.endswith('.py'):
515 if not os.path.isfile(name) and not name.endswith('.py'):
516 name += '.py'
516 name += '.py'
517 if os.path.isfile(name):
517 if os.path.isfile(name):
518 return name
518 return name
519 else:
519 else:
520 raise IOError,'File `%s` not found.' % name
520 raise IOError,'File `%s` not found.' % name
521
521
522 #-----------------------------------------------------------------------------
522 #-----------------------------------------------------------------------------
523 def filefind(fname,alt_dirs = None):
523 def filefind(fname,alt_dirs = None):
524 """Return the given filename either in the current directory, if it
524 """Return the given filename either in the current directory, if it
525 exists, or in a specified list of directories.
525 exists, or in a specified list of directories.
526
526
527 ~ expansion is done on all file and directory names.
527 ~ expansion is done on all file and directory names.
528
528
529 Upon an unsuccessful search, raise an IOError exception."""
529 Upon an unsuccessful search, raise an IOError exception."""
530
530
531 if alt_dirs is None:
531 if alt_dirs is None:
532 try:
532 try:
533 alt_dirs = get_home_dir()
533 alt_dirs = get_home_dir()
534 except HomeDirError:
534 except HomeDirError:
535 alt_dirs = os.getcwd()
535 alt_dirs = os.getcwd()
536 search = [fname] + list_strings(alt_dirs)
536 search = [fname] + list_strings(alt_dirs)
537 search = map(os.path.expanduser,search)
537 search = map(os.path.expanduser,search)
538 #print 'search list for',fname,'list:',search # dbg
538 #print 'search list for',fname,'list:',search # dbg
539 fname = search[0]
539 fname = search[0]
540 if os.path.isfile(fname):
540 if os.path.isfile(fname):
541 return fname
541 return fname
542 for direc in search[1:]:
542 for direc in search[1:]:
543 testname = os.path.join(direc,fname)
543 testname = os.path.join(direc,fname)
544 #print 'testname',testname # dbg
544 #print 'testname',testname # dbg
545 if os.path.isfile(testname):
545 if os.path.isfile(testname):
546 return testname
546 return testname
547 raise IOError,'File' + `fname` + \
547 raise IOError,'File' + `fname` + \
548 ' not found in current or supplied directories:' + `alt_dirs`
548 ' not found in current or supplied directories:' + `alt_dirs`
549
549
550 #----------------------------------------------------------------------------
550 #----------------------------------------------------------------------------
551 def file_read(filename):
551 def file_read(filename):
552 """Read a file and close it. Returns the file source."""
552 """Read a file and close it. Returns the file source."""
553 fobj = open(filename,'r');
553 fobj = open(filename,'r');
554 source = fobj.read();
554 source = fobj.read();
555 fobj.close()
555 fobj.close()
556 return source
556 return source
557
557
558 def file_readlines(filename):
558 def file_readlines(filename):
559 """Read a file and close it. Returns the file source using readlines()."""
559 """Read a file and close it. Returns the file source using readlines()."""
560 fobj = open(filename,'r');
560 fobj = open(filename,'r');
561 lines = fobj.readlines();
561 lines = fobj.readlines();
562 fobj.close()
562 fobj.close()
563 return lines
563 return lines
564
564
565 #----------------------------------------------------------------------------
565 #----------------------------------------------------------------------------
566 def target_outdated(target,deps):
566 def target_outdated(target,deps):
567 """Determine whether a target is out of date.
567 """Determine whether a target is out of date.
568
568
569 target_outdated(target,deps) -> 1/0
569 target_outdated(target,deps) -> 1/0
570
570
571 deps: list of filenames which MUST exist.
571 deps: list of filenames which MUST exist.
572 target: single filename which may or may not exist.
572 target: single filename which may or may not exist.
573
573
574 If target doesn't exist or is older than any file listed in deps, return
574 If target doesn't exist or is older than any file listed in deps, return
575 true, otherwise return false.
575 true, otherwise return false.
576 """
576 """
577 try:
577 try:
578 target_time = os.path.getmtime(target)
578 target_time = os.path.getmtime(target)
579 except os.error:
579 except os.error:
580 return 1
580 return 1
581 for dep in deps:
581 for dep in deps:
582 dep_time = os.path.getmtime(dep)
582 dep_time = os.path.getmtime(dep)
583 if dep_time > target_time:
583 if dep_time > target_time:
584 #print "For target",target,"Dep failed:",dep # dbg
584 #print "For target",target,"Dep failed:",dep # dbg
585 #print "times (dep,tar):",dep_time,target_time # dbg
585 #print "times (dep,tar):",dep_time,target_time # dbg
586 return 1
586 return 1
587 return 0
587 return 0
588
588
589 #-----------------------------------------------------------------------------
589 #-----------------------------------------------------------------------------
590 def target_update(target,deps,cmd):
590 def target_update(target,deps,cmd):
591 """Update a target with a given command given a list of dependencies.
591 """Update a target with a given command given a list of dependencies.
592
592
593 target_update(target,deps,cmd) -> runs cmd if target is outdated.
593 target_update(target,deps,cmd) -> runs cmd if target is outdated.
594
594
595 This is just a wrapper around target_outdated() which calls the given
595 This is just a wrapper around target_outdated() which calls the given
596 command if target is outdated."""
596 command if target is outdated."""
597
597
598 if target_outdated(target,deps):
598 if target_outdated(target,deps):
599 xsys(cmd)
599 xsys(cmd)
600
600
601 #----------------------------------------------------------------------------
601 #----------------------------------------------------------------------------
602 def unquote_ends(istr):
602 def unquote_ends(istr):
603 """Remove a single pair of quotes from the endpoints of a string."""
603 """Remove a single pair of quotes from the endpoints of a string."""
604
604
605 if not istr:
605 if not istr:
606 return istr
606 return istr
607 if (istr[0]=="'" and istr[-1]=="'") or \
607 if (istr[0]=="'" and istr[-1]=="'") or \
608 (istr[0]=='"' and istr[-1]=='"'):
608 (istr[0]=='"' and istr[-1]=='"'):
609 return istr[1:-1]
609 return istr[1:-1]
610 else:
610 else:
611 return istr
611 return istr
612
612
613 #----------------------------------------------------------------------------
613 #----------------------------------------------------------------------------
614 def process_cmdline(argv,names=[],defaults={},usage=''):
614 def process_cmdline(argv,names=[],defaults={},usage=''):
615 """ Process command-line options and arguments.
615 """ Process command-line options and arguments.
616
616
617 Arguments:
617 Arguments:
618
618
619 - argv: list of arguments, typically sys.argv.
619 - argv: list of arguments, typically sys.argv.
620
620
621 - names: list of option names. See DPyGetOpt docs for details on options
621 - names: list of option names. See DPyGetOpt docs for details on options
622 syntax.
622 syntax.
623
623
624 - defaults: dict of default values.
624 - defaults: dict of default values.
625
625
626 - usage: optional usage notice to print if a wrong argument is passed.
626 - usage: optional usage notice to print if a wrong argument is passed.
627
627
628 Return a dict of options and a list of free arguments."""
628 Return a dict of options and a list of free arguments."""
629
629
630 getopt = DPyGetOpt.DPyGetOpt()
630 getopt = DPyGetOpt.DPyGetOpt()
631 getopt.setIgnoreCase(0)
631 getopt.setIgnoreCase(0)
632 getopt.parseConfiguration(names)
632 getopt.parseConfiguration(names)
633
633
634 try:
634 try:
635 getopt.processArguments(argv)
635 getopt.processArguments(argv)
636 except DPyGetOpt.ArgumentError, exc:
636 except DPyGetOpt.ArgumentError, exc:
637 print usage
637 print usage
638 warn('"%s"' % exc,level=4)
638 warn('"%s"' % exc,level=4)
639
639
640 defaults.update(getopt.optionValues)
640 defaults.update(getopt.optionValues)
641 args = getopt.freeValues
641 args = getopt.freeValues
642
642
643 return defaults,args
643 return defaults,args
644
644
645 #----------------------------------------------------------------------------
645 #----------------------------------------------------------------------------
646 def optstr2types(ostr):
646 def optstr2types(ostr):
647 """Convert a string of option names to a dict of type mappings.
647 """Convert a string of option names to a dict of type mappings.
648
648
649 optstr2types(str) -> {None:'string_opts',int:'int_opts',float:'float_opts'}
649 optstr2types(str) -> {None:'string_opts',int:'int_opts',float:'float_opts'}
650
650
651 This is used to get the types of all the options in a string formatted
651 This is used to get the types of all the options in a string formatted
652 with the conventions of DPyGetOpt. The 'type' None is used for options
652 with the conventions of DPyGetOpt. The 'type' None is used for options
653 which are strings (they need no further conversion). This function's main
653 which are strings (they need no further conversion). This function's main
654 use is to get a typemap for use with read_dict().
654 use is to get a typemap for use with read_dict().
655 """
655 """
656
656
657 typeconv = {None:'',int:'',float:''}
657 typeconv = {None:'',int:'',float:''}
658 typemap = {'s':None,'i':int,'f':float}
658 typemap = {'s':None,'i':int,'f':float}
659 opt_re = re.compile(r'([\w]*)([^:=]*:?=?)([sif]?)')
659 opt_re = re.compile(r'([\w]*)([^:=]*:?=?)([sif]?)')
660
660
661 for w in ostr.split():
661 for w in ostr.split():
662 oname,alias,otype = opt_re.match(w).groups()
662 oname,alias,otype = opt_re.match(w).groups()
663 if otype == '' or alias == '!': # simple switches are integers too
663 if otype == '' or alias == '!': # simple switches are integers too
664 otype = 'i'
664 otype = 'i'
665 typeconv[typemap[otype]] += oname + ' '
665 typeconv[typemap[otype]] += oname + ' '
666 return typeconv
666 return typeconv
667
667
668 #----------------------------------------------------------------------------
668 #----------------------------------------------------------------------------
669 def read_dict(filename,type_conv=None,**opt):
669 def read_dict(filename,type_conv=None,**opt):
670
670
671 """Read a dictionary of key=value pairs from an input file, optionally
671 """Read a dictionary of key=value pairs from an input file, optionally
672 performing conversions on the resulting values.
672 performing conversions on the resulting values.
673
673
674 read_dict(filename,type_conv,**opt) -> dict
674 read_dict(filename,type_conv,**opt) -> dict
675
675
676 Only one value per line is accepted, the format should be
676 Only one value per line is accepted, the format should be
677 # optional comments are ignored
677 # optional comments are ignored
678 key value\n
678 key value\n
679
679
680 Args:
680 Args:
681
681
682 - type_conv: A dictionary specifying which keys need to be converted to
682 - type_conv: A dictionary specifying which keys need to be converted to
683 which types. By default all keys are read as strings. This dictionary
683 which types. By default all keys are read as strings. This dictionary
684 should have as its keys valid conversion functions for strings
684 should have as its keys valid conversion functions for strings
685 (int,long,float,complex, or your own). The value for each key
685 (int,long,float,complex, or your own). The value for each key
686 (converter) should be a whitespace separated string containing the names
686 (converter) should be a whitespace separated string containing the names
687 of all the entries in the file to be converted using that function. For
687 of all the entries in the file to be converted using that function. For
688 keys to be left alone, use None as the conversion function (only needed
688 keys to be left alone, use None as the conversion function (only needed
689 with purge=1, see below).
689 with purge=1, see below).
690
690
691 - opt: dictionary with extra options as below (default in parens)
691 - opt: dictionary with extra options as below (default in parens)
692
692
693 purge(0): if set to 1, all keys *not* listed in type_conv are purged out
693 purge(0): if set to 1, all keys *not* listed in type_conv are purged out
694 of the dictionary to be returned. If purge is going to be used, the
694 of the dictionary to be returned. If purge is going to be used, the
695 set of keys to be left as strings also has to be explicitly specified
695 set of keys to be left as strings also has to be explicitly specified
696 using the (non-existent) conversion function None.
696 using the (non-existent) conversion function None.
697
697
698 fs(None): field separator. This is the key/value separator to be used
698 fs(None): field separator. This is the key/value separator to be used
699 when parsing the file. The None default means any whitespace [behavior
699 when parsing the file. The None default means any whitespace [behavior
700 of string.split()].
700 of string.split()].
701
701
702 strip(0): if 1, strip string values of leading/trailinig whitespace.
702 strip(0): if 1, strip string values of leading/trailinig whitespace.
703
703
704 warn(1): warning level if requested keys are not found in file.
704 warn(1): warning level if requested keys are not found in file.
705 - 0: silently ignore.
705 - 0: silently ignore.
706 - 1: inform but proceed.
706 - 1: inform but proceed.
707 - 2: raise KeyError exception.
707 - 2: raise KeyError exception.
708
708
709 no_empty(0): if 1, remove keys with whitespace strings as a value.
709 no_empty(0): if 1, remove keys with whitespace strings as a value.
710
710
711 unique([]): list of keys (or space separated string) which can't be
711 unique([]): list of keys (or space separated string) which can't be
712 repeated. If one such key is found in the file, each new instance
712 repeated. If one such key is found in the file, each new instance
713 overwrites the previous one. For keys not listed here, the behavior is
713 overwrites the previous one. For keys not listed here, the behavior is
714 to make a list of all appearances.
714 to make a list of all appearances.
715
715
716 Example:
716 Example:
717 If the input file test.ini has:
717 If the input file test.ini has:
718 i 3
718 i 3
719 x 4.5
719 x 4.5
720 y 5.5
720 y 5.5
721 s hi ho
721 s hi ho
722 Then:
722 Then:
723
723
724 >>> type_conv={int:'i',float:'x',None:'s'}
724 >>> type_conv={int:'i',float:'x',None:'s'}
725 >>> read_dict('test.ini')
725 >>> read_dict('test.ini')
726 {'i': '3', 's': 'hi ho', 'x': '4.5', 'y': '5.5'}
726 {'i': '3', 's': 'hi ho', 'x': '4.5', 'y': '5.5'}
727 >>> read_dict('test.ini',type_conv)
727 >>> read_dict('test.ini',type_conv)
728 {'i': 3, 's': 'hi ho', 'x': 4.5, 'y': '5.5'}
728 {'i': 3, 's': 'hi ho', 'x': 4.5, 'y': '5.5'}
729 >>> read_dict('test.ini',type_conv,purge=1)
729 >>> read_dict('test.ini',type_conv,purge=1)
730 {'i': 3, 's': 'hi ho', 'x': 4.5}
730 {'i': 3, 's': 'hi ho', 'x': 4.5}
731 """
731 """
732
732
733 # starting config
733 # starting config
734 opt.setdefault('purge',0)
734 opt.setdefault('purge',0)
735 opt.setdefault('fs',None) # field sep defaults to any whitespace
735 opt.setdefault('fs',None) # field sep defaults to any whitespace
736 opt.setdefault('strip',0)
736 opt.setdefault('strip',0)
737 opt.setdefault('warn',1)
737 opt.setdefault('warn',1)
738 opt.setdefault('no_empty',0)
738 opt.setdefault('no_empty',0)
739 opt.setdefault('unique','')
739 opt.setdefault('unique','')
740 if type(opt['unique']) in StringTypes:
740 if type(opt['unique']) in StringTypes:
741 unique_keys = qw(opt['unique'])
741 unique_keys = qw(opt['unique'])
742 elif type(opt['unique']) in (types.TupleType,types.ListType):
742 elif type(opt['unique']) in (types.TupleType,types.ListType):
743 unique_keys = opt['unique']
743 unique_keys = opt['unique']
744 else:
744 else:
745 raise ValueError, 'Unique keys must be given as a string, List or Tuple'
745 raise ValueError, 'Unique keys must be given as a string, List or Tuple'
746
746
747 dict = {}
747 dict = {}
748 # first read in table of values as strings
748 # first read in table of values as strings
749 file = open(filename,'r')
749 file = open(filename,'r')
750 for line in file.readlines():
750 for line in file.readlines():
751 line = line.strip()
751 line = line.strip()
752 if len(line) and line[0]=='#': continue
752 if len(line) and line[0]=='#': continue
753 if len(line)>0:
753 if len(line)>0:
754 lsplit = line.split(opt['fs'],1)
754 lsplit = line.split(opt['fs'],1)
755 try:
755 try:
756 key,val = lsplit
756 key,val = lsplit
757 except ValueError:
757 except ValueError:
758 key,val = lsplit[0],''
758 key,val = lsplit[0],''
759 key = key.strip()
759 key = key.strip()
760 if opt['strip']: val = val.strip()
760 if opt['strip']: val = val.strip()
761 if val == "''" or val == '""': val = ''
761 if val == "''" or val == '""': val = ''
762 if opt['no_empty'] and (val=='' or val.isspace()):
762 if opt['no_empty'] and (val=='' or val.isspace()):
763 continue
763 continue
764 # if a key is found more than once in the file, build a list
764 # if a key is found more than once in the file, build a list
765 # unless it's in the 'unique' list. In that case, last found in file
765 # unless it's in the 'unique' list. In that case, last found in file
766 # takes precedence. User beware.
766 # takes precedence. User beware.
767 try:
767 try:
768 if dict[key] and key in unique_keys:
768 if dict[key] and key in unique_keys:
769 dict[key] = val
769 dict[key] = val
770 elif type(dict[key]) is types.ListType:
770 elif type(dict[key]) is types.ListType:
771 dict[key].append(val)
771 dict[key].append(val)
772 else:
772 else:
773 dict[key] = [dict[key],val]
773 dict[key] = [dict[key],val]
774 except KeyError:
774 except KeyError:
775 dict[key] = val
775 dict[key] = val
776 # purge if requested
776 # purge if requested
777 if opt['purge']:
777 if opt['purge']:
778 accepted_keys = qwflat(type_conv.values())
778 accepted_keys = qwflat(type_conv.values())
779 for key in dict.keys():
779 for key in dict.keys():
780 if key in accepted_keys: continue
780 if key in accepted_keys: continue
781 del(dict[key])
781 del(dict[key])
782 # now convert if requested
782 # now convert if requested
783 if type_conv==None: return dict
783 if type_conv==None: return dict
784 conversions = type_conv.keys()
784 conversions = type_conv.keys()
785 try: conversions.remove(None)
785 try: conversions.remove(None)
786 except: pass
786 except: pass
787 for convert in conversions:
787 for convert in conversions:
788 for val in qw(type_conv[convert]):
788 for val in qw(type_conv[convert]):
789 try:
789 try:
790 dict[val] = convert(dict[val])
790 dict[val] = convert(dict[val])
791 except KeyError,e:
791 except KeyError,e:
792 if opt['warn'] == 0:
792 if opt['warn'] == 0:
793 pass
793 pass
794 elif opt['warn'] == 1:
794 elif opt['warn'] == 1:
795 print >>sys.stderr, 'Warning: key',val,\
795 print >>sys.stderr, 'Warning: key',val,\
796 'not found in file',filename
796 'not found in file',filename
797 elif opt['warn'] == 2:
797 elif opt['warn'] == 2:
798 raise KeyError,e
798 raise KeyError,e
799 else:
799 else:
800 raise ValueError,'Warning level must be 0,1 or 2'
800 raise ValueError,'Warning level must be 0,1 or 2'
801
801
802 return dict
802 return dict
803
803
804 #----------------------------------------------------------------------------
804 #----------------------------------------------------------------------------
805 def flag_calls(func):
805 def flag_calls(func):
806 """Wrap a function to detect and flag when it gets called.
806 """Wrap a function to detect and flag when it gets called.
807
807
808 This is a decorator which takes a function and wraps it in a function with
808 This is a decorator which takes a function and wraps it in a function with
809 a 'called' attribute. wrapper.called is initialized to False.
809 a 'called' attribute. wrapper.called is initialized to False.
810
810
811 The wrapper.called attribute is set to False right before each call to the
811 The wrapper.called attribute is set to False right before each call to the
812 wrapped function, so if the call fails it remains False. After the call
812 wrapped function, so if the call fails it remains False. After the call
813 completes, wrapper.called is set to True and the output is returned.
813 completes, wrapper.called is set to True and the output is returned.
814
814
815 Testing for truth in wrapper.called allows you to determine if a call to
815 Testing for truth in wrapper.called allows you to determine if a call to
816 func() was attempted and succeeded."""
816 func() was attempted and succeeded."""
817
817
818 def wrapper(*args,**kw):
818 def wrapper(*args,**kw):
819 wrapper.called = False
819 wrapper.called = False
820 out = func(*args,**kw)
820 out = func(*args,**kw)
821 wrapper.called = True
821 wrapper.called = True
822 return out
822 return out
823
823
824 wrapper.called = False
824 wrapper.called = False
825 wrapper.__doc__ = func.__doc__
825 wrapper.__doc__ = func.__doc__
826 return wrapper
826 return wrapper
827
827
828 #----------------------------------------------------------------------------
828 #----------------------------------------------------------------------------
829 def dhook_wrap(func,*a,**k):
829 def dhook_wrap(func,*a,**k):
830 """Wrap a function call in a sys.displayhook controller.
830 """Wrap a function call in a sys.displayhook controller.
831
831
832 Returns a wrapper around func which calls func, with all its arguments and
832 Returns a wrapper around func which calls func, with all its arguments and
833 keywords unmodified, using the default sys.displayhook. Since IPython
833 keywords unmodified, using the default sys.displayhook. Since IPython
834 modifies sys.displayhook, it breaks the behavior of certain systems that
834 modifies sys.displayhook, it breaks the behavior of certain systems that
835 rely on the default behavior, notably doctest.
835 rely on the default behavior, notably doctest.
836 """
836 """
837
837
838 def f(*a,**k):
838 def f(*a,**k):
839
839
840 dhook_s = sys.displayhook
840 dhook_s = sys.displayhook
841 sys.displayhook = sys.__displayhook__
841 sys.displayhook = sys.__displayhook__
842 try:
842 try:
843 out = func(*a,**k)
843 out = func(*a,**k)
844 finally:
844 finally:
845 sys.displayhook = dhook_s
845 sys.displayhook = dhook_s
846
846
847 return out
847 return out
848
848
849 f.__doc__ = func.__doc__
849 f.__doc__ = func.__doc__
850 return f
850 return f
851
851
852 #----------------------------------------------------------------------------
852 #----------------------------------------------------------------------------
853 def doctest_reload():
853 def doctest_reload():
854 """Properly reload doctest to reuse it interactively.
854 """Properly reload doctest to reuse it interactively.
855
855
856 This routine:
856 This routine:
857
857
858 - reloads doctest
858 - reloads doctest
859
859
860 - resets its global 'master' attribute to None, so that multiple uses of
860 - resets its global 'master' attribute to None, so that multiple uses of
861 the module interactively don't produce cumulative reports.
861 the module interactively don't produce cumulative reports.
862
862
863 - Monkeypatches its core test runner method to protect it from IPython's
863 - Monkeypatches its core test runner method to protect it from IPython's
864 modified displayhook. Doctest expects the default displayhook behavior
864 modified displayhook. Doctest expects the default displayhook behavior
865 deep down, so our modification breaks it completely. For this reason, a
865 deep down, so our modification breaks it completely. For this reason, a
866 hard monkeypatch seems like a reasonable solution rather than asking
866 hard monkeypatch seems like a reasonable solution rather than asking
867 users to manually use a different doctest runner when under IPython."""
867 users to manually use a different doctest runner when under IPython."""
868
868
869 import doctest
869 import doctest
870 reload(doctest)
870 reload(doctest)
871 doctest.master=None
871 doctest.master=None
872
872
873 try:
873 try:
874 doctest.DocTestRunner
874 doctest.DocTestRunner
875 except AttributeError:
875 except AttributeError:
876 # This is only for python 2.3 compatibility, remove once we move to
876 # This is only for python 2.3 compatibility, remove once we move to
877 # 2.4 only.
877 # 2.4 only.
878 pass
878 pass
879 else:
879 else:
880 doctest.DocTestRunner.run = dhook_wrap(doctest.DocTestRunner.run)
880 doctest.DocTestRunner.run = dhook_wrap(doctest.DocTestRunner.run)
881
881
882 #----------------------------------------------------------------------------
882 #----------------------------------------------------------------------------
883 class HomeDirError(Error):
883 class HomeDirError(Error):
884 pass
884 pass
885
885
886 def get_home_dir():
886 def get_home_dir():
887 """Return the closest possible equivalent to a 'home' directory.
887 """Return the closest possible equivalent to a 'home' directory.
888
888
889 We first try $HOME. Absent that, on NT it's $HOMEDRIVE\$HOMEPATH.
889 We first try $HOME. Absent that, on NT it's $HOMEDRIVE\$HOMEPATH.
890
890
891 Currently only Posix and NT are implemented, a HomeDirError exception is
891 Currently only Posix and NT are implemented, a HomeDirError exception is
892 raised for all other OSes. """
892 raised for all other OSes. """
893
893
894 isdir = os.path.isdir
894 isdir = os.path.isdir
895 env = os.environ
895 env = os.environ
896
896
897 # first, check py2exe distribution root directory for _ipython.
897 # first, check py2exe distribution root directory for _ipython.
898 # This overrides all. Normally does not exist.
898 # This overrides all. Normally does not exist.
899
899
900 if '\\library.zip\\' in IPython.__file__.lower():
900 if '\\library.zip\\' in IPython.__file__.lower():
901 root, rest = IPython.__file__.lower().split('library.zip')
901 root, rest = IPython.__file__.lower().split('library.zip')
902 if isdir(root + '_ipython'):
902 if isdir(root + '_ipython'):
903 os.environ["IPYKITROOT"] = root.rstrip('\\')
903 os.environ["IPYKITROOT"] = root.rstrip('\\')
904 return root
904 return root
905
905
906 try:
906 try:
907 homedir = env['HOME']
907 homedir = env['HOME']
908 if not isdir(homedir):
908 if not isdir(homedir):
909 # in case a user stuck some string which does NOT resolve to a
909 # in case a user stuck some string which does NOT resolve to a
910 # valid path, it's as good as if we hadn't foud it
910 # valid path, it's as good as if we hadn't foud it
911 raise KeyError
911 raise KeyError
912 return homedir
912 return homedir
913 except KeyError:
913 except KeyError:
914 if os.name == 'posix':
914 if os.name == 'posix':
915 raise HomeDirError,'undefined $HOME, IPython can not proceed.'
915 raise HomeDirError,'undefined $HOME, IPython can not proceed.'
916 elif os.name == 'nt':
916 elif os.name == 'nt':
917 # For some strange reason, win9x returns 'nt' for os.name.
917 # For some strange reason, win9x returns 'nt' for os.name.
918 try:
918 try:
919 homedir = os.path.join(env['HOMEDRIVE'],env['HOMEPATH'])
919 homedir = os.path.join(env['HOMEDRIVE'],env['HOMEPATH'])
920 if not isdir(homedir):
920 if not isdir(homedir):
921 homedir = os.path.join(env['USERPROFILE'])
921 homedir = os.path.join(env['USERPROFILE'])
922 if not isdir(homedir):
922 if not isdir(homedir):
923 raise HomeDirError
923 raise HomeDirError
924 return homedir
924 return homedir
925 except:
925 except:
926 try:
926 try:
927 # Use the registry to get the 'My Documents' folder.
927 # Use the registry to get the 'My Documents' folder.
928 import _winreg as wreg
928 import _winreg as wreg
929 key = wreg.OpenKey(wreg.HKEY_CURRENT_USER,
929 key = wreg.OpenKey(wreg.HKEY_CURRENT_USER,
930 "Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders")
930 "Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders")
931 homedir = wreg.QueryValueEx(key,'Personal')[0]
931 homedir = wreg.QueryValueEx(key,'Personal')[0]
932 key.Close()
932 key.Close()
933 if not isdir(homedir):
933 if not isdir(homedir):
934 e = ('Invalid "Personal" folder registry key '
934 e = ('Invalid "Personal" folder registry key '
935 'typically "My Documents".\n'
935 'typically "My Documents".\n'
936 'Value: %s\n'
936 'Value: %s\n'
937 'This is not a valid directory on your system.' %
937 'This is not a valid directory on your system.' %
938 homedir)
938 homedir)
939 raise HomeDirError(e)
939 raise HomeDirError(e)
940 return homedir
940 return homedir
941 except HomeDirError:
941 except HomeDirError:
942 raise
942 raise
943 except:
943 except:
944 return 'C:\\'
944 return 'C:\\'
945 elif os.name == 'dos':
945 elif os.name == 'dos':
946 # Desperate, may do absurd things in classic MacOS. May work under DOS.
946 # Desperate, may do absurd things in classic MacOS. May work under DOS.
947 return 'C:\\'
947 return 'C:\\'
948 else:
948 else:
949 raise HomeDirError,'support for your operating system not implemented.'
949 raise HomeDirError,'support for your operating system not implemented.'
950
950
951 #****************************************************************************
951 #****************************************************************************
952 # strings and text
952 # strings and text
953
953
954 class LSString(str):
954 class LSString(str):
955 """String derivative with a special access attributes.
955 """String derivative with a special access attributes.
956
956
957 These are normal strings, but with the special attributes:
957 These are normal strings, but with the special attributes:
958
958
959 .l (or .list) : value as list (split on newlines).
959 .l (or .list) : value as list (split on newlines).
960 .n (or .nlstr): original value (the string itself).
960 .n (or .nlstr): original value (the string itself).
961 .s (or .spstr): value as whitespace-separated string.
961 .s (or .spstr): value as whitespace-separated string.
962 .p (or .paths): list of path objects
962 .p (or .paths): list of path objects
963
963
964 Any values which require transformations are computed only once and
964 Any values which require transformations are computed only once and
965 cached.
965 cached.
966
966
967 Such strings are very useful to efficiently interact with the shell, which
967 Such strings are very useful to efficiently interact with the shell, which
968 typically only understands whitespace-separated options for commands."""
968 typically only understands whitespace-separated options for commands."""
969
969
970 def get_list(self):
970 def get_list(self):
971 try:
971 try:
972 return self.__list
972 return self.__list
973 except AttributeError:
973 except AttributeError:
974 self.__list = self.split('\n')
974 self.__list = self.split('\n')
975 return self.__list
975 return self.__list
976
976
977 l = list = property(get_list)
977 l = list = property(get_list)
978
978
979 def get_spstr(self):
979 def get_spstr(self):
980 try:
980 try:
981 return self.__spstr
981 return self.__spstr
982 except AttributeError:
982 except AttributeError:
983 self.__spstr = self.replace('\n',' ')
983 self.__spstr = self.replace('\n',' ')
984 return self.__spstr
984 return self.__spstr
985
985
986 s = spstr = property(get_spstr)
986 s = spstr = property(get_spstr)
987
987
988 def get_nlstr(self):
988 def get_nlstr(self):
989 return self
989 return self
990
990
991 n = nlstr = property(get_nlstr)
991 n = nlstr = property(get_nlstr)
992
992
993 def get_paths(self):
993 def get_paths(self):
994 try:
994 try:
995 return self.__paths
995 return self.__paths
996 except AttributeError:
996 except AttributeError:
997 self.__paths = [path(p) for p in self.split('\n') if os.path.exists(p)]
997 self.__paths = [path(p) for p in self.split('\n') if os.path.exists(p)]
998 return self.__paths
998 return self.__paths
999
999
1000 p = paths = property(get_paths)
1000 p = paths = property(get_paths)
1001
1001
1002 def print_lsstring(arg):
1002 def print_lsstring(arg):
1003 """ Prettier (non-repr-like) and more informative printer for LSString """
1003 """ Prettier (non-repr-like) and more informative printer for LSString """
1004 print "LSString (.p, .n, .l, .s available). Value:"
1004 print "LSString (.p, .n, .l, .s available). Value:"
1005 print arg
1005 print arg
1006
1006
1007 print_lsstring = result_display.when_type(LSString)(print_lsstring)
1007 print_lsstring = result_display.when_type(LSString)(print_lsstring)
1008
1008
1009 #----------------------------------------------------------------------------
1009 #----------------------------------------------------------------------------
1010 class SList(list):
1010 class SList(list):
1011 """List derivative with a special access attributes.
1011 """List derivative with a special access attributes.
1012
1012
1013 These are normal lists, but with the special attributes:
1013 These are normal lists, but with the special attributes:
1014
1014
1015 .l (or .list) : value as list (the list itself).
1015 .l (or .list) : value as list (the list itself).
1016 .n (or .nlstr): value as a string, joined on newlines.
1016 .n (or .nlstr): value as a string, joined on newlines.
1017 .s (or .spstr): value as a string, joined on spaces.
1017 .s (or .spstr): value as a string, joined on spaces.
1018 .p (or .paths): list of path objects
1018 .p (or .paths): list of path objects
1019
1019
1020 Any values which require transformations are computed only once and
1020 Any values which require transformations are computed only once and
1021 cached."""
1021 cached."""
1022
1022
1023 def get_list(self):
1023 def get_list(self):
1024 return self
1024 return self
1025
1025
1026 l = list = property(get_list)
1026 l = list = property(get_list)
1027
1027
1028 def get_spstr(self):
1028 def get_spstr(self):
1029 try:
1029 try:
1030 return self.__spstr
1030 return self.__spstr
1031 except AttributeError:
1031 except AttributeError:
1032 self.__spstr = ' '.join(self)
1032 self.__spstr = ' '.join(self)
1033 return self.__spstr
1033 return self.__spstr
1034
1034
1035 s = spstr = property(get_spstr)
1035 s = spstr = property(get_spstr)
1036
1036
1037 def get_nlstr(self):
1037 def get_nlstr(self):
1038 try:
1038 try:
1039 return self.__nlstr
1039 return self.__nlstr
1040 except AttributeError:
1040 except AttributeError:
1041 self.__nlstr = '\n'.join(self)
1041 self.__nlstr = '\n'.join(self)
1042 return self.__nlstr
1042 return self.__nlstr
1043
1043
1044 n = nlstr = property(get_nlstr)
1044 n = nlstr = property(get_nlstr)
1045
1045
1046 def get_paths(self):
1046 def get_paths(self):
1047 try:
1047 try:
1048 return self.__paths
1048 return self.__paths
1049 except AttributeError:
1049 except AttributeError:
1050 self.__paths = [path(p) for p in self if os.path.exists(p)]
1050 self.__paths = [path(p) for p in self if os.path.exists(p)]
1051 return self.__paths
1051 return self.__paths
1052
1052
1053 p = paths = property(get_paths)
1053 p = paths = property(get_paths)
1054
1054
1055 def grep(self, pattern, prune = False):
1055 def grep(self, pattern, prune = False, field = None):
1056 """ Return all strings matching 'pattern' (a regex or callable)
1056 """ Return all strings matching 'pattern' (a regex or callable)
1057
1057
1058 This is case-insensitive. If prune is true, return all items
1058 This is case-insensitive. If prune is true, return all items
1059 NOT matching the pattern.
1059 NOT matching the pattern.
1060
1060
1061 If field is specified, the match must occur in the specified
1062 whitespace-separated field.
1063
1061 Examples::
1064 Examples::
1062
1065
1063 a.grep( lambda x: x.startswith('C') )
1066 a.grep( lambda x: x.startswith('C') )
1064 a.grep('Cha.*log', prune=1)
1067 a.grep('Cha.*log', prune=1)
1068 a.grep('chm', field=-1)
1065 """
1069 """
1070
1071 def match_target(s):
1072 if field is None:
1073 return s
1074 parts = s.split()
1075 try:
1076 tgt = parts[field]
1077 return tgt
1078 except IndexError:
1079 return ""
1080
1066 if isinstance(pattern, basestring):
1081 if isinstance(pattern, basestring):
1067 pred = lambda x : re.search(pattern, x, re.IGNORECASE)
1082 pred = lambda x : re.search(pattern, x, re.IGNORECASE)
1068 else:
1083 else:
1069 pred = pattern
1084 pred = pattern
1070 if not prune:
1085 if not prune:
1071 return SList([el for el in self if pred(el)])
1086 return SList([el for el in self if pred(match_target(el))])
1072 else:
1087 else:
1073 return SList([el for el in self if not pred(el)])
1088 return SList([el for el in self if not pred(match_target(el))])
1074 def fields(self, *fields):
1089 def fields(self, *fields):
1075 """ Collect whitespace-separated fields from string list
1090 """ Collect whitespace-separated fields from string list
1076
1091
1077 Allows quick awk-like usage of string lists.
1092 Allows quick awk-like usage of string lists.
1078
1093
1079 Example data (in var a, created by 'a = !ls -l')::
1094 Example data (in var a, created by 'a = !ls -l')::
1080 -rwxrwxrwx 1 ville None 18 Dec 14 2006 ChangeLog
1095 -rwxrwxrwx 1 ville None 18 Dec 14 2006 ChangeLog
1081 drwxrwxrwx+ 6 ville None 0 Oct 24 18:05 IPython
1096 drwxrwxrwx+ 6 ville None 0 Oct 24 18:05 IPython
1082
1097
1083 a.fields(0) is ['-rwxrwxrwx', 'drwxrwxrwx+']
1098 a.fields(0) is ['-rwxrwxrwx', 'drwxrwxrwx+']
1084 a.fields(1,0) is ['1 -rwxrwxrwx', '6 drwxrwxrwx+']
1099 a.fields(1,0) is ['1 -rwxrwxrwx', '6 drwxrwxrwx+']
1085 (note the joining by space).
1100 (note the joining by space).
1101 a.fields(-1) is ['ChangeLog', 'IPython']
1086
1102
1087 IndexErrors are ignored.
1103 IndexErrors are ignored.
1088
1104
1089 Without args, fields() just split()'s the strings.
1105 Without args, fields() just split()'s the strings.
1090 """
1106 """
1091 if len(fields) == 0:
1107 if len(fields) == 0:
1092 return [el.split() for el in self]
1108 return [el.split() for el in self]
1093
1109
1094 res = SList()
1110 res = SList()
1095 for el in [f.split() for f in self]:
1111 for el in [f.split() for f in self]:
1096 lineparts = []
1112 lineparts = []
1097
1113
1098 for fd in fields:
1114 for fd in fields:
1099 try:
1115 try:
1100 lineparts.append(el[fd])
1116 lineparts.append(el[fd])
1101 except IndexError:
1117 except IndexError:
1102 pass
1118 pass
1103 if lineparts:
1119 if lineparts:
1104 res.append(" ".join(lineparts))
1120 res.append(" ".join(lineparts))
1105
1121
1106 return res
1122 return res
1107
1123
1108
1124
1109
1125
1110
1126
1111
1127
1112 def print_slist(arg):
1128 def print_slist(arg):
1113 """ Prettier (non-repr-like) and more informative printer for SList """
1129 """ Prettier (non-repr-like) and more informative printer for SList """
1114 print "SList (.p, .n, .l, .s, .grep(), .fields() available). Value:"
1130 print "SList (.p, .n, .l, .s, .grep(), .fields() available). Value:"
1115 nlprint(arg)
1131 nlprint(arg)
1116
1132
1117 print_slist = result_display.when_type(SList)(print_slist)
1133 print_slist = result_display.when_type(SList)(print_slist)
1118
1134
1119
1135
1120
1136
1121 #----------------------------------------------------------------------------
1137 #----------------------------------------------------------------------------
1122 def esc_quotes(strng):
1138 def esc_quotes(strng):
1123 """Return the input string with single and double quotes escaped out"""
1139 """Return the input string with single and double quotes escaped out"""
1124
1140
1125 return strng.replace('"','\\"').replace("'","\\'")
1141 return strng.replace('"','\\"').replace("'","\\'")
1126
1142
1127 #----------------------------------------------------------------------------
1143 #----------------------------------------------------------------------------
1128 def make_quoted_expr(s):
1144 def make_quoted_expr(s):
1129 """Return string s in appropriate quotes, using raw string if possible.
1145 """Return string s in appropriate quotes, using raw string if possible.
1130
1146
1131 Effectively this turns string: cd \ao\ao\
1147 Effectively this turns string: cd \ao\ao\
1132 to: r"cd \ao\ao\_"[:-1]
1148 to: r"cd \ao\ao\_"[:-1]
1133
1149
1134 Note the use of raw string and padding at the end to allow trailing backslash.
1150 Note the use of raw string and padding at the end to allow trailing backslash.
1135
1151
1136 """
1152 """
1137
1153
1138 tail = ''
1154 tail = ''
1139 tailpadding = ''
1155 tailpadding = ''
1140 raw = ''
1156 raw = ''
1141 if "\\" in s:
1157 if "\\" in s:
1142 raw = 'r'
1158 raw = 'r'
1143 if s.endswith('\\'):
1159 if s.endswith('\\'):
1144 tail = '[:-1]'
1160 tail = '[:-1]'
1145 tailpadding = '_'
1161 tailpadding = '_'
1146 if '"' not in s:
1162 if '"' not in s:
1147 quote = '"'
1163 quote = '"'
1148 elif "'" not in s:
1164 elif "'" not in s:
1149 quote = "'"
1165 quote = "'"
1150 elif '"""' not in s and not s.endswith('"'):
1166 elif '"""' not in s and not s.endswith('"'):
1151 quote = '"""'
1167 quote = '"""'
1152 elif "'''" not in s and not s.endswith("'"):
1168 elif "'''" not in s and not s.endswith("'"):
1153 quote = "'''"
1169 quote = "'''"
1154 else:
1170 else:
1155 # give up, backslash-escaped string will do
1171 # give up, backslash-escaped string will do
1156 return '"%s"' % esc_quotes(s)
1172 return '"%s"' % esc_quotes(s)
1157 res = raw + quote + s + tailpadding + quote + tail
1173 res = raw + quote + s + tailpadding + quote + tail
1158 return res
1174 return res
1159
1175
1160
1176
1161 #----------------------------------------------------------------------------
1177 #----------------------------------------------------------------------------
1162 def raw_input_multi(header='', ps1='==> ', ps2='..> ',terminate_str = '.'):
1178 def raw_input_multi(header='', ps1='==> ', ps2='..> ',terminate_str = '.'):
1163 """Take multiple lines of input.
1179 """Take multiple lines of input.
1164
1180
1165 A list with each line of input as a separate element is returned when a
1181 A list with each line of input as a separate element is returned when a
1166 termination string is entered (defaults to a single '.'). Input can also
1182 termination string is entered (defaults to a single '.'). Input can also
1167 terminate via EOF (^D in Unix, ^Z-RET in Windows).
1183 terminate via EOF (^D in Unix, ^Z-RET in Windows).
1168
1184
1169 Lines of input which end in \\ are joined into single entries (and a
1185 Lines of input which end in \\ are joined into single entries (and a
1170 secondary continuation prompt is issued as long as the user terminates
1186 secondary continuation prompt is issued as long as the user terminates
1171 lines with \\). This allows entering very long strings which are still
1187 lines with \\). This allows entering very long strings which are still
1172 meant to be treated as single entities.
1188 meant to be treated as single entities.
1173 """
1189 """
1174
1190
1175 try:
1191 try:
1176 if header:
1192 if header:
1177 header += '\n'
1193 header += '\n'
1178 lines = [raw_input(header + ps1)]
1194 lines = [raw_input(header + ps1)]
1179 except EOFError:
1195 except EOFError:
1180 return []
1196 return []
1181 terminate = [terminate_str]
1197 terminate = [terminate_str]
1182 try:
1198 try:
1183 while lines[-1:] != terminate:
1199 while lines[-1:] != terminate:
1184 new_line = raw_input(ps1)
1200 new_line = raw_input(ps1)
1185 while new_line.endswith('\\'):
1201 while new_line.endswith('\\'):
1186 new_line = new_line[:-1] + raw_input(ps2)
1202 new_line = new_line[:-1] + raw_input(ps2)
1187 lines.append(new_line)
1203 lines.append(new_line)
1188
1204
1189 return lines[:-1] # don't return the termination command
1205 return lines[:-1] # don't return the termination command
1190 except EOFError:
1206 except EOFError:
1191 print
1207 print
1192 return lines
1208 return lines
1193
1209
1194 #----------------------------------------------------------------------------
1210 #----------------------------------------------------------------------------
1195 def raw_input_ext(prompt='', ps2='... '):
1211 def raw_input_ext(prompt='', ps2='... '):
1196 """Similar to raw_input(), but accepts extended lines if input ends with \\."""
1212 """Similar to raw_input(), but accepts extended lines if input ends with \\."""
1197
1213
1198 line = raw_input(prompt)
1214 line = raw_input(prompt)
1199 while line.endswith('\\'):
1215 while line.endswith('\\'):
1200 line = line[:-1] + raw_input(ps2)
1216 line = line[:-1] + raw_input(ps2)
1201 return line
1217 return line
1202
1218
1203 #----------------------------------------------------------------------------
1219 #----------------------------------------------------------------------------
1204 def ask_yes_no(prompt,default=None):
1220 def ask_yes_no(prompt,default=None):
1205 """Asks a question and returns a boolean (y/n) answer.
1221 """Asks a question and returns a boolean (y/n) answer.
1206
1222
1207 If default is given (one of 'y','n'), it is used if the user input is
1223 If default is given (one of 'y','n'), it is used if the user input is
1208 empty. Otherwise the question is repeated until an answer is given.
1224 empty. Otherwise the question is repeated until an answer is given.
1209
1225
1210 An EOF is treated as the default answer. If there is no default, an
1226 An EOF is treated as the default answer. If there is no default, an
1211 exception is raised to prevent infinite loops.
1227 exception is raised to prevent infinite loops.
1212
1228
1213 Valid answers are: y/yes/n/no (match is not case sensitive)."""
1229 Valid answers are: y/yes/n/no (match is not case sensitive)."""
1214
1230
1215 answers = {'y':True,'n':False,'yes':True,'no':False}
1231 answers = {'y':True,'n':False,'yes':True,'no':False}
1216 ans = None
1232 ans = None
1217 while ans not in answers.keys():
1233 while ans not in answers.keys():
1218 try:
1234 try:
1219 ans = raw_input(prompt+' ').lower()
1235 ans = raw_input(prompt+' ').lower()
1220 if not ans: # response was an empty string
1236 if not ans: # response was an empty string
1221 ans = default
1237 ans = default
1222 except KeyboardInterrupt:
1238 except KeyboardInterrupt:
1223 pass
1239 pass
1224 except EOFError:
1240 except EOFError:
1225 if default in answers.keys():
1241 if default in answers.keys():
1226 ans = default
1242 ans = default
1227 print
1243 print
1228 else:
1244 else:
1229 raise
1245 raise
1230
1246
1231 return answers[ans]
1247 return answers[ans]
1232
1248
1233 #----------------------------------------------------------------------------
1249 #----------------------------------------------------------------------------
1234 def marquee(txt='',width=78,mark='*'):
1250 def marquee(txt='',width=78,mark='*'):
1235 """Return the input string centered in a 'marquee'."""
1251 """Return the input string centered in a 'marquee'."""
1236 if not txt:
1252 if not txt:
1237 return (mark*width)[:width]
1253 return (mark*width)[:width]
1238 nmark = (width-len(txt)-2)/len(mark)/2
1254 nmark = (width-len(txt)-2)/len(mark)/2
1239 if nmark < 0: nmark =0
1255 if nmark < 0: nmark =0
1240 marks = mark*nmark
1256 marks = mark*nmark
1241 return '%s %s %s' % (marks,txt,marks)
1257 return '%s %s %s' % (marks,txt,marks)
1242
1258
1243 #----------------------------------------------------------------------------
1259 #----------------------------------------------------------------------------
1244 class EvalDict:
1260 class EvalDict:
1245 """
1261 """
1246 Emulate a dict which evaluates its contents in the caller's frame.
1262 Emulate a dict which evaluates its contents in the caller's frame.
1247
1263
1248 Usage:
1264 Usage:
1249 >>>number = 19
1265 >>>number = 19
1250 >>>text = "python"
1266 >>>text = "python"
1251 >>>print "%(text.capitalize())s %(number/9.0).1f rules!" % EvalDict()
1267 >>>print "%(text.capitalize())s %(number/9.0).1f rules!" % EvalDict()
1252 """
1268 """
1253
1269
1254 # This version is due to sismex01@hebmex.com on c.l.py, and is basically a
1270 # This version is due to sismex01@hebmex.com on c.l.py, and is basically a
1255 # modified (shorter) version of:
1271 # modified (shorter) version of:
1256 # http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/66018 by
1272 # http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/66018 by
1257 # Skip Montanaro (skip@pobox.com).
1273 # Skip Montanaro (skip@pobox.com).
1258
1274
1259 def __getitem__(self, name):
1275 def __getitem__(self, name):
1260 frame = sys._getframe(1)
1276 frame = sys._getframe(1)
1261 return eval(name, frame.f_globals, frame.f_locals)
1277 return eval(name, frame.f_globals, frame.f_locals)
1262
1278
1263 EvalString = EvalDict # for backwards compatibility
1279 EvalString = EvalDict # for backwards compatibility
1264 #----------------------------------------------------------------------------
1280 #----------------------------------------------------------------------------
1265 def qw(words,flat=0,sep=None,maxsplit=-1):
1281 def qw(words,flat=0,sep=None,maxsplit=-1):
1266 """Similar to Perl's qw() operator, but with some more options.
1282 """Similar to Perl's qw() operator, but with some more options.
1267
1283
1268 qw(words,flat=0,sep=' ',maxsplit=-1) -> words.split(sep,maxsplit)
1284 qw(words,flat=0,sep=' ',maxsplit=-1) -> words.split(sep,maxsplit)
1269
1285
1270 words can also be a list itself, and with flat=1, the output will be
1286 words can also be a list itself, and with flat=1, the output will be
1271 recursively flattened. Examples:
1287 recursively flattened. Examples:
1272
1288
1273 >>> qw('1 2')
1289 >>> qw('1 2')
1274 ['1', '2']
1290 ['1', '2']
1275 >>> qw(['a b','1 2',['m n','p q']])
1291 >>> qw(['a b','1 2',['m n','p q']])
1276 [['a', 'b'], ['1', '2'], [['m', 'n'], ['p', 'q']]]
1292 [['a', 'b'], ['1', '2'], [['m', 'n'], ['p', 'q']]]
1277 >>> qw(['a b','1 2',['m n','p q']],flat=1)
1293 >>> qw(['a b','1 2',['m n','p q']],flat=1)
1278 ['a', 'b', '1', '2', 'm', 'n', 'p', 'q'] """
1294 ['a', 'b', '1', '2', 'm', 'n', 'p', 'q'] """
1279
1295
1280 if type(words) in StringTypes:
1296 if type(words) in StringTypes:
1281 return [word.strip() for word in words.split(sep,maxsplit)
1297 return [word.strip() for word in words.split(sep,maxsplit)
1282 if word and not word.isspace() ]
1298 if word and not word.isspace() ]
1283 if flat:
1299 if flat:
1284 return flatten(map(qw,words,[1]*len(words)))
1300 return flatten(map(qw,words,[1]*len(words)))
1285 return map(qw,words)
1301 return map(qw,words)
1286
1302
1287 #----------------------------------------------------------------------------
1303 #----------------------------------------------------------------------------
1288 def qwflat(words,sep=None,maxsplit=-1):
1304 def qwflat(words,sep=None,maxsplit=-1):
1289 """Calls qw(words) in flat mode. It's just a convenient shorthand."""
1305 """Calls qw(words) in flat mode. It's just a convenient shorthand."""
1290 return qw(words,1,sep,maxsplit)
1306 return qw(words,1,sep,maxsplit)
1291
1307
1292 #----------------------------------------------------------------------------
1308 #----------------------------------------------------------------------------
1293 def qw_lol(indata):
1309 def qw_lol(indata):
1294 """qw_lol('a b') -> [['a','b']],
1310 """qw_lol('a b') -> [['a','b']],
1295 otherwise it's just a call to qw().
1311 otherwise it's just a call to qw().
1296
1312
1297 We need this to make sure the modules_some keys *always* end up as a
1313 We need this to make sure the modules_some keys *always* end up as a
1298 list of lists."""
1314 list of lists."""
1299
1315
1300 if type(indata) in StringTypes:
1316 if type(indata) in StringTypes:
1301 return [qw(indata)]
1317 return [qw(indata)]
1302 else:
1318 else:
1303 return qw(indata)
1319 return qw(indata)
1304
1320
1305 #-----------------------------------------------------------------------------
1321 #-----------------------------------------------------------------------------
1306 def list_strings(arg):
1322 def list_strings(arg):
1307 """Always return a list of strings, given a string or list of strings
1323 """Always return a list of strings, given a string or list of strings
1308 as input."""
1324 as input."""
1309
1325
1310 if type(arg) in StringTypes: return [arg]
1326 if type(arg) in StringTypes: return [arg]
1311 else: return arg
1327 else: return arg
1312
1328
1313 #----------------------------------------------------------------------------
1329 #----------------------------------------------------------------------------
1314 def grep(pat,list,case=1):
1330 def grep(pat,list,case=1):
1315 """Simple minded grep-like function.
1331 """Simple minded grep-like function.
1316 grep(pat,list) returns occurrences of pat in list, None on failure.
1332 grep(pat,list) returns occurrences of pat in list, None on failure.
1317
1333
1318 It only does simple string matching, with no support for regexps. Use the
1334 It only does simple string matching, with no support for regexps. Use the
1319 option case=0 for case-insensitive matching."""
1335 option case=0 for case-insensitive matching."""
1320
1336
1321 # This is pretty crude. At least it should implement copying only references
1337 # This is pretty crude. At least it should implement copying only references
1322 # to the original data in case it's big. Now it copies the data for output.
1338 # to the original data in case it's big. Now it copies the data for output.
1323 out=[]
1339 out=[]
1324 if case:
1340 if case:
1325 for term in list:
1341 for term in list:
1326 if term.find(pat)>-1: out.append(term)
1342 if term.find(pat)>-1: out.append(term)
1327 else:
1343 else:
1328 lpat=pat.lower()
1344 lpat=pat.lower()
1329 for term in list:
1345 for term in list:
1330 if term.lower().find(lpat)>-1: out.append(term)
1346 if term.lower().find(lpat)>-1: out.append(term)
1331
1347
1332 if len(out): return out
1348 if len(out): return out
1333 else: return None
1349 else: return None
1334
1350
1335 #----------------------------------------------------------------------------
1351 #----------------------------------------------------------------------------
1336 def dgrep(pat,*opts):
1352 def dgrep(pat,*opts):
1337 """Return grep() on dir()+dir(__builtins__).
1353 """Return grep() on dir()+dir(__builtins__).
1338
1354
1339 A very common use of grep() when working interactively."""
1355 A very common use of grep() when working interactively."""
1340
1356
1341 return grep(pat,dir(__main__)+dir(__main__.__builtins__),*opts)
1357 return grep(pat,dir(__main__)+dir(__main__.__builtins__),*opts)
1342
1358
1343 #----------------------------------------------------------------------------
1359 #----------------------------------------------------------------------------
1344 def idgrep(pat):
1360 def idgrep(pat):
1345 """Case-insensitive dgrep()"""
1361 """Case-insensitive dgrep()"""
1346
1362
1347 return dgrep(pat,0)
1363 return dgrep(pat,0)
1348
1364
1349 #----------------------------------------------------------------------------
1365 #----------------------------------------------------------------------------
1350 def igrep(pat,list):
1366 def igrep(pat,list):
1351 """Synonym for case-insensitive grep."""
1367 """Synonym for case-insensitive grep."""
1352
1368
1353 return grep(pat,list,case=0)
1369 return grep(pat,list,case=0)
1354
1370
1355 #----------------------------------------------------------------------------
1371 #----------------------------------------------------------------------------
1356 def indent(str,nspaces=4,ntabs=0):
1372 def indent(str,nspaces=4,ntabs=0):
1357 """Indent a string a given number of spaces or tabstops.
1373 """Indent a string a given number of spaces or tabstops.
1358
1374
1359 indent(str,nspaces=4,ntabs=0) -> indent str by ntabs+nspaces.
1375 indent(str,nspaces=4,ntabs=0) -> indent str by ntabs+nspaces.
1360 """
1376 """
1361 if str is None:
1377 if str is None:
1362 return
1378 return
1363 ind = '\t'*ntabs+' '*nspaces
1379 ind = '\t'*ntabs+' '*nspaces
1364 outstr = '%s%s' % (ind,str.replace(os.linesep,os.linesep+ind))
1380 outstr = '%s%s' % (ind,str.replace(os.linesep,os.linesep+ind))
1365 if outstr.endswith(os.linesep+ind):
1381 if outstr.endswith(os.linesep+ind):
1366 return outstr[:-len(ind)]
1382 return outstr[:-len(ind)]
1367 else:
1383 else:
1368 return outstr
1384 return outstr
1369
1385
1370 #-----------------------------------------------------------------------------
1386 #-----------------------------------------------------------------------------
1371 def native_line_ends(filename,backup=1):
1387 def native_line_ends(filename,backup=1):
1372 """Convert (in-place) a file to line-ends native to the current OS.
1388 """Convert (in-place) a file to line-ends native to the current OS.
1373
1389
1374 If the optional backup argument is given as false, no backup of the
1390 If the optional backup argument is given as false, no backup of the
1375 original file is left. """
1391 original file is left. """
1376
1392
1377 backup_suffixes = {'posix':'~','dos':'.bak','nt':'.bak','mac':'.bak'}
1393 backup_suffixes = {'posix':'~','dos':'.bak','nt':'.bak','mac':'.bak'}
1378
1394
1379 bak_filename = filename + backup_suffixes[os.name]
1395 bak_filename = filename + backup_suffixes[os.name]
1380
1396
1381 original = open(filename).read()
1397 original = open(filename).read()
1382 shutil.copy2(filename,bak_filename)
1398 shutil.copy2(filename,bak_filename)
1383 try:
1399 try:
1384 new = open(filename,'wb')
1400 new = open(filename,'wb')
1385 new.write(os.linesep.join(original.splitlines()))
1401 new.write(os.linesep.join(original.splitlines()))
1386 new.write(os.linesep) # ALWAYS put an eol at the end of the file
1402 new.write(os.linesep) # ALWAYS put an eol at the end of the file
1387 new.close()
1403 new.close()
1388 except:
1404 except:
1389 os.rename(bak_filename,filename)
1405 os.rename(bak_filename,filename)
1390 if not backup:
1406 if not backup:
1391 try:
1407 try:
1392 os.remove(bak_filename)
1408 os.remove(bak_filename)
1393 except:
1409 except:
1394 pass
1410 pass
1395
1411
1396 #----------------------------------------------------------------------------
1412 #----------------------------------------------------------------------------
1397 def get_pager_cmd(pager_cmd = None):
1413 def get_pager_cmd(pager_cmd = None):
1398 """Return a pager command.
1414 """Return a pager command.
1399
1415
1400 Makes some attempts at finding an OS-correct one."""
1416 Makes some attempts at finding an OS-correct one."""
1401
1417
1402 if os.name == 'posix':
1418 if os.name == 'posix':
1403 default_pager_cmd = 'less -r' # -r for color control sequences
1419 default_pager_cmd = 'less -r' # -r for color control sequences
1404 elif os.name in ['nt','dos']:
1420 elif os.name in ['nt','dos']:
1405 default_pager_cmd = 'type'
1421 default_pager_cmd = 'type'
1406
1422
1407 if pager_cmd is None:
1423 if pager_cmd is None:
1408 try:
1424 try:
1409 pager_cmd = os.environ['PAGER']
1425 pager_cmd = os.environ['PAGER']
1410 except:
1426 except:
1411 pager_cmd = default_pager_cmd
1427 pager_cmd = default_pager_cmd
1412 return pager_cmd
1428 return pager_cmd
1413
1429
1414 #-----------------------------------------------------------------------------
1430 #-----------------------------------------------------------------------------
1415 def get_pager_start(pager,start):
1431 def get_pager_start(pager,start):
1416 """Return the string for paging files with an offset.
1432 """Return the string for paging files with an offset.
1417
1433
1418 This is the '+N' argument which less and more (under Unix) accept.
1434 This is the '+N' argument which less and more (under Unix) accept.
1419 """
1435 """
1420
1436
1421 if pager in ['less','more']:
1437 if pager in ['less','more']:
1422 if start:
1438 if start:
1423 start_string = '+' + str(start)
1439 start_string = '+' + str(start)
1424 else:
1440 else:
1425 start_string = ''
1441 start_string = ''
1426 else:
1442 else:
1427 start_string = ''
1443 start_string = ''
1428 return start_string
1444 return start_string
1429
1445
1430 #----------------------------------------------------------------------------
1446 #----------------------------------------------------------------------------
1431 # (X)emacs on W32 doesn't like to be bypassed with msvcrt.getch()
1447 # (X)emacs on W32 doesn't like to be bypassed with msvcrt.getch()
1432 if os.name == 'nt' and os.environ.get('TERM','dumb') != 'emacs':
1448 if os.name == 'nt' and os.environ.get('TERM','dumb') != 'emacs':
1433 import msvcrt
1449 import msvcrt
1434 def page_more():
1450 def page_more():
1435 """ Smart pausing between pages
1451 """ Smart pausing between pages
1436
1452
1437 @return: True if need print more lines, False if quit
1453 @return: True if need print more lines, False if quit
1438 """
1454 """
1439 Term.cout.write('---Return to continue, q to quit--- ')
1455 Term.cout.write('---Return to continue, q to quit--- ')
1440 ans = msvcrt.getch()
1456 ans = msvcrt.getch()
1441 if ans in ("q", "Q"):
1457 if ans in ("q", "Q"):
1442 result = False
1458 result = False
1443 else:
1459 else:
1444 result = True
1460 result = True
1445 Term.cout.write("\b"*37 + " "*37 + "\b"*37)
1461 Term.cout.write("\b"*37 + " "*37 + "\b"*37)
1446 return result
1462 return result
1447 else:
1463 else:
1448 def page_more():
1464 def page_more():
1449 ans = raw_input('---Return to continue, q to quit--- ')
1465 ans = raw_input('---Return to continue, q to quit--- ')
1450 if ans.lower().startswith('q'):
1466 if ans.lower().startswith('q'):
1451 return False
1467 return False
1452 else:
1468 else:
1453 return True
1469 return True
1454
1470
1455 esc_re = re.compile(r"(\x1b[^m]+m)")
1471 esc_re = re.compile(r"(\x1b[^m]+m)")
1456
1472
1457 def page_dumb(strng,start=0,screen_lines=25):
1473 def page_dumb(strng,start=0,screen_lines=25):
1458 """Very dumb 'pager' in Python, for when nothing else works.
1474 """Very dumb 'pager' in Python, for when nothing else works.
1459
1475
1460 Only moves forward, same interface as page(), except for pager_cmd and
1476 Only moves forward, same interface as page(), except for pager_cmd and
1461 mode."""
1477 mode."""
1462
1478
1463 out_ln = strng.splitlines()[start:]
1479 out_ln = strng.splitlines()[start:]
1464 screens = chop(out_ln,screen_lines-1)
1480 screens = chop(out_ln,screen_lines-1)
1465 if len(screens) == 1:
1481 if len(screens) == 1:
1466 print >>Term.cout, os.linesep.join(screens[0])
1482 print >>Term.cout, os.linesep.join(screens[0])
1467 else:
1483 else:
1468 last_escape = ""
1484 last_escape = ""
1469 for scr in screens[0:-1]:
1485 for scr in screens[0:-1]:
1470 hunk = os.linesep.join(scr)
1486 hunk = os.linesep.join(scr)
1471 print >>Term.cout, last_escape + hunk
1487 print >>Term.cout, last_escape + hunk
1472 if not page_more():
1488 if not page_more():
1473 return
1489 return
1474 esc_list = esc_re.findall(hunk)
1490 esc_list = esc_re.findall(hunk)
1475 if len(esc_list) > 0:
1491 if len(esc_list) > 0:
1476 last_escape = esc_list[-1]
1492 last_escape = esc_list[-1]
1477 print >>Term.cout, last_escape + os.linesep.join(screens[-1])
1493 print >>Term.cout, last_escape + os.linesep.join(screens[-1])
1478
1494
1479 #----------------------------------------------------------------------------
1495 #----------------------------------------------------------------------------
1480 def page(strng,start=0,screen_lines=0,pager_cmd = None):
1496 def page(strng,start=0,screen_lines=0,pager_cmd = None):
1481 """Print a string, piping through a pager after a certain length.
1497 """Print a string, piping through a pager after a certain length.
1482
1498
1483 The screen_lines parameter specifies the number of *usable* lines of your
1499 The screen_lines parameter specifies the number of *usable* lines of your
1484 terminal screen (total lines minus lines you need to reserve to show other
1500 terminal screen (total lines minus lines you need to reserve to show other
1485 information).
1501 information).
1486
1502
1487 If you set screen_lines to a number <=0, page() will try to auto-determine
1503 If you set screen_lines to a number <=0, page() will try to auto-determine
1488 your screen size and will only use up to (screen_size+screen_lines) for
1504 your screen size and will only use up to (screen_size+screen_lines) for
1489 printing, paging after that. That is, if you want auto-detection but need
1505 printing, paging after that. That is, if you want auto-detection but need
1490 to reserve the bottom 3 lines of the screen, use screen_lines = -3, and for
1506 to reserve the bottom 3 lines of the screen, use screen_lines = -3, and for
1491 auto-detection without any lines reserved simply use screen_lines = 0.
1507 auto-detection without any lines reserved simply use screen_lines = 0.
1492
1508
1493 If a string won't fit in the allowed lines, it is sent through the
1509 If a string won't fit in the allowed lines, it is sent through the
1494 specified pager command. If none given, look for PAGER in the environment,
1510 specified pager command. If none given, look for PAGER in the environment,
1495 and ultimately default to less.
1511 and ultimately default to less.
1496
1512
1497 If no system pager works, the string is sent through a 'dumb pager'
1513 If no system pager works, the string is sent through a 'dumb pager'
1498 written in python, very simplistic.
1514 written in python, very simplistic.
1499 """
1515 """
1500
1516
1501
1517
1502 # first, try the hook
1518 # first, try the hook
1503 ip = IPython.ipapi.get()
1519 ip = IPython.ipapi.get()
1504 if ip:
1520 if ip:
1505 try:
1521 try:
1506 ip.IP.hooks.show_in_pager(strng)
1522 ip.IP.hooks.show_in_pager(strng)
1507 return
1523 return
1508 except IPython.ipapi.TryNext:
1524 except IPython.ipapi.TryNext:
1509 pass
1525 pass
1510
1526
1511 # Ugly kludge, but calling curses.initscr() flat out crashes in emacs
1527 # Ugly kludge, but calling curses.initscr() flat out crashes in emacs
1512 TERM = os.environ.get('TERM','dumb')
1528 TERM = os.environ.get('TERM','dumb')
1513 if TERM in ['dumb','emacs'] and os.name != 'nt':
1529 if TERM in ['dumb','emacs'] and os.name != 'nt':
1514 print strng
1530 print strng
1515 return
1531 return
1516 # chop off the topmost part of the string we don't want to see
1532 # chop off the topmost part of the string we don't want to see
1517 str_lines = strng.split(os.linesep)[start:]
1533 str_lines = strng.split(os.linesep)[start:]
1518 str_toprint = os.linesep.join(str_lines)
1534 str_toprint = os.linesep.join(str_lines)
1519 num_newlines = len(str_lines)
1535 num_newlines = len(str_lines)
1520 len_str = len(str_toprint)
1536 len_str = len(str_toprint)
1521
1537
1522 # Dumb heuristics to guesstimate number of on-screen lines the string
1538 # Dumb heuristics to guesstimate number of on-screen lines the string
1523 # takes. Very basic, but good enough for docstrings in reasonable
1539 # takes. Very basic, but good enough for docstrings in reasonable
1524 # terminals. If someone later feels like refining it, it's not hard.
1540 # terminals. If someone later feels like refining it, it's not hard.
1525 numlines = max(num_newlines,int(len_str/80)+1)
1541 numlines = max(num_newlines,int(len_str/80)+1)
1526
1542
1527 if os.name == "nt":
1543 if os.name == "nt":
1528 screen_lines_def = get_console_size(defaulty=25)[1]
1544 screen_lines_def = get_console_size(defaulty=25)[1]
1529 else:
1545 else:
1530 screen_lines_def = 25 # default value if we can't auto-determine
1546 screen_lines_def = 25 # default value if we can't auto-determine
1531
1547
1532 # auto-determine screen size
1548 # auto-determine screen size
1533 if screen_lines <= 0:
1549 if screen_lines <= 0:
1534 if TERM=='xterm':
1550 if TERM=='xterm':
1535 try:
1551 try:
1536 import curses
1552 import curses
1537 if hasattr(curses,'initscr'):
1553 if hasattr(curses,'initscr'):
1538 use_curses = 1
1554 use_curses = 1
1539 else:
1555 else:
1540 use_curses = 0
1556 use_curses = 0
1541 except ImportError:
1557 except ImportError:
1542 use_curses = 0
1558 use_curses = 0
1543 else:
1559 else:
1544 # curses causes problems on many terminals other than xterm.
1560 # curses causes problems on many terminals other than xterm.
1545 use_curses = 0
1561 use_curses = 0
1546 if use_curses:
1562 if use_curses:
1547 scr = curses.initscr()
1563 scr = curses.initscr()
1548 screen_lines_real,screen_cols = scr.getmaxyx()
1564 screen_lines_real,screen_cols = scr.getmaxyx()
1549 curses.endwin()
1565 curses.endwin()
1550 screen_lines += screen_lines_real
1566 screen_lines += screen_lines_real
1551 #print '***Screen size:',screen_lines_real,'lines x',\
1567 #print '***Screen size:',screen_lines_real,'lines x',\
1552 #screen_cols,'columns.' # dbg
1568 #screen_cols,'columns.' # dbg
1553 else:
1569 else:
1554 screen_lines += screen_lines_def
1570 screen_lines += screen_lines_def
1555
1571
1556 #print 'numlines',numlines,'screenlines',screen_lines # dbg
1572 #print 'numlines',numlines,'screenlines',screen_lines # dbg
1557 if numlines <= screen_lines :
1573 if numlines <= screen_lines :
1558 #print '*** normal print' # dbg
1574 #print '*** normal print' # dbg
1559 print >>Term.cout, str_toprint
1575 print >>Term.cout, str_toprint
1560 else:
1576 else:
1561 # Try to open pager and default to internal one if that fails.
1577 # Try to open pager and default to internal one if that fails.
1562 # All failure modes are tagged as 'retval=1', to match the return
1578 # All failure modes are tagged as 'retval=1', to match the return
1563 # value of a failed system command. If any intermediate attempt
1579 # value of a failed system command. If any intermediate attempt
1564 # sets retval to 1, at the end we resort to our own page_dumb() pager.
1580 # sets retval to 1, at the end we resort to our own page_dumb() pager.
1565 pager_cmd = get_pager_cmd(pager_cmd)
1581 pager_cmd = get_pager_cmd(pager_cmd)
1566 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1582 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1567 if os.name == 'nt':
1583 if os.name == 'nt':
1568 if pager_cmd.startswith('type'):
1584 if pager_cmd.startswith('type'):
1569 # The default WinXP 'type' command is failing on complex strings.
1585 # The default WinXP 'type' command is failing on complex strings.
1570 retval = 1
1586 retval = 1
1571 else:
1587 else:
1572 tmpname = tempfile.mktemp('.txt')
1588 tmpname = tempfile.mktemp('.txt')
1573 tmpfile = file(tmpname,'wt')
1589 tmpfile = file(tmpname,'wt')
1574 tmpfile.write(strng)
1590 tmpfile.write(strng)
1575 tmpfile.close()
1591 tmpfile.close()
1576 cmd = "%s < %s" % (pager_cmd,tmpname)
1592 cmd = "%s < %s" % (pager_cmd,tmpname)
1577 if os.system(cmd):
1593 if os.system(cmd):
1578 retval = 1
1594 retval = 1
1579 else:
1595 else:
1580 retval = None
1596 retval = None
1581 os.remove(tmpname)
1597 os.remove(tmpname)
1582 else:
1598 else:
1583 try:
1599 try:
1584 retval = None
1600 retval = None
1585 # if I use popen4, things hang. No idea why.
1601 # if I use popen4, things hang. No idea why.
1586 #pager,shell_out = os.popen4(pager_cmd)
1602 #pager,shell_out = os.popen4(pager_cmd)
1587 pager = os.popen(pager_cmd,'w')
1603 pager = os.popen(pager_cmd,'w')
1588 pager.write(strng)
1604 pager.write(strng)
1589 pager.close()
1605 pager.close()
1590 retval = pager.close() # success returns None
1606 retval = pager.close() # success returns None
1591 except IOError,msg: # broken pipe when user quits
1607 except IOError,msg: # broken pipe when user quits
1592 if msg.args == (32,'Broken pipe'):
1608 if msg.args == (32,'Broken pipe'):
1593 retval = None
1609 retval = None
1594 else:
1610 else:
1595 retval = 1
1611 retval = 1
1596 except OSError:
1612 except OSError:
1597 # Other strange problems, sometimes seen in Win2k/cygwin
1613 # Other strange problems, sometimes seen in Win2k/cygwin
1598 retval = 1
1614 retval = 1
1599 if retval is not None:
1615 if retval is not None:
1600 page_dumb(strng,screen_lines=screen_lines)
1616 page_dumb(strng,screen_lines=screen_lines)
1601
1617
1602 #----------------------------------------------------------------------------
1618 #----------------------------------------------------------------------------
1603 def page_file(fname,start = 0, pager_cmd = None):
1619 def page_file(fname,start = 0, pager_cmd = None):
1604 """Page a file, using an optional pager command and starting line.
1620 """Page a file, using an optional pager command and starting line.
1605 """
1621 """
1606
1622
1607 pager_cmd = get_pager_cmd(pager_cmd)
1623 pager_cmd = get_pager_cmd(pager_cmd)
1608 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1624 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1609
1625
1610 try:
1626 try:
1611 if os.environ['TERM'] in ['emacs','dumb']:
1627 if os.environ['TERM'] in ['emacs','dumb']:
1612 raise EnvironmentError
1628 raise EnvironmentError
1613 xsys(pager_cmd + ' ' + fname)
1629 xsys(pager_cmd + ' ' + fname)
1614 except:
1630 except:
1615 try:
1631 try:
1616 if start > 0:
1632 if start > 0:
1617 start -= 1
1633 start -= 1
1618 page(open(fname).read(),start)
1634 page(open(fname).read(),start)
1619 except:
1635 except:
1620 print 'Unable to show file',`fname`
1636 print 'Unable to show file',`fname`
1621
1637
1622
1638
1623 #----------------------------------------------------------------------------
1639 #----------------------------------------------------------------------------
1624 def snip_print(str,width = 75,print_full = 0,header = ''):
1640 def snip_print(str,width = 75,print_full = 0,header = ''):
1625 """Print a string snipping the midsection to fit in width.
1641 """Print a string snipping the midsection to fit in width.
1626
1642
1627 print_full: mode control:
1643 print_full: mode control:
1628 - 0: only snip long strings
1644 - 0: only snip long strings
1629 - 1: send to page() directly.
1645 - 1: send to page() directly.
1630 - 2: snip long strings and ask for full length viewing with page()
1646 - 2: snip long strings and ask for full length viewing with page()
1631 Return 1 if snipping was necessary, 0 otherwise."""
1647 Return 1 if snipping was necessary, 0 otherwise."""
1632
1648
1633 if print_full == 1:
1649 if print_full == 1:
1634 page(header+str)
1650 page(header+str)
1635 return 0
1651 return 0
1636
1652
1637 print header,
1653 print header,
1638 if len(str) < width:
1654 if len(str) < width:
1639 print str
1655 print str
1640 snip = 0
1656 snip = 0
1641 else:
1657 else:
1642 whalf = int((width -5)/2)
1658 whalf = int((width -5)/2)
1643 print str[:whalf] + ' <...> ' + str[-whalf:]
1659 print str[:whalf] + ' <...> ' + str[-whalf:]
1644 snip = 1
1660 snip = 1
1645 if snip and print_full == 2:
1661 if snip and print_full == 2:
1646 if raw_input(header+' Snipped. View (y/n)? [N]').lower() == 'y':
1662 if raw_input(header+' Snipped. View (y/n)? [N]').lower() == 'y':
1647 page(str)
1663 page(str)
1648 return snip
1664 return snip
1649
1665
1650 #****************************************************************************
1666 #****************************************************************************
1651 # lists, dicts and structures
1667 # lists, dicts and structures
1652
1668
1653 def belong(candidates,checklist):
1669 def belong(candidates,checklist):
1654 """Check whether a list of items appear in a given list of options.
1670 """Check whether a list of items appear in a given list of options.
1655
1671
1656 Returns a list of 1 and 0, one for each candidate given."""
1672 Returns a list of 1 and 0, one for each candidate given."""
1657
1673
1658 return [x in checklist for x in candidates]
1674 return [x in checklist for x in candidates]
1659
1675
1660 #----------------------------------------------------------------------------
1676 #----------------------------------------------------------------------------
1661 def uniq_stable(elems):
1677 def uniq_stable(elems):
1662 """uniq_stable(elems) -> list
1678 """uniq_stable(elems) -> list
1663
1679
1664 Return from an iterable, a list of all the unique elements in the input,
1680 Return from an iterable, a list of all the unique elements in the input,
1665 but maintaining the order in which they first appear.
1681 but maintaining the order in which they first appear.
1666
1682
1667 A naive solution to this problem which just makes a dictionary with the
1683 A naive solution to this problem which just makes a dictionary with the
1668 elements as keys fails to respect the stability condition, since
1684 elements as keys fails to respect the stability condition, since
1669 dictionaries are unsorted by nature.
1685 dictionaries are unsorted by nature.
1670
1686
1671 Note: All elements in the input must be valid dictionary keys for this
1687 Note: All elements in the input must be valid dictionary keys for this
1672 routine to work, as it internally uses a dictionary for efficiency
1688 routine to work, as it internally uses a dictionary for efficiency
1673 reasons."""
1689 reasons."""
1674
1690
1675 unique = []
1691 unique = []
1676 unique_dict = {}
1692 unique_dict = {}
1677 for nn in elems:
1693 for nn in elems:
1678 if nn not in unique_dict:
1694 if nn not in unique_dict:
1679 unique.append(nn)
1695 unique.append(nn)
1680 unique_dict[nn] = None
1696 unique_dict[nn] = None
1681 return unique
1697 return unique
1682
1698
1683 #----------------------------------------------------------------------------
1699 #----------------------------------------------------------------------------
1684 class NLprinter:
1700 class NLprinter:
1685 """Print an arbitrarily nested list, indicating index numbers.
1701 """Print an arbitrarily nested list, indicating index numbers.
1686
1702
1687 An instance of this class called nlprint is available and callable as a
1703 An instance of this class called nlprint is available and callable as a
1688 function.
1704 function.
1689
1705
1690 nlprint(list,indent=' ',sep=': ') -> prints indenting each level by 'indent'
1706 nlprint(list,indent=' ',sep=': ') -> prints indenting each level by 'indent'
1691 and using 'sep' to separate the index from the value. """
1707 and using 'sep' to separate the index from the value. """
1692
1708
1693 def __init__(self):
1709 def __init__(self):
1694 self.depth = 0
1710 self.depth = 0
1695
1711
1696 def __call__(self,lst,pos='',**kw):
1712 def __call__(self,lst,pos='',**kw):
1697 """Prints the nested list numbering levels."""
1713 """Prints the nested list numbering levels."""
1698 kw.setdefault('indent',' ')
1714 kw.setdefault('indent',' ')
1699 kw.setdefault('sep',': ')
1715 kw.setdefault('sep',': ')
1700 kw.setdefault('start',0)
1716 kw.setdefault('start',0)
1701 kw.setdefault('stop',len(lst))
1717 kw.setdefault('stop',len(lst))
1702 # we need to remove start and stop from kw so they don't propagate
1718 # we need to remove start and stop from kw so they don't propagate
1703 # into a recursive call for a nested list.
1719 # into a recursive call for a nested list.
1704 start = kw['start']; del kw['start']
1720 start = kw['start']; del kw['start']
1705 stop = kw['stop']; del kw['stop']
1721 stop = kw['stop']; del kw['stop']
1706 if self.depth == 0 and 'header' in kw.keys():
1722 if self.depth == 0 and 'header' in kw.keys():
1707 print kw['header']
1723 print kw['header']
1708
1724
1709 for idx in range(start,stop):
1725 for idx in range(start,stop):
1710 elem = lst[idx]
1726 elem = lst[idx]
1711 if type(elem)==type([]):
1727 if type(elem)==type([]):
1712 self.depth += 1
1728 self.depth += 1
1713 self.__call__(elem,itpl('$pos$idx,'),**kw)
1729 self.__call__(elem,itpl('$pos$idx,'),**kw)
1714 self.depth -= 1
1730 self.depth -= 1
1715 else:
1731 else:
1716 printpl(kw['indent']*self.depth+'$pos$idx$kw["sep"]$elem')
1732 printpl(kw['indent']*self.depth+'$pos$idx$kw["sep"]$elem')
1717
1733
1718 nlprint = NLprinter()
1734 nlprint = NLprinter()
1719 #----------------------------------------------------------------------------
1735 #----------------------------------------------------------------------------
1720 def all_belong(candidates,checklist):
1736 def all_belong(candidates,checklist):
1721 """Check whether a list of items ALL appear in a given list of options.
1737 """Check whether a list of items ALL appear in a given list of options.
1722
1738
1723 Returns a single 1 or 0 value."""
1739 Returns a single 1 or 0 value."""
1724
1740
1725 return 1-(0 in [x in checklist for x in candidates])
1741 return 1-(0 in [x in checklist for x in candidates])
1726
1742
1727 #----------------------------------------------------------------------------
1743 #----------------------------------------------------------------------------
1728 def sort_compare(lst1,lst2,inplace = 1):
1744 def sort_compare(lst1,lst2,inplace = 1):
1729 """Sort and compare two lists.
1745 """Sort and compare two lists.
1730
1746
1731 By default it does it in place, thus modifying the lists. Use inplace = 0
1747 By default it does it in place, thus modifying the lists. Use inplace = 0
1732 to avoid that (at the cost of temporary copy creation)."""
1748 to avoid that (at the cost of temporary copy creation)."""
1733 if not inplace:
1749 if not inplace:
1734 lst1 = lst1[:]
1750 lst1 = lst1[:]
1735 lst2 = lst2[:]
1751 lst2 = lst2[:]
1736 lst1.sort(); lst2.sort()
1752 lst1.sort(); lst2.sort()
1737 return lst1 == lst2
1753 return lst1 == lst2
1738
1754
1739 #----------------------------------------------------------------------------
1755 #----------------------------------------------------------------------------
1740 def mkdict(**kwargs):
1756 def mkdict(**kwargs):
1741 """Return a dict from a keyword list.
1757 """Return a dict from a keyword list.
1742
1758
1743 It's just syntactic sugar for making ditcionary creation more convenient:
1759 It's just syntactic sugar for making ditcionary creation more convenient:
1744 # the standard way
1760 # the standard way
1745 >>>data = { 'red' : 1, 'green' : 2, 'blue' : 3 }
1761 >>>data = { 'red' : 1, 'green' : 2, 'blue' : 3 }
1746 # a cleaner way
1762 # a cleaner way
1747 >>>data = dict(red=1, green=2, blue=3)
1763 >>>data = dict(red=1, green=2, blue=3)
1748
1764
1749 If you need more than this, look at the Struct() class."""
1765 If you need more than this, look at the Struct() class."""
1750
1766
1751 return kwargs
1767 return kwargs
1752
1768
1753 #----------------------------------------------------------------------------
1769 #----------------------------------------------------------------------------
1754 def list2dict(lst):
1770 def list2dict(lst):
1755 """Takes a list of (key,value) pairs and turns it into a dict."""
1771 """Takes a list of (key,value) pairs and turns it into a dict."""
1756
1772
1757 dic = {}
1773 dic = {}
1758 for k,v in lst: dic[k] = v
1774 for k,v in lst: dic[k] = v
1759 return dic
1775 return dic
1760
1776
1761 #----------------------------------------------------------------------------
1777 #----------------------------------------------------------------------------
1762 def list2dict2(lst,default=''):
1778 def list2dict2(lst,default=''):
1763 """Takes a list and turns it into a dict.
1779 """Takes a list and turns it into a dict.
1764 Much slower than list2dict, but more versatile. This version can take
1780 Much slower than list2dict, but more versatile. This version can take
1765 lists with sublists of arbitrary length (including sclars)."""
1781 lists with sublists of arbitrary length (including sclars)."""
1766
1782
1767 dic = {}
1783 dic = {}
1768 for elem in lst:
1784 for elem in lst:
1769 if type(elem) in (types.ListType,types.TupleType):
1785 if type(elem) in (types.ListType,types.TupleType):
1770 size = len(elem)
1786 size = len(elem)
1771 if size == 0:
1787 if size == 0:
1772 pass
1788 pass
1773 elif size == 1:
1789 elif size == 1:
1774 dic[elem] = default
1790 dic[elem] = default
1775 else:
1791 else:
1776 k,v = elem[0], elem[1:]
1792 k,v = elem[0], elem[1:]
1777 if len(v) == 1: v = v[0]
1793 if len(v) == 1: v = v[0]
1778 dic[k] = v
1794 dic[k] = v
1779 else:
1795 else:
1780 dic[elem] = default
1796 dic[elem] = default
1781 return dic
1797 return dic
1782
1798
1783 #----------------------------------------------------------------------------
1799 #----------------------------------------------------------------------------
1784 def flatten(seq):
1800 def flatten(seq):
1785 """Flatten a list of lists (NOT recursive, only works for 2d lists)."""
1801 """Flatten a list of lists (NOT recursive, only works for 2d lists)."""
1786
1802
1787 return [x for subseq in seq for x in subseq]
1803 return [x for subseq in seq for x in subseq]
1788
1804
1789 #----------------------------------------------------------------------------
1805 #----------------------------------------------------------------------------
1790 def get_slice(seq,start=0,stop=None,step=1):
1806 def get_slice(seq,start=0,stop=None,step=1):
1791 """Get a slice of a sequence with variable step. Specify start,stop,step."""
1807 """Get a slice of a sequence with variable step. Specify start,stop,step."""
1792 if stop == None:
1808 if stop == None:
1793 stop = len(seq)
1809 stop = len(seq)
1794 item = lambda i: seq[i]
1810 item = lambda i: seq[i]
1795 return map(item,xrange(start,stop,step))
1811 return map(item,xrange(start,stop,step))
1796
1812
1797 #----------------------------------------------------------------------------
1813 #----------------------------------------------------------------------------
1798 def chop(seq,size):
1814 def chop(seq,size):
1799 """Chop a sequence into chunks of the given size."""
1815 """Chop a sequence into chunks of the given size."""
1800 chunk = lambda i: seq[i:i+size]
1816 chunk = lambda i: seq[i:i+size]
1801 return map(chunk,xrange(0,len(seq),size))
1817 return map(chunk,xrange(0,len(seq),size))
1802
1818
1803 #----------------------------------------------------------------------------
1819 #----------------------------------------------------------------------------
1804 # with is a keyword as of python 2.5, so this function is renamed to withobj
1820 # with is a keyword as of python 2.5, so this function is renamed to withobj
1805 # from its old 'with' name.
1821 # from its old 'with' name.
1806 def with_obj(object, **args):
1822 def with_obj(object, **args):
1807 """Set multiple attributes for an object, similar to Pascal's with.
1823 """Set multiple attributes for an object, similar to Pascal's with.
1808
1824
1809 Example:
1825 Example:
1810 with_obj(jim,
1826 with_obj(jim,
1811 born = 1960,
1827 born = 1960,
1812 haircolour = 'Brown',
1828 haircolour = 'Brown',
1813 eyecolour = 'Green')
1829 eyecolour = 'Green')
1814
1830
1815 Credit: Greg Ewing, in
1831 Credit: Greg Ewing, in
1816 http://mail.python.org/pipermail/python-list/2001-May/040703.html.
1832 http://mail.python.org/pipermail/python-list/2001-May/040703.html.
1817
1833
1818 NOTE: up until IPython 0.7.2, this was called simply 'with', but 'with'
1834 NOTE: up until IPython 0.7.2, this was called simply 'with', but 'with'
1819 has become a keyword for Python 2.5, so we had to rename it."""
1835 has become a keyword for Python 2.5, so we had to rename it."""
1820
1836
1821 object.__dict__.update(args)
1837 object.__dict__.update(args)
1822
1838
1823 #----------------------------------------------------------------------------
1839 #----------------------------------------------------------------------------
1824 def setattr_list(obj,alist,nspace = None):
1840 def setattr_list(obj,alist,nspace = None):
1825 """Set a list of attributes for an object taken from a namespace.
1841 """Set a list of attributes for an object taken from a namespace.
1826
1842
1827 setattr_list(obj,alist,nspace) -> sets in obj all the attributes listed in
1843 setattr_list(obj,alist,nspace) -> sets in obj all the attributes listed in
1828 alist with their values taken from nspace, which must be a dict (something
1844 alist with their values taken from nspace, which must be a dict (something
1829 like locals() will often do) If nspace isn't given, locals() of the
1845 like locals() will often do) If nspace isn't given, locals() of the
1830 *caller* is used, so in most cases you can omit it.
1846 *caller* is used, so in most cases you can omit it.
1831
1847
1832 Note that alist can be given as a string, which will be automatically
1848 Note that alist can be given as a string, which will be automatically
1833 split into a list on whitespace. If given as a list, it must be a list of
1849 split into a list on whitespace. If given as a list, it must be a list of
1834 *strings* (the variable names themselves), not of variables."""
1850 *strings* (the variable names themselves), not of variables."""
1835
1851
1836 # this grabs the local variables from the *previous* call frame -- that is
1852 # this grabs the local variables from the *previous* call frame -- that is
1837 # the locals from the function that called setattr_list().
1853 # the locals from the function that called setattr_list().
1838 # - snipped from weave.inline()
1854 # - snipped from weave.inline()
1839 if nspace is None:
1855 if nspace is None:
1840 call_frame = sys._getframe().f_back
1856 call_frame = sys._getframe().f_back
1841 nspace = call_frame.f_locals
1857 nspace = call_frame.f_locals
1842
1858
1843 if type(alist) in StringTypes:
1859 if type(alist) in StringTypes:
1844 alist = alist.split()
1860 alist = alist.split()
1845 for attr in alist:
1861 for attr in alist:
1846 val = eval(attr,nspace)
1862 val = eval(attr,nspace)
1847 setattr(obj,attr,val)
1863 setattr(obj,attr,val)
1848
1864
1849 #----------------------------------------------------------------------------
1865 #----------------------------------------------------------------------------
1850 def getattr_list(obj,alist,*args):
1866 def getattr_list(obj,alist,*args):
1851 """getattr_list(obj,alist[, default]) -> attribute list.
1867 """getattr_list(obj,alist[, default]) -> attribute list.
1852
1868
1853 Get a list of named attributes for an object. When a default argument is
1869 Get a list of named attributes for an object. When a default argument is
1854 given, it is returned when the attribute doesn't exist; without it, an
1870 given, it is returned when the attribute doesn't exist; without it, an
1855 exception is raised in that case.
1871 exception is raised in that case.
1856
1872
1857 Note that alist can be given as a string, which will be automatically
1873 Note that alist can be given as a string, which will be automatically
1858 split into a list on whitespace. If given as a list, it must be a list of
1874 split into a list on whitespace. If given as a list, it must be a list of
1859 *strings* (the variable names themselves), not of variables."""
1875 *strings* (the variable names themselves), not of variables."""
1860
1876
1861 if type(alist) in StringTypes:
1877 if type(alist) in StringTypes:
1862 alist = alist.split()
1878 alist = alist.split()
1863 if args:
1879 if args:
1864 if len(args)==1:
1880 if len(args)==1:
1865 default = args[0]
1881 default = args[0]
1866 return map(lambda attr: getattr(obj,attr,default),alist)
1882 return map(lambda attr: getattr(obj,attr,default),alist)
1867 else:
1883 else:
1868 raise ValueError,'getattr_list() takes only one optional argument'
1884 raise ValueError,'getattr_list() takes only one optional argument'
1869 else:
1885 else:
1870 return map(lambda attr: getattr(obj,attr),alist)
1886 return map(lambda attr: getattr(obj,attr),alist)
1871
1887
1872 #----------------------------------------------------------------------------
1888 #----------------------------------------------------------------------------
1873 def map_method(method,object_list,*argseq,**kw):
1889 def map_method(method,object_list,*argseq,**kw):
1874 """map_method(method,object_list,*args,**kw) -> list
1890 """map_method(method,object_list,*args,**kw) -> list
1875
1891
1876 Return a list of the results of applying the methods to the items of the
1892 Return a list of the results of applying the methods to the items of the
1877 argument sequence(s). If more than one sequence is given, the method is
1893 argument sequence(s). If more than one sequence is given, the method is
1878 called with an argument list consisting of the corresponding item of each
1894 called with an argument list consisting of the corresponding item of each
1879 sequence. All sequences must be of the same length.
1895 sequence. All sequences must be of the same length.
1880
1896
1881 Keyword arguments are passed verbatim to all objects called.
1897 Keyword arguments are passed verbatim to all objects called.
1882
1898
1883 This is Python code, so it's not nearly as fast as the builtin map()."""
1899 This is Python code, so it's not nearly as fast as the builtin map()."""
1884
1900
1885 out_list = []
1901 out_list = []
1886 idx = 0
1902 idx = 0
1887 for object in object_list:
1903 for object in object_list:
1888 try:
1904 try:
1889 handler = getattr(object, method)
1905 handler = getattr(object, method)
1890 except AttributeError:
1906 except AttributeError:
1891 out_list.append(None)
1907 out_list.append(None)
1892 else:
1908 else:
1893 if argseq:
1909 if argseq:
1894 args = map(lambda lst:lst[idx],argseq)
1910 args = map(lambda lst:lst[idx],argseq)
1895 #print 'ob',object,'hand',handler,'ar',args # dbg
1911 #print 'ob',object,'hand',handler,'ar',args # dbg
1896 out_list.append(handler(args,**kw))
1912 out_list.append(handler(args,**kw))
1897 else:
1913 else:
1898 out_list.append(handler(**kw))
1914 out_list.append(handler(**kw))
1899 idx += 1
1915 idx += 1
1900 return out_list
1916 return out_list
1901
1917
1902 #----------------------------------------------------------------------------
1918 #----------------------------------------------------------------------------
1903 def get_class_members(cls):
1919 def get_class_members(cls):
1904 ret = dir(cls)
1920 ret = dir(cls)
1905 if hasattr(cls,'__bases__'):
1921 if hasattr(cls,'__bases__'):
1906 for base in cls.__bases__:
1922 for base in cls.__bases__:
1907 ret.extend(get_class_members(base))
1923 ret.extend(get_class_members(base))
1908 return ret
1924 return ret
1909
1925
1910 #----------------------------------------------------------------------------
1926 #----------------------------------------------------------------------------
1911 def dir2(obj):
1927 def dir2(obj):
1912 """dir2(obj) -> list of strings
1928 """dir2(obj) -> list of strings
1913
1929
1914 Extended version of the Python builtin dir(), which does a few extra
1930 Extended version of the Python builtin dir(), which does a few extra
1915 checks, and supports common objects with unusual internals that confuse
1931 checks, and supports common objects with unusual internals that confuse
1916 dir(), such as Traits and PyCrust.
1932 dir(), such as Traits and PyCrust.
1917
1933
1918 This version is guaranteed to return only a list of true strings, whereas
1934 This version is guaranteed to return only a list of true strings, whereas
1919 dir() returns anything that objects inject into themselves, even if they
1935 dir() returns anything that objects inject into themselves, even if they
1920 are later not really valid for attribute access (many extension libraries
1936 are later not really valid for attribute access (many extension libraries
1921 have such bugs).
1937 have such bugs).
1922 """
1938 """
1923
1939
1924 # Start building the attribute list via dir(), and then complete it
1940 # Start building the attribute list via dir(), and then complete it
1925 # with a few extra special-purpose calls.
1941 # with a few extra special-purpose calls.
1926 words = dir(obj)
1942 words = dir(obj)
1927
1943
1928 if hasattr(obj,'__class__'):
1944 if hasattr(obj,'__class__'):
1929 words.append('__class__')
1945 words.append('__class__')
1930 words.extend(get_class_members(obj.__class__))
1946 words.extend(get_class_members(obj.__class__))
1931 #if '__base__' in words: 1/0
1947 #if '__base__' in words: 1/0
1932
1948
1933 # Some libraries (such as traits) may introduce duplicates, we want to
1949 # Some libraries (such as traits) may introduce duplicates, we want to
1934 # track and clean this up if it happens
1950 # track and clean this up if it happens
1935 may_have_dupes = False
1951 may_have_dupes = False
1936
1952
1937 # this is the 'dir' function for objects with Enthought's traits
1953 # this is the 'dir' function for objects with Enthought's traits
1938 if hasattr(obj, 'trait_names'):
1954 if hasattr(obj, 'trait_names'):
1939 try:
1955 try:
1940 words.extend(obj.trait_names())
1956 words.extend(obj.trait_names())
1941 may_have_dupes = True
1957 may_have_dupes = True
1942 except TypeError:
1958 except TypeError:
1943 # This will happen if `obj` is a class and not an instance.
1959 # This will happen if `obj` is a class and not an instance.
1944 pass
1960 pass
1945
1961
1946 # Support for PyCrust-style _getAttributeNames magic method.
1962 # Support for PyCrust-style _getAttributeNames magic method.
1947 if hasattr(obj, '_getAttributeNames'):
1963 if hasattr(obj, '_getAttributeNames'):
1948 try:
1964 try:
1949 words.extend(obj._getAttributeNames())
1965 words.extend(obj._getAttributeNames())
1950 may_have_dupes = True
1966 may_have_dupes = True
1951 except TypeError:
1967 except TypeError:
1952 # `obj` is a class and not an instance. Ignore
1968 # `obj` is a class and not an instance. Ignore
1953 # this error.
1969 # this error.
1954 pass
1970 pass
1955
1971
1956 if may_have_dupes:
1972 if may_have_dupes:
1957 # eliminate possible duplicates, as some traits may also
1973 # eliminate possible duplicates, as some traits may also
1958 # appear as normal attributes in the dir() call.
1974 # appear as normal attributes in the dir() call.
1959 words = list(set(words))
1975 words = list(set(words))
1960 words.sort()
1976 words.sort()
1961
1977
1962 # filter out non-string attributes which may be stuffed by dir() calls
1978 # filter out non-string attributes which may be stuffed by dir() calls
1963 # and poor coding in third-party modules
1979 # and poor coding in third-party modules
1964 return [w for w in words if isinstance(w, basestring)]
1980 return [w for w in words if isinstance(w, basestring)]
1965
1981
1966 #----------------------------------------------------------------------------
1982 #----------------------------------------------------------------------------
1967 def import_fail_info(mod_name,fns=None):
1983 def import_fail_info(mod_name,fns=None):
1968 """Inform load failure for a module."""
1984 """Inform load failure for a module."""
1969
1985
1970 if fns == None:
1986 if fns == None:
1971 warn("Loading of %s failed.\n" % (mod_name,))
1987 warn("Loading of %s failed.\n" % (mod_name,))
1972 else:
1988 else:
1973 warn("Loading of %s from %s failed.\n" % (fns,mod_name))
1989 warn("Loading of %s from %s failed.\n" % (fns,mod_name))
1974
1990
1975 #----------------------------------------------------------------------------
1991 #----------------------------------------------------------------------------
1976 # Proposed popitem() extension, written as a method
1992 # Proposed popitem() extension, written as a method
1977
1993
1978
1994
1979 class NotGiven: pass
1995 class NotGiven: pass
1980
1996
1981 def popkey(dct,key,default=NotGiven):
1997 def popkey(dct,key,default=NotGiven):
1982 """Return dct[key] and delete dct[key].
1998 """Return dct[key] and delete dct[key].
1983
1999
1984 If default is given, return it if dct[key] doesn't exist, otherwise raise
2000 If default is given, return it if dct[key] doesn't exist, otherwise raise
1985 KeyError. """
2001 KeyError. """
1986
2002
1987 try:
2003 try:
1988 val = dct[key]
2004 val = dct[key]
1989 except KeyError:
2005 except KeyError:
1990 if default is NotGiven:
2006 if default is NotGiven:
1991 raise
2007 raise
1992 else:
2008 else:
1993 return default
2009 return default
1994 else:
2010 else:
1995 del dct[key]
2011 del dct[key]
1996 return val
2012 return val
1997
2013
1998 def wrap_deprecated(func, suggest = '<nothing>'):
2014 def wrap_deprecated(func, suggest = '<nothing>'):
1999 def newFunc(*args, **kwargs):
2015 def newFunc(*args, **kwargs):
2000 warnings.warn("Call to deprecated function %s, use %s instead" %
2016 warnings.warn("Call to deprecated function %s, use %s instead" %
2001 ( func.__name__, suggest),
2017 ( func.__name__, suggest),
2002 category=DeprecationWarning,
2018 category=DeprecationWarning,
2003 stacklevel = 2)
2019 stacklevel = 2)
2004 return func(*args, **kwargs)
2020 return func(*args, **kwargs)
2005 return newFunc
2021 return newFunc
2006
2022
2007 #*************************** end of file <genutils.py> **********************
2023 #*************************** end of file <genutils.py> **********************
2008
2024
@@ -1,7571 +1,7575
1 2008-04-15 Ville Vainio <vivainio@gmail.com>
2
3 * genutils.py: SList.grep supports 'field' argument
4
1 2008-04-09 Ville Vainio <vivainio@gmail.com>
5 2008-04-09 Ville Vainio <vivainio@gmail.com>
2
6
3 * deep_reload.py: do not crash on from __future__ import
7 * deep_reload.py: do not crash on from __future__ import
4 absolute_import. Close #244.
8 absolute_import. Close #244.
5
9
6 2008-04-02 Ville Vainio <vivainio@gmail.com>
10 2008-04-02 Ville Vainio <vivainio@gmail.com>
7
11
8 * ipy_winpdb.py: New extension for winpdb integration. %wdb
12 * ipy_winpdb.py: New extension for winpdb integration. %wdb
9 test.py is winpdb equivalent of %run -d test.py. winpdb is a
13 test.py is winpdb equivalent of %run -d test.py. winpdb is a
10 crossplatform remote GUI debugger based on wxpython.
14 crossplatform remote GUI debugger based on wxpython.
11
15
12 2008-03-29 Ville Vainio <vivainio@gmail.com>
16 2008-03-29 Ville Vainio <vivainio@gmail.com>
13
17
14 * ipython.rst, do_sphinx.py: New documentation base, based on
18 * ipython.rst, do_sphinx.py: New documentation base, based on
15 reStucturedText and Sphinx (html/pdf generation). The old Lyx
19 reStucturedText and Sphinx (html/pdf generation). The old Lyx
16 based documentation will not be updated anymore.
20 based documentation will not be updated anymore.
17
21
18 * jobctrl.py: Use shell in Popen for 'start' command (in windows).
22 * jobctrl.py: Use shell in Popen for 'start' command (in windows).
19
23
20 2008-03-24 Ville Vainio <vivainio@gmail.com>
24 2008-03-24 Ville Vainio <vivainio@gmail.com>
21
25
22 * ipython.rst, do_sphinx.py: New documentation base, based on
26 * ipython.rst, do_sphinx.py: New documentation base, based on
23 reStucturedText and Sphinx (html/pdf generation). The old Lyx
27 reStucturedText and Sphinx (html/pdf generation). The old Lyx
24 based documentation will not be updated anymore.
28 based documentation will not be updated anymore.
25
29
26 ipython.rst has up to date documentation on matters that were not
30 ipython.rst has up to date documentation on matters that were not
27 documented at all, and it also removes various
31 documented at all, and it also removes various
28 misdocumented/deprecated features.
32 misdocumented/deprecated features.
29
33
30 2008-03-22 Ville Vainio <vivainio@gmail.com>
34 2008-03-22 Ville Vainio <vivainio@gmail.com>
31
35
32 * Shell.py: Merge mtexp branch:
36 * Shell.py: Merge mtexp branch:
33 https://code.launchpad.net/~ipython/ipython/mtexp
37 https://code.launchpad.net/~ipython/ipython/mtexp
34
38
35 Privides simpler and more robust MTInteractiveShell that won't
39 Privides simpler and more robust MTInteractiveShell that won't
36 deadlock, even when the worker thread (GUI) stops doing runcode()
40 deadlock, even when the worker thread (GUI) stops doing runcode()
37 regularly. r71.
41 regularly. r71.
38
42
39 2008-03-20 Ville Vainio <vivainio@gmail.com>
43 2008-03-20 Ville Vainio <vivainio@gmail.com>
40
44
41 * twshell.py: New shell that runs IPython code in Twisted reactor.
45 * twshell.py: New shell that runs IPython code in Twisted reactor.
42 Launch by doing ipython -twisted. r67.
46 Launch by doing ipython -twisted. r67.
43
47
44 2008-03-19 Ville Vainio <vivainio@gmail.com>
48 2008-03-19 Ville Vainio <vivainio@gmail.com>
45
49
46 * Magic.py: %rehashx works correctly when shadowed system commands
50 * Magic.py: %rehashx works correctly when shadowed system commands
47 have upper case characters (e.g. Print.exe). r64.
51 have upper case characters (e.g. Print.exe). r64.
48
52
49 * ipy_bzr.py, ipy_app_completers.py: new bzr completer that also
53 * ipy_bzr.py, ipy_app_completers.py: new bzr completer that also
50 knows options to commands, based on bzrtools. Uses bzrlib
54 knows options to commands, based on bzrtools. Uses bzrlib
51 directly. r66.
55 directly. r66.
52
56
53 2008-03-16 Ville Vainio <vivainio@gmail.com>
57 2008-03-16 Ville Vainio <vivainio@gmail.com>
54
58
55 * make_tarball.py: Fixed for bzr.
59 * make_tarball.py: Fixed for bzr.
56
60
57 * ipapi.py: Better _ip.runlines() script cleanup. r56,r79.
61 * ipapi.py: Better _ip.runlines() script cleanup. r56,r79.
58
62
59 * ipy_vimserver.py, ipy.vim: New extension for vim server mode,
63 * ipy_vimserver.py, ipy.vim: New extension for vim server mode,
60 by Erich Heine.
64 by Erich Heine.
61
65
62 2008-03-12 Ville Vainio <vivainio@gmail.com>
66 2008-03-12 Ville Vainio <vivainio@gmail.com>
63
67
64 * ipmaker.py: Force (reload?) import of ipy_user_conf and
68 * ipmaker.py: Force (reload?) import of ipy_user_conf and
65 ipy_profile_foo, so that embedded instances can be relaunched and
69 ipy_profile_foo, so that embedded instances can be relaunched and
66 configuration is still done. r50
70 configuration is still done. r50
67
71
68 * ipapi.py, test_embed.py: Allow specifying shell class in
72 * ipapi.py, test_embed.py: Allow specifying shell class in
69 launch_new_instance & make_new instance. Use this in
73 launch_new_instance & make_new instance. Use this in
70 test_embed.py. r51.
74 test_embed.py. r51.
71
75
72 test_embed.py is also a good and simple demo of embedding IPython.
76 test_embed.py is also a good and simple demo of embedding IPython.
73
77
74
78
75 2008-03-10 Ville Vainio <vivainio@gmail.com>
79 2008-03-10 Ville Vainio <vivainio@gmail.com>
76
80
77 * tool/update_revnum.py: Change to bzr revisioning scheme in
81 * tool/update_revnum.py: Change to bzr revisioning scheme in
78 revision numbers.
82 revision numbers.
79
83
80 * Shell.py: Threading improvements:
84 * Shell.py: Threading improvements:
81
85
82 In multithreaded shells, do not hang on macros and o.autoexec
86 In multithreaded shells, do not hang on macros and o.autoexec
83 commands (or anything executed with _ip.runlines()) anymore. Allow
87 commands (or anything executed with _ip.runlines()) anymore. Allow
84 recursive execution of IPython code in
88 recursive execution of IPython code in
85 MTInteractiveShell.runsource by checking if we are already in
89 MTInteractiveShell.runsource by checking if we are already in
86 worker thread, and execute code directly if we are. r48.
90 worker thread, and execute code directly if we are. r48.
87
91
88 MTInteractiveShell.runsource: execute code directly if worker
92 MTInteractiveShell.runsource: execute code directly if worker
89 thread is not running yet (this is the case in config files). r49.
93 thread is not running yet (this is the case in config files). r49.
90
94
91 2008-03-09 Ville Vainio <vivainio@gmail.com>
95 2008-03-09 Ville Vainio <vivainio@gmail.com>
92
96
93 * ipy_profile_sh.py: You can now use $LA or LA() to refer to last
97 * ipy_profile_sh.py: You can now use $LA or LA() to refer to last
94 argument of previous command in sh profile. Similar to bash '!$'.
98 argument of previous command in sh profile. Similar to bash '!$'.
95 LA(3) or $LA(3) stands for last argument of input history command
99 LA(3) or $LA(3) stands for last argument of input history command
96 3.
100 3.
97
101
98 * Shell.py: -pylab names don't clutter %whos listing.
102 * Shell.py: -pylab names don't clutter %whos listing.
99
103
100 2008-03-07 Ville Vainio <vivainio@gmail.com>
104 2008-03-07 Ville Vainio <vivainio@gmail.com>
101
105
102 * ipy_autoreload.py: new extension (by Pauli Virtanen) for
106 * ipy_autoreload.py: new extension (by Pauli Virtanen) for
103 autoreloading modules; try %autoreload and %aimport. Close #154.
107 autoreloading modules; try %autoreload and %aimport. Close #154.
104 Uses the new pre_runcode_hook.
108 Uses the new pre_runcode_hook.
105
109
106 2008-02-24 Ville Vainio <vivainio@gmail.com>
110 2008-02-24 Ville Vainio <vivainio@gmail.com>
107
111
108 * platutils_posix.py: freeze_term_title works
112 * platutils_posix.py: freeze_term_title works
109
113
110 2008-02-21 Ville Vainio <vivainio@gmail.com>
114 2008-02-21 Ville Vainio <vivainio@gmail.com>
111
115
112 * Magic.py: %quickref does not crash with empty docstring
116 * Magic.py: %quickref does not crash with empty docstring
113
117
114 2008-02-20 Ville Vainio <vivainio@gmail.com>
118 2008-02-20 Ville Vainio <vivainio@gmail.com>
115
119
116 * completer.py: do not treat [](){} as protectable chars anymore,
120 * completer.py: do not treat [](){} as protectable chars anymore,
117 close #233.
121 close #233.
118
122
119 * completer.py: do not treat [](){} as protectable chars anymore
123 * completer.py: do not treat [](){} as protectable chars anymore
120
124
121 * magic.py, test_cpaste.py: Allow different prefix for pasting
125 * magic.py, test_cpaste.py: Allow different prefix for pasting
122 from email
126 from email
123
127
124 2008-02-17 Ville Vainio <vivainio@gmail.com>
128 2008-02-17 Ville Vainio <vivainio@gmail.com>
125
129
126 * Switched over to Launchpad/bzr as primary VCS.
130 * Switched over to Launchpad/bzr as primary VCS.
127
131
128 2008-02-14 Ville Vainio <vivainio@gmail.com>
132 2008-02-14 Ville Vainio <vivainio@gmail.com>
129
133
130 * ipapi.py: _ip.runlines() is now much more liberal about
134 * ipapi.py: _ip.runlines() is now much more liberal about
131 indentation - it cleans up the scripts it gets
135 indentation - it cleans up the scripts it gets
132
136
133 2008-02-14 Ville Vainio <vivainio@gmail.com>
137 2008-02-14 Ville Vainio <vivainio@gmail.com>
134
138
135 * Extensions/ipy_leo.py: created 'ILeo' IPython-Leo bridge.
139 * Extensions/ipy_leo.py: created 'ILeo' IPython-Leo bridge.
136 Changes to it (later on) are too numerous to list in ChangeLog
140 Changes to it (later on) are too numerous to list in ChangeLog
137 until it stabilizes
141 until it stabilizes
138
142
139 2008-02-07 Darren Dale <darren.dale@cornell.edu>
143 2008-02-07 Darren Dale <darren.dale@cornell.edu>
140
144
141 * IPython/Shell.py: Call QtCore.pyqtRemoveInputHook() when creating
145 * IPython/Shell.py: Call QtCore.pyqtRemoveInputHook() when creating
142 an IPShellQt4. PyQt4-4.2.1 and later uses PyOS_InputHook to improve
146 an IPShellQt4. PyQt4-4.2.1 and later uses PyOS_InputHook to improve
143 interaction in the interpreter (like Tkinter does), but it seems to
147 interaction in the interpreter (like Tkinter does), but it seems to
144 partially interfere with the IPython implementation and exec_()
148 partially interfere with the IPython implementation and exec_()
145 still seems to block. So we disable the PyQt implementation and
149 still seems to block. So we disable the PyQt implementation and
146 stick with the IPython one for now.
150 stick with the IPython one for now.
147
151
148 2008-02-02 Walter Doerwald <walter@livinglogic.de>
152 2008-02-02 Walter Doerwald <walter@livinglogic.de>
149
153
150 * ipipe.py: A new ipipe table has been added: ialias produces all
154 * ipipe.py: A new ipipe table has been added: ialias produces all
151 entries from IPython's alias table.
155 entries from IPython's alias table.
152
156
153 2008-02-01 Fernando Perez <Fernando.Perez@colorado.edu>
157 2008-02-01 Fernando Perez <Fernando.Perez@colorado.edu>
154
158
155 * IPython/Shell.py (MTInteractiveShell.runcode): Improve handling
159 * IPython/Shell.py (MTInteractiveShell.runcode): Improve handling
156 of KBINT in threaded shells. After code provided by Marc in #212.
160 of KBINT in threaded shells. After code provided by Marc in #212.
157
161
158 2008-01-30 Fernando Perez <Fernando.Perez@colorado.edu>
162 2008-01-30 Fernando Perez <Fernando.Perez@colorado.edu>
159
163
160 * IPython/Shell.py (MTInteractiveShell.__init__): Fixed deadlock
164 * IPython/Shell.py (MTInteractiveShell.__init__): Fixed deadlock
161 that could occur due to a race condition in threaded shells.
165 that could occur due to a race condition in threaded shells.
162 Thanks to code provided by Marc, as #210.
166 Thanks to code provided by Marc, as #210.
163
167
164 2008-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
168 2008-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
165
169
166 * IPython/Magic.py (magic_doctest_mode): respect the user's
170 * IPython/Magic.py (magic_doctest_mode): respect the user's
167 settings for input separators rather than overriding them. After
171 settings for input separators rather than overriding them. After
168 a report by Jeff Kowalczyk <jtk-AT-yahoo.com>
172 a report by Jeff Kowalczyk <jtk-AT-yahoo.com>
169
173
170 * IPython/history.py (magic_history): Add support for declaring an
174 * IPython/history.py (magic_history): Add support for declaring an
171 output file directly from the history command.
175 output file directly from the history command.
172
176
173 2008-01-21 Walter Doerwald <walter@livinglogic.de>
177 2008-01-21 Walter Doerwald <walter@livinglogic.de>
174
178
175 * ipipe.py: Register ipipe's displayhooks via the generic function
179 * ipipe.py: Register ipipe's displayhooks via the generic function
176 generics.result_display() instead of using ipapi.set_hook().
180 generics.result_display() instead of using ipapi.set_hook().
177
181
178 2008-01-19 Walter Doerwald <walter@livinglogic.de>
182 2008-01-19 Walter Doerwald <walter@livinglogic.de>
179
183
180 * ibrowse.py, igrid.py, ipipe.py:
184 * ibrowse.py, igrid.py, ipipe.py:
181 The input object can now be passed to the constructor of the display classes.
185 The input object can now be passed to the constructor of the display classes.
182 This makes it possible to use them with objects that implement __or__.
186 This makes it possible to use them with objects that implement __or__.
183 Use this constructor in the displayhook instead of piping.
187 Use this constructor in the displayhook instead of piping.
184
188
185 * ipipe.py: Importing astyle.py is done as late as possible to
189 * ipipe.py: Importing astyle.py is done as late as possible to
186 avoid problems with circular imports.
190 avoid problems with circular imports.
187
191
188 2008-01-19 Ville Vainio <vivainio@gmail.com>
192 2008-01-19 Ville Vainio <vivainio@gmail.com>
189
193
190 * hooks.py, iplib.py: Added 'shell_hook' to customize how
194 * hooks.py, iplib.py: Added 'shell_hook' to customize how
191 IPython calls shell.
195 IPython calls shell.
192
196
193 * hooks.py, iplib.py: Added 'show_in_pager' hook to specify
197 * hooks.py, iplib.py: Added 'show_in_pager' hook to specify
194 how IPython pages text (%page, %pycat, %pdoc etc.)
198 how IPython pages text (%page, %pycat, %pdoc etc.)
195
199
196 * Extensions/jobctrl.py: Use shell_hook. New magics: '%tasks'
200 * Extensions/jobctrl.py: Use shell_hook. New magics: '%tasks'
197 and '%kill' to kill hanging processes that won't obey ctrl+C.
201 and '%kill' to kill hanging processes that won't obey ctrl+C.
198
202
199 2008-01-16 Ville Vainio <vivainio@gmail.com>
203 2008-01-16 Ville Vainio <vivainio@gmail.com>
200
204
201 * ipy_completers.py: pyw extension support for %run completer.
205 * ipy_completers.py: pyw extension support for %run completer.
202
206
203 2008-01-11 Ville Vainio <vivainio@gmail.com>
207 2008-01-11 Ville Vainio <vivainio@gmail.com>
204
208
205 * iplib.py, ipmaker.py: new rc option - autoexec. It's a list
209 * iplib.py, ipmaker.py: new rc option - autoexec. It's a list
206 of ipython commands to be run when IPython has started up
210 of ipython commands to be run when IPython has started up
207 (just before running the scripts and -c arg on command line).
211 (just before running the scripts and -c arg on command line).
208
212
209 * ipy_user_conf.py: Added an example on how to change term
213 * ipy_user_conf.py: Added an example on how to change term
210 colors in config file (through using autoexec).
214 colors in config file (through using autoexec).
211
215
212 * completer.py, test_completer.py: Ability to specify custom
216 * completer.py, test_completer.py: Ability to specify custom
213 get_endidx to replace readline.get_endidx. For emacs users.
217 get_endidx to replace readline.get_endidx. For emacs users.
214
218
215 2008-01-10 Ville Vainio <vivainio@gmail.com>
219 2008-01-10 Ville Vainio <vivainio@gmail.com>
216
220
217 * Prompts.py (set_p_str): do not crash on illegal prompt strings
221 * Prompts.py (set_p_str): do not crash on illegal prompt strings
218
222
219 2008-01-08 Ville Vainio <vivainio@gmail.com>
223 2008-01-08 Ville Vainio <vivainio@gmail.com>
220
224
221 * '%macro -r' (raw mode) is now default in sh profile.
225 * '%macro -r' (raw mode) is now default in sh profile.
222
226
223 2007-12-31 Ville Vainio <vivainio@gmail.com>
227 2007-12-31 Ville Vainio <vivainio@gmail.com>
224
228
225 * completer.py: custom completer matching is now case sensitive
229 * completer.py: custom completer matching is now case sensitive
226 (#207).
230 (#207).
227
231
228 * ultraTB.py, iplib.py: Add some KeyboardInterrupt catching in
232 * ultraTB.py, iplib.py: Add some KeyboardInterrupt catching in
229 an attempt to prevent occasional crashes.
233 an attempt to prevent occasional crashes.
230
234
231 * CrashHandler.py: Crash log dump now asks user to press enter
235 * CrashHandler.py: Crash log dump now asks user to press enter
232 before exiting.
236 before exiting.
233
237
234 * Store _ip in user_ns instead of __builtin__, enabling safer
238 * Store _ip in user_ns instead of __builtin__, enabling safer
235 coexistence of multiple IPython instances in the same python
239 coexistence of multiple IPython instances in the same python
236 interpreter (#197).
240 interpreter (#197).
237
241
238 * Debugger.py, ipmaker.py: Need to add '-pydb' command line
242 * Debugger.py, ipmaker.py: Need to add '-pydb' command line
239 switch to enable pydb in post-mortem debugging and %run -d.
243 switch to enable pydb in post-mortem debugging and %run -d.
240
244
241 2007-12-28 Ville Vainio <vivainio@gmail.com>
245 2007-12-28 Ville Vainio <vivainio@gmail.com>
242
246
243 * ipy_server.py: TCP socket server for "remote control" of an IPython
247 * ipy_server.py: TCP socket server for "remote control" of an IPython
244 instance.
248 instance.
245
249
246 * Debugger.py: Change to PSF license
250 * Debugger.py: Change to PSF license
247
251
248 * simplegeneric.py: Add license & author notes.
252 * simplegeneric.py: Add license & author notes.
249
253
250 * ipy_fsops.py: Added PathObj and FileObj, an object-oriented way
254 * ipy_fsops.py: Added PathObj and FileObj, an object-oriented way
251 to navigate file system with a custom completer. Run
255 to navigate file system with a custom completer. Run
252 ipy_fsops.test_pathobj() to play with it.
256 ipy_fsops.test_pathobj() to play with it.
253
257
254 2007-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
258 2007-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
255
259
256 * IPython/dtutils.py: Add utilities for interactively running
260 * IPython/dtutils.py: Add utilities for interactively running
257 doctests. Still needs work to more easily handle the namespace of
261 doctests. Still needs work to more easily handle the namespace of
258 the package one may be working on, but the basics are in place.
262 the package one may be working on, but the basics are in place.
259
263
260 2007-12-27 Ville Vainio <vivainio@gmail.com>
264 2007-12-27 Ville Vainio <vivainio@gmail.com>
261
265
262 * ipy_completers.py: Applied arno's patch to get proper list of
266 * ipy_completers.py: Applied arno's patch to get proper list of
263 packages in import completer. Closes #196.
267 packages in import completer. Closes #196.
264
268
265 2007-12-20 Ville Vainio <vivainio@gmail.com>
269 2007-12-20 Ville Vainio <vivainio@gmail.com>
266
270
267 * completer.py, generics.py(complete_object): Allow
271 * completer.py, generics.py(complete_object): Allow
268 custom complers based on python objects via simplegeneric.
272 custom complers based on python objects via simplegeneric.
269 See generics.py / my_demo_complete_object
273 See generics.py / my_demo_complete_object
270
274
271 2007-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
275 2007-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
272
276
273 * IPython/Prompts.py (BasePrompt.__nonzero__): add proper boolean
277 * IPython/Prompts.py (BasePrompt.__nonzero__): add proper boolean
274 behavior to prompt objects, useful for display hooks to adjust
278 behavior to prompt objects, useful for display hooks to adjust
275 themselves depending on whether prompts will be there or not.
279 themselves depending on whether prompts will be there or not.
276
280
277 2007-12-13 Ville Vainio <vivainio@gmail.com>
281 2007-12-13 Ville Vainio <vivainio@gmail.com>
278
282
279 * iplib.py(raw_input): unix readline does not allow unicode in
283 * iplib.py(raw_input): unix readline does not allow unicode in
280 history, encode to normal string. After patch by Tiago.
284 history, encode to normal string. After patch by Tiago.
281 Close #201
285 Close #201
282
286
283 2007-12-12 Ville Vainio <vivainio@gmail.com>
287 2007-12-12 Ville Vainio <vivainio@gmail.com>
284
288
285 * genutils.py (abbrev_cwd): Terminal title now shows 2 levels of
289 * genutils.py (abbrev_cwd): Terminal title now shows 2 levels of
286 current directory.
290 current directory.
287
291
288 2007-12-12 Fernando Perez <Fernando.Perez@colorado.edu>
292 2007-12-12 Fernando Perez <Fernando.Perez@colorado.edu>
289
293
290 * IPython/Shell.py (_select_shell): add support for controlling
294 * IPython/Shell.py (_select_shell): add support for controlling
291 the pylab threading mode directly at the command line, without
295 the pylab threading mode directly at the command line, without
292 having to modify MPL config files. Added unit tests for this
296 having to modify MPL config files. Added unit tests for this
293 feature, though manual/docs update is still pending, will do later.
297 feature, though manual/docs update is still pending, will do later.
294
298
295 2007-12-11 Ville Vainio <vivainio@gmail.com>
299 2007-12-11 Ville Vainio <vivainio@gmail.com>
296
300
297 * ext_rescapture.py: var = !cmd is no longer verbose (to facilitate
301 * ext_rescapture.py: var = !cmd is no longer verbose (to facilitate
298 use in scripts)
302 use in scripts)
299
303
300 2007-12-07 Ville Vainio <vivainio@gmail.com>
304 2007-12-07 Ville Vainio <vivainio@gmail.com>
301
305
302 * iplib.py, ipy_profile_sh.py: Do not escape # on command lines
306 * iplib.py, ipy_profile_sh.py: Do not escape # on command lines
303 anymore (to \#) - even if it is a comment char that is implicitly
307 anymore (to \#) - even if it is a comment char that is implicitly
304 escaped in some unix shells in interactive mode, it is ok to leave
308 escaped in some unix shells in interactive mode, it is ok to leave
305 it in IPython as such.
309 it in IPython as such.
306
310
307
311
308 2007-12-01 Robert Kern <robert.kern@gmail.com>
312 2007-12-01 Robert Kern <robert.kern@gmail.com>
309
313
310 * IPython/ultraTB.py (findsource): Improve the monkeypatch to
314 * IPython/ultraTB.py (findsource): Improve the monkeypatch to
311 inspect.findsource(). It can now find source lines inside zipped
315 inspect.findsource(). It can now find source lines inside zipped
312 packages.
316 packages.
313
317
314 * IPython/ultraTB.py: When constructing tracebacks, try to use __file__
318 * IPython/ultraTB.py: When constructing tracebacks, try to use __file__
315 in the frame's namespace before trusting the filename in the code object
319 in the frame's namespace before trusting the filename in the code object
316 which created the frame.
320 which created the frame.
317
321
318 2007-11-29 *** Released version 0.8.2
322 2007-11-29 *** Released version 0.8.2
319
323
320 2007-11-25 Fernando Perez <Fernando.Perez@colorado.edu>
324 2007-11-25 Fernando Perez <Fernando.Perez@colorado.edu>
321
325
322 * IPython/Logger.py (Logger.logstop): add a proper logstop()
326 * IPython/Logger.py (Logger.logstop): add a proper logstop()
323 method to fully stop the logger, along with a corresponding
327 method to fully stop the logger, along with a corresponding
324 %logstop magic for interactive use.
328 %logstop magic for interactive use.
325
329
326 * IPython/Extensions/ipy_host_completers.py: added new host
330 * IPython/Extensions/ipy_host_completers.py: added new host
327 completers functionality, contributed by Gael Pasgrimaud
331 completers functionality, contributed by Gael Pasgrimaud
328 <gawel-AT-afpy.org>.
332 <gawel-AT-afpy.org>.
329
333
330 2007-11-24 Fernando Perez <Fernando.Perez@colorado.edu>
334 2007-11-24 Fernando Perez <Fernando.Perez@colorado.edu>
331
335
332 * IPython/DPyGetOpt.py (ArgumentError): Apply patch by Paul Mueller
336 * IPython/DPyGetOpt.py (ArgumentError): Apply patch by Paul Mueller
333 <gakusei-AT-dakotacom.net>, to fix deprecated string exceptions in
337 <gakusei-AT-dakotacom.net>, to fix deprecated string exceptions in
334 options handling. Unicode fix in %whos (committed a while ago)
338 options handling. Unicode fix in %whos (committed a while ago)
335 was also contributed by Paul.
339 was also contributed by Paul.
336
340
337 2007-11-23 Darren Dale <darren.dale@cornell.edu>
341 2007-11-23 Darren Dale <darren.dale@cornell.edu>
338 * ipy_traits_completer.py: let traits_completer respect the user's
342 * ipy_traits_completer.py: let traits_completer respect the user's
339 readline_omit__names setting.
343 readline_omit__names setting.
340
344
341 2007-11-08 Ville Vainio <vivainio@gmail.com>
345 2007-11-08 Ville Vainio <vivainio@gmail.com>
342
346
343 * ipy_completers.py (import completer): assume 'xml' module exists.
347 * ipy_completers.py (import completer): assume 'xml' module exists.
344 Do not add every module twice anymore. Closes #196.
348 Do not add every module twice anymore. Closes #196.
345
349
346 * ipy_completers.py, ipy_app_completers.py: Add proper apt-get
350 * ipy_completers.py, ipy_app_completers.py: Add proper apt-get
347 completer that uses apt-cache to search for existing packages.
351 completer that uses apt-cache to search for existing packages.
348
352
349 2007-11-06 Ville Vainio <vivainio@gmail.com>
353 2007-11-06 Ville Vainio <vivainio@gmail.com>
350
354
351 * Prompts.py: Do not update _oh and _123 when do_full_cache is not
355 * Prompts.py: Do not update _oh and _123 when do_full_cache is not
352 true. Closes #194.
356 true. Closes #194.
353
357
354 2007-11-01 Brian Granger <ellisonbg@gmail.com>
358 2007-11-01 Brian Granger <ellisonbg@gmail.com>
355
359
356 * iplib.py, rlineimpl.py: Applied Body Water's patches to get IPython
360 * iplib.py, rlineimpl.py: Applied Body Water's patches to get IPython
357 working with OS X 10.5 libedit implementation of readline.
361 working with OS X 10.5 libedit implementation of readline.
358
362
359 2007-10-24 Ville Vainio <vivainio@gmail.com>
363 2007-10-24 Ville Vainio <vivainio@gmail.com>
360
364
361 * iplib.py(user_setup): To route around buggy installations where
365 * iplib.py(user_setup): To route around buggy installations where
362 UserConfig is not available, create a minimal _ipython.
366 UserConfig is not available, create a minimal _ipython.
363
367
364 * iplib.py: Unicode fixes from Jorgen.
368 * iplib.py: Unicode fixes from Jorgen.
365
369
366 * genutils.py: Slist now has new method 'fields()' for extraction of
370 * genutils.py: Slist now has new method 'fields()' for extraction of
367 whitespace-separated fields from line-oriented data.
371 whitespace-separated fields from line-oriented data.
368
372
369 2007-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
373 2007-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
370
374
371 * IPython/OInspect.py (Inspector.pinfo): fix bug that could arise
375 * IPython/OInspect.py (Inspector.pinfo): fix bug that could arise
372 when querying objects with no __class__ attribute (such as
376 when querying objects with no __class__ attribute (such as
373 f2py-generated modules).
377 f2py-generated modules).
374
378
375 2007-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
379 2007-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
376
380
377 * IPython/Magic.py (magic_time): track compilation time and report
381 * IPython/Magic.py (magic_time): track compilation time and report
378 it if longer than 0.1s (fix done to %time and %timeit). After a
382 it if longer than 0.1s (fix done to %time and %timeit). After a
379 SAGE bug report: http://trac.sagemath.org/sage_trac/ticket/632.
383 SAGE bug report: http://trac.sagemath.org/sage_trac/ticket/632.
380
384
381 2007-09-18 Ville Vainio <vivainio@gmail.com>
385 2007-09-18 Ville Vainio <vivainio@gmail.com>
382
386
383 * genutils.py(make_quoted_expr): Do not use Itpl, it does
387 * genutils.py(make_quoted_expr): Do not use Itpl, it does
384 not support unicode at the moment. Fixes (many) magic calls with
388 not support unicode at the moment. Fixes (many) magic calls with
385 special characters.
389 special characters.
386
390
387 2007-09-14 Fernando Perez <Fernando.Perez@colorado.edu>
391 2007-09-14 Fernando Perez <Fernando.Perez@colorado.edu>
388
392
389 * IPython/genutils.py (doctest_reload): expose the doctest
393 * IPython/genutils.py (doctest_reload): expose the doctest
390 reloader to the user so that people can easily reset doctest while
394 reloader to the user so that people can easily reset doctest while
391 using it interactively. Fixes a problem reported by Jorgen.
395 using it interactively. Fixes a problem reported by Jorgen.
392
396
393 * IPython/iplib.py (InteractiveShell.__init__): protect the
397 * IPython/iplib.py (InteractiveShell.__init__): protect the
394 FakeModule instances used for __main__ in %run calls from
398 FakeModule instances used for __main__ in %run calls from
395 deletion, so that user code defined in them isn't left with
399 deletion, so that user code defined in them isn't left with
396 dangling references due to the Python module deletion machinery.
400 dangling references due to the Python module deletion machinery.
397 This should fix the problems reported by Darren.
401 This should fix the problems reported by Darren.
398
402
399 2007-09-10 Darren Dale <dd55@cornell.edu>
403 2007-09-10 Darren Dale <dd55@cornell.edu>
400
404
401 * Cleanup of IPShellQt and IPShellQt4
405 * Cleanup of IPShellQt and IPShellQt4
402
406
403 2007-09-09 Fernando Perez <Fernando.Perez@colorado.edu>
407 2007-09-09 Fernando Perez <Fernando.Perez@colorado.edu>
404
408
405 * IPython/FakeModule.py (FakeModule.__init__): further fixes for
409 * IPython/FakeModule.py (FakeModule.__init__): further fixes for
406 doctest support.
410 doctest support.
407
411
408 * IPython/iplib.py (safe_execfile): minor docstring improvements.
412 * IPython/iplib.py (safe_execfile): minor docstring improvements.
409
413
410 2007-09-08 Ville Vainio <vivainio@gmail.com>
414 2007-09-08 Ville Vainio <vivainio@gmail.com>
411
415
412 * Magic.py (%pushd, %popd, %dirs): Fix dir stack - push *current*
416 * Magic.py (%pushd, %popd, %dirs): Fix dir stack - push *current*
413 directory, not the target directory.
417 directory, not the target directory.
414
418
415 * ipapi.py, Magic.py, iplib.py: Add ipapi.UsageError, a lighter weight
419 * ipapi.py, Magic.py, iplib.py: Add ipapi.UsageError, a lighter weight
416 exception that won't print the tracebacks. Switched many magics to
420 exception that won't print the tracebacks. Switched many magics to
417 raise them on error situations, also GetoptError is not printed
421 raise them on error situations, also GetoptError is not printed
418 anymore.
422 anymore.
419
423
420 2007-09-07 Ville Vainio <vivainio@gmail.com>
424 2007-09-07 Ville Vainio <vivainio@gmail.com>
421
425
422 * iplib.py: do not auto-alias "dir", it screws up other dir auto
426 * iplib.py: do not auto-alias "dir", it screws up other dir auto
423 aliases.
427 aliases.
424
428
425 * genutils.py: SList.grep() implemented.
429 * genutils.py: SList.grep() implemented.
426
430
427 * ipy_editors.py, UserConfig/ipy_user_conf.py: Add some editors
431 * ipy_editors.py, UserConfig/ipy_user_conf.py: Add some editors
428 for easy "out of the box" setup of several common editors, so that
432 for easy "out of the box" setup of several common editors, so that
429 e.g. '%edit os.path.isfile' will jump to the correct line
433 e.g. '%edit os.path.isfile' will jump to the correct line
430 automatically. Contributions for command lines of your favourite
434 automatically. Contributions for command lines of your favourite
431 editors welcome.
435 editors welcome.
432
436
433 2007-09-07 Fernando Perez <Fernando.Perez@colorado.edu>
437 2007-09-07 Fernando Perez <Fernando.Perez@colorado.edu>
434
438
435 * IPython/OInspect.py (Inspector.pinfo): fixed bug that was
439 * IPython/OInspect.py (Inspector.pinfo): fixed bug that was
436 preventing source display in certain cases. In reality I think
440 preventing source display in certain cases. In reality I think
437 the problem is with Ubuntu's Python build, but this change works
441 the problem is with Ubuntu's Python build, but this change works
438 around the issue in some cases (not in all, unfortunately). I'd
442 around the issue in some cases (not in all, unfortunately). I'd
439 filed a Python bug on this with more details, but in the change of
443 filed a Python bug on this with more details, but in the change of
440 bug trackers it seems to have been lost.
444 bug trackers it seems to have been lost.
441
445
442 * IPython/Magic.py (magic_dhist): restore %dhist. No, cd -TAB is
446 * IPython/Magic.py (magic_dhist): restore %dhist. No, cd -TAB is
443 not the same, it's not self-documenting, doesn't allow range
447 not the same, it's not self-documenting, doesn't allow range
444 selection, and sorts alphabetically instead of numerically.
448 selection, and sorts alphabetically instead of numerically.
445 (magic_r): restore %r. No, "up + enter. One char magic" is not
449 (magic_r): restore %r. No, "up + enter. One char magic" is not
446 the same thing, since %r takes parameters to allow fast retrieval
450 the same thing, since %r takes parameters to allow fast retrieval
447 of old commands. I've received emails from users who use this a
451 of old commands. I've received emails from users who use this a
448 LOT, so it stays.
452 LOT, so it stays.
449 (magic_automagic): restore %automagic. "use _ip.option.automagic"
453 (magic_automagic): restore %automagic. "use _ip.option.automagic"
450 is not a valid replacement b/c it doesn't provide an complete
454 is not a valid replacement b/c it doesn't provide an complete
451 explanation (which the automagic docstring does).
455 explanation (which the automagic docstring does).
452 (magic_autocall): restore %autocall, with improved docstring.
456 (magic_autocall): restore %autocall, with improved docstring.
453 Same argument as for others, "use _ip.options.autocall" is not a
457 Same argument as for others, "use _ip.options.autocall" is not a
454 valid replacement.
458 valid replacement.
455 (magic_pdef): restore %pdef & friends. Used widely, mentioned in
459 (magic_pdef): restore %pdef & friends. Used widely, mentioned in
456 tutorials and online docs.
460 tutorials and online docs.
457
461
458 2007-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
462 2007-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
459
463
460 * IPython/usage.py (quick_reference): mention magics in quickref,
464 * IPython/usage.py (quick_reference): mention magics in quickref,
461 modified main banner to mention %quickref.
465 modified main banner to mention %quickref.
462
466
463 * IPython/FakeModule.py (FakeModule): fixes for doctest compatibility.
467 * IPython/FakeModule.py (FakeModule): fixes for doctest compatibility.
464
468
465 2007-09-06 Ville Vainio <vivainio@gmail.com>
469 2007-09-06 Ville Vainio <vivainio@gmail.com>
466
470
467 * ipy_rehashdir.py, ipy_workdir.py, ipy_fsops.py, iplib.py:
471 * ipy_rehashdir.py, ipy_workdir.py, ipy_fsops.py, iplib.py:
468 Callable aliases now pass the _ip as first arg. This breaks
472 Callable aliases now pass the _ip as first arg. This breaks
469 compatibility with earlier 0.8.2.svn series! (though they should
473 compatibility with earlier 0.8.2.svn series! (though they should
470 not have been in use yet outside these few extensions)
474 not have been in use yet outside these few extensions)
471
475
472 2007-09-05 Ville Vainio <vivainio@gmail.com>
476 2007-09-05 Ville Vainio <vivainio@gmail.com>
473
477
474 * external/mglob.py: expand('dirname') => ['dirname'], instead
478 * external/mglob.py: expand('dirname') => ['dirname'], instead
475 of ['dirname/foo','dirname/bar', ...].
479 of ['dirname/foo','dirname/bar', ...].
476
480
477 * Extensions/ipy_fsops.py: added, has usefull shell utils for plain
481 * Extensions/ipy_fsops.py: added, has usefull shell utils for plain
478 win32 installations: icp, imv, imkdir, igrep, irm, collect (collect
482 win32 installations: icp, imv, imkdir, igrep, irm, collect (collect
479 is useful for others as well).
483 is useful for others as well).
480
484
481 * iplib.py: on callable aliases (as opposed to old style aliases),
485 * iplib.py: on callable aliases (as opposed to old style aliases),
482 do var_expand() immediately, and use make_quoted_expr instead
486 do var_expand() immediately, and use make_quoted_expr instead
483 of hardcoded r"""
487 of hardcoded r"""
484
488
485 * Extensions/ipy_profile_sh.py: Try to detect cygwin on win32,
489 * Extensions/ipy_profile_sh.py: Try to detect cygwin on win32,
486 if not available load ipy_fsops.py for cp, mv, etc. replacements
490 if not available load ipy_fsops.py for cp, mv, etc. replacements
487
491
488 * OInspect.py, ipy_which.py: improve %which and obj? for callable
492 * OInspect.py, ipy_which.py: improve %which and obj? for callable
489 aliases
493 aliases
490
494
491 2007-09-04 Ville Vainio <vivainio@gmail.com>
495 2007-09-04 Ville Vainio <vivainio@gmail.com>
492
496
493 * ipy_profile_zope.py: add zope profile, by Stefan Eletzhofer.
497 * ipy_profile_zope.py: add zope profile, by Stefan Eletzhofer.
494 Relicensed under BSD with the authors approval.
498 Relicensed under BSD with the authors approval.
495
499
496 * ipmaker.py, usage.py: Remove %magic from default banner, improve
500 * ipmaker.py, usage.py: Remove %magic from default banner, improve
497 %quickref
501 %quickref
498
502
499 2007-09-03 Ville Vainio <vivainio@gmail.com>
503 2007-09-03 Ville Vainio <vivainio@gmail.com>
500
504
501 * Magic.py: %time now passes expression through prefilter,
505 * Magic.py: %time now passes expression through prefilter,
502 allowing IPython syntax.
506 allowing IPython syntax.
503
507
504 2007-09-01 Ville Vainio <vivainio@gmail.com>
508 2007-09-01 Ville Vainio <vivainio@gmail.com>
505
509
506 * ipmaker.py: Always show full traceback when newstyle config fails
510 * ipmaker.py: Always show full traceback when newstyle config fails
507
511
508 2007-08-27 Ville Vainio <vivainio@gmail.com>
512 2007-08-27 Ville Vainio <vivainio@gmail.com>
509
513
510 * Magic.py: fix %cd for nonexistent dir when dhist is empty, close #180
514 * Magic.py: fix %cd for nonexistent dir when dhist is empty, close #180
511
515
512 2007-08-26 Ville Vainio <vivainio@gmail.com>
516 2007-08-26 Ville Vainio <vivainio@gmail.com>
513
517
514 * ipmaker.py: Command line args have the highest priority again
518 * ipmaker.py: Command line args have the highest priority again
515
519
516 * iplib.py, ipmaker.py: -i command line argument now behaves as in
520 * iplib.py, ipmaker.py: -i command line argument now behaves as in
517 normal python, i.e. leaves the IPython session running after -c
521 normal python, i.e. leaves the IPython session running after -c
518 command or running a batch file from command line.
522 command or running a batch file from command line.
519
523
520 2007-08-22 Ville Vainio <vivainio@gmail.com>
524 2007-08-22 Ville Vainio <vivainio@gmail.com>
521
525
522 * iplib.py: no extra empty (last) line in raw hist w/ multiline
526 * iplib.py: no extra empty (last) line in raw hist w/ multiline
523 statements
527 statements
524
528
525 * logger.py: Fix bug where blank lines in history were not
529 * logger.py: Fix bug where blank lines in history were not
526 added until AFTER adding the current line; translated and raw
530 added until AFTER adding the current line; translated and raw
527 history should finally be in sync with prompt now.
531 history should finally be in sync with prompt now.
528
532
529 * ipy_completers.py: quick_completer now makes it easy to create
533 * ipy_completers.py: quick_completer now makes it easy to create
530 trivial custom completers
534 trivial custom completers
531
535
532 * clearcmd.py: shadow history compression & erasing, fixed input hist
536 * clearcmd.py: shadow history compression & erasing, fixed input hist
533 clearing.
537 clearing.
534
538
535 * envpersist.py, history.py: %env (sh profile only), %hist completers
539 * envpersist.py, history.py: %env (sh profile only), %hist completers
536
540
537 * genutils.py, Prompts.py, Magic.py: win32 - prompt (with \yDEPTH) and
541 * genutils.py, Prompts.py, Magic.py: win32 - prompt (with \yDEPTH) and
538 term title now include the drive letter, and always use / instead of
542 term title now include the drive letter, and always use / instead of
539 os.sep (as per recommended approach for win32 ipython in general).
543 os.sep (as per recommended approach for win32 ipython in general).
540
544
541 * ipykit.py, ipy_kitcfg.py: special launcher for ipykit. Allows running
545 * ipykit.py, ipy_kitcfg.py: special launcher for ipykit. Allows running
542 plain python scripts from ipykit command line by running
546 plain python scripts from ipykit command line by running
543 "py myscript.py", even w/o installed python.
547 "py myscript.py", even w/o installed python.
544
548
545 2007-08-21 Ville Vainio <vivainio@gmail.com>
549 2007-08-21 Ville Vainio <vivainio@gmail.com>
546
550
547 * ipmaker.py: finding ipythonrc-PROF now skips ipy_profile_PROF.
551 * ipmaker.py: finding ipythonrc-PROF now skips ipy_profile_PROF.
548 (for backwards compatibility)
552 (for backwards compatibility)
549
553
550 * history.py: switch back to %hist -t from %hist -r as default.
554 * history.py: switch back to %hist -t from %hist -r as default.
551 At least until raw history is fixed for good.
555 At least until raw history is fixed for good.
552
556
553 2007-08-20 Ville Vainio <vivainio@gmail.com>
557 2007-08-20 Ville Vainio <vivainio@gmail.com>
554
558
555 * ipapi.py, iplib.py: DebugTools accessible via _ip.dbg, to catch &
559 * ipapi.py, iplib.py: DebugTools accessible via _ip.dbg, to catch &
556 locate alias redeclarations etc. Also, avoid handling
560 locate alias redeclarations etc. Also, avoid handling
557 _ip.IP.alias_table directly, prefer using _ip.defalias.
561 _ip.IP.alias_table directly, prefer using _ip.defalias.
558
562
559
563
560 2007-08-15 Ville Vainio <vivainio@gmail.com>
564 2007-08-15 Ville Vainio <vivainio@gmail.com>
561
565
562 * prefilter.py: ! is now always served first
566 * prefilter.py: ! is now always served first
563
567
564 2007-08-15 Fernando Perez <Fernando.Perez@colorado.edu>
568 2007-08-15 Fernando Perez <Fernando.Perez@colorado.edu>
565
569
566 * IPython/iplib.py (safe_execfile): fix the SystemExit
570 * IPython/iplib.py (safe_execfile): fix the SystemExit
567 auto-suppression code to work in Python2.4 (the internal structure
571 auto-suppression code to work in Python2.4 (the internal structure
568 of that exception changed and I'd only tested the code with 2.5).
572 of that exception changed and I'd only tested the code with 2.5).
569 Bug reported by a SciPy attendee.
573 Bug reported by a SciPy attendee.
570
574
571 2007-08-13 Ville Vainio <vivainio@gmail.com>
575 2007-08-13 Ville Vainio <vivainio@gmail.com>
572
576
573 * prefilter.py: reverted !c:/bin/foo fix, made % in
577 * prefilter.py: reverted !c:/bin/foo fix, made % in
574 multiline specials work again
578 multiline specials work again
575
579
576 2007-08-13 Ville Vainio <vivainio@gmail.com>
580 2007-08-13 Ville Vainio <vivainio@gmail.com>
577
581
578 * prefilter.py: Take more care to special-case !, so that
582 * prefilter.py: Take more care to special-case !, so that
579 !c:/bin/foo.exe works.
583 !c:/bin/foo.exe works.
580
584
581 * setup.py: if we are building eggs, strip all docs and
585 * setup.py: if we are building eggs, strip all docs and
582 examples (it doesn't make sense to bytecompile examples,
586 examples (it doesn't make sense to bytecompile examples,
583 and docs would be in an awkward place anyway).
587 and docs would be in an awkward place anyway).
584
588
585 * Ryan Krauss' patch fixes start menu shortcuts when IPython
589 * Ryan Krauss' patch fixes start menu shortcuts when IPython
586 is installed into a directory that has spaces in the name.
590 is installed into a directory that has spaces in the name.
587
591
588 2007-08-13 Fernando Perez <Fernando.Perez@colorado.edu>
592 2007-08-13 Fernando Perez <Fernando.Perez@colorado.edu>
589
593
590 * IPython/Magic.py (magic_doctest_mode): fix prompt separators in
594 * IPython/Magic.py (magic_doctest_mode): fix prompt separators in
591 doctest profile and %doctest_mode, so they actually generate the
595 doctest profile and %doctest_mode, so they actually generate the
592 blank lines needed by doctest to separate individual tests.
596 blank lines needed by doctest to separate individual tests.
593
597
594 * IPython/iplib.py (safe_execfile): modify so that running code
598 * IPython/iplib.py (safe_execfile): modify so that running code
595 which calls sys.exit(0) (or equivalently, raise SystemExit(0))
599 which calls sys.exit(0) (or equivalently, raise SystemExit(0))
596 doesn't get a printed traceback. Any other value in sys.exit(),
600 doesn't get a printed traceback. Any other value in sys.exit(),
597 including the empty call, still generates a traceback. This
601 including the empty call, still generates a traceback. This
598 enables use of %run without having to pass '-e' for codes that
602 enables use of %run without having to pass '-e' for codes that
599 correctly set the exit status flag.
603 correctly set the exit status flag.
600
604
601 2007-08-12 Fernando Perez <Fernando.Perez@colorado.edu>
605 2007-08-12 Fernando Perez <Fernando.Perez@colorado.edu>
602
606
603 * IPython/iplib.py (InteractiveShell.post_config_initialization):
607 * IPython/iplib.py (InteractiveShell.post_config_initialization):
604 fix problems with doctests failing when run inside IPython due to
608 fix problems with doctests failing when run inside IPython due to
605 IPython's modifications of sys.displayhook.
609 IPython's modifications of sys.displayhook.
606
610
607 2007-8-9 Fernando Perez <fperez@planck.colorado.edu>
611 2007-8-9 Fernando Perez <fperez@planck.colorado.edu>
608
612
609 * IPython/ipapi.py (to_user_ns): update to accept a dict as well as
613 * IPython/ipapi.py (to_user_ns): update to accept a dict as well as
610 a string with names.
614 a string with names.
611
615
612 2007-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
616 2007-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
613
617
614 * IPython/Magic.py (magic_doctest_mode): added new %doctest_mode
618 * IPython/Magic.py (magic_doctest_mode): added new %doctest_mode
615 magic to toggle on/off the doctest pasting support without having
619 magic to toggle on/off the doctest pasting support without having
616 to leave a session to switch to a separate profile.
620 to leave a session to switch to a separate profile.
617
621
618 2007-08-08 Fernando Perez <Fernando.Perez@colorado.edu>
622 2007-08-08 Fernando Perez <Fernando.Perez@colorado.edu>
619
623
620 * IPython/Extensions/ipy_profile_doctest.py (main): fix prompt to
624 * IPython/Extensions/ipy_profile_doctest.py (main): fix prompt to
621 introduce a blank line between inputs, to conform to doctest
625 introduce a blank line between inputs, to conform to doctest
622 requirements.
626 requirements.
623
627
624 * IPython/OInspect.py (Inspector.pinfo): fix another part where
628 * IPython/OInspect.py (Inspector.pinfo): fix another part where
625 auto-generated docstrings for new-style classes were showing up.
629 auto-generated docstrings for new-style classes were showing up.
626
630
627 2007-08-07 Fernando Perez <Fernando.Perez@colorado.edu>
631 2007-08-07 Fernando Perez <Fernando.Perez@colorado.edu>
628
632
629 * api_changes: Add new file to track backward-incompatible
633 * api_changes: Add new file to track backward-incompatible
630 user-visible changes.
634 user-visible changes.
631
635
632 2007-08-06 Ville Vainio <vivainio@gmail.com>
636 2007-08-06 Ville Vainio <vivainio@gmail.com>
633
637
634 * ipmaker.py: fix bug where user_config_ns didn't exist at all
638 * ipmaker.py: fix bug where user_config_ns didn't exist at all
635 before all the config files were handled.
639 before all the config files were handled.
636
640
637 2007-08-04 Fernando Perez <Fernando.Perez@colorado.edu>
641 2007-08-04 Fernando Perez <Fernando.Perez@colorado.edu>
638
642
639 * IPython/irunner.py (RunnerFactory): Add new factory class for
643 * IPython/irunner.py (RunnerFactory): Add new factory class for
640 creating reusable runners based on filenames.
644 creating reusable runners based on filenames.
641
645
642 * IPython/Extensions/ipy_profile_doctest.py: New profile for
646 * IPython/Extensions/ipy_profile_doctest.py: New profile for
643 doctest support. It sets prompts/exceptions as similar to
647 doctest support. It sets prompts/exceptions as similar to
644 standard Python as possible, so that ipython sessions in this
648 standard Python as possible, so that ipython sessions in this
645 profile can be easily pasted as doctests with minimal
649 profile can be easily pasted as doctests with minimal
646 modifications. It also enables pasting of doctests from external
650 modifications. It also enables pasting of doctests from external
647 sources (even if they have leading whitespace), so that you can
651 sources (even if they have leading whitespace), so that you can
648 rerun doctests from existing sources.
652 rerun doctests from existing sources.
649
653
650 * IPython/iplib.py (_prefilter): fix a buglet where after entering
654 * IPython/iplib.py (_prefilter): fix a buglet where after entering
651 some whitespace, the prompt would become a continuation prompt
655 some whitespace, the prompt would become a continuation prompt
652 with no way of exiting it other than Ctrl-C. This fix brings us
656 with no way of exiting it other than Ctrl-C. This fix brings us
653 into conformity with how the default python prompt works.
657 into conformity with how the default python prompt works.
654
658
655 * IPython/Extensions/InterpreterPasteInput.py (prefilter_paste):
659 * IPython/Extensions/InterpreterPasteInput.py (prefilter_paste):
656 Add support for pasting not only lines that start with '>>>', but
660 Add support for pasting not only lines that start with '>>>', but
657 also with ' >>>'. That is, arbitrary whitespace can now precede
661 also with ' >>>'. That is, arbitrary whitespace can now precede
658 the prompts. This makes the system useful for pasting doctests
662 the prompts. This makes the system useful for pasting doctests
659 from docstrings back into a normal session.
663 from docstrings back into a normal session.
660
664
661 2007-08-02 Fernando Perez <Fernando.Perez@colorado.edu>
665 2007-08-02 Fernando Perez <Fernando.Perez@colorado.edu>
662
666
663 * IPython/Shell.py (IPShellEmbed.__call__): fix bug introduced in
667 * IPython/Shell.py (IPShellEmbed.__call__): fix bug introduced in
664 r1357, which had killed multiple invocations of an embedded
668 r1357, which had killed multiple invocations of an embedded
665 ipython (this means that example-embed has been broken for over 1
669 ipython (this means that example-embed has been broken for over 1
666 year!!!). Rather than possibly breaking the batch stuff for which
670 year!!!). Rather than possibly breaking the batch stuff for which
667 the code in iplib.py/interact was introduced, I worked around the
671 the code in iplib.py/interact was introduced, I worked around the
668 problem in the embedding class in Shell.py. We really need a
672 problem in the embedding class in Shell.py. We really need a
669 bloody test suite for this code, I'm sick of finding stuff that
673 bloody test suite for this code, I'm sick of finding stuff that
670 used to work breaking left and right every time I use an old
674 used to work breaking left and right every time I use an old
671 feature I hadn't touched in a few months.
675 feature I hadn't touched in a few months.
672 (kill_embedded): Add a new magic that only shows up in embedded
676 (kill_embedded): Add a new magic that only shows up in embedded
673 mode, to allow users to permanently deactivate an embedded instance.
677 mode, to allow users to permanently deactivate an embedded instance.
674
678
675 2007-08-01 Ville Vainio <vivainio@gmail.com>
679 2007-08-01 Ville Vainio <vivainio@gmail.com>
676
680
677 * iplib.py, ipy_profile_sh.py (runlines): Fix the bug where raw
681 * iplib.py, ipy_profile_sh.py (runlines): Fix the bug where raw
678 history gets out of sync on runlines (e.g. when running macros).
682 history gets out of sync on runlines (e.g. when running macros).
679
683
680 2007-07-31 Fernando Perez <Fernando.Perez@colorado.edu>
684 2007-07-31 Fernando Perez <Fernando.Perez@colorado.edu>
681
685
682 * IPython/Magic.py (magic_colors): fix win32-related error message
686 * IPython/Magic.py (magic_colors): fix win32-related error message
683 that could appear under *nix when readline was missing. Patch by
687 that could appear under *nix when readline was missing. Patch by
684 Scott Jackson, closes #175.
688 Scott Jackson, closes #175.
685
689
686 2007-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
690 2007-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
687
691
688 * IPython/Extensions/ipy_traits_completer.py: Add a new custom
692 * IPython/Extensions/ipy_traits_completer.py: Add a new custom
689 completer that it traits-aware, so that traits objects don't show
693 completer that it traits-aware, so that traits objects don't show
690 all of their internal attributes all the time.
694 all of their internal attributes all the time.
691
695
692 * IPython/genutils.py (dir2): moved this code from inside
696 * IPython/genutils.py (dir2): moved this code from inside
693 completer.py to expose it publicly, so I could use it in the
697 completer.py to expose it publicly, so I could use it in the
694 wildcards bugfix.
698 wildcards bugfix.
695
699
696 * IPython/wildcard.py (NameSpace.__init__): fix a bug reported by
700 * IPython/wildcard.py (NameSpace.__init__): fix a bug reported by
697 Stefan with Traits.
701 Stefan with Traits.
698
702
699 * IPython/completer.py (Completer.attr_matches): change internal
703 * IPython/completer.py (Completer.attr_matches): change internal
700 var name from 'object' to 'obj', since 'object' is now a builtin
704 var name from 'object' to 'obj', since 'object' is now a builtin
701 and this can lead to weird bugs if reusing this code elsewhere.
705 and this can lead to weird bugs if reusing this code elsewhere.
702
706
703 2007-07-25 Fernando Perez <Fernando.Perez@colorado.edu>
707 2007-07-25 Fernando Perez <Fernando.Perez@colorado.edu>
704
708
705 * IPython/OInspect.py (Inspector.pinfo): fix small glitches in
709 * IPython/OInspect.py (Inspector.pinfo): fix small glitches in
706 'foo?' and update the code to prevent printing of default
710 'foo?' and update the code to prevent printing of default
707 docstrings that started appearing after I added support for
711 docstrings that started appearing after I added support for
708 new-style classes. The approach I'm using isn't ideal (I just
712 new-style classes. The approach I'm using isn't ideal (I just
709 special-case those strings) but I'm not sure how to more robustly
713 special-case those strings) but I'm not sure how to more robustly
710 differentiate between truly user-written strings and Python's
714 differentiate between truly user-written strings and Python's
711 automatic ones.
715 automatic ones.
712
716
713 2007-07-09 Ville Vainio <vivainio@gmail.com>
717 2007-07-09 Ville Vainio <vivainio@gmail.com>
714
718
715 * completer.py: Applied Matthew Neeley's patch:
719 * completer.py: Applied Matthew Neeley's patch:
716 Dynamic attributes from trait_names and _getAttributeNames are added
720 Dynamic attributes from trait_names and _getAttributeNames are added
717 to the list of tab completions, but when this happens, the attribute
721 to the list of tab completions, but when this happens, the attribute
718 list is turned into a set, so the attributes are unordered when
722 list is turned into a set, so the attributes are unordered when
719 printed, which makes it hard to find the right completion. This patch
723 printed, which makes it hard to find the right completion. This patch
720 turns this set back into a list and sort it.
724 turns this set back into a list and sort it.
721
725
722 2007-07-06 Fernando Perez <Fernando.Perez@colorado.edu>
726 2007-07-06 Fernando Perez <Fernando.Perez@colorado.edu>
723
727
724 * IPython/OInspect.py (Inspector.pinfo): Add support for new-style
728 * IPython/OInspect.py (Inspector.pinfo): Add support for new-style
725 classes in various inspector functions.
729 classes in various inspector functions.
726
730
727 2007-06-28 Ville Vainio <vivainio@gmail.com>
731 2007-06-28 Ville Vainio <vivainio@gmail.com>
728
732
729 * shadowns.py, iplib.py, ipapi.py, OInspect.py:
733 * shadowns.py, iplib.py, ipapi.py, OInspect.py:
730 Implement "shadow" namespace, and callable aliases that reside there.
734 Implement "shadow" namespace, and callable aliases that reside there.
731 Use them by:
735 Use them by:
732
736
733 _ip.defalias('foo',myfunc) # creates _sh.foo that points to myfunc
737 _ip.defalias('foo',myfunc) # creates _sh.foo that points to myfunc
734
738
735 foo hello world
739 foo hello world
736 (gets translated to:)
740 (gets translated to:)
737 _sh.foo(r"""hello world""")
741 _sh.foo(r"""hello world""")
738
742
739 In practice, this kind of alias can take the role of a magic function
743 In practice, this kind of alias can take the role of a magic function
740
744
741 * New generic inspect_object, called on obj? and obj??
745 * New generic inspect_object, called on obj? and obj??
742
746
743 2007-06-15 Fernando Perez <Fernando.Perez@colorado.edu>
747 2007-06-15 Fernando Perez <Fernando.Perez@colorado.edu>
744
748
745 * IPython/ultraTB.py (findsource): fix a problem with
749 * IPython/ultraTB.py (findsource): fix a problem with
746 inspect.getfile that can cause crashes during traceback construction.
750 inspect.getfile that can cause crashes during traceback construction.
747
751
748 2007-06-14 Ville Vainio <vivainio@gmail.com>
752 2007-06-14 Ville Vainio <vivainio@gmail.com>
749
753
750 * iplib.py (handle_auto): Try to use ascii for printing "--->"
754 * iplib.py (handle_auto): Try to use ascii for printing "--->"
751 autocall rewrite indication, becausesometimes unicode fails to print
755 autocall rewrite indication, becausesometimes unicode fails to print
752 properly (and you get ' - - - '). Use plain uncoloured ---> for
756 properly (and you get ' - - - '). Use plain uncoloured ---> for
753 unicode.
757 unicode.
754
758
755 * shadow history. Usable through "%hist -g <pat>" and "%rep 0123".
759 * shadow history. Usable through "%hist -g <pat>" and "%rep 0123".
756
760
757 . pickleshare 'hash' commands (hget, hset, hcompress,
761 . pickleshare 'hash' commands (hget, hset, hcompress,
758 hdict) for efficient shadow history storage.
762 hdict) for efficient shadow history storage.
759
763
760 2007-06-13 Ville Vainio <vivainio@gmail.com>
764 2007-06-13 Ville Vainio <vivainio@gmail.com>
761
765
762 * ipapi.py: _ip.to_user_ns(vars, interactive = True).
766 * ipapi.py: _ip.to_user_ns(vars, interactive = True).
763 Added kw arg 'interactive', tell whether vars should be visible
767 Added kw arg 'interactive', tell whether vars should be visible
764 with %whos.
768 with %whos.
765
769
766 2007-06-11 Ville Vainio <vivainio@gmail.com>
770 2007-06-11 Ville Vainio <vivainio@gmail.com>
767
771
768 * pspersistence.py, Magic.py, iplib.py: directory history now saved
772 * pspersistence.py, Magic.py, iplib.py: directory history now saved
769 to db
773 to db
770
774
771 * iplib.py: "ipython -c <cmd>" now passes the command through prefilter.
775 * iplib.py: "ipython -c <cmd>" now passes the command through prefilter.
772 Also, it exits IPython immediately after evaluating the command (just like
776 Also, it exits IPython immediately after evaluating the command (just like
773 std python)
777 std python)
774
778
775 2007-06-05 Walter Doerwald <walter@livinglogic.de>
779 2007-06-05 Walter Doerwald <walter@livinglogic.de>
776
780
777 * IPython/Extensions/ipipe.py: Added a new table icap, which executes a
781 * IPython/Extensions/ipipe.py: Added a new table icap, which executes a
778 Python string and captures the output. (Idea and original patch by
782 Python string and captures the output. (Idea and original patch by
779 Stefan van der Walt)
783 Stefan van der Walt)
780
784
781 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
785 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
782
786
783 * IPython/ultraTB.py (VerboseTB.text): update printing of
787 * IPython/ultraTB.py (VerboseTB.text): update printing of
784 exception types for Python 2.5 (now all exceptions in the stdlib
788 exception types for Python 2.5 (now all exceptions in the stdlib
785 are new-style classes).
789 are new-style classes).
786
790
787 2007-05-31 Walter Doerwald <walter@livinglogic.de>
791 2007-05-31 Walter Doerwald <walter@livinglogic.de>
788
792
789 * IPython/Extensions/igrid.py: Add new commands refresh and
793 * IPython/Extensions/igrid.py: Add new commands refresh and
790 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
794 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
791 the iterator once (refresh) or after every x seconds (refresh_timer).
795 the iterator once (refresh) or after every x seconds (refresh_timer).
792 Add a working implementation of "searchexpression", where the text
796 Add a working implementation of "searchexpression", where the text
793 entered is not the text to search for, but an expression that must
797 entered is not the text to search for, but an expression that must
794 be true. Added display of shortcuts to the menu. Added commands "pickinput"
798 be true. Added display of shortcuts to the menu. Added commands "pickinput"
795 and "pickinputattr" that put the object or attribute under the cursor
799 and "pickinputattr" that put the object or attribute under the cursor
796 in the input line. Split the statusbar to be able to display the currently
800 in the input line. Split the statusbar to be able to display the currently
797 active refresh interval. (Patch by Nik Tautenhahn)
801 active refresh interval. (Patch by Nik Tautenhahn)
798
802
799 2007-05-29 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
803 2007-05-29 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
800
804
801 * fixing set_term_title to use ctypes as default
805 * fixing set_term_title to use ctypes as default
802
806
803 * fixing set_term_title fallback to work when curent dir
807 * fixing set_term_title fallback to work when curent dir
804 is on a windows network share
808 is on a windows network share
805
809
806 2007-05-28 Ville Vainio <vivainio@gmail.com>
810 2007-05-28 Ville Vainio <vivainio@gmail.com>
807
811
808 * %cpaste: strip + with > from left (diffs).
812 * %cpaste: strip + with > from left (diffs).
809
813
810 * iplib.py: Fix crash when readline not installed
814 * iplib.py: Fix crash when readline not installed
811
815
812 2007-05-26 Ville Vainio <vivainio@gmail.com>
816 2007-05-26 Ville Vainio <vivainio@gmail.com>
813
817
814 * generics.py: introduce easy to extend result_display generic
818 * generics.py: introduce easy to extend result_display generic
815 function (using simplegeneric.py).
819 function (using simplegeneric.py).
816
820
817 * Fixed the append functionality of %set.
821 * Fixed the append functionality of %set.
818
822
819 2007-05-25 Ville Vainio <vivainio@gmail.com>
823 2007-05-25 Ville Vainio <vivainio@gmail.com>
820
824
821 * New magic: %rep (fetch / run old commands from history)
825 * New magic: %rep (fetch / run old commands from history)
822
826
823 * New extension: mglob (%mglob magic), for powerful glob / find /filter
827 * New extension: mglob (%mglob magic), for powerful glob / find /filter
824 like functionality
828 like functionality
825
829
826 % maghistory.py: %hist -g PATTERM greps the history for pattern
830 % maghistory.py: %hist -g PATTERM greps the history for pattern
827
831
828 2007-05-24 Walter Doerwald <walter@livinglogic.de>
832 2007-05-24 Walter Doerwald <walter@livinglogic.de>
829
833
830 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
834 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
831 browse the IPython input history
835 browse the IPython input history
832
836
833 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
837 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
834 (mapped to "i") can be used to put the object under the curser in the input
838 (mapped to "i") can be used to put the object under the curser in the input
835 line. pickinputattr (mapped to "I") does the same for the attribute under
839 line. pickinputattr (mapped to "I") does the same for the attribute under
836 the cursor.
840 the cursor.
837
841
838 2007-05-24 Ville Vainio <vivainio@gmail.com>
842 2007-05-24 Ville Vainio <vivainio@gmail.com>
839
843
840 * Grand magic cleansing (changeset [2380]):
844 * Grand magic cleansing (changeset [2380]):
841
845
842 * Introduce ipy_legacy.py where the following magics were
846 * Introduce ipy_legacy.py where the following magics were
843 moved:
847 moved:
844
848
845 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
849 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
846
850
847 If you need them, either use default profile or "import ipy_legacy"
851 If you need them, either use default profile or "import ipy_legacy"
848 in your ipy_user_conf.py
852 in your ipy_user_conf.py
849
853
850 * Move sh and scipy profile to Extensions from UserConfig. this implies
854 * Move sh and scipy profile to Extensions from UserConfig. this implies
851 you should not edit them, but you don't need to run %upgrade when
855 you should not edit them, but you don't need to run %upgrade when
852 upgrading IPython anymore.
856 upgrading IPython anymore.
853
857
854 * %hist/%history now operates in "raw" mode by default. To get the old
858 * %hist/%history now operates in "raw" mode by default. To get the old
855 behaviour, run '%hist -n' (native mode).
859 behaviour, run '%hist -n' (native mode).
856
860
857 * split ipy_stock_completers.py to ipy_stock_completers.py and
861 * split ipy_stock_completers.py to ipy_stock_completers.py and
858 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
862 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
859 installed as default.
863 installed as default.
860
864
861 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
865 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
862 handling.
866 handling.
863
867
864 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
868 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
865 input if readline is available.
869 input if readline is available.
866
870
867 2007-05-23 Ville Vainio <vivainio@gmail.com>
871 2007-05-23 Ville Vainio <vivainio@gmail.com>
868
872
869 * macro.py: %store uses __getstate__ properly
873 * macro.py: %store uses __getstate__ properly
870
874
871 * exesetup.py: added new setup script for creating
875 * exesetup.py: added new setup script for creating
872 standalone IPython executables with py2exe (i.e.
876 standalone IPython executables with py2exe (i.e.
873 no python installation required).
877 no python installation required).
874
878
875 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
879 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
876 its place.
880 its place.
877
881
878 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
882 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
879
883
880 2007-05-21 Ville Vainio <vivainio@gmail.com>
884 2007-05-21 Ville Vainio <vivainio@gmail.com>
881
885
882 * platutil_win32.py (set_term_title): handle
886 * platutil_win32.py (set_term_title): handle
883 failure of 'title' system call properly.
887 failure of 'title' system call properly.
884
888
885 2007-05-17 Walter Doerwald <walter@livinglogic.de>
889 2007-05-17 Walter Doerwald <walter@livinglogic.de>
886
890
887 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
891 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
888 (Bug detected by Paul Mueller).
892 (Bug detected by Paul Mueller).
889
893
890 2007-05-16 Ville Vainio <vivainio@gmail.com>
894 2007-05-16 Ville Vainio <vivainio@gmail.com>
891
895
892 * ipy_profile_sci.py, ipython_win_post_install.py: Create
896 * ipy_profile_sci.py, ipython_win_post_install.py: Create
893 new "sci" profile, effectively a modern version of the old
897 new "sci" profile, effectively a modern version of the old
894 "scipy" profile (which is now slated for deprecation).
898 "scipy" profile (which is now slated for deprecation).
895
899
896 2007-05-15 Ville Vainio <vivainio@gmail.com>
900 2007-05-15 Ville Vainio <vivainio@gmail.com>
897
901
898 * pycolorize.py, pycolor.1: Paul Mueller's patches that
902 * pycolorize.py, pycolor.1: Paul Mueller's patches that
899 make pycolorize read input from stdin when run without arguments.
903 make pycolorize read input from stdin when run without arguments.
900
904
901 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
905 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
902
906
903 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
907 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
904 it in sh profile (instead of ipy_system_conf.py).
908 it in sh profile (instead of ipy_system_conf.py).
905
909
906 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
910 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
907 aliases are now lower case on windows (MyCommand.exe => mycommand).
911 aliases are now lower case on windows (MyCommand.exe => mycommand).
908
912
909 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
913 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
910 Macros are now callable objects that inherit from ipapi.IPyAutocall,
914 Macros are now callable objects that inherit from ipapi.IPyAutocall,
911 i.e. get autocalled regardless of system autocall setting.
915 i.e. get autocalled regardless of system autocall setting.
912
916
913 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
917 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
914
918
915 * IPython/rlineimpl.py: check for clear_history in readline and
919 * IPython/rlineimpl.py: check for clear_history in readline and
916 make it a dummy no-op if not available. This function isn't
920 make it a dummy no-op if not available. This function isn't
917 guaranteed to be in the API and appeared in Python 2.4, so we need
921 guaranteed to be in the API and appeared in Python 2.4, so we need
918 to check it ourselves. Also, clean up this file quite a bit.
922 to check it ourselves. Also, clean up this file quite a bit.
919
923
920 * ipython.1: update man page and full manual with information
924 * ipython.1: update man page and full manual with information
921 about threads (remove outdated warning). Closes #151.
925 about threads (remove outdated warning). Closes #151.
922
926
923 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
927 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
924
928
925 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
929 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
926 in trunk (note that this made it into the 0.8.1 release already,
930 in trunk (note that this made it into the 0.8.1 release already,
927 but the changelogs didn't get coordinated). Many thanks to Gael
931 but the changelogs didn't get coordinated). Many thanks to Gael
928 Varoquaux <gael.varoquaux-AT-normalesup.org>
932 Varoquaux <gael.varoquaux-AT-normalesup.org>
929
933
930 2007-05-09 *** Released version 0.8.1
934 2007-05-09 *** Released version 0.8.1
931
935
932 2007-05-10 Walter Doerwald <walter@livinglogic.de>
936 2007-05-10 Walter Doerwald <walter@livinglogic.de>
933
937
934 * IPython/Extensions/igrid.py: Incorporate html help into
938 * IPython/Extensions/igrid.py: Incorporate html help into
935 the module, so we don't have to search for the file.
939 the module, so we don't have to search for the file.
936
940
937 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
941 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
938
942
939 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
943 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
940
944
941 2007-04-30 Ville Vainio <vivainio@gmail.com>
945 2007-04-30 Ville Vainio <vivainio@gmail.com>
942
946
943 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
947 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
944 user has illegal (non-ascii) home directory name
948 user has illegal (non-ascii) home directory name
945
949
946 2007-04-27 Ville Vainio <vivainio@gmail.com>
950 2007-04-27 Ville Vainio <vivainio@gmail.com>
947
951
948 * platutils_win32.py: implement set_term_title for windows
952 * platutils_win32.py: implement set_term_title for windows
949
953
950 * Update version number
954 * Update version number
951
955
952 * ipy_profile_sh.py: more informative prompt (2 dir levels)
956 * ipy_profile_sh.py: more informative prompt (2 dir levels)
953
957
954 2007-04-26 Walter Doerwald <walter@livinglogic.de>
958 2007-04-26 Walter Doerwald <walter@livinglogic.de>
955
959
956 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
960 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
957 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
961 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
958 bug discovered by Ville).
962 bug discovered by Ville).
959
963
960 2007-04-26 Ville Vainio <vivainio@gmail.com>
964 2007-04-26 Ville Vainio <vivainio@gmail.com>
961
965
962 * Extensions/ipy_completers.py: Olivier's module completer now
966 * Extensions/ipy_completers.py: Olivier's module completer now
963 saves the list of root modules if it takes > 4 secs on the first run.
967 saves the list of root modules if it takes > 4 secs on the first run.
964
968
965 * Magic.py (%rehashx): %rehashx now clears the completer cache
969 * Magic.py (%rehashx): %rehashx now clears the completer cache
966
970
967
971
968 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
972 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
969
973
970 * ipython.el: fix incorrect color scheme, reported by Stefan.
974 * ipython.el: fix incorrect color scheme, reported by Stefan.
971 Closes #149.
975 Closes #149.
972
976
973 * IPython/PyColorize.py (Parser.format2): fix state-handling
977 * IPython/PyColorize.py (Parser.format2): fix state-handling
974 logic. I still don't like how that code handles state, but at
978 logic. I still don't like how that code handles state, but at
975 least now it should be correct, if inelegant. Closes #146.
979 least now it should be correct, if inelegant. Closes #146.
976
980
977 2007-04-25 Ville Vainio <vivainio@gmail.com>
981 2007-04-25 Ville Vainio <vivainio@gmail.com>
978
982
979 * Extensions/ipy_which.py: added extension for %which magic, works
983 * Extensions/ipy_which.py: added extension for %which magic, works
980 a lot like unix 'which' but also finds and expands aliases, and
984 a lot like unix 'which' but also finds and expands aliases, and
981 allows wildcards.
985 allows wildcards.
982
986
983 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
987 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
984 as opposed to returning nothing.
988 as opposed to returning nothing.
985
989
986 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
990 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
987 ipy_stock_completers on default profile, do import on sh profile.
991 ipy_stock_completers on default profile, do import on sh profile.
988
992
989 2007-04-22 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
993 2007-04-22 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
990
994
991 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
995 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
992 like ipython.py foo.py which raised a IndexError.
996 like ipython.py foo.py which raised a IndexError.
993
997
994 2007-04-21 Ville Vainio <vivainio@gmail.com>
998 2007-04-21 Ville Vainio <vivainio@gmail.com>
995
999
996 * Extensions/ipy_extutil.py: added extension to manage other ipython
1000 * Extensions/ipy_extutil.py: added extension to manage other ipython
997 extensions. Now only supports 'ls' == list extensions.
1001 extensions. Now only supports 'ls' == list extensions.
998
1002
999 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
1003 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
1000
1004
1001 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
1005 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
1002 would prevent use of the exception system outside of a running
1006 would prevent use of the exception system outside of a running
1003 IPython instance.
1007 IPython instance.
1004
1008
1005 2007-04-20 Ville Vainio <vivainio@gmail.com>
1009 2007-04-20 Ville Vainio <vivainio@gmail.com>
1006
1010
1007 * Extensions/ipy_render.py: added extension for easy
1011 * Extensions/ipy_render.py: added extension for easy
1008 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
1012 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
1009 'Iptl' template notation,
1013 'Iptl' template notation,
1010
1014
1011 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
1015 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
1012 safer & faster 'import' completer.
1016 safer & faster 'import' completer.
1013
1017
1014 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
1018 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
1015 and _ip.defalias(name, command).
1019 and _ip.defalias(name, command).
1016
1020
1017 * Extensions/ipy_exportdb.py: New extension for exporting all the
1021 * Extensions/ipy_exportdb.py: New extension for exporting all the
1018 %store'd data in a portable format (normal ipapi calls like
1022 %store'd data in a portable format (normal ipapi calls like
1019 defmacro() etc.)
1023 defmacro() etc.)
1020
1024
1021 2007-04-19 Ville Vainio <vivainio@gmail.com>
1025 2007-04-19 Ville Vainio <vivainio@gmail.com>
1022
1026
1023 * upgrade_dir.py: skip junk files like *.pyc
1027 * upgrade_dir.py: skip junk files like *.pyc
1024
1028
1025 * Release.py: version number to 0.8.1
1029 * Release.py: version number to 0.8.1
1026
1030
1027 2007-04-18 Ville Vainio <vivainio@gmail.com>
1031 2007-04-18 Ville Vainio <vivainio@gmail.com>
1028
1032
1029 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
1033 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
1030 and later on win32.
1034 and later on win32.
1031
1035
1032 2007-04-16 Ville Vainio <vivainio@gmail.com>
1036 2007-04-16 Ville Vainio <vivainio@gmail.com>
1033
1037
1034 * iplib.py (showtraceback): Do not crash when running w/o readline.
1038 * iplib.py (showtraceback): Do not crash when running w/o readline.
1035
1039
1036 2007-04-12 Walter Doerwald <walter@livinglogic.de>
1040 2007-04-12 Walter Doerwald <walter@livinglogic.de>
1037
1041
1038 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
1042 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
1039 sorted (case sensitive with files and dirs mixed).
1043 sorted (case sensitive with files and dirs mixed).
1040
1044
1041 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
1045 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
1042
1046
1043 * IPython/Release.py (version): Open trunk for 0.8.1 development.
1047 * IPython/Release.py (version): Open trunk for 0.8.1 development.
1044
1048
1045 2007-04-10 *** Released version 0.8.0
1049 2007-04-10 *** Released version 0.8.0
1046
1050
1047 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
1051 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
1048
1052
1049 * Tag 0.8.0 for release.
1053 * Tag 0.8.0 for release.
1050
1054
1051 * IPython/iplib.py (reloadhist): add API function to cleanly
1055 * IPython/iplib.py (reloadhist): add API function to cleanly
1052 reload the readline history, which was growing inappropriately on
1056 reload the readline history, which was growing inappropriately on
1053 every %run call.
1057 every %run call.
1054
1058
1055 * win32_manual_post_install.py (run): apply last part of Nicolas
1059 * win32_manual_post_install.py (run): apply last part of Nicolas
1056 Pernetty's patch (I'd accidentally applied it in a different
1060 Pernetty's patch (I'd accidentally applied it in a different
1057 directory and this particular file didn't get patched).
1061 directory and this particular file didn't get patched).
1058
1062
1059 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
1063 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
1060
1064
1061 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
1065 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
1062 find the main thread id and use the proper API call. Thanks to
1066 find the main thread id and use the proper API call. Thanks to
1063 Stefan for the fix.
1067 Stefan for the fix.
1064
1068
1065 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
1069 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
1066 unit tests to reflect fixed ticket #52, and add more tests sent by
1070 unit tests to reflect fixed ticket #52, and add more tests sent by
1067 him.
1071 him.
1068
1072
1069 * IPython/iplib.py (raw_input): restore the readline completer
1073 * IPython/iplib.py (raw_input): restore the readline completer
1070 state on every input, in case third-party code messed it up.
1074 state on every input, in case third-party code messed it up.
1071 (_prefilter): revert recent addition of early-escape checks which
1075 (_prefilter): revert recent addition of early-escape checks which
1072 prevent many valid alias calls from working.
1076 prevent many valid alias calls from working.
1073
1077
1074 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
1078 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
1075 flag for sigint handler so we don't run a full signal() call on
1079 flag for sigint handler so we don't run a full signal() call on
1076 each runcode access.
1080 each runcode access.
1077
1081
1078 * IPython/Magic.py (magic_whos): small improvement to diagnostic
1082 * IPython/Magic.py (magic_whos): small improvement to diagnostic
1079 message.
1083 message.
1080
1084
1081 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
1085 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
1082
1086
1083 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
1087 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
1084 asynchronous exceptions working, i.e., Ctrl-C can actually
1088 asynchronous exceptions working, i.e., Ctrl-C can actually
1085 interrupt long-running code in the multithreaded shells.
1089 interrupt long-running code in the multithreaded shells.
1086
1090
1087 This is using Tomer Filiba's great ctypes-based trick:
1091 This is using Tomer Filiba's great ctypes-based trick:
1088 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
1092 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
1089 this in the past, but hadn't been able to make it work before. So
1093 this in the past, but hadn't been able to make it work before. So
1090 far it looks like it's actually running, but this needs more
1094 far it looks like it's actually running, but this needs more
1091 testing. If it really works, I'll be *very* happy, and we'll owe
1095 testing. If it really works, I'll be *very* happy, and we'll owe
1092 a huge thank you to Tomer. My current implementation is ugly,
1096 a huge thank you to Tomer. My current implementation is ugly,
1093 hackish and uses nasty globals, but I don't want to try and clean
1097 hackish and uses nasty globals, but I don't want to try and clean
1094 anything up until we know if it actually works.
1098 anything up until we know if it actually works.
1095
1099
1096 NOTE: this feature needs ctypes to work. ctypes is included in
1100 NOTE: this feature needs ctypes to work. ctypes is included in
1097 Python2.5, but 2.4 users will need to manually install it. This
1101 Python2.5, but 2.4 users will need to manually install it. This
1098 feature makes multi-threaded shells so much more usable that it's
1102 feature makes multi-threaded shells so much more usable that it's
1099 a minor price to pay (ctypes is very easy to install, already a
1103 a minor price to pay (ctypes is very easy to install, already a
1100 requirement for win32 and available in major linux distros).
1104 requirement for win32 and available in major linux distros).
1101
1105
1102 2007-04-04 Ville Vainio <vivainio@gmail.com>
1106 2007-04-04 Ville Vainio <vivainio@gmail.com>
1103
1107
1104 * Extensions/ipy_completers.py, ipy_stock_completers.py:
1108 * Extensions/ipy_completers.py, ipy_stock_completers.py:
1105 Moved implementations of 'bundled' completers to ipy_completers.py,
1109 Moved implementations of 'bundled' completers to ipy_completers.py,
1106 they are only enabled in ipy_stock_completers.py.
1110 they are only enabled in ipy_stock_completers.py.
1107
1111
1108 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
1112 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
1109
1113
1110 * IPython/PyColorize.py (Parser.format2): Fix identation of
1114 * IPython/PyColorize.py (Parser.format2): Fix identation of
1111 colorzied output and return early if color scheme is NoColor, to
1115 colorzied output and return early if color scheme is NoColor, to
1112 avoid unnecessary and expensive tokenization. Closes #131.
1116 avoid unnecessary and expensive tokenization. Closes #131.
1113
1117
1114 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
1118 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
1115
1119
1116 * IPython/Debugger.py: disable the use of pydb version 1.17. It
1120 * IPython/Debugger.py: disable the use of pydb version 1.17. It
1117 has a critical bug (a missing import that makes post-mortem not
1121 has a critical bug (a missing import that makes post-mortem not
1118 work at all). Unfortunately as of this time, this is the version
1122 work at all). Unfortunately as of this time, this is the version
1119 shipped with Ubuntu Edgy, so quite a few people have this one. I
1123 shipped with Ubuntu Edgy, so quite a few people have this one. I
1120 hope Edgy will update to a more recent package.
1124 hope Edgy will update to a more recent package.
1121
1125
1122 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
1126 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
1123
1127
1124 * IPython/iplib.py (_prefilter): close #52, second part of a patch
1128 * IPython/iplib.py (_prefilter): close #52, second part of a patch
1125 set by Stefan (only the first part had been applied before).
1129 set by Stefan (only the first part had been applied before).
1126
1130
1127 * IPython/Extensions/ipy_stock_completers.py (module_completer):
1131 * IPython/Extensions/ipy_stock_completers.py (module_completer):
1128 remove usage of the dangerous pkgutil.walk_packages(). See
1132 remove usage of the dangerous pkgutil.walk_packages(). See
1129 details in comments left in the code.
1133 details in comments left in the code.
1130
1134
1131 * IPython/Magic.py (magic_whos): add support for numpy arrays
1135 * IPython/Magic.py (magic_whos): add support for numpy arrays
1132 similar to what we had for Numeric.
1136 similar to what we had for Numeric.
1133
1137
1134 * IPython/completer.py (IPCompleter.complete): extend the
1138 * IPython/completer.py (IPCompleter.complete): extend the
1135 complete() call API to support completions by other mechanisms
1139 complete() call API to support completions by other mechanisms
1136 than readline. Closes #109.
1140 than readline. Closes #109.
1137
1141
1138 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
1142 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
1139 protect against a bug in Python's execfile(). Closes #123.
1143 protect against a bug in Python's execfile(). Closes #123.
1140
1144
1141 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
1145 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
1142
1146
1143 * IPython/iplib.py (split_user_input): ensure that when splitting
1147 * IPython/iplib.py (split_user_input): ensure that when splitting
1144 user input, the part that can be treated as a python name is pure
1148 user input, the part that can be treated as a python name is pure
1145 ascii (Python identifiers MUST be pure ascii). Part of the
1149 ascii (Python identifiers MUST be pure ascii). Part of the
1146 ongoing Unicode support work.
1150 ongoing Unicode support work.
1147
1151
1148 * IPython/Prompts.py (prompt_specials_color): Add \N for the
1152 * IPython/Prompts.py (prompt_specials_color): Add \N for the
1149 actual prompt number, without any coloring. This allows users to
1153 actual prompt number, without any coloring. This allows users to
1150 produce numbered prompts with their own colors. Added after a
1154 produce numbered prompts with their own colors. Added after a
1151 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
1155 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
1152
1156
1153 2007-03-31 Walter Doerwald <walter@livinglogic.de>
1157 2007-03-31 Walter Doerwald <walter@livinglogic.de>
1154
1158
1155 * IPython/Extensions/igrid.py: Map the return key
1159 * IPython/Extensions/igrid.py: Map the return key
1156 to enter() and shift-return to enterattr().
1160 to enter() and shift-return to enterattr().
1157
1161
1158 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
1162 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
1159
1163
1160 * IPython/Magic.py (magic_psearch): add unicode support by
1164 * IPython/Magic.py (magic_psearch): add unicode support by
1161 encoding to ascii the input, since this routine also only deals
1165 encoding to ascii the input, since this routine also only deals
1162 with valid Python names. Fixes a bug reported by Stefan.
1166 with valid Python names. Fixes a bug reported by Stefan.
1163
1167
1164 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
1168 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
1165
1169
1166 * IPython/Magic.py (_inspect): convert unicode input into ascii
1170 * IPython/Magic.py (_inspect): convert unicode input into ascii
1167 before trying to evaluate it as a Python identifier. This fixes a
1171 before trying to evaluate it as a Python identifier. This fixes a
1168 problem that the new unicode support had introduced when analyzing
1172 problem that the new unicode support had introduced when analyzing
1169 long definition lines for functions.
1173 long definition lines for functions.
1170
1174
1171 2007-03-24 Walter Doerwald <walter@livinglogic.de>
1175 2007-03-24 Walter Doerwald <walter@livinglogic.de>
1172
1176
1173 * IPython/Extensions/igrid.py: Fix picking. Using
1177 * IPython/Extensions/igrid.py: Fix picking. Using
1174 igrid with wxPython 2.6 and -wthread should work now.
1178 igrid with wxPython 2.6 and -wthread should work now.
1175 igrid.display() simply tries to create a frame without
1179 igrid.display() simply tries to create a frame without
1176 an application. Only if this fails an application is created.
1180 an application. Only if this fails an application is created.
1177
1181
1178 2007-03-23 Walter Doerwald <walter@livinglogic.de>
1182 2007-03-23 Walter Doerwald <walter@livinglogic.de>
1179
1183
1180 * IPython/Extensions/path.py: Updated to version 2.2.
1184 * IPython/Extensions/path.py: Updated to version 2.2.
1181
1185
1182 2007-03-23 Ville Vainio <vivainio@gmail.com>
1186 2007-03-23 Ville Vainio <vivainio@gmail.com>
1183
1187
1184 * iplib.py: recursive alias expansion now works better, so that
1188 * iplib.py: recursive alias expansion now works better, so that
1185 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
1189 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
1186 doesn't trip up the process, if 'd' has been aliased to 'ls'.
1190 doesn't trip up the process, if 'd' has been aliased to 'ls'.
1187
1191
1188 * Extensions/ipy_gnuglobal.py added, provides %global magic
1192 * Extensions/ipy_gnuglobal.py added, provides %global magic
1189 for users of http://www.gnu.org/software/global
1193 for users of http://www.gnu.org/software/global
1190
1194
1191 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
1195 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
1192 Closes #52. Patch by Stefan van der Walt.
1196 Closes #52. Patch by Stefan van der Walt.
1193
1197
1194 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
1198 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
1195
1199
1196 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
1200 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
1197 respect the __file__ attribute when using %run. Thanks to a bug
1201 respect the __file__ attribute when using %run. Thanks to a bug
1198 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
1202 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
1199
1203
1200 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
1204 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
1201
1205
1202 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
1206 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
1203 input. Patch sent by Stefan.
1207 input. Patch sent by Stefan.
1204
1208
1205 2007-03-20 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
1209 2007-03-20 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
1206 * IPython/Extensions/ipy_stock_completer.py
1210 * IPython/Extensions/ipy_stock_completer.py
1207 shlex_split, fix bug in shlex_split. len function
1211 shlex_split, fix bug in shlex_split. len function
1208 call was missing an if statement. Caused shlex_split to
1212 call was missing an if statement. Caused shlex_split to
1209 sometimes return "" as last element.
1213 sometimes return "" as last element.
1210
1214
1211 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
1215 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
1212
1216
1213 * IPython/completer.py
1217 * IPython/completer.py
1214 (IPCompleter.file_matches.single_dir_expand): fix a problem
1218 (IPCompleter.file_matches.single_dir_expand): fix a problem
1215 reported by Stefan, where directories containign a single subdir
1219 reported by Stefan, where directories containign a single subdir
1216 would be completed too early.
1220 would be completed too early.
1217
1221
1218 * IPython/Shell.py (_load_pylab): Make the execution of 'from
1222 * IPython/Shell.py (_load_pylab): Make the execution of 'from
1219 pylab import *' when -pylab is given be optional. A new flag,
1223 pylab import *' when -pylab is given be optional. A new flag,
1220 pylab_import_all controls this behavior, the default is True for
1224 pylab_import_all controls this behavior, the default is True for
1221 backwards compatibility.
1225 backwards compatibility.
1222
1226
1223 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
1227 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
1224 modified) R. Bernstein's patch for fully syntax highlighted
1228 modified) R. Bernstein's patch for fully syntax highlighted
1225 tracebacks. The functionality is also available under ultraTB for
1229 tracebacks. The functionality is also available under ultraTB for
1226 non-ipython users (someone using ultraTB but outside an ipython
1230 non-ipython users (someone using ultraTB but outside an ipython
1227 session). They can select the color scheme by setting the
1231 session). They can select the color scheme by setting the
1228 module-level global DEFAULT_SCHEME. The highlight functionality
1232 module-level global DEFAULT_SCHEME. The highlight functionality
1229 also works when debugging.
1233 also works when debugging.
1230
1234
1231 * IPython/genutils.py (IOStream.close): small patch by
1235 * IPython/genutils.py (IOStream.close): small patch by
1232 R. Bernstein for improved pydb support.
1236 R. Bernstein for improved pydb support.
1233
1237
1234 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
1238 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
1235 DaveS <davls@telus.net> to improve support of debugging under
1239 DaveS <davls@telus.net> to improve support of debugging under
1236 NTEmacs, including improved pydb behavior.
1240 NTEmacs, including improved pydb behavior.
1237
1241
1238 * IPython/Magic.py (magic_prun): Fix saving of profile info for
1242 * IPython/Magic.py (magic_prun): Fix saving of profile info for
1239 Python 2.5, where the stats object API changed a little. Thanks
1243 Python 2.5, where the stats object API changed a little. Thanks
1240 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
1244 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
1241
1245
1242 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
1246 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
1243 Pernetty's patch to improve support for (X)Emacs under Win32.
1247 Pernetty's patch to improve support for (X)Emacs under Win32.
1244
1248
1245 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
1249 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
1246
1250
1247 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
1251 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
1248 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
1252 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
1249 a report by Nik Tautenhahn.
1253 a report by Nik Tautenhahn.
1250
1254
1251 2007-03-16 Walter Doerwald <walter@livinglogic.de>
1255 2007-03-16 Walter Doerwald <walter@livinglogic.de>
1252
1256
1253 * setup.py: Add the igrid help files to the list of data files
1257 * setup.py: Add the igrid help files to the list of data files
1254 to be installed alongside igrid.
1258 to be installed alongside igrid.
1255 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
1259 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
1256 Show the input object of the igrid browser as the window tile.
1260 Show the input object of the igrid browser as the window tile.
1257 Show the object the cursor is on in the statusbar.
1261 Show the object the cursor is on in the statusbar.
1258
1262
1259 2007-03-15 Ville Vainio <vivainio@gmail.com>
1263 2007-03-15 Ville Vainio <vivainio@gmail.com>
1260
1264
1261 * Extensions/ipy_stock_completers.py: Fixed exception
1265 * Extensions/ipy_stock_completers.py: Fixed exception
1262 on mismatching quotes in %run completer. Patch by
1266 on mismatching quotes in %run completer. Patch by
1263 Jorgen Stenarson. Closes #127.
1267 Jorgen Stenarson. Closes #127.
1264
1268
1265 2007-03-14 Ville Vainio <vivainio@gmail.com>
1269 2007-03-14 Ville Vainio <vivainio@gmail.com>
1266
1270
1267 * Extensions/ext_rehashdir.py: Do not do auto_alias
1271 * Extensions/ext_rehashdir.py: Do not do auto_alias
1268 in %rehashdir, it clobbers %store'd aliases.
1272 in %rehashdir, it clobbers %store'd aliases.
1269
1273
1270 * UserConfig/ipy_profile_sh.py: envpersist.py extension
1274 * UserConfig/ipy_profile_sh.py: envpersist.py extension
1271 (beefed up %env) imported for sh profile.
1275 (beefed up %env) imported for sh profile.
1272
1276
1273 2007-03-10 Walter Doerwald <walter@livinglogic.de>
1277 2007-03-10 Walter Doerwald <walter@livinglogic.de>
1274
1278
1275 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
1279 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
1276 as the default browser.
1280 as the default browser.
1277 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
1281 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
1278 As igrid displays all attributes it ever encounters, fetch() (which has
1282 As igrid displays all attributes it ever encounters, fetch() (which has
1279 been renamed to _fetch()) doesn't have to recalculate the display attributes
1283 been renamed to _fetch()) doesn't have to recalculate the display attributes
1280 every time a new item is fetched. This should speed up scrolling.
1284 every time a new item is fetched. This should speed up scrolling.
1281
1285
1282 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
1286 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
1283
1287
1284 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
1288 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
1285 Schmolck's recently reported tab-completion bug (my previous one
1289 Schmolck's recently reported tab-completion bug (my previous one
1286 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
1290 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
1287
1291
1288 2007-03-09 Walter Doerwald <walter@livinglogic.de>
1292 2007-03-09 Walter Doerwald <walter@livinglogic.de>
1289
1293
1290 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
1294 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
1291 Close help window if exiting igrid.
1295 Close help window if exiting igrid.
1292
1296
1293 2007-03-02 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
1297 2007-03-02 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
1294
1298
1295 * IPython/Extensions/ipy_defaults.py: Check if readline is available
1299 * IPython/Extensions/ipy_defaults.py: Check if readline is available
1296 before calling functions from readline.
1300 before calling functions from readline.
1297
1301
1298 2007-03-02 Walter Doerwald <walter@livinglogic.de>
1302 2007-03-02 Walter Doerwald <walter@livinglogic.de>
1299
1303
1300 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
1304 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
1301 igrid is a wxPython-based display object for ipipe. If your system has
1305 igrid is a wxPython-based display object for ipipe. If your system has
1302 wx installed igrid will be the default display. Without wx ipipe falls
1306 wx installed igrid will be the default display. Without wx ipipe falls
1303 back to ibrowse (which needs curses). If no curses is installed ipipe
1307 back to ibrowse (which needs curses). If no curses is installed ipipe
1304 falls back to idump.
1308 falls back to idump.
1305
1309
1306 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
1310 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
1307
1311
1308 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
1312 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
1309 my changes from yesterday, they introduced bugs. Will reactivate
1313 my changes from yesterday, they introduced bugs. Will reactivate
1310 once I get a correct solution, which will be much easier thanks to
1314 once I get a correct solution, which will be much easier thanks to
1311 Dan Milstein's new prefilter test suite.
1315 Dan Milstein's new prefilter test suite.
1312
1316
1313 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
1317 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
1314
1318
1315 * IPython/iplib.py (split_user_input): fix input splitting so we
1319 * IPython/iplib.py (split_user_input): fix input splitting so we
1316 don't attempt attribute accesses on things that can't possibly be
1320 don't attempt attribute accesses on things that can't possibly be
1317 valid Python attributes. After a bug report by Alex Schmolck.
1321 valid Python attributes. After a bug report by Alex Schmolck.
1318 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
1322 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
1319 %magic with explicit % prefix.
1323 %magic with explicit % prefix.
1320
1324
1321 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
1325 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
1322
1326
1323 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
1327 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
1324 avoid a DeprecationWarning from GTK.
1328 avoid a DeprecationWarning from GTK.
1325
1329
1326 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
1330 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
1327
1331
1328 * IPython/genutils.py (clock): I modified clock() to return total
1332 * IPython/genutils.py (clock): I modified clock() to return total
1329 time, user+system. This is a more commonly needed metric. I also
1333 time, user+system. This is a more commonly needed metric. I also
1330 introduced the new clocku/clocks to get only user/system time if
1334 introduced the new clocku/clocks to get only user/system time if
1331 one wants those instead.
1335 one wants those instead.
1332
1336
1333 ***WARNING: API CHANGE*** clock() used to return only user time,
1337 ***WARNING: API CHANGE*** clock() used to return only user time,
1334 so if you want exactly the same results as before, use clocku
1338 so if you want exactly the same results as before, use clocku
1335 instead.
1339 instead.
1336
1340
1337 2007-02-22 Ville Vainio <vivainio@gmail.com>
1341 2007-02-22 Ville Vainio <vivainio@gmail.com>
1338
1342
1339 * IPython/Extensions/ipy_p4.py: Extension for improved
1343 * IPython/Extensions/ipy_p4.py: Extension for improved
1340 p4 (perforce version control system) experience.
1344 p4 (perforce version control system) experience.
1341 Adds %p4 magic with p4 command completion and
1345 Adds %p4 magic with p4 command completion and
1342 automatic -G argument (marshall output as python dict)
1346 automatic -G argument (marshall output as python dict)
1343
1347
1344 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
1348 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
1345
1349
1346 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
1350 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
1347 stop marks.
1351 stop marks.
1348 (ClearingMixin): a simple mixin to easily make a Demo class clear
1352 (ClearingMixin): a simple mixin to easily make a Demo class clear
1349 the screen in between blocks and have empty marquees. The
1353 the screen in between blocks and have empty marquees. The
1350 ClearDemo and ClearIPDemo classes that use it are included.
1354 ClearDemo and ClearIPDemo classes that use it are included.
1351
1355
1352 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
1356 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
1353
1357
1354 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
1358 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
1355 protect against exceptions at Python shutdown time. Patch
1359 protect against exceptions at Python shutdown time. Patch
1356 sumbmitted to upstream.
1360 sumbmitted to upstream.
1357
1361
1358 2007-02-14 Walter Doerwald <walter@livinglogic.de>
1362 2007-02-14 Walter Doerwald <walter@livinglogic.de>
1359
1363
1360 * IPython/Extensions/ibrowse.py: If entering the first object level
1364 * IPython/Extensions/ibrowse.py: If entering the first object level
1361 (i.e. the object for which the browser has been started) fails,
1365 (i.e. the object for which the browser has been started) fails,
1362 now the error is raised directly (aborting the browser) instead of
1366 now the error is raised directly (aborting the browser) instead of
1363 running into an empty levels list later.
1367 running into an empty levels list later.
1364
1368
1365 2007-02-03 Walter Doerwald <walter@livinglogic.de>
1369 2007-02-03 Walter Doerwald <walter@livinglogic.de>
1366
1370
1367 * IPython/Extensions/ipipe.py: Add an xrepr implementation
1371 * IPython/Extensions/ipipe.py: Add an xrepr implementation
1368 for the noitem object.
1372 for the noitem object.
1369
1373
1370 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
1374 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
1371
1375
1372 * IPython/completer.py (Completer.attr_matches): Fix small
1376 * IPython/completer.py (Completer.attr_matches): Fix small
1373 tab-completion bug with Enthought Traits objects with units.
1377 tab-completion bug with Enthought Traits objects with units.
1374 Thanks to a bug report by Tom Denniston
1378 Thanks to a bug report by Tom Denniston
1375 <tom.denniston-AT-alum.dartmouth.org>.
1379 <tom.denniston-AT-alum.dartmouth.org>.
1376
1380
1377 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
1381 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
1378
1382
1379 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
1383 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
1380 bug where only .ipy or .py would be completed. Once the first
1384 bug where only .ipy or .py would be completed. Once the first
1381 argument to %run has been given, all completions are valid because
1385 argument to %run has been given, all completions are valid because
1382 they are the arguments to the script, which may well be non-python
1386 they are the arguments to the script, which may well be non-python
1383 filenames.
1387 filenames.
1384
1388
1385 * IPython/irunner.py (InteractiveRunner.run_source): major updates
1389 * IPython/irunner.py (InteractiveRunner.run_source): major updates
1386 to irunner to allow it to correctly support real doctesting of
1390 to irunner to allow it to correctly support real doctesting of
1387 out-of-process ipython code.
1391 out-of-process ipython code.
1388
1392
1389 * IPython/Magic.py (magic_cd): Make the setting of the terminal
1393 * IPython/Magic.py (magic_cd): Make the setting of the terminal
1390 title an option (-noterm_title) because it completely breaks
1394 title an option (-noterm_title) because it completely breaks
1391 doctesting.
1395 doctesting.
1392
1396
1393 * IPython/demo.py: fix IPythonDemo class that was not actually working.
1397 * IPython/demo.py: fix IPythonDemo class that was not actually working.
1394
1398
1395 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
1399 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
1396
1400
1397 * IPython/irunner.py (main): fix small bug where extensions were
1401 * IPython/irunner.py (main): fix small bug where extensions were
1398 not being correctly recognized.
1402 not being correctly recognized.
1399
1403
1400 2007-01-23 Walter Doerwald <walter@livinglogic.de>
1404 2007-01-23 Walter Doerwald <walter@livinglogic.de>
1401
1405
1402 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
1406 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
1403 a string containing a single line yields the string itself as the
1407 a string containing a single line yields the string itself as the
1404 only item.
1408 only item.
1405
1409
1406 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
1410 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
1407 object if it's the same as the one on the last level (This avoids
1411 object if it's the same as the one on the last level (This avoids
1408 infinite recursion for one line strings).
1412 infinite recursion for one line strings).
1409
1413
1410 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1414 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1411
1415
1412 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
1416 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
1413 all output streams before printing tracebacks. This ensures that
1417 all output streams before printing tracebacks. This ensures that
1414 user output doesn't end up interleaved with traceback output.
1418 user output doesn't end up interleaved with traceback output.
1415
1419
1416 2007-01-10 Ville Vainio <vivainio@gmail.com>
1420 2007-01-10 Ville Vainio <vivainio@gmail.com>
1417
1421
1418 * Extensions/envpersist.py: Turbocharged %env that remembers
1422 * Extensions/envpersist.py: Turbocharged %env that remembers
1419 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
1423 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
1420 "%env VISUAL=jed".
1424 "%env VISUAL=jed".
1421
1425
1422 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
1426 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
1423
1427
1424 * IPython/iplib.py (showtraceback): ensure that we correctly call
1428 * IPython/iplib.py (showtraceback): ensure that we correctly call
1425 custom handlers in all cases (some with pdb were slipping through,
1429 custom handlers in all cases (some with pdb were slipping through,
1426 but I'm not exactly sure why).
1430 but I'm not exactly sure why).
1427
1431
1428 * IPython/Debugger.py (Tracer.__init__): added new class to
1432 * IPython/Debugger.py (Tracer.__init__): added new class to
1429 support set_trace-like usage of IPython's enhanced debugger.
1433 support set_trace-like usage of IPython's enhanced debugger.
1430
1434
1431 2006-12-24 Ville Vainio <vivainio@gmail.com>
1435 2006-12-24 Ville Vainio <vivainio@gmail.com>
1432
1436
1433 * ipmaker.py: more informative message when ipy_user_conf
1437 * ipmaker.py: more informative message when ipy_user_conf
1434 import fails (suggest running %upgrade).
1438 import fails (suggest running %upgrade).
1435
1439
1436 * tools/run_ipy_in_profiler.py: Utility to see where
1440 * tools/run_ipy_in_profiler.py: Utility to see where
1437 the time during IPython startup is spent.
1441 the time during IPython startup is spent.
1438
1442
1439 2006-12-20 Ville Vainio <vivainio@gmail.com>
1443 2006-12-20 Ville Vainio <vivainio@gmail.com>
1440
1444
1441 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
1445 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
1442
1446
1443 * ipapi.py: Add new ipapi method, expand_alias.
1447 * ipapi.py: Add new ipapi method, expand_alias.
1444
1448
1445 * Release.py: Bump up version to 0.7.4.svn
1449 * Release.py: Bump up version to 0.7.4.svn
1446
1450
1447 2006-12-17 Ville Vainio <vivainio@gmail.com>
1451 2006-12-17 Ville Vainio <vivainio@gmail.com>
1448
1452
1449 * Extensions/jobctrl.py: Fixed &cmd arg arg...
1453 * Extensions/jobctrl.py: Fixed &cmd arg arg...
1450 to work properly on posix too
1454 to work properly on posix too
1451
1455
1452 * Release.py: Update revnum (version is still just 0.7.3).
1456 * Release.py: Update revnum (version is still just 0.7.3).
1453
1457
1454 2006-12-15 Ville Vainio <vivainio@gmail.com>
1458 2006-12-15 Ville Vainio <vivainio@gmail.com>
1455
1459
1456 * scripts/ipython_win_post_install: create ipython.py in
1460 * scripts/ipython_win_post_install: create ipython.py in
1457 prefix + "/scripts".
1461 prefix + "/scripts".
1458
1462
1459 * Release.py: Update version to 0.7.3.
1463 * Release.py: Update version to 0.7.3.
1460
1464
1461 2006-12-14 Ville Vainio <vivainio@gmail.com>
1465 2006-12-14 Ville Vainio <vivainio@gmail.com>
1462
1466
1463 * scripts/ipython_win_post_install: Overwrite old shortcuts
1467 * scripts/ipython_win_post_install: Overwrite old shortcuts
1464 if they already exist
1468 if they already exist
1465
1469
1466 * Release.py: release 0.7.3rc2
1470 * Release.py: release 0.7.3rc2
1467
1471
1468 2006-12-13 Ville Vainio <vivainio@gmail.com>
1472 2006-12-13 Ville Vainio <vivainio@gmail.com>
1469
1473
1470 * Branch and update Release.py for 0.7.3rc1
1474 * Branch and update Release.py for 0.7.3rc1
1471
1475
1472 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
1476 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
1473
1477
1474 * IPython/Shell.py (IPShellWX): update for current WX naming
1478 * IPython/Shell.py (IPShellWX): update for current WX naming
1475 conventions, to avoid a deprecation warning with current WX
1479 conventions, to avoid a deprecation warning with current WX
1476 versions. Thanks to a report by Danny Shevitz.
1480 versions. Thanks to a report by Danny Shevitz.
1477
1481
1478 2006-12-12 Ville Vainio <vivainio@gmail.com>
1482 2006-12-12 Ville Vainio <vivainio@gmail.com>
1479
1483
1480 * ipmaker.py: apply david cournapeau's patch to make
1484 * ipmaker.py: apply david cournapeau's patch to make
1481 import_some work properly even when ipythonrc does
1485 import_some work properly even when ipythonrc does
1482 import_some on empty list (it was an old bug!).
1486 import_some on empty list (it was an old bug!).
1483
1487
1484 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
1488 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
1485 Add deprecation note to ipythonrc and a url to wiki
1489 Add deprecation note to ipythonrc and a url to wiki
1486 in ipy_user_conf.py
1490 in ipy_user_conf.py
1487
1491
1488
1492
1489 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
1493 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
1490 as if it was typed on IPython command prompt, i.e.
1494 as if it was typed on IPython command prompt, i.e.
1491 as IPython script.
1495 as IPython script.
1492
1496
1493 * example-magic.py, magic_grepl.py: remove outdated examples
1497 * example-magic.py, magic_grepl.py: remove outdated examples
1494
1498
1495 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
1499 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
1496
1500
1497 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
1501 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
1498 is called before any exception has occurred.
1502 is called before any exception has occurred.
1499
1503
1500 2006-12-08 Ville Vainio <vivainio@gmail.com>
1504 2006-12-08 Ville Vainio <vivainio@gmail.com>
1501
1505
1502 * Extensions/ipy_stock_completers.py: fix cd completer
1506 * Extensions/ipy_stock_completers.py: fix cd completer
1503 to translate /'s to \'s again.
1507 to translate /'s to \'s again.
1504
1508
1505 * completer.py: prevent traceback on file completions w/
1509 * completer.py: prevent traceback on file completions w/
1506 backslash.
1510 backslash.
1507
1511
1508 * Release.py: Update release number to 0.7.3b3 for release
1512 * Release.py: Update release number to 0.7.3b3 for release
1509
1513
1510 2006-12-07 Ville Vainio <vivainio@gmail.com>
1514 2006-12-07 Ville Vainio <vivainio@gmail.com>
1511
1515
1512 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
1516 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
1513 while executing external code. Provides more shell-like behaviour
1517 while executing external code. Provides more shell-like behaviour
1514 and overall better response to ctrl + C / ctrl + break.
1518 and overall better response to ctrl + C / ctrl + break.
1515
1519
1516 * tools/make_tarball.py: new script to create tarball straight from svn
1520 * tools/make_tarball.py: new script to create tarball straight from svn
1517 (setup.py sdist doesn't work on win32).
1521 (setup.py sdist doesn't work on win32).
1518
1522
1519 * Extensions/ipy_stock_completers.py: fix cd completer to give up
1523 * Extensions/ipy_stock_completers.py: fix cd completer to give up
1520 on dirnames with spaces and use the default completer instead.
1524 on dirnames with spaces and use the default completer instead.
1521
1525
1522 * Revision.py: Change version to 0.7.3b2 for release.
1526 * Revision.py: Change version to 0.7.3b2 for release.
1523
1527
1524 2006-12-05 Ville Vainio <vivainio@gmail.com>
1528 2006-12-05 Ville Vainio <vivainio@gmail.com>
1525
1529
1526 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
1530 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
1527 pydb patch 4 (rm debug printing, py 2.5 checking)
1531 pydb patch 4 (rm debug printing, py 2.5 checking)
1528
1532
1529 2006-11-30 Walter Doerwald <walter@livinglogic.de>
1533 2006-11-30 Walter Doerwald <walter@livinglogic.de>
1530 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
1534 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
1531 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
1535 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
1532 "refreshfind" (mapped to "R") does the same but tries to go back to the same
1536 "refreshfind" (mapped to "R") does the same but tries to go back to the same
1533 object the cursor was on before the refresh. The command "markrange" is
1537 object the cursor was on before the refresh. The command "markrange" is
1534 mapped to "%" now.
1538 mapped to "%" now.
1535 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
1539 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
1536
1540
1537 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
1541 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
1538
1542
1539 * IPython/Magic.py (magic_debug): new %debug magic to activate the
1543 * IPython/Magic.py (magic_debug): new %debug magic to activate the
1540 interactive debugger on the last traceback, without having to call
1544 interactive debugger on the last traceback, without having to call
1541 %pdb and rerun your code. Made minor changes in various modules,
1545 %pdb and rerun your code. Made minor changes in various modules,
1542 should automatically recognize pydb if available.
1546 should automatically recognize pydb if available.
1543
1547
1544 2006-11-28 Ville Vainio <vivainio@gmail.com>
1548 2006-11-28 Ville Vainio <vivainio@gmail.com>
1545
1549
1546 * completer.py: If the text start with !, show file completions
1550 * completer.py: If the text start with !, show file completions
1547 properly. This helps when trying to complete command name
1551 properly. This helps when trying to complete command name
1548 for shell escapes.
1552 for shell escapes.
1549
1553
1550 2006-11-27 Ville Vainio <vivainio@gmail.com>
1554 2006-11-27 Ville Vainio <vivainio@gmail.com>
1551
1555
1552 * ipy_stock_completers.py: bzr completer submitted by Stefan van
1556 * ipy_stock_completers.py: bzr completer submitted by Stefan van
1553 der Walt. Clean up svn and hg completers by using a common
1557 der Walt. Clean up svn and hg completers by using a common
1554 vcs_completer.
1558 vcs_completer.
1555
1559
1556 2006-11-26 Ville Vainio <vivainio@gmail.com>
1560 2006-11-26 Ville Vainio <vivainio@gmail.com>
1557
1561
1558 * Remove ipconfig and %config; you should use _ip.options structure
1562 * Remove ipconfig and %config; you should use _ip.options structure
1559 directly instead!
1563 directly instead!
1560
1564
1561 * genutils.py: add wrap_deprecated function for deprecating callables
1565 * genutils.py: add wrap_deprecated function for deprecating callables
1562
1566
1563 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
1567 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
1564 _ip.system instead. ipalias is redundant.
1568 _ip.system instead. ipalias is redundant.
1565
1569
1566 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
1570 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
1567 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
1571 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
1568 explicit.
1572 explicit.
1569
1573
1570 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
1574 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
1571 completer. Try it by entering 'hg ' and pressing tab.
1575 completer. Try it by entering 'hg ' and pressing tab.
1572
1576
1573 * macro.py: Give Macro a useful __repr__ method
1577 * macro.py: Give Macro a useful __repr__ method
1574
1578
1575 * Magic.py: %whos abbreviates the typename of Macro for brevity.
1579 * Magic.py: %whos abbreviates the typename of Macro for brevity.
1576
1580
1577 2006-11-24 Walter Doerwald <walter@livinglogic.de>
1581 2006-11-24 Walter Doerwald <walter@livinglogic.de>
1578 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
1582 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
1579 we don't get a duplicate ipipe module, where registration of the xrepr
1583 we don't get a duplicate ipipe module, where registration of the xrepr
1580 implementation for Text is useless.
1584 implementation for Text is useless.
1581
1585
1582 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
1586 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
1583
1587
1584 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
1588 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
1585
1589
1586 2006-11-24 Ville Vainio <vivainio@gmail.com>
1590 2006-11-24 Ville Vainio <vivainio@gmail.com>
1587
1591
1588 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
1592 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
1589 try to use "cProfile" instead of the slower pure python
1593 try to use "cProfile" instead of the slower pure python
1590 "profile"
1594 "profile"
1591
1595
1592 2006-11-23 Ville Vainio <vivainio@gmail.com>
1596 2006-11-23 Ville Vainio <vivainio@gmail.com>
1593
1597
1594 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
1598 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
1595 Qt+IPython+Designer link in documentation.
1599 Qt+IPython+Designer link in documentation.
1596
1600
1597 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
1601 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
1598 correct Pdb object to %pydb.
1602 correct Pdb object to %pydb.
1599
1603
1600
1604
1601 2006-11-22 Walter Doerwald <walter@livinglogic.de>
1605 2006-11-22 Walter Doerwald <walter@livinglogic.de>
1602 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
1606 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
1603 generic xrepr(), otherwise the list implementation would kick in.
1607 generic xrepr(), otherwise the list implementation would kick in.
1604
1608
1605 2006-11-21 Ville Vainio <vivainio@gmail.com>
1609 2006-11-21 Ville Vainio <vivainio@gmail.com>
1606
1610
1607 * upgrade_dir.py: Now actually overwrites a nonmodified user file
1611 * upgrade_dir.py: Now actually overwrites a nonmodified user file
1608 with one from UserConfig.
1612 with one from UserConfig.
1609
1613
1610 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
1614 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
1611 it was missing which broke the sh profile.
1615 it was missing which broke the sh profile.
1612
1616
1613 * completer.py: file completer now uses explicit '/' instead
1617 * completer.py: file completer now uses explicit '/' instead
1614 of os.path.join, expansion of 'foo' was broken on win32
1618 of os.path.join, expansion of 'foo' was broken on win32
1615 if there was one directory with name 'foobar'.
1619 if there was one directory with name 'foobar'.
1616
1620
1617 * A bunch of patches from Kirill Smelkov:
1621 * A bunch of patches from Kirill Smelkov:
1618
1622
1619 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
1623 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
1620
1624
1621 * [patch 7/9] Implement %page -r (page in raw mode) -
1625 * [patch 7/9] Implement %page -r (page in raw mode) -
1622
1626
1623 * [patch 5/9] ScientificPython webpage has moved
1627 * [patch 5/9] ScientificPython webpage has moved
1624
1628
1625 * [patch 4/9] The manual mentions %ds, should be %dhist
1629 * [patch 4/9] The manual mentions %ds, should be %dhist
1626
1630
1627 * [patch 3/9] Kill old bits from %prun doc.
1631 * [patch 3/9] Kill old bits from %prun doc.
1628
1632
1629 * [patch 1/9] Fix typos here and there.
1633 * [patch 1/9] Fix typos here and there.
1630
1634
1631 2006-11-08 Ville Vainio <vivainio@gmail.com>
1635 2006-11-08 Ville Vainio <vivainio@gmail.com>
1632
1636
1633 * completer.py (attr_matches): catch all exceptions raised
1637 * completer.py (attr_matches): catch all exceptions raised
1634 by eval of expr with dots.
1638 by eval of expr with dots.
1635
1639
1636 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
1640 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
1637
1641
1638 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
1642 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
1639 input if it starts with whitespace. This allows you to paste
1643 input if it starts with whitespace. This allows you to paste
1640 indented input from any editor without manually having to type in
1644 indented input from any editor without manually having to type in
1641 the 'if 1:', which is convenient when working interactively.
1645 the 'if 1:', which is convenient when working interactively.
1642 Slightly modifed version of a patch by Bo Peng
1646 Slightly modifed version of a patch by Bo Peng
1643 <bpeng-AT-rice.edu>.
1647 <bpeng-AT-rice.edu>.
1644
1648
1645 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1649 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1646
1650
1647 * IPython/irunner.py (main): modified irunner so it automatically
1651 * IPython/irunner.py (main): modified irunner so it automatically
1648 recognizes the right runner to use based on the extension (.py for
1652 recognizes the right runner to use based on the extension (.py for
1649 python, .ipy for ipython and .sage for sage).
1653 python, .ipy for ipython and .sage for sage).
1650
1654
1651 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
1655 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
1652 visible in ipapi as ip.config(), to programatically control the
1656 visible in ipapi as ip.config(), to programatically control the
1653 internal rc object. There's an accompanying %config magic for
1657 internal rc object. There's an accompanying %config magic for
1654 interactive use, which has been enhanced to match the
1658 interactive use, which has been enhanced to match the
1655 funtionality in ipconfig.
1659 funtionality in ipconfig.
1656
1660
1657 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
1661 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
1658 so it's not just a toggle, it now takes an argument. Add support
1662 so it's not just a toggle, it now takes an argument. Add support
1659 for a customizable header when making system calls, as the new
1663 for a customizable header when making system calls, as the new
1660 system_header variable in the ipythonrc file.
1664 system_header variable in the ipythonrc file.
1661
1665
1662 2006-11-03 Walter Doerwald <walter@livinglogic.de>
1666 2006-11-03 Walter Doerwald <walter@livinglogic.de>
1663
1667
1664 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
1668 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
1665 generic functions (using Philip J. Eby's simplegeneric package).
1669 generic functions (using Philip J. Eby's simplegeneric package).
1666 This makes it possible to customize the display of third-party classes
1670 This makes it possible to customize the display of third-party classes
1667 without having to monkeypatch them. xiter() no longer supports a mode
1671 without having to monkeypatch them. xiter() no longer supports a mode
1668 argument and the XMode class has been removed. The same functionality can
1672 argument and the XMode class has been removed. The same functionality can
1669 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
1673 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
1670 One consequence of the switch to generic functions is that xrepr() and
1674 One consequence of the switch to generic functions is that xrepr() and
1671 xattrs() implementation must define the default value for the mode
1675 xattrs() implementation must define the default value for the mode
1672 argument themselves and xattrs() implementations must return real
1676 argument themselves and xattrs() implementations must return real
1673 descriptors.
1677 descriptors.
1674
1678
1675 * IPython/external: This new subpackage will contain all third-party
1679 * IPython/external: This new subpackage will contain all third-party
1676 packages that are bundled with IPython. (The first one is simplegeneric).
1680 packages that are bundled with IPython. (The first one is simplegeneric).
1677
1681
1678 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
1682 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
1679 directory which as been dropped in r1703.
1683 directory which as been dropped in r1703.
1680
1684
1681 * IPython/Extensions/ipipe.py (iless): Fixed.
1685 * IPython/Extensions/ipipe.py (iless): Fixed.
1682
1686
1683 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
1687 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
1684
1688
1685 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1689 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1686
1690
1687 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
1691 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
1688 handling in variable expansion so that shells and magics recognize
1692 handling in variable expansion so that shells and magics recognize
1689 function local scopes correctly. Bug reported by Brian.
1693 function local scopes correctly. Bug reported by Brian.
1690
1694
1691 * scripts/ipython: remove the very first entry in sys.path which
1695 * scripts/ipython: remove the very first entry in sys.path which
1692 Python auto-inserts for scripts, so that sys.path under IPython is
1696 Python auto-inserts for scripts, so that sys.path under IPython is
1693 as similar as possible to that under plain Python.
1697 as similar as possible to that under plain Python.
1694
1698
1695 * IPython/completer.py (IPCompleter.file_matches): Fix
1699 * IPython/completer.py (IPCompleter.file_matches): Fix
1696 tab-completion so that quotes are not closed unless the completion
1700 tab-completion so that quotes are not closed unless the completion
1697 is unambiguous. After a request by Stefan. Minor cleanups in
1701 is unambiguous. After a request by Stefan. Minor cleanups in
1698 ipy_stock_completers.
1702 ipy_stock_completers.
1699
1703
1700 2006-11-02 Ville Vainio <vivainio@gmail.com>
1704 2006-11-02 Ville Vainio <vivainio@gmail.com>
1701
1705
1702 * ipy_stock_completers.py: Add %run and %cd completers.
1706 * ipy_stock_completers.py: Add %run and %cd completers.
1703
1707
1704 * completer.py: Try running custom completer for both
1708 * completer.py: Try running custom completer for both
1705 "foo" and "%foo" if the command is just "foo". Ignore case
1709 "foo" and "%foo" if the command is just "foo". Ignore case
1706 when filtering possible completions.
1710 when filtering possible completions.
1707
1711
1708 * UserConfig/ipy_user_conf.py: install stock completers as default
1712 * UserConfig/ipy_user_conf.py: install stock completers as default
1709
1713
1710 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
1714 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
1711 simplified readline history save / restore through a wrapper
1715 simplified readline history save / restore through a wrapper
1712 function
1716 function
1713
1717
1714
1718
1715 2006-10-31 Ville Vainio <vivainio@gmail.com>
1719 2006-10-31 Ville Vainio <vivainio@gmail.com>
1716
1720
1717 * strdispatch.py, completer.py, ipy_stock_completers.py:
1721 * strdispatch.py, completer.py, ipy_stock_completers.py:
1718 Allow str_key ("command") in completer hooks. Implement
1722 Allow str_key ("command") in completer hooks. Implement
1719 trivial completer for 'import' (stdlib modules only). Rename
1723 trivial completer for 'import' (stdlib modules only). Rename
1720 ipy_linux_package_managers.py to ipy_stock_completers.py.
1724 ipy_linux_package_managers.py to ipy_stock_completers.py.
1721 SVN completer.
1725 SVN completer.
1722
1726
1723 * Extensions/ledit.py: %magic line editor for easily and
1727 * Extensions/ledit.py: %magic line editor for easily and
1724 incrementally manipulating lists of strings. The magic command
1728 incrementally manipulating lists of strings. The magic command
1725 name is %led.
1729 name is %led.
1726
1730
1727 2006-10-30 Ville Vainio <vivainio@gmail.com>
1731 2006-10-30 Ville Vainio <vivainio@gmail.com>
1728
1732
1729 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
1733 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
1730 Bernsteins's patches for pydb integration.
1734 Bernsteins's patches for pydb integration.
1731 http://bashdb.sourceforge.net/pydb/
1735 http://bashdb.sourceforge.net/pydb/
1732
1736
1733 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
1737 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
1734 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
1738 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
1735 custom completer hook to allow the users to implement their own
1739 custom completer hook to allow the users to implement their own
1736 completers. See ipy_linux_package_managers.py for example. The
1740 completers. See ipy_linux_package_managers.py for example. The
1737 hook name is 'complete_command'.
1741 hook name is 'complete_command'.
1738
1742
1739 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
1743 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
1740
1744
1741 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
1745 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
1742 Numeric leftovers.
1746 Numeric leftovers.
1743
1747
1744 * ipython.el (py-execute-region): apply Stefan's patch to fix
1748 * ipython.el (py-execute-region): apply Stefan's patch to fix
1745 garbled results if the python shell hasn't been previously started.
1749 garbled results if the python shell hasn't been previously started.
1746
1750
1747 * IPython/genutils.py (arg_split): moved to genutils, since it's a
1751 * IPython/genutils.py (arg_split): moved to genutils, since it's a
1748 pretty generic function and useful for other things.
1752 pretty generic function and useful for other things.
1749
1753
1750 * IPython/OInspect.py (getsource): Add customizable source
1754 * IPython/OInspect.py (getsource): Add customizable source
1751 extractor. After a request/patch form W. Stein (SAGE).
1755 extractor. After a request/patch form W. Stein (SAGE).
1752
1756
1753 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
1757 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
1754 window size to a more reasonable value from what pexpect does,
1758 window size to a more reasonable value from what pexpect does,
1755 since their choice causes wrapping bugs with long input lines.
1759 since their choice causes wrapping bugs with long input lines.
1756
1760
1757 2006-10-28 Ville Vainio <vivainio@gmail.com>
1761 2006-10-28 Ville Vainio <vivainio@gmail.com>
1758
1762
1759 * Magic.py (%run): Save and restore the readline history from
1763 * Magic.py (%run): Save and restore the readline history from
1760 file around %run commands to prevent side effects from
1764 file around %run commands to prevent side effects from
1761 %runned programs that might use readline (e.g. pydb).
1765 %runned programs that might use readline (e.g. pydb).
1762
1766
1763 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
1767 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
1764 invoking the pydb enhanced debugger.
1768 invoking the pydb enhanced debugger.
1765
1769
1766 2006-10-23 Walter Doerwald <walter@livinglogic.de>
1770 2006-10-23 Walter Doerwald <walter@livinglogic.de>
1767
1771
1768 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
1772 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
1769 call the base class method and propagate the return value to
1773 call the base class method and propagate the return value to
1770 ifile. This is now done by path itself.
1774 ifile. This is now done by path itself.
1771
1775
1772 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1776 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1773
1777
1774 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
1778 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
1775 api: set_crash_handler(), to expose the ability to change the
1779 api: set_crash_handler(), to expose the ability to change the
1776 internal crash handler.
1780 internal crash handler.
1777
1781
1778 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
1782 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
1779 the various parameters of the crash handler so that apps using
1783 the various parameters of the crash handler so that apps using
1780 IPython as their engine can customize crash handling. Ipmlemented
1784 IPython as their engine can customize crash handling. Ipmlemented
1781 at the request of SAGE.
1785 at the request of SAGE.
1782
1786
1783 2006-10-14 Ville Vainio <vivainio@gmail.com>
1787 2006-10-14 Ville Vainio <vivainio@gmail.com>
1784
1788
1785 * Magic.py, ipython.el: applied first "safe" part of Rocky
1789 * Magic.py, ipython.el: applied first "safe" part of Rocky
1786 Bernstein's patch set for pydb integration.
1790 Bernstein's patch set for pydb integration.
1787
1791
1788 * Magic.py (%unalias, %alias): %store'd aliases can now be
1792 * Magic.py (%unalias, %alias): %store'd aliases can now be
1789 removed with '%unalias'. %alias w/o args now shows most
1793 removed with '%unalias'. %alias w/o args now shows most
1790 interesting (stored / manually defined) aliases last
1794 interesting (stored / manually defined) aliases last
1791 where they catch the eye w/o scrolling.
1795 where they catch the eye w/o scrolling.
1792
1796
1793 * Magic.py (%rehashx), ext_rehashdir.py: files with
1797 * Magic.py (%rehashx), ext_rehashdir.py: files with
1794 'py' extension are always considered executable, even
1798 'py' extension are always considered executable, even
1795 when not in PATHEXT environment variable.
1799 when not in PATHEXT environment variable.
1796
1800
1797 2006-10-12 Ville Vainio <vivainio@gmail.com>
1801 2006-10-12 Ville Vainio <vivainio@gmail.com>
1798
1802
1799 * jobctrl.py: Add new "jobctrl" extension for spawning background
1803 * jobctrl.py: Add new "jobctrl" extension for spawning background
1800 processes with "&find /". 'import jobctrl' to try it out. Requires
1804 processes with "&find /". 'import jobctrl' to try it out. Requires
1801 'subprocess' module, standard in python 2.4+.
1805 'subprocess' module, standard in python 2.4+.
1802
1806
1803 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1807 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1804 so if foo -> bar and bar -> baz, then foo -> baz.
1808 so if foo -> bar and bar -> baz, then foo -> baz.
1805
1809
1806 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1810 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1807
1811
1808 * IPython/Magic.py (Magic.parse_options): add a new posix option
1812 * IPython/Magic.py (Magic.parse_options): add a new posix option
1809 to allow parsing of input args in magics that doesn't strip quotes
1813 to allow parsing of input args in magics that doesn't strip quotes
1810 (if posix=False). This also closes %timeit bug reported by
1814 (if posix=False). This also closes %timeit bug reported by
1811 Stefan.
1815 Stefan.
1812
1816
1813 2006-10-03 Ville Vainio <vivainio@gmail.com>
1817 2006-10-03 Ville Vainio <vivainio@gmail.com>
1814
1818
1815 * iplib.py (raw_input, interact): Return ValueError catching for
1819 * iplib.py (raw_input, interact): Return ValueError catching for
1816 raw_input. Fixes infinite loop for sys.stdin.close() or
1820 raw_input. Fixes infinite loop for sys.stdin.close() or
1817 sys.stdout.close().
1821 sys.stdout.close().
1818
1822
1819 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1823 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1820
1824
1821 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1825 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1822 to help in handling doctests. irunner is now pretty useful for
1826 to help in handling doctests. irunner is now pretty useful for
1823 running standalone scripts and simulate a full interactive session
1827 running standalone scripts and simulate a full interactive session
1824 in a format that can be then pasted as a doctest.
1828 in a format that can be then pasted as a doctest.
1825
1829
1826 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1830 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1827 on top of the default (useless) ones. This also fixes the nasty
1831 on top of the default (useless) ones. This also fixes the nasty
1828 way in which 2.5's Quitter() exits (reverted [1785]).
1832 way in which 2.5's Quitter() exits (reverted [1785]).
1829
1833
1830 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1834 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1831 2.5.
1835 2.5.
1832
1836
1833 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1837 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1834 color scheme is updated as well when color scheme is changed
1838 color scheme is updated as well when color scheme is changed
1835 interactively.
1839 interactively.
1836
1840
1837 2006-09-27 Ville Vainio <vivainio@gmail.com>
1841 2006-09-27 Ville Vainio <vivainio@gmail.com>
1838
1842
1839 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1843 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1840 infinite loop and just exit. It's a hack, but will do for a while.
1844 infinite loop and just exit. It's a hack, but will do for a while.
1841
1845
1842 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1846 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1843
1847
1844 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1848 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1845 the constructor, this makes it possible to get a list of only directories
1849 the constructor, this makes it possible to get a list of only directories
1846 or only files.
1850 or only files.
1847
1851
1848 2006-08-12 Ville Vainio <vivainio@gmail.com>
1852 2006-08-12 Ville Vainio <vivainio@gmail.com>
1849
1853
1850 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1854 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1851 they broke unittest
1855 they broke unittest
1852
1856
1853 2006-08-11 Ville Vainio <vivainio@gmail.com>
1857 2006-08-11 Ville Vainio <vivainio@gmail.com>
1854
1858
1855 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1859 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1856 by resolving issue properly, i.e. by inheriting FakeModule
1860 by resolving issue properly, i.e. by inheriting FakeModule
1857 from types.ModuleType. Pickling ipython interactive data
1861 from types.ModuleType. Pickling ipython interactive data
1858 should still work as usual (testing appreciated).
1862 should still work as usual (testing appreciated).
1859
1863
1860 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1864 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1861
1865
1862 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1866 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1863 running under python 2.3 with code from 2.4 to fix a bug with
1867 running under python 2.3 with code from 2.4 to fix a bug with
1864 help(). Reported by the Debian maintainers, Norbert Tretkowski
1868 help(). Reported by the Debian maintainers, Norbert Tretkowski
1865 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1869 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1866 <afayolle-AT-debian.org>.
1870 <afayolle-AT-debian.org>.
1867
1871
1868 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1872 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1869
1873
1870 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1874 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1871 (which was displaying "quit" twice).
1875 (which was displaying "quit" twice).
1872
1876
1873 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1877 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1874
1878
1875 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1879 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1876 the mode argument).
1880 the mode argument).
1877
1881
1878 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1882 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1879
1883
1880 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1884 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1881 not running under IPython.
1885 not running under IPython.
1882
1886
1883 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1887 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1884 and make it iterable (iterating over the attribute itself). Add two new
1888 and make it iterable (iterating over the attribute itself). Add two new
1885 magic strings for __xattrs__(): If the string starts with "-", the attribute
1889 magic strings for __xattrs__(): If the string starts with "-", the attribute
1886 will not be displayed in ibrowse's detail view (but it can still be
1890 will not be displayed in ibrowse's detail view (but it can still be
1887 iterated over). This makes it possible to add attributes that are large
1891 iterated over). This makes it possible to add attributes that are large
1888 lists or generator methods to the detail view. Replace magic attribute names
1892 lists or generator methods to the detail view. Replace magic attribute names
1889 and _attrname() and _getattr() with "descriptors": For each type of magic
1893 and _attrname() and _getattr() with "descriptors": For each type of magic
1890 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1894 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1891 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1895 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1892 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1896 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1893 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1897 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1894 are still supported.
1898 are still supported.
1895
1899
1896 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1900 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1897 fails in ibrowse.fetch(), the exception object is added as the last item
1901 fails in ibrowse.fetch(), the exception object is added as the last item
1898 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1902 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1899 a generator throws an exception midway through execution.
1903 a generator throws an exception midway through execution.
1900
1904
1901 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1905 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1902 encoding into methods.
1906 encoding into methods.
1903
1907
1904 2006-07-26 Ville Vainio <vivainio@gmail.com>
1908 2006-07-26 Ville Vainio <vivainio@gmail.com>
1905
1909
1906 * iplib.py: history now stores multiline input as single
1910 * iplib.py: history now stores multiline input as single
1907 history entries. Patch by Jorgen Cederlof.
1911 history entries. Patch by Jorgen Cederlof.
1908
1912
1909 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1913 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1910
1914
1911 * IPython/Extensions/ibrowse.py: Make cursor visible over
1915 * IPython/Extensions/ibrowse.py: Make cursor visible over
1912 non existing attributes.
1916 non existing attributes.
1913
1917
1914 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1918 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1915
1919
1916 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1920 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1917 error output of the running command doesn't mess up the screen.
1921 error output of the running command doesn't mess up the screen.
1918
1922
1919 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1923 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1920
1924
1921 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1925 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1922 argument. This sorts the items themselves.
1926 argument. This sorts the items themselves.
1923
1927
1924 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1928 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1925
1929
1926 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1930 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1927 Compile expression strings into code objects. This should speed
1931 Compile expression strings into code objects. This should speed
1928 up ifilter and friends somewhat.
1932 up ifilter and friends somewhat.
1929
1933
1930 2006-07-08 Ville Vainio <vivainio@gmail.com>
1934 2006-07-08 Ville Vainio <vivainio@gmail.com>
1931
1935
1932 * Magic.py: %cpaste now strips > from the beginning of lines
1936 * Magic.py: %cpaste now strips > from the beginning of lines
1933 to ease pasting quoted code from emails. Contributed by
1937 to ease pasting quoted code from emails. Contributed by
1934 Stefan van der Walt.
1938 Stefan van der Walt.
1935
1939
1936 2006-06-29 Ville Vainio <vivainio@gmail.com>
1940 2006-06-29 Ville Vainio <vivainio@gmail.com>
1937
1941
1938 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1942 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1939 mode, patch contributed by Darren Dale. NEEDS TESTING!
1943 mode, patch contributed by Darren Dale. NEEDS TESTING!
1940
1944
1941 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1945 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1942
1946
1943 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1947 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1944 a blue background. Fix fetching new display rows when the browser
1948 a blue background. Fix fetching new display rows when the browser
1945 scrolls more than a screenful (e.g. by using the goto command).
1949 scrolls more than a screenful (e.g. by using the goto command).
1946
1950
1947 2006-06-27 Ville Vainio <vivainio@gmail.com>
1951 2006-06-27 Ville Vainio <vivainio@gmail.com>
1948
1952
1949 * Magic.py (_inspect, _ofind) Apply David Huard's
1953 * Magic.py (_inspect, _ofind) Apply David Huard's
1950 patch for displaying the correct docstring for 'property'
1954 patch for displaying the correct docstring for 'property'
1951 attributes.
1955 attributes.
1952
1956
1953 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1957 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1954
1958
1955 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1959 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1956 commands into the methods implementing them.
1960 commands into the methods implementing them.
1957
1961
1958 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1962 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1959
1963
1960 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1964 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1961 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1965 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1962 autoindent support was authored by Jin Liu.
1966 autoindent support was authored by Jin Liu.
1963
1967
1964 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1968 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1965
1969
1966 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1970 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1967 for keymaps with a custom class that simplifies handling.
1971 for keymaps with a custom class that simplifies handling.
1968
1972
1969 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1973 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1970
1974
1971 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1975 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1972 resizing. This requires Python 2.5 to work.
1976 resizing. This requires Python 2.5 to work.
1973
1977
1974 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1978 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1975
1979
1976 * IPython/Extensions/ibrowse.py: Add two new commands to
1980 * IPython/Extensions/ibrowse.py: Add two new commands to
1977 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1981 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1978 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1982 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1979 attributes again. Remapped the help command to "?". Display
1983 attributes again. Remapped the help command to "?". Display
1980 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1984 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1981 as keys for the "home" and "end" commands. Add three new commands
1985 as keys for the "home" and "end" commands. Add three new commands
1982 to the input mode for "find" and friends: "delend" (CTRL-K)
1986 to the input mode for "find" and friends: "delend" (CTRL-K)
1983 deletes to the end of line. "incsearchup" searches upwards in the
1987 deletes to the end of line. "incsearchup" searches upwards in the
1984 command history for an input that starts with the text before the cursor.
1988 command history for an input that starts with the text before the cursor.
1985 "incsearchdown" does the same downwards. Removed a bogus mapping of
1989 "incsearchdown" does the same downwards. Removed a bogus mapping of
1986 the x key to "delete".
1990 the x key to "delete".
1987
1991
1988 2006-06-15 Ville Vainio <vivainio@gmail.com>
1992 2006-06-15 Ville Vainio <vivainio@gmail.com>
1989
1993
1990 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1994 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1991 used to create prompts dynamically, instead of the "old" way of
1995 used to create prompts dynamically, instead of the "old" way of
1992 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1996 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1993 way still works (it's invoked by the default hook), of course.
1997 way still works (it's invoked by the default hook), of course.
1994
1998
1995 * Prompts.py: added generate_output_prompt hook for altering output
1999 * Prompts.py: added generate_output_prompt hook for altering output
1996 prompt
2000 prompt
1997
2001
1998 * Release.py: Changed version string to 0.7.3.svn.
2002 * Release.py: Changed version string to 0.7.3.svn.
1999
2003
2000 2006-06-15 Walter Doerwald <walter@livinglogic.de>
2004 2006-06-15 Walter Doerwald <walter@livinglogic.de>
2001
2005
2002 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
2006 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
2003 the call to fetch() always tries to fetch enough data for at least one
2007 the call to fetch() always tries to fetch enough data for at least one
2004 full screen. This makes it possible to simply call moveto(0,0,True) in
2008 full screen. This makes it possible to simply call moveto(0,0,True) in
2005 the constructor. Fix typos and removed the obsolete goto attribute.
2009 the constructor. Fix typos and removed the obsolete goto attribute.
2006
2010
2007 2006-06-12 Ville Vainio <vivainio@gmail.com>
2011 2006-06-12 Ville Vainio <vivainio@gmail.com>
2008
2012
2009 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
2013 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
2010 allowing $variable interpolation within multiline statements,
2014 allowing $variable interpolation within multiline statements,
2011 though so far only with "sh" profile for a testing period.
2015 though so far only with "sh" profile for a testing period.
2012 The patch also enables splitting long commands with \ but it
2016 The patch also enables splitting long commands with \ but it
2013 doesn't work properly yet.
2017 doesn't work properly yet.
2014
2018
2015 2006-06-12 Walter Doerwald <walter@livinglogic.de>
2019 2006-06-12 Walter Doerwald <walter@livinglogic.de>
2016
2020
2017 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
2021 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
2018 input history and the position of the cursor in the input history for
2022 input history and the position of the cursor in the input history for
2019 the find, findbackwards and goto command.
2023 the find, findbackwards and goto command.
2020
2024
2021 2006-06-10 Walter Doerwald <walter@livinglogic.de>
2025 2006-06-10 Walter Doerwald <walter@livinglogic.de>
2022
2026
2023 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
2027 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
2024 implements the basic functionality of browser commands that require
2028 implements the basic functionality of browser commands that require
2025 input. Reimplement the goto, find and findbackwards commands as
2029 input. Reimplement the goto, find and findbackwards commands as
2026 subclasses of _CommandInput. Add an input history and keymaps to those
2030 subclasses of _CommandInput. Add an input history and keymaps to those
2027 commands. Add "\r" as a keyboard shortcut for the enterdefault and
2031 commands. Add "\r" as a keyboard shortcut for the enterdefault and
2028 execute commands.
2032 execute commands.
2029
2033
2030 2006-06-07 Ville Vainio <vivainio@gmail.com>
2034 2006-06-07 Ville Vainio <vivainio@gmail.com>
2031
2035
2032 * iplib.py: ipython mybatch.ipy exits ipython immediately after
2036 * iplib.py: ipython mybatch.ipy exits ipython immediately after
2033 running the batch files instead of leaving the session open.
2037 running the batch files instead of leaving the session open.
2034
2038
2035 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
2039 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
2036
2040
2037 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
2041 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
2038 the original fix was incomplete. Patch submitted by W. Maier.
2042 the original fix was incomplete. Patch submitted by W. Maier.
2039
2043
2040 2006-06-07 Ville Vainio <vivainio@gmail.com>
2044 2006-06-07 Ville Vainio <vivainio@gmail.com>
2041
2045
2042 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
2046 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
2043 Confirmation prompts can be supressed by 'quiet' option.
2047 Confirmation prompts can be supressed by 'quiet' option.
2044 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
2048 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
2045
2049
2046 2006-06-06 *** Released version 0.7.2
2050 2006-06-06 *** Released version 0.7.2
2047
2051
2048 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
2052 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
2049
2053
2050 * IPython/Release.py (version): Made 0.7.2 final for release.
2054 * IPython/Release.py (version): Made 0.7.2 final for release.
2051 Repo tagged and release cut.
2055 Repo tagged and release cut.
2052
2056
2053 2006-06-05 Ville Vainio <vivainio@gmail.com>
2057 2006-06-05 Ville Vainio <vivainio@gmail.com>
2054
2058
2055 * Magic.py (magic_rehashx): Honor no_alias list earlier in
2059 * Magic.py (magic_rehashx): Honor no_alias list earlier in
2056 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
2060 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
2057
2061
2058 * upgrade_dir.py: try import 'path' module a bit harder
2062 * upgrade_dir.py: try import 'path' module a bit harder
2059 (for %upgrade)
2063 (for %upgrade)
2060
2064
2061 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
2065 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
2062
2066
2063 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
2067 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
2064 instead of looping 20 times.
2068 instead of looping 20 times.
2065
2069
2066 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
2070 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
2067 correctly at initialization time. Bug reported by Krishna Mohan
2071 correctly at initialization time. Bug reported by Krishna Mohan
2068 Gundu <gkmohan-AT-gmail.com> on the user list.
2072 Gundu <gkmohan-AT-gmail.com> on the user list.
2069
2073
2070 * IPython/Release.py (version): Mark 0.7.2 version to start
2074 * IPython/Release.py (version): Mark 0.7.2 version to start
2071 testing for release on 06/06.
2075 testing for release on 06/06.
2072
2076
2073 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
2077 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
2074
2078
2075 * scripts/irunner: thin script interface so users don't have to
2079 * scripts/irunner: thin script interface so users don't have to
2076 find the module and call it as an executable, since modules rarely
2080 find the module and call it as an executable, since modules rarely
2077 live in people's PATH.
2081 live in people's PATH.
2078
2082
2079 * IPython/irunner.py (InteractiveRunner.__init__): added
2083 * IPython/irunner.py (InteractiveRunner.__init__): added
2080 delaybeforesend attribute to control delays with newer versions of
2084 delaybeforesend attribute to control delays with newer versions of
2081 pexpect. Thanks to detailed help from pexpect's author, Noah
2085 pexpect. Thanks to detailed help from pexpect's author, Noah
2082 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
2086 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
2083 correctly (it works in NoColor mode).
2087 correctly (it works in NoColor mode).
2084
2088
2085 * IPython/iplib.py (handle_normal): fix nasty crash reported on
2089 * IPython/iplib.py (handle_normal): fix nasty crash reported on
2086 SAGE list, from improper log() calls.
2090 SAGE list, from improper log() calls.
2087
2091
2088 2006-05-31 Ville Vainio <vivainio@gmail.com>
2092 2006-05-31 Ville Vainio <vivainio@gmail.com>
2089
2093
2090 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
2094 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
2091 with args in parens to work correctly with dirs that have spaces.
2095 with args in parens to work correctly with dirs that have spaces.
2092
2096
2093 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
2097 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
2094
2098
2095 * IPython/Logger.py (Logger.logstart): add option to log raw input
2099 * IPython/Logger.py (Logger.logstart): add option to log raw input
2096 instead of the processed one. A -r flag was added to the
2100 instead of the processed one. A -r flag was added to the
2097 %logstart magic used for controlling logging.
2101 %logstart magic used for controlling logging.
2098
2102
2099 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
2103 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
2100
2104
2101 * IPython/iplib.py (InteractiveShell.__init__): add check for the
2105 * IPython/iplib.py (InteractiveShell.__init__): add check for the
2102 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
2106 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
2103 recognize the option. After a bug report by Will Maier. This
2107 recognize the option. After a bug report by Will Maier. This
2104 closes #64 (will do it after confirmation from W. Maier).
2108 closes #64 (will do it after confirmation from W. Maier).
2105
2109
2106 * IPython/irunner.py: New module to run scripts as if manually
2110 * IPython/irunner.py: New module to run scripts as if manually
2107 typed into an interactive environment, based on pexpect. After a
2111 typed into an interactive environment, based on pexpect. After a
2108 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
2112 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
2109 ipython-user list. Simple unittests in the tests/ directory.
2113 ipython-user list. Simple unittests in the tests/ directory.
2110
2114
2111 * tools/release: add Will Maier, OpenBSD port maintainer, to
2115 * tools/release: add Will Maier, OpenBSD port maintainer, to
2112 recepients list. We are now officially part of the OpenBSD ports:
2116 recepients list. We are now officially part of the OpenBSD ports:
2113 http://www.openbsd.org/ports.html ! Many thanks to Will for the
2117 http://www.openbsd.org/ports.html ! Many thanks to Will for the
2114 work.
2118 work.
2115
2119
2116 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
2120 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
2117
2121
2118 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
2122 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
2119 so that it doesn't break tkinter apps.
2123 so that it doesn't break tkinter apps.
2120
2124
2121 * IPython/iplib.py (_prefilter): fix bug where aliases would
2125 * IPython/iplib.py (_prefilter): fix bug where aliases would
2122 shadow variables when autocall was fully off. Reported by SAGE
2126 shadow variables when autocall was fully off. Reported by SAGE
2123 author William Stein.
2127 author William Stein.
2124
2128
2125 * IPython/OInspect.py (Inspector.__init__): add a flag to control
2129 * IPython/OInspect.py (Inspector.__init__): add a flag to control
2126 at what detail level strings are computed when foo? is requested.
2130 at what detail level strings are computed when foo? is requested.
2127 This allows users to ask for example that the string form of an
2131 This allows users to ask for example that the string form of an
2128 object is only computed when foo?? is called, or even never, by
2132 object is only computed when foo?? is called, or even never, by
2129 setting the object_info_string_level >= 2 in the configuration
2133 setting the object_info_string_level >= 2 in the configuration
2130 file. This new option has been added and documented. After a
2134 file. This new option has been added and documented. After a
2131 request by SAGE to be able to control the printing of very large
2135 request by SAGE to be able to control the printing of very large
2132 objects more easily.
2136 objects more easily.
2133
2137
2134 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
2138 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
2135
2139
2136 * IPython/ipmaker.py (make_IPython): remove the ipython call path
2140 * IPython/ipmaker.py (make_IPython): remove the ipython call path
2137 from sys.argv, to be 100% consistent with how Python itself works
2141 from sys.argv, to be 100% consistent with how Python itself works
2138 (as seen for example with python -i file.py). After a bug report
2142 (as seen for example with python -i file.py). After a bug report
2139 by Jeffrey Collins.
2143 by Jeffrey Collins.
2140
2144
2141 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
2145 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
2142 nasty bug which was preventing custom namespaces with -pylab,
2146 nasty bug which was preventing custom namespaces with -pylab,
2143 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
2147 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
2144 compatibility (long gone from mpl).
2148 compatibility (long gone from mpl).
2145
2149
2146 * IPython/ipapi.py (make_session): name change: create->make. We
2150 * IPython/ipapi.py (make_session): name change: create->make. We
2147 use make in other places (ipmaker,...), it's shorter and easier to
2151 use make in other places (ipmaker,...), it's shorter and easier to
2148 type and say, etc. I'm trying to clean things before 0.7.2 so
2152 type and say, etc. I'm trying to clean things before 0.7.2 so
2149 that I can keep things stable wrt to ipapi in the chainsaw branch.
2153 that I can keep things stable wrt to ipapi in the chainsaw branch.
2150
2154
2151 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
2155 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
2152 python-mode recognizes our debugger mode. Add support for
2156 python-mode recognizes our debugger mode. Add support for
2153 autoindent inside (X)emacs. After a patch sent in by Jin Liu
2157 autoindent inside (X)emacs. After a patch sent in by Jin Liu
2154 <m.liu.jin-AT-gmail.com> originally written by
2158 <m.liu.jin-AT-gmail.com> originally written by
2155 doxgen-AT-newsmth.net (with minor modifications for xemacs
2159 doxgen-AT-newsmth.net (with minor modifications for xemacs
2156 compatibility)
2160 compatibility)
2157
2161
2158 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
2162 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
2159 tracebacks when walking the stack so that the stack tracking system
2163 tracebacks when walking the stack so that the stack tracking system
2160 in emacs' python-mode can identify the frames correctly.
2164 in emacs' python-mode can identify the frames correctly.
2161
2165
2162 * IPython/ipmaker.py (make_IPython): make the internal (and
2166 * IPython/ipmaker.py (make_IPython): make the internal (and
2163 default config) autoedit_syntax value false by default. Too many
2167 default config) autoedit_syntax value false by default. Too many
2164 users have complained to me (both on and off-list) about problems
2168 users have complained to me (both on and off-list) about problems
2165 with this option being on by default, so I'm making it default to
2169 with this option being on by default, so I'm making it default to
2166 off. It can still be enabled by anyone via the usual mechanisms.
2170 off. It can still be enabled by anyone via the usual mechanisms.
2167
2171
2168 * IPython/completer.py (Completer.attr_matches): add support for
2172 * IPython/completer.py (Completer.attr_matches): add support for
2169 PyCrust-style _getAttributeNames magic method. Patch contributed
2173 PyCrust-style _getAttributeNames magic method. Patch contributed
2170 by <mscott-AT-goldenspud.com>. Closes #50.
2174 by <mscott-AT-goldenspud.com>. Closes #50.
2171
2175
2172 * IPython/iplib.py (InteractiveShell.__init__): remove the
2176 * IPython/iplib.py (InteractiveShell.__init__): remove the
2173 deletion of exit/quit from __builtin__, which can break
2177 deletion of exit/quit from __builtin__, which can break
2174 third-party tools like the Zope debugging console. The
2178 third-party tools like the Zope debugging console. The
2175 %exit/%quit magics remain. In general, it's probably a good idea
2179 %exit/%quit magics remain. In general, it's probably a good idea
2176 not to delete anything from __builtin__, since we never know what
2180 not to delete anything from __builtin__, since we never know what
2177 that will break. In any case, python now (for 2.5) will support
2181 that will break. In any case, python now (for 2.5) will support
2178 'real' exit/quit, so this issue is moot. Closes #55.
2182 'real' exit/quit, so this issue is moot. Closes #55.
2179
2183
2180 * IPython/genutils.py (with_obj): rename the 'with' function to
2184 * IPython/genutils.py (with_obj): rename the 'with' function to
2181 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
2185 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
2182 becomes a language keyword. Closes #53.
2186 becomes a language keyword. Closes #53.
2183
2187
2184 * IPython/FakeModule.py (FakeModule.__init__): add a proper
2188 * IPython/FakeModule.py (FakeModule.__init__): add a proper
2185 __file__ attribute to this so it fools more things into thinking
2189 __file__ attribute to this so it fools more things into thinking
2186 it is a real module. Closes #59.
2190 it is a real module. Closes #59.
2187
2191
2188 * IPython/Magic.py (magic_edit): add -n option to open the editor
2192 * IPython/Magic.py (magic_edit): add -n option to open the editor
2189 at a specific line number. After a patch by Stefan van der Walt.
2193 at a specific line number. After a patch by Stefan van der Walt.
2190
2194
2191 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
2195 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
2192
2196
2193 * IPython/iplib.py (edit_syntax_error): fix crash when for some
2197 * IPython/iplib.py (edit_syntax_error): fix crash when for some
2194 reason the file could not be opened. After automatic crash
2198 reason the file could not be opened. After automatic crash
2195 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
2199 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
2196 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
2200 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
2197 (_should_recompile): Don't fire editor if using %bg, since there
2201 (_should_recompile): Don't fire editor if using %bg, since there
2198 is no file in the first place. From the same report as above.
2202 is no file in the first place. From the same report as above.
2199 (raw_input): protect against faulty third-party prefilters. After
2203 (raw_input): protect against faulty third-party prefilters. After
2200 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
2204 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
2201 while running under SAGE.
2205 while running under SAGE.
2202
2206
2203 2006-05-23 Ville Vainio <vivainio@gmail.com>
2207 2006-05-23 Ville Vainio <vivainio@gmail.com>
2204
2208
2205 * ipapi.py: Stripped down ip.to_user_ns() to work only as
2209 * ipapi.py: Stripped down ip.to_user_ns() to work only as
2206 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
2210 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
2207 now returns None (again), unless dummy is specifically allowed by
2211 now returns None (again), unless dummy is specifically allowed by
2208 ipapi.get(allow_dummy=True).
2212 ipapi.get(allow_dummy=True).
2209
2213
2210 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
2214 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
2211
2215
2212 * IPython: remove all 2.2-compatibility objects and hacks from
2216 * IPython: remove all 2.2-compatibility objects and hacks from
2213 everywhere, since we only support 2.3 at this point. Docs
2217 everywhere, since we only support 2.3 at this point. Docs
2214 updated.
2218 updated.
2215
2219
2216 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
2220 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
2217 Anything requiring extra validation can be turned into a Python
2221 Anything requiring extra validation can be turned into a Python
2218 property in the future. I used a property for the db one b/c
2222 property in the future. I used a property for the db one b/c
2219 there was a nasty circularity problem with the initialization
2223 there was a nasty circularity problem with the initialization
2220 order, which right now I don't have time to clean up.
2224 order, which right now I don't have time to clean up.
2221
2225
2222 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
2226 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
2223 another locking bug reported by Jorgen. I'm not 100% sure though,
2227 another locking bug reported by Jorgen. I'm not 100% sure though,
2224 so more testing is needed...
2228 so more testing is needed...
2225
2229
2226 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
2230 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
2227
2231
2228 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
2232 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
2229 local variables from any routine in user code (typically executed
2233 local variables from any routine in user code (typically executed
2230 with %run) directly into the interactive namespace. Very useful
2234 with %run) directly into the interactive namespace. Very useful
2231 when doing complex debugging.
2235 when doing complex debugging.
2232 (IPythonNotRunning): Changed the default None object to a dummy
2236 (IPythonNotRunning): Changed the default None object to a dummy
2233 whose attributes can be queried as well as called without
2237 whose attributes can be queried as well as called without
2234 exploding, to ease writing code which works transparently both in
2238 exploding, to ease writing code which works transparently both in
2235 and out of ipython and uses some of this API.
2239 and out of ipython and uses some of this API.
2236
2240
2237 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
2241 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
2238
2242
2239 * IPython/hooks.py (result_display): Fix the fact that our display
2243 * IPython/hooks.py (result_display): Fix the fact that our display
2240 hook was using str() instead of repr(), as the default python
2244 hook was using str() instead of repr(), as the default python
2241 console does. This had gone unnoticed b/c it only happened if
2245 console does. This had gone unnoticed b/c it only happened if
2242 %Pprint was off, but the inconsistency was there.
2246 %Pprint was off, but the inconsistency was there.
2243
2247
2244 2006-05-15 Ville Vainio <vivainio@gmail.com>
2248 2006-05-15 Ville Vainio <vivainio@gmail.com>
2245
2249
2246 * Oinspect.py: Only show docstring for nonexisting/binary files
2250 * Oinspect.py: Only show docstring for nonexisting/binary files
2247 when doing object??, closing ticket #62
2251 when doing object??, closing ticket #62
2248
2252
2249 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
2253 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
2250
2254
2251 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
2255 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
2252 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
2256 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
2253 was being released in a routine which hadn't checked if it had
2257 was being released in a routine which hadn't checked if it had
2254 been the one to acquire it.
2258 been the one to acquire it.
2255
2259
2256 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
2260 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
2257
2261
2258 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
2262 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
2259
2263
2260 2006-04-11 Ville Vainio <vivainio@gmail.com>
2264 2006-04-11 Ville Vainio <vivainio@gmail.com>
2261
2265
2262 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
2266 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
2263 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
2267 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
2264 prefilters, allowing stuff like magics and aliases in the file.
2268 prefilters, allowing stuff like magics and aliases in the file.
2265
2269
2266 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
2270 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
2267 added. Supported now are "%clear in" and "%clear out" (clear input and
2271 added. Supported now are "%clear in" and "%clear out" (clear input and
2268 output history, respectively). Also fixed CachedOutput.flush to
2272 output history, respectively). Also fixed CachedOutput.flush to
2269 properly flush the output cache.
2273 properly flush the output cache.
2270
2274
2271 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
2275 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
2272 half-success (and fail explicitly).
2276 half-success (and fail explicitly).
2273
2277
2274 2006-03-28 Ville Vainio <vivainio@gmail.com>
2278 2006-03-28 Ville Vainio <vivainio@gmail.com>
2275
2279
2276 * iplib.py: Fix quoting of aliases so that only argless ones
2280 * iplib.py: Fix quoting of aliases so that only argless ones
2277 are quoted
2281 are quoted
2278
2282
2279 2006-03-28 Ville Vainio <vivainio@gmail.com>
2283 2006-03-28 Ville Vainio <vivainio@gmail.com>
2280
2284
2281 * iplib.py: Quote aliases with spaces in the name.
2285 * iplib.py: Quote aliases with spaces in the name.
2282 "c:\program files\blah\bin" is now legal alias target.
2286 "c:\program files\blah\bin" is now legal alias target.
2283
2287
2284 * ext_rehashdir.py: Space no longer allowed as arg
2288 * ext_rehashdir.py: Space no longer allowed as arg
2285 separator, since space is legal in path names.
2289 separator, since space is legal in path names.
2286
2290
2287 2006-03-16 Ville Vainio <vivainio@gmail.com>
2291 2006-03-16 Ville Vainio <vivainio@gmail.com>
2288
2292
2289 * upgrade_dir.py: Take path.py from Extensions, correcting
2293 * upgrade_dir.py: Take path.py from Extensions, correcting
2290 %upgrade magic
2294 %upgrade magic
2291
2295
2292 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
2296 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
2293
2297
2294 * hooks.py: Only enclose editor binary in quotes if legal and
2298 * hooks.py: Only enclose editor binary in quotes if legal and
2295 necessary (space in the name, and is an existing file). Fixes a bug
2299 necessary (space in the name, and is an existing file). Fixes a bug
2296 reported by Zachary Pincus.
2300 reported by Zachary Pincus.
2297
2301
2298 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
2302 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
2299
2303
2300 * Manual: thanks to a tip on proper color handling for Emacs, by
2304 * Manual: thanks to a tip on proper color handling for Emacs, by
2301 Eric J Haywiser <ejh1-AT-MIT.EDU>.
2305 Eric J Haywiser <ejh1-AT-MIT.EDU>.
2302
2306
2303 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
2307 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
2304 by applying the provided patch. Thanks to Liu Jin
2308 by applying the provided patch. Thanks to Liu Jin
2305 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
2309 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
2306 XEmacs/Linux, I'm trusting the submitter that it actually helps
2310 XEmacs/Linux, I'm trusting the submitter that it actually helps
2307 under win32/GNU Emacs. Will revisit if any problems are reported.
2311 under win32/GNU Emacs. Will revisit if any problems are reported.
2308
2312
2309 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
2313 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
2310
2314
2311 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
2315 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
2312 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
2316 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
2313
2317
2314 2006-03-12 Ville Vainio <vivainio@gmail.com>
2318 2006-03-12 Ville Vainio <vivainio@gmail.com>
2315
2319
2316 * Magic.py (magic_timeit): Added %timeit magic, contributed by
2320 * Magic.py (magic_timeit): Added %timeit magic, contributed by
2317 Torsten Marek.
2321 Torsten Marek.
2318
2322
2319 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
2323 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
2320
2324
2321 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
2325 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
2322 line ranges works again.
2326 line ranges works again.
2323
2327
2324 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
2328 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
2325
2329
2326 * IPython/iplib.py (showtraceback): add back sys.last_traceback
2330 * IPython/iplib.py (showtraceback): add back sys.last_traceback
2327 and friends, after a discussion with Zach Pincus on ipython-user.
2331 and friends, after a discussion with Zach Pincus on ipython-user.
2328 I'm not 100% sure, but after thinking about it quite a bit, it may
2332 I'm not 100% sure, but after thinking about it quite a bit, it may
2329 be OK. Testing with the multithreaded shells didn't reveal any
2333 be OK. Testing with the multithreaded shells didn't reveal any
2330 problems, but let's keep an eye out.
2334 problems, but let's keep an eye out.
2331
2335
2332 In the process, I fixed a few things which were calling
2336 In the process, I fixed a few things which were calling
2333 self.InteractiveTB() directly (like safe_execfile), which is a
2337 self.InteractiveTB() directly (like safe_execfile), which is a
2334 mistake: ALL exception reporting should be done by calling
2338 mistake: ALL exception reporting should be done by calling
2335 self.showtraceback(), which handles state and tab-completion and
2339 self.showtraceback(), which handles state and tab-completion and
2336 more.
2340 more.
2337
2341
2338 2006-03-01 Ville Vainio <vivainio@gmail.com>
2342 2006-03-01 Ville Vainio <vivainio@gmail.com>
2339
2343
2340 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
2344 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
2341 To use, do "from ipipe import *".
2345 To use, do "from ipipe import *".
2342
2346
2343 2006-02-24 Ville Vainio <vivainio@gmail.com>
2347 2006-02-24 Ville Vainio <vivainio@gmail.com>
2344
2348
2345 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
2349 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
2346 "cleanly" and safely than the older upgrade mechanism.
2350 "cleanly" and safely than the older upgrade mechanism.
2347
2351
2348 2006-02-21 Ville Vainio <vivainio@gmail.com>
2352 2006-02-21 Ville Vainio <vivainio@gmail.com>
2349
2353
2350 * Magic.py: %save works again.
2354 * Magic.py: %save works again.
2351
2355
2352 2006-02-15 Ville Vainio <vivainio@gmail.com>
2356 2006-02-15 Ville Vainio <vivainio@gmail.com>
2353
2357
2354 * Magic.py: %Pprint works again
2358 * Magic.py: %Pprint works again
2355
2359
2356 * Extensions/ipy_sane_defaults.py: Provide everything provided
2360 * Extensions/ipy_sane_defaults.py: Provide everything provided
2357 in default ipythonrc, to make it possible to have a completely empty
2361 in default ipythonrc, to make it possible to have a completely empty
2358 ipythonrc (and thus completely rc-file free configuration)
2362 ipythonrc (and thus completely rc-file free configuration)
2359
2363
2360 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
2364 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
2361
2365
2362 * IPython/hooks.py (editor): quote the call to the editor command,
2366 * IPython/hooks.py (editor): quote the call to the editor command,
2363 to allow commands with spaces in them. Problem noted by watching
2367 to allow commands with spaces in them. Problem noted by watching
2364 Ian Oswald's video about textpad under win32 at
2368 Ian Oswald's video about textpad under win32 at
2365 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
2369 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
2366
2370
2367 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
2371 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
2368 describing magics (we haven't used @ for a loong time).
2372 describing magics (we haven't used @ for a loong time).
2369
2373
2370 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
2374 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
2371 contributed by marienz to close
2375 contributed by marienz to close
2372 http://www.scipy.net/roundup/ipython/issue53.
2376 http://www.scipy.net/roundup/ipython/issue53.
2373
2377
2374 2006-02-10 Ville Vainio <vivainio@gmail.com>
2378 2006-02-10 Ville Vainio <vivainio@gmail.com>
2375
2379
2376 * genutils.py: getoutput now works in win32 too
2380 * genutils.py: getoutput now works in win32 too
2377
2381
2378 * completer.py: alias and magic completion only invoked
2382 * completer.py: alias and magic completion only invoked
2379 at the first "item" in the line, to avoid "cd %store"
2383 at the first "item" in the line, to avoid "cd %store"
2380 nonsense.
2384 nonsense.
2381
2385
2382 2006-02-09 Ville Vainio <vivainio@gmail.com>
2386 2006-02-09 Ville Vainio <vivainio@gmail.com>
2383
2387
2384 * test/*: Added a unit testing framework (finally).
2388 * test/*: Added a unit testing framework (finally).
2385 '%run runtests.py' to run test_*.
2389 '%run runtests.py' to run test_*.
2386
2390
2387 * ipapi.py: Exposed runlines and set_custom_exc
2391 * ipapi.py: Exposed runlines and set_custom_exc
2388
2392
2389 2006-02-07 Ville Vainio <vivainio@gmail.com>
2393 2006-02-07 Ville Vainio <vivainio@gmail.com>
2390
2394
2391 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
2395 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
2392 instead use "f(1 2)" as before.
2396 instead use "f(1 2)" as before.
2393
2397
2394 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
2398 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
2395
2399
2396 * IPython/demo.py (IPythonDemo): Add new classes to the demo
2400 * IPython/demo.py (IPythonDemo): Add new classes to the demo
2397 facilities, for demos processed by the IPython input filter
2401 facilities, for demos processed by the IPython input filter
2398 (IPythonDemo), and for running a script one-line-at-a-time as a
2402 (IPythonDemo), and for running a script one-line-at-a-time as a
2399 demo, both for pure Python (LineDemo) and for IPython-processed
2403 demo, both for pure Python (LineDemo) and for IPython-processed
2400 input (IPythonLineDemo). After a request by Dave Kohel, from the
2404 input (IPythonLineDemo). After a request by Dave Kohel, from the
2401 SAGE team.
2405 SAGE team.
2402 (Demo.edit): added an edit() method to the demo objects, to edit
2406 (Demo.edit): added an edit() method to the demo objects, to edit
2403 the in-memory copy of the last executed block.
2407 the in-memory copy of the last executed block.
2404
2408
2405 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
2409 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
2406 processing to %edit, %macro and %save. These commands can now be
2410 processing to %edit, %macro and %save. These commands can now be
2407 invoked on the unprocessed input as it was typed by the user
2411 invoked on the unprocessed input as it was typed by the user
2408 (without any prefilters applied). After requests by the SAGE team
2412 (without any prefilters applied). After requests by the SAGE team
2409 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
2413 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
2410
2414
2411 2006-02-01 Ville Vainio <vivainio@gmail.com>
2415 2006-02-01 Ville Vainio <vivainio@gmail.com>
2412
2416
2413 * setup.py, eggsetup.py: easy_install ipython==dev works
2417 * setup.py, eggsetup.py: easy_install ipython==dev works
2414 correctly now (on Linux)
2418 correctly now (on Linux)
2415
2419
2416 * ipy_user_conf,ipmaker: user config changes, removed spurious
2420 * ipy_user_conf,ipmaker: user config changes, removed spurious
2417 warnings
2421 warnings
2418
2422
2419 * iplib: if rc.banner is string, use it as is.
2423 * iplib: if rc.banner is string, use it as is.
2420
2424
2421 * Magic: %pycat accepts a string argument and pages it's contents.
2425 * Magic: %pycat accepts a string argument and pages it's contents.
2422
2426
2423
2427
2424 2006-01-30 Ville Vainio <vivainio@gmail.com>
2428 2006-01-30 Ville Vainio <vivainio@gmail.com>
2425
2429
2426 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
2430 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
2427 Now %store and bookmarks work through PickleShare, meaning that
2431 Now %store and bookmarks work through PickleShare, meaning that
2428 concurrent access is possible and all ipython sessions see the
2432 concurrent access is possible and all ipython sessions see the
2429 same database situation all the time, instead of snapshot of
2433 same database situation all the time, instead of snapshot of
2430 the situation when the session was started. Hence, %bookmark
2434 the situation when the session was started. Hence, %bookmark
2431 results are immediately accessible from othes sessions. The database
2435 results are immediately accessible from othes sessions. The database
2432 is also available for use by user extensions. See:
2436 is also available for use by user extensions. See:
2433 http://www.python.org/pypi/pickleshare
2437 http://www.python.org/pypi/pickleshare
2434
2438
2435 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
2439 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
2436
2440
2437 * aliases can now be %store'd
2441 * aliases can now be %store'd
2438
2442
2439 * path.py moved to Extensions so that pickleshare does not need
2443 * path.py moved to Extensions so that pickleshare does not need
2440 IPython-specific import. Extensions added to pythonpath right
2444 IPython-specific import. Extensions added to pythonpath right
2441 at __init__.
2445 at __init__.
2442
2446
2443 * iplib.py: ipalias deprecated/redundant; aliases are converted and
2447 * iplib.py: ipalias deprecated/redundant; aliases are converted and
2444 called with _ip.system and the pre-transformed command string.
2448 called with _ip.system and the pre-transformed command string.
2445
2449
2446 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
2450 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
2447
2451
2448 * IPython/iplib.py (interact): Fix that we were not catching
2452 * IPython/iplib.py (interact): Fix that we were not catching
2449 KeyboardInterrupt exceptions properly. I'm not quite sure why the
2453 KeyboardInterrupt exceptions properly. I'm not quite sure why the
2450 logic here had to change, but it's fixed now.
2454 logic here had to change, but it's fixed now.
2451
2455
2452 2006-01-29 Ville Vainio <vivainio@gmail.com>
2456 2006-01-29 Ville Vainio <vivainio@gmail.com>
2453
2457
2454 * iplib.py: Try to import pyreadline on Windows.
2458 * iplib.py: Try to import pyreadline on Windows.
2455
2459
2456 2006-01-27 Ville Vainio <vivainio@gmail.com>
2460 2006-01-27 Ville Vainio <vivainio@gmail.com>
2457
2461
2458 * iplib.py: Expose ipapi as _ip in builtin namespace.
2462 * iplib.py: Expose ipapi as _ip in builtin namespace.
2459 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
2463 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
2460 and ip_set_hook (-> _ip.set_hook) redundant. % and !
2464 and ip_set_hook (-> _ip.set_hook) redundant. % and !
2461 syntax now produce _ip.* variant of the commands.
2465 syntax now produce _ip.* variant of the commands.
2462
2466
2463 * "_ip.options().autoedit_syntax = 2" automatically throws
2467 * "_ip.options().autoedit_syntax = 2" automatically throws
2464 user to editor for syntax error correction without prompting.
2468 user to editor for syntax error correction without prompting.
2465
2469
2466 2006-01-27 Ville Vainio <vivainio@gmail.com>
2470 2006-01-27 Ville Vainio <vivainio@gmail.com>
2467
2471
2468 * ipmaker.py: Give "realistic" sys.argv for scripts (without
2472 * ipmaker.py: Give "realistic" sys.argv for scripts (without
2469 'ipython' at argv[0]) executed through command line.
2473 'ipython' at argv[0]) executed through command line.
2470 NOTE: this DEPRECATES calling ipython with multiple scripts
2474 NOTE: this DEPRECATES calling ipython with multiple scripts
2471 ("ipython a.py b.py c.py")
2475 ("ipython a.py b.py c.py")
2472
2476
2473 * iplib.py, hooks.py: Added configurable input prefilter,
2477 * iplib.py, hooks.py: Added configurable input prefilter,
2474 named 'input_prefilter'. See ext_rescapture.py for example
2478 named 'input_prefilter'. See ext_rescapture.py for example
2475 usage.
2479 usage.
2476
2480
2477 * ext_rescapture.py, Magic.py: Better system command output capture
2481 * ext_rescapture.py, Magic.py: Better system command output capture
2478 through 'var = !ls' (deprecates user-visible %sc). Same notation
2482 through 'var = !ls' (deprecates user-visible %sc). Same notation
2479 applies for magics, 'var = %alias' assigns alias list to var.
2483 applies for magics, 'var = %alias' assigns alias list to var.
2480
2484
2481 * ipapi.py: added meta() for accessing extension-usable data store.
2485 * ipapi.py: added meta() for accessing extension-usable data store.
2482
2486
2483 * iplib.py: added InteractiveShell.getapi(). New magics should be
2487 * iplib.py: added InteractiveShell.getapi(). New magics should be
2484 written doing self.getapi() instead of using the shell directly.
2488 written doing self.getapi() instead of using the shell directly.
2485
2489
2486 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
2490 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
2487 %store foo >> ~/myfoo.txt to store variables to files (in clean
2491 %store foo >> ~/myfoo.txt to store variables to files (in clean
2488 textual form, not a restorable pickle).
2492 textual form, not a restorable pickle).
2489
2493
2490 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
2494 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
2491
2495
2492 * usage.py, Magic.py: added %quickref
2496 * usage.py, Magic.py: added %quickref
2493
2497
2494 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
2498 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
2495
2499
2496 * GetoptErrors when invoking magics etc. with wrong args
2500 * GetoptErrors when invoking magics etc. with wrong args
2497 are now more helpful:
2501 are now more helpful:
2498 GetoptError: option -l not recognized (allowed: "qb" )
2502 GetoptError: option -l not recognized (allowed: "qb" )
2499
2503
2500 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
2504 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
2501
2505
2502 * IPython/demo.py (Demo.show): Flush stdout after each block, so
2506 * IPython/demo.py (Demo.show): Flush stdout after each block, so
2503 computationally intensive blocks don't appear to stall the demo.
2507 computationally intensive blocks don't appear to stall the demo.
2504
2508
2505 2006-01-24 Ville Vainio <vivainio@gmail.com>
2509 2006-01-24 Ville Vainio <vivainio@gmail.com>
2506
2510
2507 * iplib.py, hooks.py: 'result_display' hook can return a non-None
2511 * iplib.py, hooks.py: 'result_display' hook can return a non-None
2508 value to manipulate resulting history entry.
2512 value to manipulate resulting history entry.
2509
2513
2510 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
2514 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
2511 to instance methods of IPApi class, to make extending an embedded
2515 to instance methods of IPApi class, to make extending an embedded
2512 IPython feasible. See ext_rehashdir.py for example usage.
2516 IPython feasible. See ext_rehashdir.py for example usage.
2513
2517
2514 * Merged 1071-1076 from branches/0.7.1
2518 * Merged 1071-1076 from branches/0.7.1
2515
2519
2516
2520
2517 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
2521 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
2518
2522
2519 * tools/release (daystamp): Fix build tools to use the new
2523 * tools/release (daystamp): Fix build tools to use the new
2520 eggsetup.py script to build lightweight eggs.
2524 eggsetup.py script to build lightweight eggs.
2521
2525
2522 * Applied changesets 1062 and 1064 before 0.7.1 release.
2526 * Applied changesets 1062 and 1064 before 0.7.1 release.
2523
2527
2524 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
2528 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
2525 see the raw input history (without conversions like %ls ->
2529 see the raw input history (without conversions like %ls ->
2526 ipmagic("ls")). After a request from W. Stein, SAGE
2530 ipmagic("ls")). After a request from W. Stein, SAGE
2527 (http://modular.ucsd.edu/sage) developer. This information is
2531 (http://modular.ucsd.edu/sage) developer. This information is
2528 stored in the input_hist_raw attribute of the IPython instance, so
2532 stored in the input_hist_raw attribute of the IPython instance, so
2529 developers can access it if needed (it's an InputList instance).
2533 developers can access it if needed (it's an InputList instance).
2530
2534
2531 * Versionstring = 0.7.2.svn
2535 * Versionstring = 0.7.2.svn
2532
2536
2533 * eggsetup.py: A separate script for constructing eggs, creates
2537 * eggsetup.py: A separate script for constructing eggs, creates
2534 proper launch scripts even on Windows (an .exe file in
2538 proper launch scripts even on Windows (an .exe file in
2535 \python24\scripts).
2539 \python24\scripts).
2536
2540
2537 * ipapi.py: launch_new_instance, launch entry point needed for the
2541 * ipapi.py: launch_new_instance, launch entry point needed for the
2538 egg.
2542 egg.
2539
2543
2540 2006-01-23 Ville Vainio <vivainio@gmail.com>
2544 2006-01-23 Ville Vainio <vivainio@gmail.com>
2541
2545
2542 * Added %cpaste magic for pasting python code
2546 * Added %cpaste magic for pasting python code
2543
2547
2544 2006-01-22 Ville Vainio <vivainio@gmail.com>
2548 2006-01-22 Ville Vainio <vivainio@gmail.com>
2545
2549
2546 * Merge from branches/0.7.1 into trunk, revs 1052-1057
2550 * Merge from branches/0.7.1 into trunk, revs 1052-1057
2547
2551
2548 * Versionstring = 0.7.2.svn
2552 * Versionstring = 0.7.2.svn
2549
2553
2550 * eggsetup.py: A separate script for constructing eggs, creates
2554 * eggsetup.py: A separate script for constructing eggs, creates
2551 proper launch scripts even on Windows (an .exe file in
2555 proper launch scripts even on Windows (an .exe file in
2552 \python24\scripts).
2556 \python24\scripts).
2553
2557
2554 * ipapi.py: launch_new_instance, launch entry point needed for the
2558 * ipapi.py: launch_new_instance, launch entry point needed for the
2555 egg.
2559 egg.
2556
2560
2557 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
2561 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
2558
2562
2559 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
2563 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
2560 %pfile foo would print the file for foo even if it was a binary.
2564 %pfile foo would print the file for foo even if it was a binary.
2561 Now, extensions '.so' and '.dll' are skipped.
2565 Now, extensions '.so' and '.dll' are skipped.
2562
2566
2563 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
2567 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
2564 bug, where macros would fail in all threaded modes. I'm not 100%
2568 bug, where macros would fail in all threaded modes. I'm not 100%
2565 sure, so I'm going to put out an rc instead of making a release
2569 sure, so I'm going to put out an rc instead of making a release
2566 today, and wait for feedback for at least a few days.
2570 today, and wait for feedback for at least a few days.
2567
2571
2568 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
2572 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
2569 it...) the handling of pasting external code with autoindent on.
2573 it...) the handling of pasting external code with autoindent on.
2570 To get out of a multiline input, the rule will appear for most
2574 To get out of a multiline input, the rule will appear for most
2571 users unchanged: two blank lines or change the indent level
2575 users unchanged: two blank lines or change the indent level
2572 proposed by IPython. But there is a twist now: you can
2576 proposed by IPython. But there is a twist now: you can
2573 add/subtract only *one or two spaces*. If you add/subtract three
2577 add/subtract only *one or two spaces*. If you add/subtract three
2574 or more (unless you completely delete the line), IPython will
2578 or more (unless you completely delete the line), IPython will
2575 accept that line, and you'll need to enter a second one of pure
2579 accept that line, and you'll need to enter a second one of pure
2576 whitespace. I know it sounds complicated, but I can't find a
2580 whitespace. I know it sounds complicated, but I can't find a
2577 different solution that covers all the cases, with the right
2581 different solution that covers all the cases, with the right
2578 heuristics. Hopefully in actual use, nobody will really notice
2582 heuristics. Hopefully in actual use, nobody will really notice
2579 all these strange rules and things will 'just work'.
2583 all these strange rules and things will 'just work'.
2580
2584
2581 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
2585 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
2582
2586
2583 * IPython/iplib.py (interact): catch exceptions which can be
2587 * IPython/iplib.py (interact): catch exceptions which can be
2584 triggered asynchronously by signal handlers. Thanks to an
2588 triggered asynchronously by signal handlers. Thanks to an
2585 automatic crash report, submitted by Colin Kingsley
2589 automatic crash report, submitted by Colin Kingsley
2586 <tercel-AT-gentoo.org>.
2590 <tercel-AT-gentoo.org>.
2587
2591
2588 2006-01-20 Ville Vainio <vivainio@gmail.com>
2592 2006-01-20 Ville Vainio <vivainio@gmail.com>
2589
2593
2590 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
2594 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
2591 (%rehashdir, very useful, try it out) of how to extend ipython
2595 (%rehashdir, very useful, try it out) of how to extend ipython
2592 with new magics. Also added Extensions dir to pythonpath to make
2596 with new magics. Also added Extensions dir to pythonpath to make
2593 importing extensions easy.
2597 importing extensions easy.
2594
2598
2595 * %store now complains when trying to store interactively declared
2599 * %store now complains when trying to store interactively declared
2596 classes / instances of those classes.
2600 classes / instances of those classes.
2597
2601
2598 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
2602 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
2599 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
2603 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
2600 if they exist, and ipy_user_conf.py with some defaults is created for
2604 if they exist, and ipy_user_conf.py with some defaults is created for
2601 the user.
2605 the user.
2602
2606
2603 * Startup rehashing done by the config file, not InterpreterExec.
2607 * Startup rehashing done by the config file, not InterpreterExec.
2604 This means system commands are available even without selecting the
2608 This means system commands are available even without selecting the
2605 pysh profile. It's the sensible default after all.
2609 pysh profile. It's the sensible default after all.
2606
2610
2607 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
2611 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
2608
2612
2609 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
2613 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
2610 multiline code with autoindent on working. But I am really not
2614 multiline code with autoindent on working. But I am really not
2611 sure, so this needs more testing. Will commit a debug-enabled
2615 sure, so this needs more testing. Will commit a debug-enabled
2612 version for now, while I test it some more, so that Ville and
2616 version for now, while I test it some more, so that Ville and
2613 others may also catch any problems. Also made
2617 others may also catch any problems. Also made
2614 self.indent_current_str() a method, to ensure that there's no
2618 self.indent_current_str() a method, to ensure that there's no
2615 chance of the indent space count and the corresponding string
2619 chance of the indent space count and the corresponding string
2616 falling out of sync. All code needing the string should just call
2620 falling out of sync. All code needing the string should just call
2617 the method.
2621 the method.
2618
2622
2619 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
2623 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
2620
2624
2621 * IPython/Magic.py (magic_edit): fix check for when users don't
2625 * IPython/Magic.py (magic_edit): fix check for when users don't
2622 save their output files, the try/except was in the wrong section.
2626 save their output files, the try/except was in the wrong section.
2623
2627
2624 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
2628 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
2625
2629
2626 * IPython/Magic.py (magic_run): fix __file__ global missing from
2630 * IPython/Magic.py (magic_run): fix __file__ global missing from
2627 script's namespace when executed via %run. After a report by
2631 script's namespace when executed via %run. After a report by
2628 Vivian.
2632 Vivian.
2629
2633
2630 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
2634 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
2631 when using python 2.4. The parent constructor changed in 2.4, and
2635 when using python 2.4. The parent constructor changed in 2.4, and
2632 we need to track it directly (we can't call it, as it messes up
2636 we need to track it directly (we can't call it, as it messes up
2633 readline and tab-completion inside our pdb would stop working).
2637 readline and tab-completion inside our pdb would stop working).
2634 After a bug report by R. Bernstein <rocky-AT-panix.com>.
2638 After a bug report by R. Bernstein <rocky-AT-panix.com>.
2635
2639
2636 2006-01-16 Ville Vainio <vivainio@gmail.com>
2640 2006-01-16 Ville Vainio <vivainio@gmail.com>
2637
2641
2638 * Ipython/magic.py: Reverted back to old %edit functionality
2642 * Ipython/magic.py: Reverted back to old %edit functionality
2639 that returns file contents on exit.
2643 that returns file contents on exit.
2640
2644
2641 * IPython/path.py: Added Jason Orendorff's "path" module to
2645 * IPython/path.py: Added Jason Orendorff's "path" module to
2642 IPython tree, http://www.jorendorff.com/articles/python/path/.
2646 IPython tree, http://www.jorendorff.com/articles/python/path/.
2643 You can get path objects conveniently through %sc, and !!, e.g.:
2647 You can get path objects conveniently through %sc, and !!, e.g.:
2644 sc files=ls
2648 sc files=ls
2645 for p in files.paths: # or files.p
2649 for p in files.paths: # or files.p
2646 print p,p.mtime
2650 print p,p.mtime
2647
2651
2648 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
2652 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
2649 now work again without considering the exclusion regexp -
2653 now work again without considering the exclusion regexp -
2650 hence, things like ',foo my/path' turn to 'foo("my/path")'
2654 hence, things like ',foo my/path' turn to 'foo("my/path")'
2651 instead of syntax error.
2655 instead of syntax error.
2652
2656
2653
2657
2654 2006-01-14 Ville Vainio <vivainio@gmail.com>
2658 2006-01-14 Ville Vainio <vivainio@gmail.com>
2655
2659
2656 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
2660 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
2657 ipapi decorators for python 2.4 users, options() provides access to rc
2661 ipapi decorators for python 2.4 users, options() provides access to rc
2658 data.
2662 data.
2659
2663
2660 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
2664 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
2661 as path separators (even on Linux ;-). Space character after
2665 as path separators (even on Linux ;-). Space character after
2662 backslash (as yielded by tab completer) is still space;
2666 backslash (as yielded by tab completer) is still space;
2663 "%cd long\ name" works as expected.
2667 "%cd long\ name" works as expected.
2664
2668
2665 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
2669 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
2666 as "chain of command", with priority. API stays the same,
2670 as "chain of command", with priority. API stays the same,
2667 TryNext exception raised by a hook function signals that
2671 TryNext exception raised by a hook function signals that
2668 current hook failed and next hook should try handling it, as
2672 current hook failed and next hook should try handling it, as
2669 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
2673 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
2670 requested configurable display hook, which is now implemented.
2674 requested configurable display hook, which is now implemented.
2671
2675
2672 2006-01-13 Ville Vainio <vivainio@gmail.com>
2676 2006-01-13 Ville Vainio <vivainio@gmail.com>
2673
2677
2674 * IPython/platutils*.py: platform specific utility functions,
2678 * IPython/platutils*.py: platform specific utility functions,
2675 so far only set_term_title is implemented (change terminal
2679 so far only set_term_title is implemented (change terminal
2676 label in windowing systems). %cd now changes the title to
2680 label in windowing systems). %cd now changes the title to
2677 current dir.
2681 current dir.
2678
2682
2679 * IPython/Release.py: Added myself to "authors" list,
2683 * IPython/Release.py: Added myself to "authors" list,
2680 had to create new files.
2684 had to create new files.
2681
2685
2682 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
2686 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
2683 shell escape; not a known bug but had potential to be one in the
2687 shell escape; not a known bug but had potential to be one in the
2684 future.
2688 future.
2685
2689
2686 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
2690 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
2687 extension API for IPython! See the module for usage example. Fix
2691 extension API for IPython! See the module for usage example. Fix
2688 OInspect for docstring-less magic functions.
2692 OInspect for docstring-less magic functions.
2689
2693
2690
2694
2691 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
2695 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
2692
2696
2693 * IPython/iplib.py (raw_input): temporarily deactivate all
2697 * IPython/iplib.py (raw_input): temporarily deactivate all
2694 attempts at allowing pasting of code with autoindent on. It
2698 attempts at allowing pasting of code with autoindent on. It
2695 introduced bugs (reported by Prabhu) and I can't seem to find a
2699 introduced bugs (reported by Prabhu) and I can't seem to find a
2696 robust combination which works in all cases. Will have to revisit
2700 robust combination which works in all cases. Will have to revisit
2697 later.
2701 later.
2698
2702
2699 * IPython/genutils.py: remove isspace() function. We've dropped
2703 * IPython/genutils.py: remove isspace() function. We've dropped
2700 2.2 compatibility, so it's OK to use the string method.
2704 2.2 compatibility, so it's OK to use the string method.
2701
2705
2702 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2706 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2703
2707
2704 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
2708 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
2705 matching what NOT to autocall on, to include all python binary
2709 matching what NOT to autocall on, to include all python binary
2706 operators (including things like 'and', 'or', 'is' and 'in').
2710 operators (including things like 'and', 'or', 'is' and 'in').
2707 Prompted by a bug report on 'foo & bar', but I realized we had
2711 Prompted by a bug report on 'foo & bar', but I realized we had
2708 many more potential bug cases with other operators. The regexp is
2712 many more potential bug cases with other operators. The regexp is
2709 self.re_exclude_auto, it's fairly commented.
2713 self.re_exclude_auto, it's fairly commented.
2710
2714
2711 2006-01-12 Ville Vainio <vivainio@gmail.com>
2715 2006-01-12 Ville Vainio <vivainio@gmail.com>
2712
2716
2713 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
2717 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
2714 Prettified and hardened string/backslash quoting with ipsystem(),
2718 Prettified and hardened string/backslash quoting with ipsystem(),
2715 ipalias() and ipmagic(). Now even \ characters are passed to
2719 ipalias() and ipmagic(). Now even \ characters are passed to
2716 %magics, !shell escapes and aliases exactly as they are in the
2720 %magics, !shell escapes and aliases exactly as they are in the
2717 ipython command line. Should improve backslash experience,
2721 ipython command line. Should improve backslash experience,
2718 particularly in Windows (path delimiter for some commands that
2722 particularly in Windows (path delimiter for some commands that
2719 won't understand '/'), but Unix benefits as well (regexps). %cd
2723 won't understand '/'), but Unix benefits as well (regexps). %cd
2720 magic still doesn't support backslash path delimiters, though. Also
2724 magic still doesn't support backslash path delimiters, though. Also
2721 deleted all pretense of supporting multiline command strings in
2725 deleted all pretense of supporting multiline command strings in
2722 !system or %magic commands. Thanks to Jerry McRae for suggestions.
2726 !system or %magic commands. Thanks to Jerry McRae for suggestions.
2723
2727
2724 * doc/build_doc_instructions.txt added. Documentation on how to
2728 * doc/build_doc_instructions.txt added. Documentation on how to
2725 use doc/update_manual.py, added yesterday. Both files contributed
2729 use doc/update_manual.py, added yesterday. Both files contributed
2726 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
2730 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
2727 doc/*.sh for deprecation at a later date.
2731 doc/*.sh for deprecation at a later date.
2728
2732
2729 * /ipython.py Added ipython.py to root directory for
2733 * /ipython.py Added ipython.py to root directory for
2730 zero-installation (tar xzvf ipython.tgz; cd ipython; python
2734 zero-installation (tar xzvf ipython.tgz; cd ipython; python
2731 ipython.py) and development convenience (no need to keep doing
2735 ipython.py) and development convenience (no need to keep doing
2732 "setup.py install" between changes).
2736 "setup.py install" between changes).
2733
2737
2734 * Made ! and !! shell escapes work (again) in multiline expressions:
2738 * Made ! and !! shell escapes work (again) in multiline expressions:
2735 if 1:
2739 if 1:
2736 !ls
2740 !ls
2737 !!ls
2741 !!ls
2738
2742
2739 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2743 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2740
2744
2741 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
2745 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
2742 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
2746 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
2743 module in case-insensitive installation. Was causing crashes
2747 module in case-insensitive installation. Was causing crashes
2744 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
2748 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
2745
2749
2746 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
2750 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
2747 <marienz-AT-gentoo.org>, closes
2751 <marienz-AT-gentoo.org>, closes
2748 http://www.scipy.net/roundup/ipython/issue51.
2752 http://www.scipy.net/roundup/ipython/issue51.
2749
2753
2750 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
2754 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
2751
2755
2752 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
2756 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
2753 problem of excessive CPU usage under *nix and keyboard lag under
2757 problem of excessive CPU usage under *nix and keyboard lag under
2754 win32.
2758 win32.
2755
2759
2756 2006-01-10 *** Released version 0.7.0
2760 2006-01-10 *** Released version 0.7.0
2757
2761
2758 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
2762 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
2759
2763
2760 * IPython/Release.py (revision): tag version number to 0.7.0,
2764 * IPython/Release.py (revision): tag version number to 0.7.0,
2761 ready for release.
2765 ready for release.
2762
2766
2763 * IPython/Magic.py (magic_edit): Add print statement to %edit so
2767 * IPython/Magic.py (magic_edit): Add print statement to %edit so
2764 it informs the user of the name of the temp. file used. This can
2768 it informs the user of the name of the temp. file used. This can
2765 help if you decide later to reuse that same file, so you know
2769 help if you decide later to reuse that same file, so you know
2766 where to copy the info from.
2770 where to copy the info from.
2767
2771
2768 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
2772 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
2769
2773
2770 * setup_bdist_egg.py: little script to build an egg. Added
2774 * setup_bdist_egg.py: little script to build an egg. Added
2771 support in the release tools as well.
2775 support in the release tools as well.
2772
2776
2773 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
2777 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
2774
2778
2775 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
2779 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
2776 version selection (new -wxversion command line and ipythonrc
2780 version selection (new -wxversion command line and ipythonrc
2777 parameter). Patch contributed by Arnd Baecker
2781 parameter). Patch contributed by Arnd Baecker
2778 <arnd.baecker-AT-web.de>.
2782 <arnd.baecker-AT-web.de>.
2779
2783
2780 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2784 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2781 embedded instances, for variables defined at the interactive
2785 embedded instances, for variables defined at the interactive
2782 prompt of the embedded ipython. Reported by Arnd.
2786 prompt of the embedded ipython. Reported by Arnd.
2783
2787
2784 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2788 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2785 it can be used as a (stateful) toggle, or with a direct parameter.
2789 it can be used as a (stateful) toggle, or with a direct parameter.
2786
2790
2787 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2791 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2788 could be triggered in certain cases and cause the traceback
2792 could be triggered in certain cases and cause the traceback
2789 printer not to work.
2793 printer not to work.
2790
2794
2791 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2795 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2792
2796
2793 * IPython/iplib.py (_should_recompile): Small fix, closes
2797 * IPython/iplib.py (_should_recompile): Small fix, closes
2794 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2798 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2795
2799
2796 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2800 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2797
2801
2798 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2802 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2799 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2803 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2800 Moad for help with tracking it down.
2804 Moad for help with tracking it down.
2801
2805
2802 * IPython/iplib.py (handle_auto): fix autocall handling for
2806 * IPython/iplib.py (handle_auto): fix autocall handling for
2803 objects which support BOTH __getitem__ and __call__ (so that f [x]
2807 objects which support BOTH __getitem__ and __call__ (so that f [x]
2804 is left alone, instead of becoming f([x]) automatically).
2808 is left alone, instead of becoming f([x]) automatically).
2805
2809
2806 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2810 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2807 Ville's patch.
2811 Ville's patch.
2808
2812
2809 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2813 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2810
2814
2811 * IPython/iplib.py (handle_auto): changed autocall semantics to
2815 * IPython/iplib.py (handle_auto): changed autocall semantics to
2812 include 'smart' mode, where the autocall transformation is NOT
2816 include 'smart' mode, where the autocall transformation is NOT
2813 applied if there are no arguments on the line. This allows you to
2817 applied if there are no arguments on the line. This allows you to
2814 just type 'foo' if foo is a callable to see its internal form,
2818 just type 'foo' if foo is a callable to see its internal form,
2815 instead of having it called with no arguments (typically a
2819 instead of having it called with no arguments (typically a
2816 mistake). The old 'full' autocall still exists: for that, you
2820 mistake). The old 'full' autocall still exists: for that, you
2817 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2821 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2818
2822
2819 * IPython/completer.py (Completer.attr_matches): add
2823 * IPython/completer.py (Completer.attr_matches): add
2820 tab-completion support for Enthoughts' traits. After a report by
2824 tab-completion support for Enthoughts' traits. After a report by
2821 Arnd and a patch by Prabhu.
2825 Arnd and a patch by Prabhu.
2822
2826
2823 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2827 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2824
2828
2825 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2829 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2826 Schmolck's patch to fix inspect.getinnerframes().
2830 Schmolck's patch to fix inspect.getinnerframes().
2827
2831
2828 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2832 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2829 for embedded instances, regarding handling of namespaces and items
2833 for embedded instances, regarding handling of namespaces and items
2830 added to the __builtin__ one. Multiple embedded instances and
2834 added to the __builtin__ one. Multiple embedded instances and
2831 recursive embeddings should work better now (though I'm not sure
2835 recursive embeddings should work better now (though I'm not sure
2832 I've got all the corner cases fixed, that code is a bit of a brain
2836 I've got all the corner cases fixed, that code is a bit of a brain
2833 twister).
2837 twister).
2834
2838
2835 * IPython/Magic.py (magic_edit): added support to edit in-memory
2839 * IPython/Magic.py (magic_edit): added support to edit in-memory
2836 macros (automatically creates the necessary temp files). %edit
2840 macros (automatically creates the necessary temp files). %edit
2837 also doesn't return the file contents anymore, it's just noise.
2841 also doesn't return the file contents anymore, it's just noise.
2838
2842
2839 * IPython/completer.py (Completer.attr_matches): revert change to
2843 * IPython/completer.py (Completer.attr_matches): revert change to
2840 complete only on attributes listed in __all__. I realized it
2844 complete only on attributes listed in __all__. I realized it
2841 cripples the tab-completion system as a tool for exploring the
2845 cripples the tab-completion system as a tool for exploring the
2842 internals of unknown libraries (it renders any non-__all__
2846 internals of unknown libraries (it renders any non-__all__
2843 attribute off-limits). I got bit by this when trying to see
2847 attribute off-limits). I got bit by this when trying to see
2844 something inside the dis module.
2848 something inside the dis module.
2845
2849
2846 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2850 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2847
2851
2848 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2852 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2849 namespace for users and extension writers to hold data in. This
2853 namespace for users and extension writers to hold data in. This
2850 follows the discussion in
2854 follows the discussion in
2851 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2855 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2852
2856
2853 * IPython/completer.py (IPCompleter.complete): small patch to help
2857 * IPython/completer.py (IPCompleter.complete): small patch to help
2854 tab-completion under Emacs, after a suggestion by John Barnard
2858 tab-completion under Emacs, after a suggestion by John Barnard
2855 <barnarj-AT-ccf.org>.
2859 <barnarj-AT-ccf.org>.
2856
2860
2857 * IPython/Magic.py (Magic.extract_input_slices): added support for
2861 * IPython/Magic.py (Magic.extract_input_slices): added support for
2858 the slice notation in magics to use N-M to represent numbers N...M
2862 the slice notation in magics to use N-M to represent numbers N...M
2859 (closed endpoints). This is used by %macro and %save.
2863 (closed endpoints). This is used by %macro and %save.
2860
2864
2861 * IPython/completer.py (Completer.attr_matches): for modules which
2865 * IPython/completer.py (Completer.attr_matches): for modules which
2862 define __all__, complete only on those. After a patch by Jeffrey
2866 define __all__, complete only on those. After a patch by Jeffrey
2863 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2867 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2864 speed up this routine.
2868 speed up this routine.
2865
2869
2866 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2870 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2867 don't know if this is the end of it, but the behavior now is
2871 don't know if this is the end of it, but the behavior now is
2868 certainly much more correct. Note that coupled with macros,
2872 certainly much more correct. Note that coupled with macros,
2869 slightly surprising (at first) behavior may occur: a macro will in
2873 slightly surprising (at first) behavior may occur: a macro will in
2870 general expand to multiple lines of input, so upon exiting, the
2874 general expand to multiple lines of input, so upon exiting, the
2871 in/out counters will both be bumped by the corresponding amount
2875 in/out counters will both be bumped by the corresponding amount
2872 (as if the macro's contents had been typed interactively). Typing
2876 (as if the macro's contents had been typed interactively). Typing
2873 %hist will reveal the intermediate (silently processed) lines.
2877 %hist will reveal the intermediate (silently processed) lines.
2874
2878
2875 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2879 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2876 pickle to fail (%run was overwriting __main__ and not restoring
2880 pickle to fail (%run was overwriting __main__ and not restoring
2877 it, but pickle relies on __main__ to operate).
2881 it, but pickle relies on __main__ to operate).
2878
2882
2879 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2883 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2880 using properties, but forgot to make the main InteractiveShell
2884 using properties, but forgot to make the main InteractiveShell
2881 class a new-style class. Properties fail silently, and
2885 class a new-style class. Properties fail silently, and
2882 mysteriously, with old-style class (getters work, but
2886 mysteriously, with old-style class (getters work, but
2883 setters don't do anything).
2887 setters don't do anything).
2884
2888
2885 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2889 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2886
2890
2887 * IPython/Magic.py (magic_history): fix history reporting bug (I
2891 * IPython/Magic.py (magic_history): fix history reporting bug (I
2888 know some nasties are still there, I just can't seem to find a
2892 know some nasties are still there, I just can't seem to find a
2889 reproducible test case to track them down; the input history is
2893 reproducible test case to track them down; the input history is
2890 falling out of sync...)
2894 falling out of sync...)
2891
2895
2892 * IPython/iplib.py (handle_shell_escape): fix bug where both
2896 * IPython/iplib.py (handle_shell_escape): fix bug where both
2893 aliases and system accesses where broken for indented code (such
2897 aliases and system accesses where broken for indented code (such
2894 as loops).
2898 as loops).
2895
2899
2896 * IPython/genutils.py (shell): fix small but critical bug for
2900 * IPython/genutils.py (shell): fix small but critical bug for
2897 win32 system access.
2901 win32 system access.
2898
2902
2899 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2903 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2900
2904
2901 * IPython/iplib.py (showtraceback): remove use of the
2905 * IPython/iplib.py (showtraceback): remove use of the
2902 sys.last_{type/value/traceback} structures, which are non
2906 sys.last_{type/value/traceback} structures, which are non
2903 thread-safe.
2907 thread-safe.
2904 (_prefilter): change control flow to ensure that we NEVER
2908 (_prefilter): change control flow to ensure that we NEVER
2905 introspect objects when autocall is off. This will guarantee that
2909 introspect objects when autocall is off. This will guarantee that
2906 having an input line of the form 'x.y', where access to attribute
2910 having an input line of the form 'x.y', where access to attribute
2907 'y' has side effects, doesn't trigger the side effect TWICE. It
2911 'y' has side effects, doesn't trigger the side effect TWICE. It
2908 is important to note that, with autocall on, these side effects
2912 is important to note that, with autocall on, these side effects
2909 can still happen.
2913 can still happen.
2910 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2914 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2911 trio. IPython offers these three kinds of special calls which are
2915 trio. IPython offers these three kinds of special calls which are
2912 not python code, and it's a good thing to have their call method
2916 not python code, and it's a good thing to have their call method
2913 be accessible as pure python functions (not just special syntax at
2917 be accessible as pure python functions (not just special syntax at
2914 the command line). It gives us a better internal implementation
2918 the command line). It gives us a better internal implementation
2915 structure, as well as exposing these for user scripting more
2919 structure, as well as exposing these for user scripting more
2916 cleanly.
2920 cleanly.
2917
2921
2918 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2922 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2919 file. Now that they'll be more likely to be used with the
2923 file. Now that they'll be more likely to be used with the
2920 persistance system (%store), I want to make sure their module path
2924 persistance system (%store), I want to make sure their module path
2921 doesn't change in the future, so that we don't break things for
2925 doesn't change in the future, so that we don't break things for
2922 users' persisted data.
2926 users' persisted data.
2923
2927
2924 * IPython/iplib.py (autoindent_update): move indentation
2928 * IPython/iplib.py (autoindent_update): move indentation
2925 management into the _text_ processing loop, not the keyboard
2929 management into the _text_ processing loop, not the keyboard
2926 interactive one. This is necessary to correctly process non-typed
2930 interactive one. This is necessary to correctly process non-typed
2927 multiline input (such as macros).
2931 multiline input (such as macros).
2928
2932
2929 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2933 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2930 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2934 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2931 which was producing problems in the resulting manual.
2935 which was producing problems in the resulting manual.
2932 (magic_whos): improve reporting of instances (show their class,
2936 (magic_whos): improve reporting of instances (show their class,
2933 instead of simply printing 'instance' which isn't terribly
2937 instead of simply printing 'instance' which isn't terribly
2934 informative).
2938 informative).
2935
2939
2936 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2940 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2937 (minor mods) to support network shares under win32.
2941 (minor mods) to support network shares under win32.
2938
2942
2939 * IPython/winconsole.py (get_console_size): add new winconsole
2943 * IPython/winconsole.py (get_console_size): add new winconsole
2940 module and fixes to page_dumb() to improve its behavior under
2944 module and fixes to page_dumb() to improve its behavior under
2941 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2945 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2942
2946
2943 * IPython/Magic.py (Macro): simplified Macro class to just
2947 * IPython/Magic.py (Macro): simplified Macro class to just
2944 subclass list. We've had only 2.2 compatibility for a very long
2948 subclass list. We've had only 2.2 compatibility for a very long
2945 time, yet I was still avoiding subclassing the builtin types. No
2949 time, yet I was still avoiding subclassing the builtin types. No
2946 more (I'm also starting to use properties, though I won't shift to
2950 more (I'm also starting to use properties, though I won't shift to
2947 2.3-specific features quite yet).
2951 2.3-specific features quite yet).
2948 (magic_store): added Ville's patch for lightweight variable
2952 (magic_store): added Ville's patch for lightweight variable
2949 persistence, after a request on the user list by Matt Wilkie
2953 persistence, after a request on the user list by Matt Wilkie
2950 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2954 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2951 details.
2955 details.
2952
2956
2953 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2957 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2954 changed the default logfile name from 'ipython.log' to
2958 changed the default logfile name from 'ipython.log' to
2955 'ipython_log.py'. These logs are real python files, and now that
2959 'ipython_log.py'. These logs are real python files, and now that
2956 we have much better multiline support, people are more likely to
2960 we have much better multiline support, people are more likely to
2957 want to use them as such. Might as well name them correctly.
2961 want to use them as such. Might as well name them correctly.
2958
2962
2959 * IPython/Magic.py: substantial cleanup. While we can't stop
2963 * IPython/Magic.py: substantial cleanup. While we can't stop
2960 using magics as mixins, due to the existing customizations 'out
2964 using magics as mixins, due to the existing customizations 'out
2961 there' which rely on the mixin naming conventions, at least I
2965 there' which rely on the mixin naming conventions, at least I
2962 cleaned out all cross-class name usage. So once we are OK with
2966 cleaned out all cross-class name usage. So once we are OK with
2963 breaking compatibility, the two systems can be separated.
2967 breaking compatibility, the two systems can be separated.
2964
2968
2965 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2969 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2966 anymore, and the class is a fair bit less hideous as well. New
2970 anymore, and the class is a fair bit less hideous as well. New
2967 features were also introduced: timestamping of input, and logging
2971 features were also introduced: timestamping of input, and logging
2968 of output results. These are user-visible with the -t and -o
2972 of output results. These are user-visible with the -t and -o
2969 options to %logstart. Closes
2973 options to %logstart. Closes
2970 http://www.scipy.net/roundup/ipython/issue11 and a request by
2974 http://www.scipy.net/roundup/ipython/issue11 and a request by
2971 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2975 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2972
2976
2973 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2977 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2974
2978
2975 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2979 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2976 better handle backslashes in paths. See the thread 'More Windows
2980 better handle backslashes in paths. See the thread 'More Windows
2977 questions part 2 - \/ characters revisited' on the iypthon user
2981 questions part 2 - \/ characters revisited' on the iypthon user
2978 list:
2982 list:
2979 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2983 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2980
2984
2981 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2985 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2982
2986
2983 (InteractiveShell.__init__): change threaded shells to not use the
2987 (InteractiveShell.__init__): change threaded shells to not use the
2984 ipython crash handler. This was causing more problems than not,
2988 ipython crash handler. This was causing more problems than not,
2985 as exceptions in the main thread (GUI code, typically) would
2989 as exceptions in the main thread (GUI code, typically) would
2986 always show up as a 'crash', when they really weren't.
2990 always show up as a 'crash', when they really weren't.
2987
2991
2988 The colors and exception mode commands (%colors/%xmode) have been
2992 The colors and exception mode commands (%colors/%xmode) have been
2989 synchronized to also take this into account, so users can get
2993 synchronized to also take this into account, so users can get
2990 verbose exceptions for their threaded code as well. I also added
2994 verbose exceptions for their threaded code as well. I also added
2991 support for activating pdb inside this exception handler as well,
2995 support for activating pdb inside this exception handler as well,
2992 so now GUI authors can use IPython's enhanced pdb at runtime.
2996 so now GUI authors can use IPython's enhanced pdb at runtime.
2993
2997
2994 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2998 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2995 true by default, and add it to the shipped ipythonrc file. Since
2999 true by default, and add it to the shipped ipythonrc file. Since
2996 this asks the user before proceeding, I think it's OK to make it
3000 this asks the user before proceeding, I think it's OK to make it
2997 true by default.
3001 true by default.
2998
3002
2999 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
3003 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
3000 of the previous special-casing of input in the eval loop. I think
3004 of the previous special-casing of input in the eval loop. I think
3001 this is cleaner, as they really are commands and shouldn't have
3005 this is cleaner, as they really are commands and shouldn't have
3002 a special role in the middle of the core code.
3006 a special role in the middle of the core code.
3003
3007
3004 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
3008 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
3005
3009
3006 * IPython/iplib.py (edit_syntax_error): added support for
3010 * IPython/iplib.py (edit_syntax_error): added support for
3007 automatically reopening the editor if the file had a syntax error
3011 automatically reopening the editor if the file had a syntax error
3008 in it. Thanks to scottt who provided the patch at:
3012 in it. Thanks to scottt who provided the patch at:
3009 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
3013 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
3010 version committed).
3014 version committed).
3011
3015
3012 * IPython/iplib.py (handle_normal): add suport for multi-line
3016 * IPython/iplib.py (handle_normal): add suport for multi-line
3013 input with emtpy lines. This fixes
3017 input with emtpy lines. This fixes
3014 http://www.scipy.net/roundup/ipython/issue43 and a similar
3018 http://www.scipy.net/roundup/ipython/issue43 and a similar
3015 discussion on the user list.
3019 discussion on the user list.
3016
3020
3017 WARNING: a behavior change is necessarily introduced to support
3021 WARNING: a behavior change is necessarily introduced to support
3018 blank lines: now a single blank line with whitespace does NOT
3022 blank lines: now a single blank line with whitespace does NOT
3019 break the input loop, which means that when autoindent is on, by
3023 break the input loop, which means that when autoindent is on, by
3020 default hitting return on the next (indented) line does NOT exit.
3024 default hitting return on the next (indented) line does NOT exit.
3021
3025
3022 Instead, to exit a multiline input you can either have:
3026 Instead, to exit a multiline input you can either have:
3023
3027
3024 - TWO whitespace lines (just hit return again), or
3028 - TWO whitespace lines (just hit return again), or
3025 - a single whitespace line of a different length than provided
3029 - a single whitespace line of a different length than provided
3026 by the autoindent (add or remove a space).
3030 by the autoindent (add or remove a space).
3027
3031
3028 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
3032 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
3029 module to better organize all readline-related functionality.
3033 module to better organize all readline-related functionality.
3030 I've deleted FlexCompleter and put all completion clases here.
3034 I've deleted FlexCompleter and put all completion clases here.
3031
3035
3032 * IPython/iplib.py (raw_input): improve indentation management.
3036 * IPython/iplib.py (raw_input): improve indentation management.
3033 It is now possible to paste indented code with autoindent on, and
3037 It is now possible to paste indented code with autoindent on, and
3034 the code is interpreted correctly (though it still looks bad on
3038 the code is interpreted correctly (though it still looks bad on
3035 screen, due to the line-oriented nature of ipython).
3039 screen, due to the line-oriented nature of ipython).
3036 (MagicCompleter.complete): change behavior so that a TAB key on an
3040 (MagicCompleter.complete): change behavior so that a TAB key on an
3037 otherwise empty line actually inserts a tab, instead of completing
3041 otherwise empty line actually inserts a tab, instead of completing
3038 on the entire global namespace. This makes it easier to use the
3042 on the entire global namespace. This makes it easier to use the
3039 TAB key for indentation. After a request by Hans Meine
3043 TAB key for indentation. After a request by Hans Meine
3040 <hans_meine-AT-gmx.net>
3044 <hans_meine-AT-gmx.net>
3041 (_prefilter): add support so that typing plain 'exit' or 'quit'
3045 (_prefilter): add support so that typing plain 'exit' or 'quit'
3042 does a sensible thing. Originally I tried to deviate as little as
3046 does a sensible thing. Originally I tried to deviate as little as
3043 possible from the default python behavior, but even that one may
3047 possible from the default python behavior, but even that one may
3044 change in this direction (thread on python-dev to that effect).
3048 change in this direction (thread on python-dev to that effect).
3045 Regardless, ipython should do the right thing even if CPython's
3049 Regardless, ipython should do the right thing even if CPython's
3046 '>>>' prompt doesn't.
3050 '>>>' prompt doesn't.
3047 (InteractiveShell): removed subclassing code.InteractiveConsole
3051 (InteractiveShell): removed subclassing code.InteractiveConsole
3048 class. By now we'd overridden just about all of its methods: I've
3052 class. By now we'd overridden just about all of its methods: I've
3049 copied the remaining two over, and now ipython is a standalone
3053 copied the remaining two over, and now ipython is a standalone
3050 class. This will provide a clearer picture for the chainsaw
3054 class. This will provide a clearer picture for the chainsaw
3051 branch refactoring.
3055 branch refactoring.
3052
3056
3053 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
3057 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
3054
3058
3055 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
3059 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
3056 failures for objects which break when dir() is called on them.
3060 failures for objects which break when dir() is called on them.
3057
3061
3058 * IPython/FlexCompleter.py (Completer.__init__): Added support for
3062 * IPython/FlexCompleter.py (Completer.__init__): Added support for
3059 distinct local and global namespaces in the completer API. This
3063 distinct local and global namespaces in the completer API. This
3060 change allows us to properly handle completion with distinct
3064 change allows us to properly handle completion with distinct
3061 scopes, including in embedded instances (this had never really
3065 scopes, including in embedded instances (this had never really
3062 worked correctly).
3066 worked correctly).
3063
3067
3064 Note: this introduces a change in the constructor for
3068 Note: this introduces a change in the constructor for
3065 MagicCompleter, as a new global_namespace parameter is now the
3069 MagicCompleter, as a new global_namespace parameter is now the
3066 second argument (the others were bumped one position).
3070 second argument (the others were bumped one position).
3067
3071
3068 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
3072 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
3069
3073
3070 * IPython/iplib.py (embed_mainloop): fix tab-completion in
3074 * IPython/iplib.py (embed_mainloop): fix tab-completion in
3071 embedded instances (which can be done now thanks to Vivian's
3075 embedded instances (which can be done now thanks to Vivian's
3072 frame-handling fixes for pdb).
3076 frame-handling fixes for pdb).
3073 (InteractiveShell.__init__): Fix namespace handling problem in
3077 (InteractiveShell.__init__): Fix namespace handling problem in
3074 embedded instances. We were overwriting __main__ unconditionally,
3078 embedded instances. We were overwriting __main__ unconditionally,
3075 and this should only be done for 'full' (non-embedded) IPython;
3079 and this should only be done for 'full' (non-embedded) IPython;
3076 embedded instances must respect the caller's __main__. Thanks to
3080 embedded instances must respect the caller's __main__. Thanks to
3077 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
3081 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
3078
3082
3079 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
3083 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
3080
3084
3081 * setup.py: added download_url to setup(). This registers the
3085 * setup.py: added download_url to setup(). This registers the
3082 download address at PyPI, which is not only useful to humans
3086 download address at PyPI, which is not only useful to humans
3083 browsing the site, but is also picked up by setuptools (the Eggs
3087 browsing the site, but is also picked up by setuptools (the Eggs
3084 machinery). Thanks to Ville and R. Kern for the info/discussion
3088 machinery). Thanks to Ville and R. Kern for the info/discussion
3085 on this.
3089 on this.
3086
3090
3087 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
3091 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
3088
3092
3089 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
3093 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
3090 This brings a lot of nice functionality to the pdb mode, which now
3094 This brings a lot of nice functionality to the pdb mode, which now
3091 has tab-completion, syntax highlighting, and better stack handling
3095 has tab-completion, syntax highlighting, and better stack handling
3092 than before. Many thanks to Vivian De Smedt
3096 than before. Many thanks to Vivian De Smedt
3093 <vivian-AT-vdesmedt.com> for the original patches.
3097 <vivian-AT-vdesmedt.com> for the original patches.
3094
3098
3095 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
3099 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
3096
3100
3097 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
3101 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
3098 sequence to consistently accept the banner argument. The
3102 sequence to consistently accept the banner argument. The
3099 inconsistency was tripping SAGE, thanks to Gary Zablackis
3103 inconsistency was tripping SAGE, thanks to Gary Zablackis
3100 <gzabl-AT-yahoo.com> for the report.
3104 <gzabl-AT-yahoo.com> for the report.
3101
3105
3102 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
3106 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
3103
3107
3104 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3108 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3105 Fix bug where a naked 'alias' call in the ipythonrc file would
3109 Fix bug where a naked 'alias' call in the ipythonrc file would
3106 cause a crash. Bug reported by Jorgen Stenarson.
3110 cause a crash. Bug reported by Jorgen Stenarson.
3107
3111
3108 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
3112 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
3109
3113
3110 * IPython/ipmaker.py (make_IPython): cleanups which should improve
3114 * IPython/ipmaker.py (make_IPython): cleanups which should improve
3111 startup time.
3115 startup time.
3112
3116
3113 * IPython/iplib.py (runcode): my globals 'fix' for embedded
3117 * IPython/iplib.py (runcode): my globals 'fix' for embedded
3114 instances had introduced a bug with globals in normal code. Now
3118 instances had introduced a bug with globals in normal code. Now
3115 it's working in all cases.
3119 it's working in all cases.
3116
3120
3117 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
3121 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
3118 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
3122 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
3119 has been introduced to set the default case sensitivity of the
3123 has been introduced to set the default case sensitivity of the
3120 searches. Users can still select either mode at runtime on a
3124 searches. Users can still select either mode at runtime on a
3121 per-search basis.
3125 per-search basis.
3122
3126
3123 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
3127 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
3124
3128
3125 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
3129 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
3126 attributes in wildcard searches for subclasses. Modified version
3130 attributes in wildcard searches for subclasses. Modified version
3127 of a patch by Jorgen.
3131 of a patch by Jorgen.
3128
3132
3129 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
3133 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
3130
3134
3131 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
3135 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
3132 embedded instances. I added a user_global_ns attribute to the
3136 embedded instances. I added a user_global_ns attribute to the
3133 InteractiveShell class to handle this.
3137 InteractiveShell class to handle this.
3134
3138
3135 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
3139 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
3136
3140
3137 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
3141 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
3138 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
3142 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
3139 (reported under win32, but may happen also in other platforms).
3143 (reported under win32, but may happen also in other platforms).
3140 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
3144 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
3141
3145
3142 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
3146 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
3143
3147
3144 * IPython/Magic.py (magic_psearch): new support for wildcard
3148 * IPython/Magic.py (magic_psearch): new support for wildcard
3145 patterns. Now, typing ?a*b will list all names which begin with a
3149 patterns. Now, typing ?a*b will list all names which begin with a
3146 and end in b, for example. The %psearch magic has full
3150 and end in b, for example. The %psearch magic has full
3147 docstrings. Many thanks to JΓΆrgen Stenarson
3151 docstrings. Many thanks to JΓΆrgen Stenarson
3148 <jorgen.stenarson-AT-bostream.nu>, author of the patches
3152 <jorgen.stenarson-AT-bostream.nu>, author of the patches
3149 implementing this functionality.
3153 implementing this functionality.
3150
3154
3151 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
3155 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
3152
3156
3153 * Manual: fixed long-standing annoyance of double-dashes (as in
3157 * Manual: fixed long-standing annoyance of double-dashes (as in
3154 --prefix=~, for example) being stripped in the HTML version. This
3158 --prefix=~, for example) being stripped in the HTML version. This
3155 is a latex2html bug, but a workaround was provided. Many thanks
3159 is a latex2html bug, but a workaround was provided. Many thanks
3156 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
3160 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
3157 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
3161 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
3158 rolling. This seemingly small issue had tripped a number of users
3162 rolling. This seemingly small issue had tripped a number of users
3159 when first installing, so I'm glad to see it gone.
3163 when first installing, so I'm glad to see it gone.
3160
3164
3161 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
3165 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
3162
3166
3163 * IPython/Extensions/numeric_formats.py: fix missing import,
3167 * IPython/Extensions/numeric_formats.py: fix missing import,
3164 reported by Stephen Walton.
3168 reported by Stephen Walton.
3165
3169
3166 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
3170 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
3167
3171
3168 * IPython/demo.py: finish demo module, fully documented now.
3172 * IPython/demo.py: finish demo module, fully documented now.
3169
3173
3170 * IPython/genutils.py (file_read): simple little utility to read a
3174 * IPython/genutils.py (file_read): simple little utility to read a
3171 file and ensure it's closed afterwards.
3175 file and ensure it's closed afterwards.
3172
3176
3173 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
3177 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
3174
3178
3175 * IPython/demo.py (Demo.__init__): added support for individually
3179 * IPython/demo.py (Demo.__init__): added support for individually
3176 tagging blocks for automatic execution.
3180 tagging blocks for automatic execution.
3177
3181
3178 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
3182 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
3179 syntax-highlighted python sources, requested by John.
3183 syntax-highlighted python sources, requested by John.
3180
3184
3181 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
3185 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
3182
3186
3183 * IPython/demo.py (Demo.again): fix bug where again() blocks after
3187 * IPython/demo.py (Demo.again): fix bug where again() blocks after
3184 finishing.
3188 finishing.
3185
3189
3186 * IPython/genutils.py (shlex_split): moved from Magic to here,
3190 * IPython/genutils.py (shlex_split): moved from Magic to here,
3187 where all 2.2 compatibility stuff lives. I needed it for demo.py.
3191 where all 2.2 compatibility stuff lives. I needed it for demo.py.
3188
3192
3189 * IPython/demo.py (Demo.__init__): added support for silent
3193 * IPython/demo.py (Demo.__init__): added support for silent
3190 blocks, improved marks as regexps, docstrings written.
3194 blocks, improved marks as regexps, docstrings written.
3191 (Demo.__init__): better docstring, added support for sys.argv.
3195 (Demo.__init__): better docstring, added support for sys.argv.
3192
3196
3193 * IPython/genutils.py (marquee): little utility used by the demo
3197 * IPython/genutils.py (marquee): little utility used by the demo
3194 code, handy in general.
3198 code, handy in general.
3195
3199
3196 * IPython/demo.py (Demo.__init__): new class for interactive
3200 * IPython/demo.py (Demo.__init__): new class for interactive
3197 demos. Not documented yet, I just wrote it in a hurry for
3201 demos. Not documented yet, I just wrote it in a hurry for
3198 scipy'05. Will docstring later.
3202 scipy'05. Will docstring later.
3199
3203
3200 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
3204 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
3201
3205
3202 * IPython/Shell.py (sigint_handler): Drastic simplification which
3206 * IPython/Shell.py (sigint_handler): Drastic simplification which
3203 also seems to make Ctrl-C work correctly across threads! This is
3207 also seems to make Ctrl-C work correctly across threads! This is
3204 so simple, that I can't beleive I'd missed it before. Needs more
3208 so simple, that I can't beleive I'd missed it before. Needs more
3205 testing, though.
3209 testing, though.
3206 (KBINT): Never mind, revert changes. I'm sure I'd tried something
3210 (KBINT): Never mind, revert changes. I'm sure I'd tried something
3207 like this before...
3211 like this before...
3208
3212
3209 * IPython/genutils.py (get_home_dir): add protection against
3213 * IPython/genutils.py (get_home_dir): add protection against
3210 non-dirs in win32 registry.
3214 non-dirs in win32 registry.
3211
3215
3212 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
3216 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
3213 bug where dict was mutated while iterating (pysh crash).
3217 bug where dict was mutated while iterating (pysh crash).
3214
3218
3215 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
3219 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
3216
3220
3217 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
3221 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
3218 spurious newlines added by this routine. After a report by
3222 spurious newlines added by this routine. After a report by
3219 F. Mantegazza.
3223 F. Mantegazza.
3220
3224
3221 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
3225 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
3222
3226
3223 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
3227 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
3224 calls. These were a leftover from the GTK 1.x days, and can cause
3228 calls. These were a leftover from the GTK 1.x days, and can cause
3225 problems in certain cases (after a report by John Hunter).
3229 problems in certain cases (after a report by John Hunter).
3226
3230
3227 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
3231 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
3228 os.getcwd() fails at init time. Thanks to patch from David Remahl
3232 os.getcwd() fails at init time. Thanks to patch from David Remahl
3229 <chmod007-AT-mac.com>.
3233 <chmod007-AT-mac.com>.
3230 (InteractiveShell.__init__): prevent certain special magics from
3234 (InteractiveShell.__init__): prevent certain special magics from
3231 being shadowed by aliases. Closes
3235 being shadowed by aliases. Closes
3232 http://www.scipy.net/roundup/ipython/issue41.
3236 http://www.scipy.net/roundup/ipython/issue41.
3233
3237
3234 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
3238 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
3235
3239
3236 * IPython/iplib.py (InteractiveShell.complete): Added new
3240 * IPython/iplib.py (InteractiveShell.complete): Added new
3237 top-level completion method to expose the completion mechanism
3241 top-level completion method to expose the completion mechanism
3238 beyond readline-based environments.
3242 beyond readline-based environments.
3239
3243
3240 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
3244 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
3241
3245
3242 * tools/ipsvnc (svnversion): fix svnversion capture.
3246 * tools/ipsvnc (svnversion): fix svnversion capture.
3243
3247
3244 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
3248 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
3245 attribute to self, which was missing. Before, it was set by a
3249 attribute to self, which was missing. Before, it was set by a
3246 routine which in certain cases wasn't being called, so the
3250 routine which in certain cases wasn't being called, so the
3247 instance could end up missing the attribute. This caused a crash.
3251 instance could end up missing the attribute. This caused a crash.
3248 Closes http://www.scipy.net/roundup/ipython/issue40.
3252 Closes http://www.scipy.net/roundup/ipython/issue40.
3249
3253
3250 2005-08-16 Fernando Perez <fperez@colorado.edu>
3254 2005-08-16 Fernando Perez <fperez@colorado.edu>
3251
3255
3252 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
3256 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
3253 contains non-string attribute. Closes
3257 contains non-string attribute. Closes
3254 http://www.scipy.net/roundup/ipython/issue38.
3258 http://www.scipy.net/roundup/ipython/issue38.
3255
3259
3256 2005-08-14 Fernando Perez <fperez@colorado.edu>
3260 2005-08-14 Fernando Perez <fperez@colorado.edu>
3257
3261
3258 * tools/ipsvnc: Minor improvements, to add changeset info.
3262 * tools/ipsvnc: Minor improvements, to add changeset info.
3259
3263
3260 2005-08-12 Fernando Perez <fperez@colorado.edu>
3264 2005-08-12 Fernando Perez <fperez@colorado.edu>
3261
3265
3262 * IPython/iplib.py (runsource): remove self.code_to_run_src
3266 * IPython/iplib.py (runsource): remove self.code_to_run_src
3263 attribute. I realized this is nothing more than
3267 attribute. I realized this is nothing more than
3264 '\n'.join(self.buffer), and having the same data in two different
3268 '\n'.join(self.buffer), and having the same data in two different
3265 places is just asking for synchronization bugs. This may impact
3269 places is just asking for synchronization bugs. This may impact
3266 people who have custom exception handlers, so I need to warn
3270 people who have custom exception handlers, so I need to warn
3267 ipython-dev about it (F. Mantegazza may use them).
3271 ipython-dev about it (F. Mantegazza may use them).
3268
3272
3269 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
3273 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
3270
3274
3271 * IPython/genutils.py: fix 2.2 compatibility (generators)
3275 * IPython/genutils.py: fix 2.2 compatibility (generators)
3272
3276
3273 2005-07-18 Fernando Perez <fperez@colorado.edu>
3277 2005-07-18 Fernando Perez <fperez@colorado.edu>
3274
3278
3275 * IPython/genutils.py (get_home_dir): fix to help users with
3279 * IPython/genutils.py (get_home_dir): fix to help users with
3276 invalid $HOME under win32.
3280 invalid $HOME under win32.
3277
3281
3278 2005-07-17 Fernando Perez <fperez@colorado.edu>
3282 2005-07-17 Fernando Perez <fperez@colorado.edu>
3279
3283
3280 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
3284 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
3281 some old hacks and clean up a bit other routines; code should be
3285 some old hacks and clean up a bit other routines; code should be
3282 simpler and a bit faster.
3286 simpler and a bit faster.
3283
3287
3284 * IPython/iplib.py (interact): removed some last-resort attempts
3288 * IPython/iplib.py (interact): removed some last-resort attempts
3285 to survive broken stdout/stderr. That code was only making it
3289 to survive broken stdout/stderr. That code was only making it
3286 harder to abstract out the i/o (necessary for gui integration),
3290 harder to abstract out the i/o (necessary for gui integration),
3287 and the crashes it could prevent were extremely rare in practice
3291 and the crashes it could prevent were extremely rare in practice
3288 (besides being fully user-induced in a pretty violent manner).
3292 (besides being fully user-induced in a pretty violent manner).
3289
3293
3290 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
3294 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
3291 Nothing major yet, but the code is simpler to read; this should
3295 Nothing major yet, but the code is simpler to read; this should
3292 make it easier to do more serious modifications in the future.
3296 make it easier to do more serious modifications in the future.
3293
3297
3294 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
3298 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
3295 which broke in .15 (thanks to a report by Ville).
3299 which broke in .15 (thanks to a report by Ville).
3296
3300
3297 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
3301 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
3298 be quite correct, I know next to nothing about unicode). This
3302 be quite correct, I know next to nothing about unicode). This
3299 will allow unicode strings to be used in prompts, amongst other
3303 will allow unicode strings to be used in prompts, amongst other
3300 cases. It also will prevent ipython from crashing when unicode
3304 cases. It also will prevent ipython from crashing when unicode
3301 shows up unexpectedly in many places. If ascii encoding fails, we
3305 shows up unexpectedly in many places. If ascii encoding fails, we
3302 assume utf_8. Currently the encoding is not a user-visible
3306 assume utf_8. Currently the encoding is not a user-visible
3303 setting, though it could be made so if there is demand for it.
3307 setting, though it could be made so if there is demand for it.
3304
3308
3305 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
3309 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
3306
3310
3307 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
3311 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
3308
3312
3309 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
3313 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
3310
3314
3311 * IPython/genutils.py: Add 2.2 compatibility here, so all other
3315 * IPython/genutils.py: Add 2.2 compatibility here, so all other
3312 code can work transparently for 2.2/2.3.
3316 code can work transparently for 2.2/2.3.
3313
3317
3314 2005-07-16 Fernando Perez <fperez@colorado.edu>
3318 2005-07-16 Fernando Perez <fperez@colorado.edu>
3315
3319
3316 * IPython/ultraTB.py (ExceptionColors): Make a global variable
3320 * IPython/ultraTB.py (ExceptionColors): Make a global variable
3317 out of the color scheme table used for coloring exception
3321 out of the color scheme table used for coloring exception
3318 tracebacks. This allows user code to add new schemes at runtime.
3322 tracebacks. This allows user code to add new schemes at runtime.
3319 This is a minimally modified version of the patch at
3323 This is a minimally modified version of the patch at
3320 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
3324 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
3321 for the contribution.
3325 for the contribution.
3322
3326
3323 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
3327 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
3324 slightly modified version of the patch in
3328 slightly modified version of the patch in
3325 http://www.scipy.net/roundup/ipython/issue34, which also allows me
3329 http://www.scipy.net/roundup/ipython/issue34, which also allows me
3326 to remove the previous try/except solution (which was costlier).
3330 to remove the previous try/except solution (which was costlier).
3327 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
3331 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
3328
3332
3329 2005-06-08 Fernando Perez <fperez@colorado.edu>
3333 2005-06-08 Fernando Perez <fperez@colorado.edu>
3330
3334
3331 * IPython/iplib.py (write/write_err): Add methods to abstract all
3335 * IPython/iplib.py (write/write_err): Add methods to abstract all
3332 I/O a bit more.
3336 I/O a bit more.
3333
3337
3334 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
3338 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
3335 warning, reported by Aric Hagberg, fix by JD Hunter.
3339 warning, reported by Aric Hagberg, fix by JD Hunter.
3336
3340
3337 2005-06-02 *** Released version 0.6.15
3341 2005-06-02 *** Released version 0.6.15
3338
3342
3339 2005-06-01 Fernando Perez <fperez@colorado.edu>
3343 2005-06-01 Fernando Perez <fperez@colorado.edu>
3340
3344
3341 * IPython/iplib.py (MagicCompleter.file_matches): Fix
3345 * IPython/iplib.py (MagicCompleter.file_matches): Fix
3342 tab-completion of filenames within open-quoted strings. Note that
3346 tab-completion of filenames within open-quoted strings. Note that
3343 this requires that in ~/.ipython/ipythonrc, users change the
3347 this requires that in ~/.ipython/ipythonrc, users change the
3344 readline delimiters configuration to read:
3348 readline delimiters configuration to read:
3345
3349
3346 readline_remove_delims -/~
3350 readline_remove_delims -/~
3347
3351
3348
3352
3349 2005-05-31 *** Released version 0.6.14
3353 2005-05-31 *** Released version 0.6.14
3350
3354
3351 2005-05-29 Fernando Perez <fperez@colorado.edu>
3355 2005-05-29 Fernando Perez <fperez@colorado.edu>
3352
3356
3353 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
3357 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
3354 with files not on the filesystem. Reported by Eliyahu Sandler
3358 with files not on the filesystem. Reported by Eliyahu Sandler
3355 <eli@gondolin.net>
3359 <eli@gondolin.net>
3356
3360
3357 2005-05-22 Fernando Perez <fperez@colorado.edu>
3361 2005-05-22 Fernando Perez <fperez@colorado.edu>
3358
3362
3359 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
3363 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
3360 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
3364 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
3361
3365
3362 2005-05-19 Fernando Perez <fperez@colorado.edu>
3366 2005-05-19 Fernando Perez <fperez@colorado.edu>
3363
3367
3364 * IPython/iplib.py (safe_execfile): close a file which could be
3368 * IPython/iplib.py (safe_execfile): close a file which could be
3365 left open (causing problems in win32, which locks open files).
3369 left open (causing problems in win32, which locks open files).
3366 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
3370 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
3367
3371
3368 2005-05-18 Fernando Perez <fperez@colorado.edu>
3372 2005-05-18 Fernando Perez <fperez@colorado.edu>
3369
3373
3370 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
3374 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
3371 keyword arguments correctly to safe_execfile().
3375 keyword arguments correctly to safe_execfile().
3372
3376
3373 2005-05-13 Fernando Perez <fperez@colorado.edu>
3377 2005-05-13 Fernando Perez <fperez@colorado.edu>
3374
3378
3375 * ipython.1: Added info about Qt to manpage, and threads warning
3379 * ipython.1: Added info about Qt to manpage, and threads warning
3376 to usage page (invoked with --help).
3380 to usage page (invoked with --help).
3377
3381
3378 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
3382 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
3379 new matcher (it goes at the end of the priority list) to do
3383 new matcher (it goes at the end of the priority list) to do
3380 tab-completion on named function arguments. Submitted by George
3384 tab-completion on named function arguments. Submitted by George
3381 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
3385 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
3382 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
3386 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
3383 for more details.
3387 for more details.
3384
3388
3385 * IPython/Magic.py (magic_run): Added new -e flag to ignore
3389 * IPython/Magic.py (magic_run): Added new -e flag to ignore
3386 SystemExit exceptions in the script being run. Thanks to a report
3390 SystemExit exceptions in the script being run. Thanks to a report
3387 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
3391 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
3388 producing very annoying behavior when running unit tests.
3392 producing very annoying behavior when running unit tests.
3389
3393
3390 2005-05-12 Fernando Perez <fperez@colorado.edu>
3394 2005-05-12 Fernando Perez <fperez@colorado.edu>
3391
3395
3392 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
3396 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
3393 which I'd broken (again) due to a changed regexp. In the process,
3397 which I'd broken (again) due to a changed regexp. In the process,
3394 added ';' as an escape to auto-quote the whole line without
3398 added ';' as an escape to auto-quote the whole line without
3395 splitting its arguments. Thanks to a report by Jerry McRae
3399 splitting its arguments. Thanks to a report by Jerry McRae
3396 <qrs0xyc02-AT-sneakemail.com>.
3400 <qrs0xyc02-AT-sneakemail.com>.
3397
3401
3398 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
3402 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
3399 possible crashes caused by a TokenError. Reported by Ed Schofield
3403 possible crashes caused by a TokenError. Reported by Ed Schofield
3400 <schofield-AT-ftw.at>.
3404 <schofield-AT-ftw.at>.
3401
3405
3402 2005-05-06 Fernando Perez <fperez@colorado.edu>
3406 2005-05-06 Fernando Perez <fperez@colorado.edu>
3403
3407
3404 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
3408 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
3405
3409
3406 2005-04-29 Fernando Perez <fperez@colorado.edu>
3410 2005-04-29 Fernando Perez <fperez@colorado.edu>
3407
3411
3408 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
3412 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
3409 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
3413 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
3410 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
3414 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
3411 which provides support for Qt interactive usage (similar to the
3415 which provides support for Qt interactive usage (similar to the
3412 existing one for WX and GTK). This had been often requested.
3416 existing one for WX and GTK). This had been often requested.
3413
3417
3414 2005-04-14 *** Released version 0.6.13
3418 2005-04-14 *** Released version 0.6.13
3415
3419
3416 2005-04-08 Fernando Perez <fperez@colorado.edu>
3420 2005-04-08 Fernando Perez <fperez@colorado.edu>
3417
3421
3418 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
3422 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
3419 from _ofind, which gets called on almost every input line. Now,
3423 from _ofind, which gets called on almost every input line. Now,
3420 we only try to get docstrings if they are actually going to be
3424 we only try to get docstrings if they are actually going to be
3421 used (the overhead of fetching unnecessary docstrings can be
3425 used (the overhead of fetching unnecessary docstrings can be
3422 noticeable for certain objects, such as Pyro proxies).
3426 noticeable for certain objects, such as Pyro proxies).
3423
3427
3424 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
3428 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
3425 for completers. For some reason I had been passing them the state
3429 for completers. For some reason I had been passing them the state
3426 variable, which completers never actually need, and was in
3430 variable, which completers never actually need, and was in
3427 conflict with the rlcompleter API. Custom completers ONLY need to
3431 conflict with the rlcompleter API. Custom completers ONLY need to
3428 take the text parameter.
3432 take the text parameter.
3429
3433
3430 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
3434 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
3431 work correctly in pysh. I've also moved all the logic which used
3435 work correctly in pysh. I've also moved all the logic which used
3432 to be in pysh.py here, which will prevent problems with future
3436 to be in pysh.py here, which will prevent problems with future
3433 upgrades. However, this time I must warn users to update their
3437 upgrades. However, this time I must warn users to update their
3434 pysh profile to include the line
3438 pysh profile to include the line
3435
3439
3436 import_all IPython.Extensions.InterpreterExec
3440 import_all IPython.Extensions.InterpreterExec
3437
3441
3438 because otherwise things won't work for them. They MUST also
3442 because otherwise things won't work for them. They MUST also
3439 delete pysh.py and the line
3443 delete pysh.py and the line
3440
3444
3441 execfile pysh.py
3445 execfile pysh.py
3442
3446
3443 from their ipythonrc-pysh.
3447 from their ipythonrc-pysh.
3444
3448
3445 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
3449 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
3446 robust in the face of objects whose dir() returns non-strings
3450 robust in the face of objects whose dir() returns non-strings
3447 (which it shouldn't, but some broken libs like ITK do). Thanks to
3451 (which it shouldn't, but some broken libs like ITK do). Thanks to
3448 a patch by John Hunter (implemented differently, though). Also
3452 a patch by John Hunter (implemented differently, though). Also
3449 minor improvements by using .extend instead of + on lists.
3453 minor improvements by using .extend instead of + on lists.
3450
3454
3451 * pysh.py:
3455 * pysh.py:
3452
3456
3453 2005-04-06 Fernando Perez <fperez@colorado.edu>
3457 2005-04-06 Fernando Perez <fperez@colorado.edu>
3454
3458
3455 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
3459 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
3456 by default, so that all users benefit from it. Those who don't
3460 by default, so that all users benefit from it. Those who don't
3457 want it can still turn it off.
3461 want it can still turn it off.
3458
3462
3459 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
3463 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
3460 config file, I'd forgotten about this, so users were getting it
3464 config file, I'd forgotten about this, so users were getting it
3461 off by default.
3465 off by default.
3462
3466
3463 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
3467 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
3464 consistency. Now magics can be called in multiline statements,
3468 consistency. Now magics can be called in multiline statements,
3465 and python variables can be expanded in magic calls via $var.
3469 and python variables can be expanded in magic calls via $var.
3466 This makes the magic system behave just like aliases or !system
3470 This makes the magic system behave just like aliases or !system
3467 calls.
3471 calls.
3468
3472
3469 2005-03-28 Fernando Perez <fperez@colorado.edu>
3473 2005-03-28 Fernando Perez <fperez@colorado.edu>
3470
3474
3471 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
3475 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
3472 expensive string additions for building command. Add support for
3476 expensive string additions for building command. Add support for
3473 trailing ';' when autocall is used.
3477 trailing ';' when autocall is used.
3474
3478
3475 2005-03-26 Fernando Perez <fperez@colorado.edu>
3479 2005-03-26 Fernando Perez <fperez@colorado.edu>
3476
3480
3477 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
3481 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
3478 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
3482 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
3479 ipython.el robust against prompts with any number of spaces
3483 ipython.el robust against prompts with any number of spaces
3480 (including 0) after the ':' character.
3484 (including 0) after the ':' character.
3481
3485
3482 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
3486 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
3483 continuation prompt, which misled users to think the line was
3487 continuation prompt, which misled users to think the line was
3484 already indented. Closes debian Bug#300847, reported to me by
3488 already indented. Closes debian Bug#300847, reported to me by
3485 Norbert Tretkowski <tretkowski-AT-inittab.de>.
3489 Norbert Tretkowski <tretkowski-AT-inittab.de>.
3486
3490
3487 2005-03-23 Fernando Perez <fperez@colorado.edu>
3491 2005-03-23 Fernando Perez <fperez@colorado.edu>
3488
3492
3489 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
3493 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
3490 properly aligned if they have embedded newlines.
3494 properly aligned if they have embedded newlines.
3491
3495
3492 * IPython/iplib.py (runlines): Add a public method to expose
3496 * IPython/iplib.py (runlines): Add a public method to expose
3493 IPython's code execution machinery, so that users can run strings
3497 IPython's code execution machinery, so that users can run strings
3494 as if they had been typed at the prompt interactively.
3498 as if they had been typed at the prompt interactively.
3495 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
3499 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
3496 methods which can call the system shell, but with python variable
3500 methods which can call the system shell, but with python variable
3497 expansion. The three such methods are: __IPYTHON__.system,
3501 expansion. The three such methods are: __IPYTHON__.system,
3498 .getoutput and .getoutputerror. These need to be documented in a
3502 .getoutput and .getoutputerror. These need to be documented in a
3499 'public API' section (to be written) of the manual.
3503 'public API' section (to be written) of the manual.
3500
3504
3501 2005-03-20 Fernando Perez <fperez@colorado.edu>
3505 2005-03-20 Fernando Perez <fperez@colorado.edu>
3502
3506
3503 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
3507 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
3504 for custom exception handling. This is quite powerful, and it
3508 for custom exception handling. This is quite powerful, and it
3505 allows for user-installable exception handlers which can trap
3509 allows for user-installable exception handlers which can trap
3506 custom exceptions at runtime and treat them separately from
3510 custom exceptions at runtime and treat them separately from
3507 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
3511 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
3508 Mantegazza <mantegazza-AT-ill.fr>.
3512 Mantegazza <mantegazza-AT-ill.fr>.
3509 (InteractiveShell.set_custom_completer): public API function to
3513 (InteractiveShell.set_custom_completer): public API function to
3510 add new completers at runtime.
3514 add new completers at runtime.
3511
3515
3512 2005-03-19 Fernando Perez <fperez@colorado.edu>
3516 2005-03-19 Fernando Perez <fperez@colorado.edu>
3513
3517
3514 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
3518 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
3515 allow objects which provide their docstrings via non-standard
3519 allow objects which provide their docstrings via non-standard
3516 mechanisms (like Pyro proxies) to still be inspected by ipython's
3520 mechanisms (like Pyro proxies) to still be inspected by ipython's
3517 ? system.
3521 ? system.
3518
3522
3519 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
3523 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
3520 automatic capture system. I tried quite hard to make it work
3524 automatic capture system. I tried quite hard to make it work
3521 reliably, and simply failed. I tried many combinations with the
3525 reliably, and simply failed. I tried many combinations with the
3522 subprocess module, but eventually nothing worked in all needed
3526 subprocess module, but eventually nothing worked in all needed
3523 cases (not blocking stdin for the child, duplicating stdout
3527 cases (not blocking stdin for the child, duplicating stdout
3524 without blocking, etc). The new %sc/%sx still do capture to these
3528 without blocking, etc). The new %sc/%sx still do capture to these
3525 magical list/string objects which make shell use much more
3529 magical list/string objects which make shell use much more
3526 conveninent, so not all is lost.
3530 conveninent, so not all is lost.
3527
3531
3528 XXX - FIX MANUAL for the change above!
3532 XXX - FIX MANUAL for the change above!
3529
3533
3530 (runsource): I copied code.py's runsource() into ipython to modify
3534 (runsource): I copied code.py's runsource() into ipython to modify
3531 it a bit. Now the code object and source to be executed are
3535 it a bit. Now the code object and source to be executed are
3532 stored in ipython. This makes this info accessible to third-party
3536 stored in ipython. This makes this info accessible to third-party
3533 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
3537 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
3534 Mantegazza <mantegazza-AT-ill.fr>.
3538 Mantegazza <mantegazza-AT-ill.fr>.
3535
3539
3536 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
3540 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
3537 history-search via readline (like C-p/C-n). I'd wanted this for a
3541 history-search via readline (like C-p/C-n). I'd wanted this for a
3538 long time, but only recently found out how to do it. For users
3542 long time, but only recently found out how to do it. For users
3539 who already have their ipythonrc files made and want this, just
3543 who already have their ipythonrc files made and want this, just
3540 add:
3544 add:
3541
3545
3542 readline_parse_and_bind "\e[A": history-search-backward
3546 readline_parse_and_bind "\e[A": history-search-backward
3543 readline_parse_and_bind "\e[B": history-search-forward
3547 readline_parse_and_bind "\e[B": history-search-forward
3544
3548
3545 2005-03-18 Fernando Perez <fperez@colorado.edu>
3549 2005-03-18 Fernando Perez <fperez@colorado.edu>
3546
3550
3547 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
3551 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
3548 LSString and SList classes which allow transparent conversions
3552 LSString and SList classes which allow transparent conversions
3549 between list mode and whitespace-separated string.
3553 between list mode and whitespace-separated string.
3550 (magic_r): Fix recursion problem in %r.
3554 (magic_r): Fix recursion problem in %r.
3551
3555
3552 * IPython/genutils.py (LSString): New class to be used for
3556 * IPython/genutils.py (LSString): New class to be used for
3553 automatic storage of the results of all alias/system calls in _o
3557 automatic storage of the results of all alias/system calls in _o
3554 and _e (stdout/err). These provide a .l/.list attribute which
3558 and _e (stdout/err). These provide a .l/.list attribute which
3555 does automatic splitting on newlines. This means that for most
3559 does automatic splitting on newlines. This means that for most
3556 uses, you'll never need to do capturing of output with %sc/%sx
3560 uses, you'll never need to do capturing of output with %sc/%sx
3557 anymore, since ipython keeps this always done for you. Note that
3561 anymore, since ipython keeps this always done for you. Note that
3558 only the LAST results are stored, the _o/e variables are
3562 only the LAST results are stored, the _o/e variables are
3559 overwritten on each call. If you need to save their contents
3563 overwritten on each call. If you need to save their contents
3560 further, simply bind them to any other name.
3564 further, simply bind them to any other name.
3561
3565
3562 2005-03-17 Fernando Perez <fperez@colorado.edu>
3566 2005-03-17 Fernando Perez <fperez@colorado.edu>
3563
3567
3564 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
3568 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
3565 prompt namespace handling.
3569 prompt namespace handling.
3566
3570
3567 2005-03-16 Fernando Perez <fperez@colorado.edu>
3571 2005-03-16 Fernando Perez <fperez@colorado.edu>
3568
3572
3569 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
3573 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
3570 classic prompts to be '>>> ' (final space was missing, and it
3574 classic prompts to be '>>> ' (final space was missing, and it
3571 trips the emacs python mode).
3575 trips the emacs python mode).
3572 (BasePrompt.__str__): Added safe support for dynamic prompt
3576 (BasePrompt.__str__): Added safe support for dynamic prompt
3573 strings. Now you can set your prompt string to be '$x', and the
3577 strings. Now you can set your prompt string to be '$x', and the
3574 value of x will be printed from your interactive namespace. The
3578 value of x will be printed from your interactive namespace. The
3575 interpolation syntax includes the full Itpl support, so
3579 interpolation syntax includes the full Itpl support, so
3576 ${foo()+x+bar()} is a valid prompt string now, and the function
3580 ${foo()+x+bar()} is a valid prompt string now, and the function
3577 calls will be made at runtime.
3581 calls will be made at runtime.
3578
3582
3579 2005-03-15 Fernando Perez <fperez@colorado.edu>
3583 2005-03-15 Fernando Perez <fperez@colorado.edu>
3580
3584
3581 * IPython/Magic.py (magic_history): renamed %hist to %history, to
3585 * IPython/Magic.py (magic_history): renamed %hist to %history, to
3582 avoid name clashes in pylab. %hist still works, it just forwards
3586 avoid name clashes in pylab. %hist still works, it just forwards
3583 the call to %history.
3587 the call to %history.
3584
3588
3585 2005-03-02 *** Released version 0.6.12
3589 2005-03-02 *** Released version 0.6.12
3586
3590
3587 2005-03-02 Fernando Perez <fperez@colorado.edu>
3591 2005-03-02 Fernando Perez <fperez@colorado.edu>
3588
3592
3589 * IPython/iplib.py (handle_magic): log magic calls properly as
3593 * IPython/iplib.py (handle_magic): log magic calls properly as
3590 ipmagic() function calls.
3594 ipmagic() function calls.
3591
3595
3592 * IPython/Magic.py (magic_time): Improved %time to support
3596 * IPython/Magic.py (magic_time): Improved %time to support
3593 statements and provide wall-clock as well as CPU time.
3597 statements and provide wall-clock as well as CPU time.
3594
3598
3595 2005-02-27 Fernando Perez <fperez@colorado.edu>
3599 2005-02-27 Fernando Perez <fperez@colorado.edu>
3596
3600
3597 * IPython/hooks.py: New hooks module, to expose user-modifiable
3601 * IPython/hooks.py: New hooks module, to expose user-modifiable
3598 IPython functionality in a clean manner. For now only the editor
3602 IPython functionality in a clean manner. For now only the editor
3599 hook is actually written, and other thigns which I intend to turn
3603 hook is actually written, and other thigns which I intend to turn
3600 into proper hooks aren't yet there. The display and prefilter
3604 into proper hooks aren't yet there. The display and prefilter
3601 stuff, for example, should be hooks. But at least now the
3605 stuff, for example, should be hooks. But at least now the
3602 framework is in place, and the rest can be moved here with more
3606 framework is in place, and the rest can be moved here with more
3603 time later. IPython had had a .hooks variable for a long time for
3607 time later. IPython had had a .hooks variable for a long time for
3604 this purpose, but I'd never actually used it for anything.
3608 this purpose, but I'd never actually used it for anything.
3605
3609
3606 2005-02-26 Fernando Perez <fperez@colorado.edu>
3610 2005-02-26 Fernando Perez <fperez@colorado.edu>
3607
3611
3608 * IPython/ipmaker.py (make_IPython): make the default ipython
3612 * IPython/ipmaker.py (make_IPython): make the default ipython
3609 directory be called _ipython under win32, to follow more the
3613 directory be called _ipython under win32, to follow more the
3610 naming peculiarities of that platform (where buggy software like
3614 naming peculiarities of that platform (where buggy software like
3611 Visual Sourcesafe breaks with .named directories). Reported by
3615 Visual Sourcesafe breaks with .named directories). Reported by
3612 Ville Vainio.
3616 Ville Vainio.
3613
3617
3614 2005-02-23 Fernando Perez <fperez@colorado.edu>
3618 2005-02-23 Fernando Perez <fperez@colorado.edu>
3615
3619
3616 * IPython/iplib.py (InteractiveShell.__init__): removed a few
3620 * IPython/iplib.py (InteractiveShell.__init__): removed a few
3617 auto_aliases for win32 which were causing problems. Users can
3621 auto_aliases for win32 which were causing problems. Users can
3618 define the ones they personally like.
3622 define the ones they personally like.
3619
3623
3620 2005-02-21 Fernando Perez <fperez@colorado.edu>
3624 2005-02-21 Fernando Perez <fperez@colorado.edu>
3621
3625
3622 * IPython/Magic.py (magic_time): new magic to time execution of
3626 * IPython/Magic.py (magic_time): new magic to time execution of
3623 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
3627 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
3624
3628
3625 2005-02-19 Fernando Perez <fperez@colorado.edu>
3629 2005-02-19 Fernando Perez <fperez@colorado.edu>
3626
3630
3627 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
3631 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
3628 into keys (for prompts, for example).
3632 into keys (for prompts, for example).
3629
3633
3630 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
3634 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
3631 prompts in case users want them. This introduces a small behavior
3635 prompts in case users want them. This introduces a small behavior
3632 change: ipython does not automatically add a space to all prompts
3636 change: ipython does not automatically add a space to all prompts
3633 anymore. To get the old prompts with a space, users should add it
3637 anymore. To get the old prompts with a space, users should add it
3634 manually to their ipythonrc file, so for example prompt_in1 should
3638 manually to their ipythonrc file, so for example prompt_in1 should
3635 now read 'In [\#]: ' instead of 'In [\#]:'.
3639 now read 'In [\#]: ' instead of 'In [\#]:'.
3636 (BasePrompt.__init__): New option prompts_pad_left (only in rc
3640 (BasePrompt.__init__): New option prompts_pad_left (only in rc
3637 file) to control left-padding of secondary prompts.
3641 file) to control left-padding of secondary prompts.
3638
3642
3639 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
3643 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
3640 the profiler can't be imported. Fix for Debian, which removed
3644 the profiler can't be imported. Fix for Debian, which removed
3641 profile.py because of License issues. I applied a slightly
3645 profile.py because of License issues. I applied a slightly
3642 modified version of the original Debian patch at
3646 modified version of the original Debian patch at
3643 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
3647 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
3644
3648
3645 2005-02-17 Fernando Perez <fperez@colorado.edu>
3649 2005-02-17 Fernando Perez <fperez@colorado.edu>
3646
3650
3647 * IPython/genutils.py (native_line_ends): Fix bug which would
3651 * IPython/genutils.py (native_line_ends): Fix bug which would
3648 cause improper line-ends under win32 b/c I was not opening files
3652 cause improper line-ends under win32 b/c I was not opening files
3649 in binary mode. Bug report and fix thanks to Ville.
3653 in binary mode. Bug report and fix thanks to Ville.
3650
3654
3651 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
3655 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
3652 trying to catch spurious foo[1] autocalls. My fix actually broke
3656 trying to catch spurious foo[1] autocalls. My fix actually broke
3653 ',/' autoquote/call with explicit escape (bad regexp).
3657 ',/' autoquote/call with explicit escape (bad regexp).
3654
3658
3655 2005-02-15 *** Released version 0.6.11
3659 2005-02-15 *** Released version 0.6.11
3656
3660
3657 2005-02-14 Fernando Perez <fperez@colorado.edu>
3661 2005-02-14 Fernando Perez <fperez@colorado.edu>
3658
3662
3659 * IPython/background_jobs.py: New background job management
3663 * IPython/background_jobs.py: New background job management
3660 subsystem. This is implemented via a new set of classes, and
3664 subsystem. This is implemented via a new set of classes, and
3661 IPython now provides a builtin 'jobs' object for background job
3665 IPython now provides a builtin 'jobs' object for background job
3662 execution. A convenience %bg magic serves as a lightweight
3666 execution. A convenience %bg magic serves as a lightweight
3663 frontend for starting the more common type of calls. This was
3667 frontend for starting the more common type of calls. This was
3664 inspired by discussions with B. Granger and the BackgroundCommand
3668 inspired by discussions with B. Granger and the BackgroundCommand
3665 class described in the book Python Scripting for Computational
3669 class described in the book Python Scripting for Computational
3666 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
3670 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
3667 (although ultimately no code from this text was used, as IPython's
3671 (although ultimately no code from this text was used, as IPython's
3668 system is a separate implementation).
3672 system is a separate implementation).
3669
3673
3670 * IPython/iplib.py (MagicCompleter.python_matches): add new option
3674 * IPython/iplib.py (MagicCompleter.python_matches): add new option
3671 to control the completion of single/double underscore names
3675 to control the completion of single/double underscore names
3672 separately. As documented in the example ipytonrc file, the
3676 separately. As documented in the example ipytonrc file, the
3673 readline_omit__names variable can now be set to 2, to omit even
3677 readline_omit__names variable can now be set to 2, to omit even
3674 single underscore names. Thanks to a patch by Brian Wong
3678 single underscore names. Thanks to a patch by Brian Wong
3675 <BrianWong-AT-AirgoNetworks.Com>.
3679 <BrianWong-AT-AirgoNetworks.Com>.
3676 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
3680 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
3677 be autocalled as foo([1]) if foo were callable. A problem for
3681 be autocalled as foo([1]) if foo were callable. A problem for
3678 things which are both callable and implement __getitem__.
3682 things which are both callable and implement __getitem__.
3679 (init_readline): Fix autoindentation for win32. Thanks to a patch
3683 (init_readline): Fix autoindentation for win32. Thanks to a patch
3680 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
3684 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
3681
3685
3682 2005-02-12 Fernando Perez <fperez@colorado.edu>
3686 2005-02-12 Fernando Perez <fperez@colorado.edu>
3683
3687
3684 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
3688 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
3685 which I had written long ago to sort out user error messages which
3689 which I had written long ago to sort out user error messages which
3686 may occur during startup. This seemed like a good idea initially,
3690 may occur during startup. This seemed like a good idea initially,
3687 but it has proven a disaster in retrospect. I don't want to
3691 but it has proven a disaster in retrospect. I don't want to
3688 change much code for now, so my fix is to set the internal 'debug'
3692 change much code for now, so my fix is to set the internal 'debug'
3689 flag to true everywhere, whose only job was precisely to control
3693 flag to true everywhere, whose only job was precisely to control
3690 this subsystem. This closes issue 28 (as well as avoiding all
3694 this subsystem. This closes issue 28 (as well as avoiding all
3691 sorts of strange hangups which occur from time to time).
3695 sorts of strange hangups which occur from time to time).
3692
3696
3693 2005-02-07 Fernando Perez <fperez@colorado.edu>
3697 2005-02-07 Fernando Perez <fperez@colorado.edu>
3694
3698
3695 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
3699 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
3696 previous call produced a syntax error.
3700 previous call produced a syntax error.
3697
3701
3698 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3702 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3699 classes without constructor.
3703 classes without constructor.
3700
3704
3701 2005-02-06 Fernando Perez <fperez@colorado.edu>
3705 2005-02-06 Fernando Perez <fperez@colorado.edu>
3702
3706
3703 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
3707 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
3704 completions with the results of each matcher, so we return results
3708 completions with the results of each matcher, so we return results
3705 to the user from all namespaces. This breaks with ipython
3709 to the user from all namespaces. This breaks with ipython
3706 tradition, but I think it's a nicer behavior. Now you get all
3710 tradition, but I think it's a nicer behavior. Now you get all
3707 possible completions listed, from all possible namespaces (python,
3711 possible completions listed, from all possible namespaces (python,
3708 filesystem, magics...) After a request by John Hunter
3712 filesystem, magics...) After a request by John Hunter
3709 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3713 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3710
3714
3711 2005-02-05 Fernando Perez <fperez@colorado.edu>
3715 2005-02-05 Fernando Perez <fperez@colorado.edu>
3712
3716
3713 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
3717 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
3714 the call had quote characters in it (the quotes were stripped).
3718 the call had quote characters in it (the quotes were stripped).
3715
3719
3716 2005-01-31 Fernando Perez <fperez@colorado.edu>
3720 2005-01-31 Fernando Perez <fperez@colorado.edu>
3717
3721
3718 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
3722 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
3719 Itpl.itpl() to make the code more robust against psyco
3723 Itpl.itpl() to make the code more robust against psyco
3720 optimizations.
3724 optimizations.
3721
3725
3722 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
3726 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
3723 of causing an exception. Quicker, cleaner.
3727 of causing an exception. Quicker, cleaner.
3724
3728
3725 2005-01-28 Fernando Perez <fperez@colorado.edu>
3729 2005-01-28 Fernando Perez <fperez@colorado.edu>
3726
3730
3727 * scripts/ipython_win_post_install.py (install): hardcode
3731 * scripts/ipython_win_post_install.py (install): hardcode
3728 sys.prefix+'python.exe' as the executable path. It turns out that
3732 sys.prefix+'python.exe' as the executable path. It turns out that
3729 during the post-installation run, sys.executable resolves to the
3733 during the post-installation run, sys.executable resolves to the
3730 name of the binary installer! I should report this as a distutils
3734 name of the binary installer! I should report this as a distutils
3731 bug, I think. I updated the .10 release with this tiny fix, to
3735 bug, I think. I updated the .10 release with this tiny fix, to
3732 avoid annoying the lists further.
3736 avoid annoying the lists further.
3733
3737
3734 2005-01-27 *** Released version 0.6.10
3738 2005-01-27 *** Released version 0.6.10
3735
3739
3736 2005-01-27 Fernando Perez <fperez@colorado.edu>
3740 2005-01-27 Fernando Perez <fperez@colorado.edu>
3737
3741
3738 * IPython/numutils.py (norm): Added 'inf' as optional name for
3742 * IPython/numutils.py (norm): Added 'inf' as optional name for
3739 L-infinity norm, included references to mathworld.com for vector
3743 L-infinity norm, included references to mathworld.com for vector
3740 norm definitions.
3744 norm definitions.
3741 (amin/amax): added amin/amax for array min/max. Similar to what
3745 (amin/amax): added amin/amax for array min/max. Similar to what
3742 pylab ships with after the recent reorganization of names.
3746 pylab ships with after the recent reorganization of names.
3743 (spike/spike_odd): removed deprecated spike/spike_odd functions.
3747 (spike/spike_odd): removed deprecated spike/spike_odd functions.
3744
3748
3745 * ipython.el: committed Alex's recent fixes and improvements.
3749 * ipython.el: committed Alex's recent fixes and improvements.
3746 Tested with python-mode from CVS, and it looks excellent. Since
3750 Tested with python-mode from CVS, and it looks excellent. Since
3747 python-mode hasn't released anything in a while, I'm temporarily
3751 python-mode hasn't released anything in a while, I'm temporarily
3748 putting a copy of today's CVS (v 4.70) of python-mode in:
3752 putting a copy of today's CVS (v 4.70) of python-mode in:
3749 http://ipython.scipy.org/tmp/python-mode.el
3753 http://ipython.scipy.org/tmp/python-mode.el
3750
3754
3751 * scripts/ipython_win_post_install.py (install): Win32 fix to use
3755 * scripts/ipython_win_post_install.py (install): Win32 fix to use
3752 sys.executable for the executable name, instead of assuming it's
3756 sys.executable for the executable name, instead of assuming it's
3753 called 'python.exe' (the post-installer would have produced broken
3757 called 'python.exe' (the post-installer would have produced broken
3754 setups on systems with a differently named python binary).
3758 setups on systems with a differently named python binary).
3755
3759
3756 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
3760 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
3757 references to os.linesep, to make the code more
3761 references to os.linesep, to make the code more
3758 platform-independent. This is also part of the win32 coloring
3762 platform-independent. This is also part of the win32 coloring
3759 fixes.
3763 fixes.
3760
3764
3761 * IPython/genutils.py (page_dumb): Remove attempts to chop long
3765 * IPython/genutils.py (page_dumb): Remove attempts to chop long
3762 lines, which actually cause coloring bugs because the length of
3766 lines, which actually cause coloring bugs because the length of
3763 the line is very difficult to correctly compute with embedded
3767 the line is very difficult to correctly compute with embedded
3764 escapes. This was the source of all the coloring problems under
3768 escapes. This was the source of all the coloring problems under
3765 Win32. I think that _finally_, Win32 users have a properly
3769 Win32. I think that _finally_, Win32 users have a properly
3766 working ipython in all respects. This would never have happened
3770 working ipython in all respects. This would never have happened
3767 if not for Gary Bishop and Viktor Ransmayr's great help and work.
3771 if not for Gary Bishop and Viktor Ransmayr's great help and work.
3768
3772
3769 2005-01-26 *** Released version 0.6.9
3773 2005-01-26 *** Released version 0.6.9
3770
3774
3771 2005-01-25 Fernando Perez <fperez@colorado.edu>
3775 2005-01-25 Fernando Perez <fperez@colorado.edu>
3772
3776
3773 * setup.py: finally, we have a true Windows installer, thanks to
3777 * setup.py: finally, we have a true Windows installer, thanks to
3774 the excellent work of Viktor Ransmayr
3778 the excellent work of Viktor Ransmayr
3775 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
3779 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
3776 Windows users. The setup routine is quite a bit cleaner thanks to
3780 Windows users. The setup routine is quite a bit cleaner thanks to
3777 this, and the post-install script uses the proper functions to
3781 this, and the post-install script uses the proper functions to
3778 allow a clean de-installation using the standard Windows Control
3782 allow a clean de-installation using the standard Windows Control
3779 Panel.
3783 Panel.
3780
3784
3781 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3785 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3782 environment variable under all OSes (including win32) if
3786 environment variable under all OSes (including win32) if
3783 available. This will give consistency to win32 users who have set
3787 available. This will give consistency to win32 users who have set
3784 this variable for any reason. If os.environ['HOME'] fails, the
3788 this variable for any reason. If os.environ['HOME'] fails, the
3785 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3789 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3786
3790
3787 2005-01-24 Fernando Perez <fperez@colorado.edu>
3791 2005-01-24 Fernando Perez <fperez@colorado.edu>
3788
3792
3789 * IPython/numutils.py (empty_like): add empty_like(), similar to
3793 * IPython/numutils.py (empty_like): add empty_like(), similar to
3790 zeros_like() but taking advantage of the new empty() Numeric routine.
3794 zeros_like() but taking advantage of the new empty() Numeric routine.
3791
3795
3792 2005-01-23 *** Released version 0.6.8
3796 2005-01-23 *** Released version 0.6.8
3793
3797
3794 2005-01-22 Fernando Perez <fperez@colorado.edu>
3798 2005-01-22 Fernando Perez <fperez@colorado.edu>
3795
3799
3796 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3800 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3797 automatic show() calls. After discussing things with JDH, it
3801 automatic show() calls. After discussing things with JDH, it
3798 turns out there are too many corner cases where this can go wrong.
3802 turns out there are too many corner cases where this can go wrong.
3799 It's best not to try to be 'too smart', and simply have ipython
3803 It's best not to try to be 'too smart', and simply have ipython
3800 reproduce as much as possible the default behavior of a normal
3804 reproduce as much as possible the default behavior of a normal
3801 python shell.
3805 python shell.
3802
3806
3803 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3807 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3804 line-splitting regexp and _prefilter() to avoid calling getattr()
3808 line-splitting regexp and _prefilter() to avoid calling getattr()
3805 on assignments. This closes
3809 on assignments. This closes
3806 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3810 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3807 readline uses getattr(), so a simple <TAB> keypress is still
3811 readline uses getattr(), so a simple <TAB> keypress is still
3808 enough to trigger getattr() calls on an object.
3812 enough to trigger getattr() calls on an object.
3809
3813
3810 2005-01-21 Fernando Perez <fperez@colorado.edu>
3814 2005-01-21 Fernando Perez <fperez@colorado.edu>
3811
3815
3812 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3816 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3813 docstring under pylab so it doesn't mask the original.
3817 docstring under pylab so it doesn't mask the original.
3814
3818
3815 2005-01-21 *** Released version 0.6.7
3819 2005-01-21 *** Released version 0.6.7
3816
3820
3817 2005-01-21 Fernando Perez <fperez@colorado.edu>
3821 2005-01-21 Fernando Perez <fperez@colorado.edu>
3818
3822
3819 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3823 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3820 signal handling for win32 users in multithreaded mode.
3824 signal handling for win32 users in multithreaded mode.
3821
3825
3822 2005-01-17 Fernando Perez <fperez@colorado.edu>
3826 2005-01-17 Fernando Perez <fperez@colorado.edu>
3823
3827
3824 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3828 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3825 instances with no __init__. After a crash report by Norbert Nemec
3829 instances with no __init__. After a crash report by Norbert Nemec
3826 <Norbert-AT-nemec-online.de>.
3830 <Norbert-AT-nemec-online.de>.
3827
3831
3828 2005-01-14 Fernando Perez <fperez@colorado.edu>
3832 2005-01-14 Fernando Perez <fperez@colorado.edu>
3829
3833
3830 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3834 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3831 names for verbose exceptions, when multiple dotted names and the
3835 names for verbose exceptions, when multiple dotted names and the
3832 'parent' object were present on the same line.
3836 'parent' object were present on the same line.
3833
3837
3834 2005-01-11 Fernando Perez <fperez@colorado.edu>
3838 2005-01-11 Fernando Perez <fperez@colorado.edu>
3835
3839
3836 * IPython/genutils.py (flag_calls): new utility to trap and flag
3840 * IPython/genutils.py (flag_calls): new utility to trap and flag
3837 calls in functions. I need it to clean up matplotlib support.
3841 calls in functions. I need it to clean up matplotlib support.
3838 Also removed some deprecated code in genutils.
3842 Also removed some deprecated code in genutils.
3839
3843
3840 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3844 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3841 that matplotlib scripts called with %run, which don't call show()
3845 that matplotlib scripts called with %run, which don't call show()
3842 themselves, still have their plotting windows open.
3846 themselves, still have their plotting windows open.
3843
3847
3844 2005-01-05 Fernando Perez <fperez@colorado.edu>
3848 2005-01-05 Fernando Perez <fperez@colorado.edu>
3845
3849
3846 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3850 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3847 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3851 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3848
3852
3849 2004-12-19 Fernando Perez <fperez@colorado.edu>
3853 2004-12-19 Fernando Perez <fperez@colorado.edu>
3850
3854
3851 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3855 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3852 parent_runcode, which was an eyesore. The same result can be
3856 parent_runcode, which was an eyesore. The same result can be
3853 obtained with Python's regular superclass mechanisms.
3857 obtained with Python's regular superclass mechanisms.
3854
3858
3855 2004-12-17 Fernando Perez <fperez@colorado.edu>
3859 2004-12-17 Fernando Perez <fperez@colorado.edu>
3856
3860
3857 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3861 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3858 reported by Prabhu.
3862 reported by Prabhu.
3859 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3863 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3860 sys.stderr) instead of explicitly calling sys.stderr. This helps
3864 sys.stderr) instead of explicitly calling sys.stderr. This helps
3861 maintain our I/O abstractions clean, for future GUI embeddings.
3865 maintain our I/O abstractions clean, for future GUI embeddings.
3862
3866
3863 * IPython/genutils.py (info): added new utility for sys.stderr
3867 * IPython/genutils.py (info): added new utility for sys.stderr
3864 unified info message handling (thin wrapper around warn()).
3868 unified info message handling (thin wrapper around warn()).
3865
3869
3866 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3870 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3867 composite (dotted) names on verbose exceptions.
3871 composite (dotted) names on verbose exceptions.
3868 (VerboseTB.nullrepr): harden against another kind of errors which
3872 (VerboseTB.nullrepr): harden against another kind of errors which
3869 Python's inspect module can trigger, and which were crashing
3873 Python's inspect module can trigger, and which were crashing
3870 IPython. Thanks to a report by Marco Lombardi
3874 IPython. Thanks to a report by Marco Lombardi
3871 <mlombard-AT-ma010192.hq.eso.org>.
3875 <mlombard-AT-ma010192.hq.eso.org>.
3872
3876
3873 2004-12-13 *** Released version 0.6.6
3877 2004-12-13 *** Released version 0.6.6
3874
3878
3875 2004-12-12 Fernando Perez <fperez@colorado.edu>
3879 2004-12-12 Fernando Perez <fperez@colorado.edu>
3876
3880
3877 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3881 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3878 generated by pygtk upon initialization if it was built without
3882 generated by pygtk upon initialization if it was built without
3879 threads (for matplotlib users). After a crash reported by
3883 threads (for matplotlib users). After a crash reported by
3880 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3884 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3881
3885
3882 * IPython/ipmaker.py (make_IPython): fix small bug in the
3886 * IPython/ipmaker.py (make_IPython): fix small bug in the
3883 import_some parameter for multiple imports.
3887 import_some parameter for multiple imports.
3884
3888
3885 * IPython/iplib.py (ipmagic): simplified the interface of
3889 * IPython/iplib.py (ipmagic): simplified the interface of
3886 ipmagic() to take a single string argument, just as it would be
3890 ipmagic() to take a single string argument, just as it would be
3887 typed at the IPython cmd line.
3891 typed at the IPython cmd line.
3888 (ipalias): Added new ipalias() with an interface identical to
3892 (ipalias): Added new ipalias() with an interface identical to
3889 ipmagic(). This completes exposing a pure python interface to the
3893 ipmagic(). This completes exposing a pure python interface to the
3890 alias and magic system, which can be used in loops or more complex
3894 alias and magic system, which can be used in loops or more complex
3891 code where IPython's automatic line mangling is not active.
3895 code where IPython's automatic line mangling is not active.
3892
3896
3893 * IPython/genutils.py (timing): changed interface of timing to
3897 * IPython/genutils.py (timing): changed interface of timing to
3894 simply run code once, which is the most common case. timings()
3898 simply run code once, which is the most common case. timings()
3895 remains unchanged, for the cases where you want multiple runs.
3899 remains unchanged, for the cases where you want multiple runs.
3896
3900
3897 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3901 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3898 bug where Python2.2 crashes with exec'ing code which does not end
3902 bug where Python2.2 crashes with exec'ing code which does not end
3899 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3903 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3900 before.
3904 before.
3901
3905
3902 2004-12-10 Fernando Perez <fperez@colorado.edu>
3906 2004-12-10 Fernando Perez <fperez@colorado.edu>
3903
3907
3904 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3908 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3905 -t to -T, to accomodate the new -t flag in %run (the %run and
3909 -t to -T, to accomodate the new -t flag in %run (the %run and
3906 %prun options are kind of intermixed, and it's not easy to change
3910 %prun options are kind of intermixed, and it's not easy to change
3907 this with the limitations of python's getopt).
3911 this with the limitations of python's getopt).
3908
3912
3909 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3913 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3910 the execution of scripts. It's not as fine-tuned as timeit.py,
3914 the execution of scripts. It's not as fine-tuned as timeit.py,
3911 but it works from inside ipython (and under 2.2, which lacks
3915 but it works from inside ipython (and under 2.2, which lacks
3912 timeit.py). Optionally a number of runs > 1 can be given for
3916 timeit.py). Optionally a number of runs > 1 can be given for
3913 timing very short-running code.
3917 timing very short-running code.
3914
3918
3915 * IPython/genutils.py (uniq_stable): new routine which returns a
3919 * IPython/genutils.py (uniq_stable): new routine which returns a
3916 list of unique elements in any iterable, but in stable order of
3920 list of unique elements in any iterable, but in stable order of
3917 appearance. I needed this for the ultraTB fixes, and it's a handy
3921 appearance. I needed this for the ultraTB fixes, and it's a handy
3918 utility.
3922 utility.
3919
3923
3920 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3924 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3921 dotted names in Verbose exceptions. This had been broken since
3925 dotted names in Verbose exceptions. This had been broken since
3922 the very start, now x.y will properly be printed in a Verbose
3926 the very start, now x.y will properly be printed in a Verbose
3923 traceback, instead of x being shown and y appearing always as an
3927 traceback, instead of x being shown and y appearing always as an
3924 'undefined global'. Getting this to work was a bit tricky,
3928 'undefined global'. Getting this to work was a bit tricky,
3925 because by default python tokenizers are stateless. Saved by
3929 because by default python tokenizers are stateless. Saved by
3926 python's ability to easily add a bit of state to an arbitrary
3930 python's ability to easily add a bit of state to an arbitrary
3927 function (without needing to build a full-blown callable object).
3931 function (without needing to build a full-blown callable object).
3928
3932
3929 Also big cleanup of this code, which had horrendous runtime
3933 Also big cleanup of this code, which had horrendous runtime
3930 lookups of zillions of attributes for colorization. Moved all
3934 lookups of zillions of attributes for colorization. Moved all
3931 this code into a few templates, which make it cleaner and quicker.
3935 this code into a few templates, which make it cleaner and quicker.
3932
3936
3933 Printout quality was also improved for Verbose exceptions: one
3937 Printout quality was also improved for Verbose exceptions: one
3934 variable per line, and memory addresses are printed (this can be
3938 variable per line, and memory addresses are printed (this can be
3935 quite handy in nasty debugging situations, which is what Verbose
3939 quite handy in nasty debugging situations, which is what Verbose
3936 is for).
3940 is for).
3937
3941
3938 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3942 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3939 the command line as scripts to be loaded by embedded instances.
3943 the command line as scripts to be loaded by embedded instances.
3940 Doing so has the potential for an infinite recursion if there are
3944 Doing so has the potential for an infinite recursion if there are
3941 exceptions thrown in the process. This fixes a strange crash
3945 exceptions thrown in the process. This fixes a strange crash
3942 reported by Philippe MULLER <muller-AT-irit.fr>.
3946 reported by Philippe MULLER <muller-AT-irit.fr>.
3943
3947
3944 2004-12-09 Fernando Perez <fperez@colorado.edu>
3948 2004-12-09 Fernando Perez <fperez@colorado.edu>
3945
3949
3946 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3950 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3947 to reflect new names in matplotlib, which now expose the
3951 to reflect new names in matplotlib, which now expose the
3948 matlab-compatible interface via a pylab module instead of the
3952 matlab-compatible interface via a pylab module instead of the
3949 'matlab' name. The new code is backwards compatible, so users of
3953 'matlab' name. The new code is backwards compatible, so users of
3950 all matplotlib versions are OK. Patch by J. Hunter.
3954 all matplotlib versions are OK. Patch by J. Hunter.
3951
3955
3952 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3956 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3953 of __init__ docstrings for instances (class docstrings are already
3957 of __init__ docstrings for instances (class docstrings are already
3954 automatically printed). Instances with customized docstrings
3958 automatically printed). Instances with customized docstrings
3955 (indep. of the class) are also recognized and all 3 separate
3959 (indep. of the class) are also recognized and all 3 separate
3956 docstrings are printed (instance, class, constructor). After some
3960 docstrings are printed (instance, class, constructor). After some
3957 comments/suggestions by J. Hunter.
3961 comments/suggestions by J. Hunter.
3958
3962
3959 2004-12-05 Fernando Perez <fperez@colorado.edu>
3963 2004-12-05 Fernando Perez <fperez@colorado.edu>
3960
3964
3961 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3965 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3962 warnings when tab-completion fails and triggers an exception.
3966 warnings when tab-completion fails and triggers an exception.
3963
3967
3964 2004-12-03 Fernando Perez <fperez@colorado.edu>
3968 2004-12-03 Fernando Perez <fperez@colorado.edu>
3965
3969
3966 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3970 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3967 be triggered when using 'run -p'. An incorrect option flag was
3971 be triggered when using 'run -p'. An incorrect option flag was
3968 being set ('d' instead of 'D').
3972 being set ('d' instead of 'D').
3969 (manpage): fix missing escaped \- sign.
3973 (manpage): fix missing escaped \- sign.
3970
3974
3971 2004-11-30 *** Released version 0.6.5
3975 2004-11-30 *** Released version 0.6.5
3972
3976
3973 2004-11-30 Fernando Perez <fperez@colorado.edu>
3977 2004-11-30 Fernando Perez <fperez@colorado.edu>
3974
3978
3975 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3979 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3976 setting with -d option.
3980 setting with -d option.
3977
3981
3978 * setup.py (docfiles): Fix problem where the doc glob I was using
3982 * setup.py (docfiles): Fix problem where the doc glob I was using
3979 was COMPLETELY BROKEN. It was giving the right files by pure
3983 was COMPLETELY BROKEN. It was giving the right files by pure
3980 accident, but failed once I tried to include ipython.el. Note:
3984 accident, but failed once I tried to include ipython.el. Note:
3981 glob() does NOT allow you to do exclusion on multiple endings!
3985 glob() does NOT allow you to do exclusion on multiple endings!
3982
3986
3983 2004-11-29 Fernando Perez <fperez@colorado.edu>
3987 2004-11-29 Fernando Perez <fperez@colorado.edu>
3984
3988
3985 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3989 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3986 the manpage as the source. Better formatting & consistency.
3990 the manpage as the source. Better formatting & consistency.
3987
3991
3988 * IPython/Magic.py (magic_run): Added new -d option, to run
3992 * IPython/Magic.py (magic_run): Added new -d option, to run
3989 scripts under the control of the python pdb debugger. Note that
3993 scripts under the control of the python pdb debugger. Note that
3990 this required changing the %prun option -d to -D, to avoid a clash
3994 this required changing the %prun option -d to -D, to avoid a clash
3991 (since %run must pass options to %prun, and getopt is too dumb to
3995 (since %run must pass options to %prun, and getopt is too dumb to
3992 handle options with string values with embedded spaces). Thanks
3996 handle options with string values with embedded spaces). Thanks
3993 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3997 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3994 (magic_who_ls): added type matching to %who and %whos, so that one
3998 (magic_who_ls): added type matching to %who and %whos, so that one
3995 can filter their output to only include variables of certain
3999 can filter their output to only include variables of certain
3996 types. Another suggestion by Matthew.
4000 types. Another suggestion by Matthew.
3997 (magic_whos): Added memory summaries in kb and Mb for arrays.
4001 (magic_whos): Added memory summaries in kb and Mb for arrays.
3998 (magic_who): Improve formatting (break lines every 9 vars).
4002 (magic_who): Improve formatting (break lines every 9 vars).
3999
4003
4000 2004-11-28 Fernando Perez <fperez@colorado.edu>
4004 2004-11-28 Fernando Perez <fperez@colorado.edu>
4001
4005
4002 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
4006 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
4003 cache when empty lines were present.
4007 cache when empty lines were present.
4004
4008
4005 2004-11-24 Fernando Perez <fperez@colorado.edu>
4009 2004-11-24 Fernando Perez <fperez@colorado.edu>
4006
4010
4007 * IPython/usage.py (__doc__): document the re-activated threading
4011 * IPython/usage.py (__doc__): document the re-activated threading
4008 options for WX and GTK.
4012 options for WX and GTK.
4009
4013
4010 2004-11-23 Fernando Perez <fperez@colorado.edu>
4014 2004-11-23 Fernando Perez <fperez@colorado.edu>
4011
4015
4012 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
4016 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
4013 the -wthread and -gthread options, along with a new -tk one to try
4017 the -wthread and -gthread options, along with a new -tk one to try
4014 and coordinate Tk threading with wx/gtk. The tk support is very
4018 and coordinate Tk threading with wx/gtk. The tk support is very
4015 platform dependent, since it seems to require Tcl and Tk to be
4019 platform dependent, since it seems to require Tcl and Tk to be
4016 built with threads (Fedora1/2 appears NOT to have it, but in
4020 built with threads (Fedora1/2 appears NOT to have it, but in
4017 Prabhu's Debian boxes it works OK). But even with some Tk
4021 Prabhu's Debian boxes it works OK). But even with some Tk
4018 limitations, this is a great improvement.
4022 limitations, this is a great improvement.
4019
4023
4020 * IPython/Prompts.py (prompt_specials_color): Added \t for time
4024 * IPython/Prompts.py (prompt_specials_color): Added \t for time
4021 info in user prompts. Patch by Prabhu.
4025 info in user prompts. Patch by Prabhu.
4022
4026
4023 2004-11-18 Fernando Perez <fperez@colorado.edu>
4027 2004-11-18 Fernando Perez <fperez@colorado.edu>
4024
4028
4025 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
4029 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
4026 EOFErrors and bail, to avoid infinite loops if a non-terminating
4030 EOFErrors and bail, to avoid infinite loops if a non-terminating
4027 file is fed into ipython. Patch submitted in issue 19 by user,
4031 file is fed into ipython. Patch submitted in issue 19 by user,
4028 many thanks.
4032 many thanks.
4029
4033
4030 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
4034 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
4031 autoquote/parens in continuation prompts, which can cause lots of
4035 autoquote/parens in continuation prompts, which can cause lots of
4032 problems. Closes roundup issue 20.
4036 problems. Closes roundup issue 20.
4033
4037
4034 2004-11-17 Fernando Perez <fperez@colorado.edu>
4038 2004-11-17 Fernando Perez <fperez@colorado.edu>
4035
4039
4036 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
4040 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
4037 reported as debian bug #280505. I'm not sure my local changelog
4041 reported as debian bug #280505. I'm not sure my local changelog
4038 entry has the proper debian format (Jack?).
4042 entry has the proper debian format (Jack?).
4039
4043
4040 2004-11-08 *** Released version 0.6.4
4044 2004-11-08 *** Released version 0.6.4
4041
4045
4042 2004-11-08 Fernando Perez <fperez@colorado.edu>
4046 2004-11-08 Fernando Perez <fperez@colorado.edu>
4043
4047
4044 * IPython/iplib.py (init_readline): Fix exit message for Windows
4048 * IPython/iplib.py (init_readline): Fix exit message for Windows
4045 when readline is active. Thanks to a report by Eric Jones
4049 when readline is active. Thanks to a report by Eric Jones
4046 <eric-AT-enthought.com>.
4050 <eric-AT-enthought.com>.
4047
4051
4048 2004-11-07 Fernando Perez <fperez@colorado.edu>
4052 2004-11-07 Fernando Perez <fperez@colorado.edu>
4049
4053
4050 * IPython/genutils.py (page): Add a trap for OSError exceptions,
4054 * IPython/genutils.py (page): Add a trap for OSError exceptions,
4051 sometimes seen by win2k/cygwin users.
4055 sometimes seen by win2k/cygwin users.
4052
4056
4053 2004-11-06 Fernando Perez <fperez@colorado.edu>
4057 2004-11-06 Fernando Perez <fperez@colorado.edu>
4054
4058
4055 * IPython/iplib.py (interact): Change the handling of %Exit from
4059 * IPython/iplib.py (interact): Change the handling of %Exit from
4056 trying to propagate a SystemExit to an internal ipython flag.
4060 trying to propagate a SystemExit to an internal ipython flag.
4057 This is less elegant than using Python's exception mechanism, but
4061 This is less elegant than using Python's exception mechanism, but
4058 I can't get that to work reliably with threads, so under -pylab
4062 I can't get that to work reliably with threads, so under -pylab
4059 %Exit was hanging IPython. Cross-thread exception handling is
4063 %Exit was hanging IPython. Cross-thread exception handling is
4060 really a bitch. Thaks to a bug report by Stephen Walton
4064 really a bitch. Thaks to a bug report by Stephen Walton
4061 <stephen.walton-AT-csun.edu>.
4065 <stephen.walton-AT-csun.edu>.
4062
4066
4063 2004-11-04 Fernando Perez <fperez@colorado.edu>
4067 2004-11-04 Fernando Perez <fperez@colorado.edu>
4064
4068
4065 * IPython/iplib.py (raw_input_original): store a pointer to the
4069 * IPython/iplib.py (raw_input_original): store a pointer to the
4066 true raw_input to harden against code which can modify it
4070 true raw_input to harden against code which can modify it
4067 (wx.py.PyShell does this and would otherwise crash ipython).
4071 (wx.py.PyShell does this and would otherwise crash ipython).
4068 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
4072 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
4069
4073
4070 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
4074 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
4071 Ctrl-C problem, which does not mess up the input line.
4075 Ctrl-C problem, which does not mess up the input line.
4072
4076
4073 2004-11-03 Fernando Perez <fperez@colorado.edu>
4077 2004-11-03 Fernando Perez <fperez@colorado.edu>
4074
4078
4075 * IPython/Release.py: Changed licensing to BSD, in all files.
4079 * IPython/Release.py: Changed licensing to BSD, in all files.
4076 (name): lowercase name for tarball/RPM release.
4080 (name): lowercase name for tarball/RPM release.
4077
4081
4078 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
4082 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
4079 use throughout ipython.
4083 use throughout ipython.
4080
4084
4081 * IPython/Magic.py (Magic._ofind): Switch to using the new
4085 * IPython/Magic.py (Magic._ofind): Switch to using the new
4082 OInspect.getdoc() function.
4086 OInspect.getdoc() function.
4083
4087
4084 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
4088 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
4085 of the line currently being canceled via Ctrl-C. It's extremely
4089 of the line currently being canceled via Ctrl-C. It's extremely
4086 ugly, but I don't know how to do it better (the problem is one of
4090 ugly, but I don't know how to do it better (the problem is one of
4087 handling cross-thread exceptions).
4091 handling cross-thread exceptions).
4088
4092
4089 2004-10-28 Fernando Perez <fperez@colorado.edu>
4093 2004-10-28 Fernando Perez <fperez@colorado.edu>
4090
4094
4091 * IPython/Shell.py (signal_handler): add signal handlers to trap
4095 * IPython/Shell.py (signal_handler): add signal handlers to trap
4092 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
4096 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
4093 report by Francesc Alted.
4097 report by Francesc Alted.
4094
4098
4095 2004-10-21 Fernando Perez <fperez@colorado.edu>
4099 2004-10-21 Fernando Perez <fperez@colorado.edu>
4096
4100
4097 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
4101 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
4098 to % for pysh syntax extensions.
4102 to % for pysh syntax extensions.
4099
4103
4100 2004-10-09 Fernando Perez <fperez@colorado.edu>
4104 2004-10-09 Fernando Perez <fperez@colorado.edu>
4101
4105
4102 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
4106 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
4103 arrays to print a more useful summary, without calling str(arr).
4107 arrays to print a more useful summary, without calling str(arr).
4104 This avoids the problem of extremely lengthy computations which
4108 This avoids the problem of extremely lengthy computations which
4105 occur if arr is large, and appear to the user as a system lockup
4109 occur if arr is large, and appear to the user as a system lockup
4106 with 100% cpu activity. After a suggestion by Kristian Sandberg
4110 with 100% cpu activity. After a suggestion by Kristian Sandberg
4107 <Kristian.Sandberg@colorado.edu>.
4111 <Kristian.Sandberg@colorado.edu>.
4108 (Magic.__init__): fix bug in global magic escapes not being
4112 (Magic.__init__): fix bug in global magic escapes not being
4109 correctly set.
4113 correctly set.
4110
4114
4111 2004-10-08 Fernando Perez <fperez@colorado.edu>
4115 2004-10-08 Fernando Perez <fperez@colorado.edu>
4112
4116
4113 * IPython/Magic.py (__license__): change to absolute imports of
4117 * IPython/Magic.py (__license__): change to absolute imports of
4114 ipython's own internal packages, to start adapting to the absolute
4118 ipython's own internal packages, to start adapting to the absolute
4115 import requirement of PEP-328.
4119 import requirement of PEP-328.
4116
4120
4117 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
4121 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
4118 files, and standardize author/license marks through the Release
4122 files, and standardize author/license marks through the Release
4119 module instead of having per/file stuff (except for files with
4123 module instead of having per/file stuff (except for files with
4120 particular licenses, like the MIT/PSF-licensed codes).
4124 particular licenses, like the MIT/PSF-licensed codes).
4121
4125
4122 * IPython/Debugger.py: remove dead code for python 2.1
4126 * IPython/Debugger.py: remove dead code for python 2.1
4123
4127
4124 2004-10-04 Fernando Perez <fperez@colorado.edu>
4128 2004-10-04 Fernando Perez <fperez@colorado.edu>
4125
4129
4126 * IPython/iplib.py (ipmagic): New function for accessing magics
4130 * IPython/iplib.py (ipmagic): New function for accessing magics
4127 via a normal python function call.
4131 via a normal python function call.
4128
4132
4129 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
4133 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
4130 from '@' to '%', to accomodate the new @decorator syntax of python
4134 from '@' to '%', to accomodate the new @decorator syntax of python
4131 2.4.
4135 2.4.
4132
4136
4133 2004-09-29 Fernando Perez <fperez@colorado.edu>
4137 2004-09-29 Fernando Perez <fperez@colorado.edu>
4134
4138
4135 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
4139 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
4136 matplotlib.use to prevent running scripts which try to switch
4140 matplotlib.use to prevent running scripts which try to switch
4137 interactive backends from within ipython. This will just crash
4141 interactive backends from within ipython. This will just crash
4138 the python interpreter, so we can't allow it (but a detailed error
4142 the python interpreter, so we can't allow it (but a detailed error
4139 is given to the user).
4143 is given to the user).
4140
4144
4141 2004-09-28 Fernando Perez <fperez@colorado.edu>
4145 2004-09-28 Fernando Perez <fperez@colorado.edu>
4142
4146
4143 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
4147 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
4144 matplotlib-related fixes so that using @run with non-matplotlib
4148 matplotlib-related fixes so that using @run with non-matplotlib
4145 scripts doesn't pop up spurious plot windows. This requires
4149 scripts doesn't pop up spurious plot windows. This requires
4146 matplotlib >= 0.63, where I had to make some changes as well.
4150 matplotlib >= 0.63, where I had to make some changes as well.
4147
4151
4148 * IPython/ipmaker.py (make_IPython): update version requirement to
4152 * IPython/ipmaker.py (make_IPython): update version requirement to
4149 python 2.2.
4153 python 2.2.
4150
4154
4151 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
4155 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
4152 banner arg for embedded customization.
4156 banner arg for embedded customization.
4153
4157
4154 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
4158 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
4155 explicit uses of __IP as the IPython's instance name. Now things
4159 explicit uses of __IP as the IPython's instance name. Now things
4156 are properly handled via the shell.name value. The actual code
4160 are properly handled via the shell.name value. The actual code
4157 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
4161 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
4158 is much better than before. I'll clean things completely when the
4162 is much better than before. I'll clean things completely when the
4159 magic stuff gets a real overhaul.
4163 magic stuff gets a real overhaul.
4160
4164
4161 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
4165 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
4162 minor changes to debian dir.
4166 minor changes to debian dir.
4163
4167
4164 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
4168 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
4165 pointer to the shell itself in the interactive namespace even when
4169 pointer to the shell itself in the interactive namespace even when
4166 a user-supplied dict is provided. This is needed for embedding
4170 a user-supplied dict is provided. This is needed for embedding
4167 purposes (found by tests with Michel Sanner).
4171 purposes (found by tests with Michel Sanner).
4168
4172
4169 2004-09-27 Fernando Perez <fperez@colorado.edu>
4173 2004-09-27 Fernando Perez <fperez@colorado.edu>
4170
4174
4171 * IPython/UserConfig/ipythonrc: remove []{} from
4175 * IPython/UserConfig/ipythonrc: remove []{} from
4172 readline_remove_delims, so that things like [modname.<TAB> do
4176 readline_remove_delims, so that things like [modname.<TAB> do
4173 proper completion. This disables [].TAB, but that's a less common
4177 proper completion. This disables [].TAB, but that's a less common
4174 case than module names in list comprehensions, for example.
4178 case than module names in list comprehensions, for example.
4175 Thanks to a report by Andrea Riciputi.
4179 Thanks to a report by Andrea Riciputi.
4176
4180
4177 2004-09-09 Fernando Perez <fperez@colorado.edu>
4181 2004-09-09 Fernando Perez <fperez@colorado.edu>
4178
4182
4179 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
4183 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
4180 blocking problems in win32 and osx. Fix by John.
4184 blocking problems in win32 and osx. Fix by John.
4181
4185
4182 2004-09-08 Fernando Perez <fperez@colorado.edu>
4186 2004-09-08 Fernando Perez <fperez@colorado.edu>
4183
4187
4184 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
4188 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
4185 for Win32 and OSX. Fix by John Hunter.
4189 for Win32 and OSX. Fix by John Hunter.
4186
4190
4187 2004-08-30 *** Released version 0.6.3
4191 2004-08-30 *** Released version 0.6.3
4188
4192
4189 2004-08-30 Fernando Perez <fperez@colorado.edu>
4193 2004-08-30 Fernando Perez <fperez@colorado.edu>
4190
4194
4191 * setup.py (isfile): Add manpages to list of dependent files to be
4195 * setup.py (isfile): Add manpages to list of dependent files to be
4192 updated.
4196 updated.
4193
4197
4194 2004-08-27 Fernando Perez <fperez@colorado.edu>
4198 2004-08-27 Fernando Perez <fperez@colorado.edu>
4195
4199
4196 * IPython/Shell.py (start): I've disabled -wthread and -gthread
4200 * IPython/Shell.py (start): I've disabled -wthread and -gthread
4197 for now. They don't really work with standalone WX/GTK code
4201 for now. They don't really work with standalone WX/GTK code
4198 (though matplotlib IS working fine with both of those backends).
4202 (though matplotlib IS working fine with both of those backends).
4199 This will neeed much more testing. I disabled most things with
4203 This will neeed much more testing. I disabled most things with
4200 comments, so turning it back on later should be pretty easy.
4204 comments, so turning it back on later should be pretty easy.
4201
4205
4202 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
4206 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
4203 autocalling of expressions like r'foo', by modifying the line
4207 autocalling of expressions like r'foo', by modifying the line
4204 split regexp. Closes
4208 split regexp. Closes
4205 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
4209 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
4206 Riley <ipythonbugs-AT-sabi.net>.
4210 Riley <ipythonbugs-AT-sabi.net>.
4207 (InteractiveShell.mainloop): honor --nobanner with banner
4211 (InteractiveShell.mainloop): honor --nobanner with banner
4208 extensions.
4212 extensions.
4209
4213
4210 * IPython/Shell.py: Significant refactoring of all classes, so
4214 * IPython/Shell.py: Significant refactoring of all classes, so
4211 that we can really support ALL matplotlib backends and threading
4215 that we can really support ALL matplotlib backends and threading
4212 models (John spotted a bug with Tk which required this). Now we
4216 models (John spotted a bug with Tk which required this). Now we
4213 should support single-threaded, WX-threads and GTK-threads, both
4217 should support single-threaded, WX-threads and GTK-threads, both
4214 for generic code and for matplotlib.
4218 for generic code and for matplotlib.
4215
4219
4216 * IPython/ipmaker.py (__call__): Changed -mpthread option to
4220 * IPython/ipmaker.py (__call__): Changed -mpthread option to
4217 -pylab, to simplify things for users. Will also remove the pylab
4221 -pylab, to simplify things for users. Will also remove the pylab
4218 profile, since now all of matplotlib configuration is directly
4222 profile, since now all of matplotlib configuration is directly
4219 handled here. This also reduces startup time.
4223 handled here. This also reduces startup time.
4220
4224
4221 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
4225 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
4222 shell wasn't being correctly called. Also in IPShellWX.
4226 shell wasn't being correctly called. Also in IPShellWX.
4223
4227
4224 * IPython/iplib.py (InteractiveShell.__init__): Added option to
4228 * IPython/iplib.py (InteractiveShell.__init__): Added option to
4225 fine-tune banner.
4229 fine-tune banner.
4226
4230
4227 * IPython/numutils.py (spike): Deprecate these spike functions,
4231 * IPython/numutils.py (spike): Deprecate these spike functions,
4228 delete (long deprecated) gnuplot_exec handler.
4232 delete (long deprecated) gnuplot_exec handler.
4229
4233
4230 2004-08-26 Fernando Perez <fperez@colorado.edu>
4234 2004-08-26 Fernando Perez <fperez@colorado.edu>
4231
4235
4232 * ipython.1: Update for threading options, plus some others which
4236 * ipython.1: Update for threading options, plus some others which
4233 were missing.
4237 were missing.
4234
4238
4235 * IPython/ipmaker.py (__call__): Added -wthread option for
4239 * IPython/ipmaker.py (__call__): Added -wthread option for
4236 wxpython thread handling. Make sure threading options are only
4240 wxpython thread handling. Make sure threading options are only
4237 valid at the command line.
4241 valid at the command line.
4238
4242
4239 * scripts/ipython: moved shell selection into a factory function
4243 * scripts/ipython: moved shell selection into a factory function
4240 in Shell.py, to keep the starter script to a minimum.
4244 in Shell.py, to keep the starter script to a minimum.
4241
4245
4242 2004-08-25 Fernando Perez <fperez@colorado.edu>
4246 2004-08-25 Fernando Perez <fperez@colorado.edu>
4243
4247
4244 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
4248 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
4245 John. Along with some recent changes he made to matplotlib, the
4249 John. Along with some recent changes he made to matplotlib, the
4246 next versions of both systems should work very well together.
4250 next versions of both systems should work very well together.
4247
4251
4248 2004-08-24 Fernando Perez <fperez@colorado.edu>
4252 2004-08-24 Fernando Perez <fperez@colorado.edu>
4249
4253
4250 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
4254 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
4251 tried to switch the profiling to using hotshot, but I'm getting
4255 tried to switch the profiling to using hotshot, but I'm getting
4252 strange errors from prof.runctx() there. I may be misreading the
4256 strange errors from prof.runctx() there. I may be misreading the
4253 docs, but it looks weird. For now the profiling code will
4257 docs, but it looks weird. For now the profiling code will
4254 continue to use the standard profiler.
4258 continue to use the standard profiler.
4255
4259
4256 2004-08-23 Fernando Perez <fperez@colorado.edu>
4260 2004-08-23 Fernando Perez <fperez@colorado.edu>
4257
4261
4258 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
4262 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
4259 threaded shell, by John Hunter. It's not quite ready yet, but
4263 threaded shell, by John Hunter. It's not quite ready yet, but
4260 close.
4264 close.
4261
4265
4262 2004-08-22 Fernando Perez <fperez@colorado.edu>
4266 2004-08-22 Fernando Perez <fperez@colorado.edu>
4263
4267
4264 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
4268 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
4265 in Magic and ultraTB.
4269 in Magic and ultraTB.
4266
4270
4267 * ipython.1: document threading options in manpage.
4271 * ipython.1: document threading options in manpage.
4268
4272
4269 * scripts/ipython: Changed name of -thread option to -gthread,
4273 * scripts/ipython: Changed name of -thread option to -gthread,
4270 since this is GTK specific. I want to leave the door open for a
4274 since this is GTK specific. I want to leave the door open for a
4271 -wthread option for WX, which will most likely be necessary. This
4275 -wthread option for WX, which will most likely be necessary. This
4272 change affects usage and ipmaker as well.
4276 change affects usage and ipmaker as well.
4273
4277
4274 * IPython/Shell.py (matplotlib_shell): Add a factory function to
4278 * IPython/Shell.py (matplotlib_shell): Add a factory function to
4275 handle the matplotlib shell issues. Code by John Hunter
4279 handle the matplotlib shell issues. Code by John Hunter
4276 <jdhunter-AT-nitace.bsd.uchicago.edu>.
4280 <jdhunter-AT-nitace.bsd.uchicago.edu>.
4277 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
4281 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
4278 broken (and disabled for end users) for now, but it puts the
4282 broken (and disabled for end users) for now, but it puts the
4279 infrastructure in place.
4283 infrastructure in place.
4280
4284
4281 2004-08-21 Fernando Perez <fperez@colorado.edu>
4285 2004-08-21 Fernando Perez <fperez@colorado.edu>
4282
4286
4283 * ipythonrc-pylab: Add matplotlib support.
4287 * ipythonrc-pylab: Add matplotlib support.
4284
4288
4285 * matplotlib_config.py: new files for matplotlib support, part of
4289 * matplotlib_config.py: new files for matplotlib support, part of
4286 the pylab profile.
4290 the pylab profile.
4287
4291
4288 * IPython/usage.py (__doc__): documented the threading options.
4292 * IPython/usage.py (__doc__): documented the threading options.
4289
4293
4290 2004-08-20 Fernando Perez <fperez@colorado.edu>
4294 2004-08-20 Fernando Perez <fperez@colorado.edu>
4291
4295
4292 * ipython: Modified the main calling routine to handle the -thread
4296 * ipython: Modified the main calling routine to handle the -thread
4293 and -mpthread options. This needs to be done as a top-level hack,
4297 and -mpthread options. This needs to be done as a top-level hack,
4294 because it determines which class to instantiate for IPython
4298 because it determines which class to instantiate for IPython
4295 itself.
4299 itself.
4296
4300
4297 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
4301 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
4298 classes to support multithreaded GTK operation without blocking,
4302 classes to support multithreaded GTK operation without blocking,
4299 and matplotlib with all backends. This is a lot of still very
4303 and matplotlib with all backends. This is a lot of still very
4300 experimental code, and threads are tricky. So it may still have a
4304 experimental code, and threads are tricky. So it may still have a
4301 few rough edges... This code owes a lot to
4305 few rough edges... This code owes a lot to
4302 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
4306 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
4303 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
4307 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
4304 to John Hunter for all the matplotlib work.
4308 to John Hunter for all the matplotlib work.
4305
4309
4306 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
4310 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
4307 options for gtk thread and matplotlib support.
4311 options for gtk thread and matplotlib support.
4308
4312
4309 2004-08-16 Fernando Perez <fperez@colorado.edu>
4313 2004-08-16 Fernando Perez <fperez@colorado.edu>
4310
4314
4311 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
4315 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
4312 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
4316 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
4313 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
4317 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
4314
4318
4315 2004-08-11 Fernando Perez <fperez@colorado.edu>
4319 2004-08-11 Fernando Perez <fperez@colorado.edu>
4316
4320
4317 * setup.py (isfile): Fix build so documentation gets updated for
4321 * setup.py (isfile): Fix build so documentation gets updated for
4318 rpms (it was only done for .tgz builds).
4322 rpms (it was only done for .tgz builds).
4319
4323
4320 2004-08-10 Fernando Perez <fperez@colorado.edu>
4324 2004-08-10 Fernando Perez <fperez@colorado.edu>
4321
4325
4322 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
4326 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
4323
4327
4324 * iplib.py : Silence syntax error exceptions in tab-completion.
4328 * iplib.py : Silence syntax error exceptions in tab-completion.
4325
4329
4326 2004-08-05 Fernando Perez <fperez@colorado.edu>
4330 2004-08-05 Fernando Perez <fperez@colorado.edu>
4327
4331
4328 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
4332 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
4329 'color off' mark for continuation prompts. This was causing long
4333 'color off' mark for continuation prompts. This was causing long
4330 continuation lines to mis-wrap.
4334 continuation lines to mis-wrap.
4331
4335
4332 2004-08-01 Fernando Perez <fperez@colorado.edu>
4336 2004-08-01 Fernando Perez <fperez@colorado.edu>
4333
4337
4334 * IPython/ipmaker.py (make_IPython): Allow the shell class used
4338 * IPython/ipmaker.py (make_IPython): Allow the shell class used
4335 for building ipython to be a parameter. All this is necessary
4339 for building ipython to be a parameter. All this is necessary
4336 right now to have a multithreaded version, but this insane
4340 right now to have a multithreaded version, but this insane
4337 non-design will be cleaned up soon. For now, it's a hack that
4341 non-design will be cleaned up soon. For now, it's a hack that
4338 works.
4342 works.
4339
4343
4340 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
4344 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
4341 args in various places. No bugs so far, but it's a dangerous
4345 args in various places. No bugs so far, but it's a dangerous
4342 practice.
4346 practice.
4343
4347
4344 2004-07-31 Fernando Perez <fperez@colorado.edu>
4348 2004-07-31 Fernando Perez <fperez@colorado.edu>
4345
4349
4346 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
4350 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
4347 fix completion of files with dots in their names under most
4351 fix completion of files with dots in their names under most
4348 profiles (pysh was OK because the completion order is different).
4352 profiles (pysh was OK because the completion order is different).
4349
4353
4350 2004-07-27 Fernando Perez <fperez@colorado.edu>
4354 2004-07-27 Fernando Perez <fperez@colorado.edu>
4351
4355
4352 * IPython/iplib.py (InteractiveShell.__init__): build dict of
4356 * IPython/iplib.py (InteractiveShell.__init__): build dict of
4353 keywords manually, b/c the one in keyword.py was removed in python
4357 keywords manually, b/c the one in keyword.py was removed in python
4354 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
4358 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
4355 This is NOT a bug under python 2.3 and earlier.
4359 This is NOT a bug under python 2.3 and earlier.
4356
4360
4357 2004-07-26 Fernando Perez <fperez@colorado.edu>
4361 2004-07-26 Fernando Perez <fperez@colorado.edu>
4358
4362
4359 * IPython/ultraTB.py (VerboseTB.text): Add another
4363 * IPython/ultraTB.py (VerboseTB.text): Add another
4360 linecache.checkcache() call to try to prevent inspect.py from
4364 linecache.checkcache() call to try to prevent inspect.py from
4361 crashing under python 2.3. I think this fixes
4365 crashing under python 2.3. I think this fixes
4362 http://www.scipy.net/roundup/ipython/issue17.
4366 http://www.scipy.net/roundup/ipython/issue17.
4363
4367
4364 2004-07-26 *** Released version 0.6.2
4368 2004-07-26 *** Released version 0.6.2
4365
4369
4366 2004-07-26 Fernando Perez <fperez@colorado.edu>
4370 2004-07-26 Fernando Perez <fperez@colorado.edu>
4367
4371
4368 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
4372 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
4369 fail for any number.
4373 fail for any number.
4370 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
4374 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
4371 empty bookmarks.
4375 empty bookmarks.
4372
4376
4373 2004-07-26 *** Released version 0.6.1
4377 2004-07-26 *** Released version 0.6.1
4374
4378
4375 2004-07-26 Fernando Perez <fperez@colorado.edu>
4379 2004-07-26 Fernando Perez <fperez@colorado.edu>
4376
4380
4377 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
4381 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
4378
4382
4379 * IPython/iplib.py (protect_filename): Applied Ville's patch for
4383 * IPython/iplib.py (protect_filename): Applied Ville's patch for
4380 escaping '()[]{}' in filenames.
4384 escaping '()[]{}' in filenames.
4381
4385
4382 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
4386 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
4383 Python 2.2 users who lack a proper shlex.split.
4387 Python 2.2 users who lack a proper shlex.split.
4384
4388
4385 2004-07-19 Fernando Perez <fperez@colorado.edu>
4389 2004-07-19 Fernando Perez <fperez@colorado.edu>
4386
4390
4387 * IPython/iplib.py (InteractiveShell.init_readline): Add support
4391 * IPython/iplib.py (InteractiveShell.init_readline): Add support
4388 for reading readline's init file. I follow the normal chain:
4392 for reading readline's init file. I follow the normal chain:
4389 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
4393 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
4390 report by Mike Heeter. This closes
4394 report by Mike Heeter. This closes
4391 http://www.scipy.net/roundup/ipython/issue16.
4395 http://www.scipy.net/roundup/ipython/issue16.
4392
4396
4393 2004-07-18 Fernando Perez <fperez@colorado.edu>
4397 2004-07-18 Fernando Perez <fperez@colorado.edu>
4394
4398
4395 * IPython/iplib.py (__init__): Add better handling of '\' under
4399 * IPython/iplib.py (__init__): Add better handling of '\' under
4396 Win32 for filenames. After a patch by Ville.
4400 Win32 for filenames. After a patch by Ville.
4397
4401
4398 2004-07-17 Fernando Perez <fperez@colorado.edu>
4402 2004-07-17 Fernando Perez <fperez@colorado.edu>
4399
4403
4400 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4404 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4401 autocalling would be triggered for 'foo is bar' if foo is
4405 autocalling would be triggered for 'foo is bar' if foo is
4402 callable. I also cleaned up the autocall detection code to use a
4406 callable. I also cleaned up the autocall detection code to use a
4403 regexp, which is faster. Bug reported by Alexander Schmolck.
4407 regexp, which is faster. Bug reported by Alexander Schmolck.
4404
4408
4405 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
4409 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
4406 '?' in them would confuse the help system. Reported by Alex
4410 '?' in them would confuse the help system. Reported by Alex
4407 Schmolck.
4411 Schmolck.
4408
4412
4409 2004-07-16 Fernando Perez <fperez@colorado.edu>
4413 2004-07-16 Fernando Perez <fperez@colorado.edu>
4410
4414
4411 * IPython/GnuplotInteractive.py (__all__): added plot2.
4415 * IPython/GnuplotInteractive.py (__all__): added plot2.
4412
4416
4413 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
4417 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
4414 plotting dictionaries, lists or tuples of 1d arrays.
4418 plotting dictionaries, lists or tuples of 1d arrays.
4415
4419
4416 * IPython/Magic.py (Magic.magic_hist): small clenaups and
4420 * IPython/Magic.py (Magic.magic_hist): small clenaups and
4417 optimizations.
4421 optimizations.
4418
4422
4419 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
4423 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
4420 the information which was there from Janko's original IPP code:
4424 the information which was there from Janko's original IPP code:
4421
4425
4422 03.05.99 20:53 porto.ifm.uni-kiel.de
4426 03.05.99 20:53 porto.ifm.uni-kiel.de
4423 --Started changelog.
4427 --Started changelog.
4424 --make clear do what it say it does
4428 --make clear do what it say it does
4425 --added pretty output of lines from inputcache
4429 --added pretty output of lines from inputcache
4426 --Made Logger a mixin class, simplifies handling of switches
4430 --Made Logger a mixin class, simplifies handling of switches
4427 --Added own completer class. .string<TAB> expands to last history
4431 --Added own completer class. .string<TAB> expands to last history
4428 line which starts with string. The new expansion is also present
4432 line which starts with string. The new expansion is also present
4429 with Ctrl-r from the readline library. But this shows, who this
4433 with Ctrl-r from the readline library. But this shows, who this
4430 can be done for other cases.
4434 can be done for other cases.
4431 --Added convention that all shell functions should accept a
4435 --Added convention that all shell functions should accept a
4432 parameter_string This opens the door for different behaviour for
4436 parameter_string This opens the door for different behaviour for
4433 each function. @cd is a good example of this.
4437 each function. @cd is a good example of this.
4434
4438
4435 04.05.99 12:12 porto.ifm.uni-kiel.de
4439 04.05.99 12:12 porto.ifm.uni-kiel.de
4436 --added logfile rotation
4440 --added logfile rotation
4437 --added new mainloop method which freezes first the namespace
4441 --added new mainloop method which freezes first the namespace
4438
4442
4439 07.05.99 21:24 porto.ifm.uni-kiel.de
4443 07.05.99 21:24 porto.ifm.uni-kiel.de
4440 --added the docreader classes. Now there is a help system.
4444 --added the docreader classes. Now there is a help system.
4441 -This is only a first try. Currently it's not easy to put new
4445 -This is only a first try. Currently it's not easy to put new
4442 stuff in the indices. But this is the way to go. Info would be
4446 stuff in the indices. But this is the way to go. Info would be
4443 better, but HTML is every where and not everybody has an info
4447 better, but HTML is every where and not everybody has an info
4444 system installed and it's not so easy to change html-docs to info.
4448 system installed and it's not so easy to change html-docs to info.
4445 --added global logfile option
4449 --added global logfile option
4446 --there is now a hook for object inspection method pinfo needs to
4450 --there is now a hook for object inspection method pinfo needs to
4447 be provided for this. Can be reached by two '??'.
4451 be provided for this. Can be reached by two '??'.
4448
4452
4449 08.05.99 20:51 porto.ifm.uni-kiel.de
4453 08.05.99 20:51 porto.ifm.uni-kiel.de
4450 --added a README
4454 --added a README
4451 --bug in rc file. Something has changed so functions in the rc
4455 --bug in rc file. Something has changed so functions in the rc
4452 file need to reference the shell and not self. Not clear if it's a
4456 file need to reference the shell and not self. Not clear if it's a
4453 bug or feature.
4457 bug or feature.
4454 --changed rc file for new behavior
4458 --changed rc file for new behavior
4455
4459
4456 2004-07-15 Fernando Perez <fperez@colorado.edu>
4460 2004-07-15 Fernando Perez <fperez@colorado.edu>
4457
4461
4458 * IPython/Logger.py (Logger.log): fixed recent bug where the input
4462 * IPython/Logger.py (Logger.log): fixed recent bug where the input
4459 cache was falling out of sync in bizarre manners when multi-line
4463 cache was falling out of sync in bizarre manners when multi-line
4460 input was present. Minor optimizations and cleanup.
4464 input was present. Minor optimizations and cleanup.
4461
4465
4462 (Logger): Remove old Changelog info for cleanup. This is the
4466 (Logger): Remove old Changelog info for cleanup. This is the
4463 information which was there from Janko's original code:
4467 information which was there from Janko's original code:
4464
4468
4465 Changes to Logger: - made the default log filename a parameter
4469 Changes to Logger: - made the default log filename a parameter
4466
4470
4467 - put a check for lines beginning with !@? in log(). Needed
4471 - put a check for lines beginning with !@? in log(). Needed
4468 (even if the handlers properly log their lines) for mid-session
4472 (even if the handlers properly log their lines) for mid-session
4469 logging activation to work properly. Without this, lines logged
4473 logging activation to work properly. Without this, lines logged
4470 in mid session, which get read from the cache, would end up
4474 in mid session, which get read from the cache, would end up
4471 'bare' (with !@? in the open) in the log. Now they are caught
4475 'bare' (with !@? in the open) in the log. Now they are caught
4472 and prepended with a #.
4476 and prepended with a #.
4473
4477
4474 * IPython/iplib.py (InteractiveShell.init_readline): added check
4478 * IPython/iplib.py (InteractiveShell.init_readline): added check
4475 in case MagicCompleter fails to be defined, so we don't crash.
4479 in case MagicCompleter fails to be defined, so we don't crash.
4476
4480
4477 2004-07-13 Fernando Perez <fperez@colorado.edu>
4481 2004-07-13 Fernando Perez <fperez@colorado.edu>
4478
4482
4479 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
4483 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
4480 of EPS if the requested filename ends in '.eps'.
4484 of EPS if the requested filename ends in '.eps'.
4481
4485
4482 2004-07-04 Fernando Perez <fperez@colorado.edu>
4486 2004-07-04 Fernando Perez <fperez@colorado.edu>
4483
4487
4484 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
4488 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
4485 escaping of quotes when calling the shell.
4489 escaping of quotes when calling the shell.
4486
4490
4487 2004-07-02 Fernando Perez <fperez@colorado.edu>
4491 2004-07-02 Fernando Perez <fperez@colorado.edu>
4488
4492
4489 * IPython/Prompts.py (CachedOutput.update): Fix problem with
4493 * IPython/Prompts.py (CachedOutput.update): Fix problem with
4490 gettext not working because we were clobbering '_'. Fixes
4494 gettext not working because we were clobbering '_'. Fixes
4491 http://www.scipy.net/roundup/ipython/issue6.
4495 http://www.scipy.net/roundup/ipython/issue6.
4492
4496
4493 2004-07-01 Fernando Perez <fperez@colorado.edu>
4497 2004-07-01 Fernando Perez <fperez@colorado.edu>
4494
4498
4495 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
4499 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
4496 into @cd. Patch by Ville.
4500 into @cd. Patch by Ville.
4497
4501
4498 * IPython/iplib.py (InteractiveShell.post_config_initialization):
4502 * IPython/iplib.py (InteractiveShell.post_config_initialization):
4499 new function to store things after ipmaker runs. Patch by Ville.
4503 new function to store things after ipmaker runs. Patch by Ville.
4500 Eventually this will go away once ipmaker is removed and the class
4504 Eventually this will go away once ipmaker is removed and the class
4501 gets cleaned up, but for now it's ok. Key functionality here is
4505 gets cleaned up, but for now it's ok. Key functionality here is
4502 the addition of the persistent storage mechanism, a dict for
4506 the addition of the persistent storage mechanism, a dict for
4503 keeping data across sessions (for now just bookmarks, but more can
4507 keeping data across sessions (for now just bookmarks, but more can
4504 be implemented later).
4508 be implemented later).
4505
4509
4506 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
4510 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
4507 persistent across sections. Patch by Ville, I modified it
4511 persistent across sections. Patch by Ville, I modified it
4508 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
4512 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
4509 added a '-l' option to list all bookmarks.
4513 added a '-l' option to list all bookmarks.
4510
4514
4511 * IPython/iplib.py (InteractiveShell.atexit_operations): new
4515 * IPython/iplib.py (InteractiveShell.atexit_operations): new
4512 center for cleanup. Registered with atexit.register(). I moved
4516 center for cleanup. Registered with atexit.register(). I moved
4513 here the old exit_cleanup(). After a patch by Ville.
4517 here the old exit_cleanup(). After a patch by Ville.
4514
4518
4515 * IPython/Magic.py (get_py_filename): added '~' to the accepted
4519 * IPython/Magic.py (get_py_filename): added '~' to the accepted
4516 characters in the hacked shlex_split for python 2.2.
4520 characters in the hacked shlex_split for python 2.2.
4517
4521
4518 * IPython/iplib.py (file_matches): more fixes to filenames with
4522 * IPython/iplib.py (file_matches): more fixes to filenames with
4519 whitespace in them. It's not perfect, but limitations in python's
4523 whitespace in them. It's not perfect, but limitations in python's
4520 readline make it impossible to go further.
4524 readline make it impossible to go further.
4521
4525
4522 2004-06-29 Fernando Perez <fperez@colorado.edu>
4526 2004-06-29 Fernando Perez <fperez@colorado.edu>
4523
4527
4524 * IPython/iplib.py (file_matches): escape whitespace correctly in
4528 * IPython/iplib.py (file_matches): escape whitespace correctly in
4525 filename completions. Bug reported by Ville.
4529 filename completions. Bug reported by Ville.
4526
4530
4527 2004-06-28 Fernando Perez <fperez@colorado.edu>
4531 2004-06-28 Fernando Perez <fperez@colorado.edu>
4528
4532
4529 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
4533 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
4530 the history file will be called 'history-PROFNAME' (or just
4534 the history file will be called 'history-PROFNAME' (or just
4531 'history' if no profile is loaded). I was getting annoyed at
4535 'history' if no profile is loaded). I was getting annoyed at
4532 getting my Numerical work history clobbered by pysh sessions.
4536 getting my Numerical work history clobbered by pysh sessions.
4533
4537
4534 * IPython/iplib.py (InteractiveShell.__init__): Internal
4538 * IPython/iplib.py (InteractiveShell.__init__): Internal
4535 getoutputerror() function so that we can honor the system_verbose
4539 getoutputerror() function so that we can honor the system_verbose
4536 flag for _all_ system calls. I also added escaping of #
4540 flag for _all_ system calls. I also added escaping of #
4537 characters here to avoid confusing Itpl.
4541 characters here to avoid confusing Itpl.
4538
4542
4539 * IPython/Magic.py (shlex_split): removed call to shell in
4543 * IPython/Magic.py (shlex_split): removed call to shell in
4540 parse_options and replaced it with shlex.split(). The annoying
4544 parse_options and replaced it with shlex.split(). The annoying
4541 part was that in Python 2.2, shlex.split() doesn't exist, so I had
4545 part was that in Python 2.2, shlex.split() doesn't exist, so I had
4542 to backport it from 2.3, with several frail hacks (the shlex
4546 to backport it from 2.3, with several frail hacks (the shlex
4543 module is rather limited in 2.2). Thanks to a suggestion by Ville
4547 module is rather limited in 2.2). Thanks to a suggestion by Ville
4544 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
4548 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
4545 problem.
4549 problem.
4546
4550
4547 (Magic.magic_system_verbose): new toggle to print the actual
4551 (Magic.magic_system_verbose): new toggle to print the actual
4548 system calls made by ipython. Mainly for debugging purposes.
4552 system calls made by ipython. Mainly for debugging purposes.
4549
4553
4550 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
4554 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
4551 doesn't support persistence. Reported (and fix suggested) by
4555 doesn't support persistence. Reported (and fix suggested) by
4552 Travis Caldwell <travis_caldwell2000@yahoo.com>.
4556 Travis Caldwell <travis_caldwell2000@yahoo.com>.
4553
4557
4554 2004-06-26 Fernando Perez <fperez@colorado.edu>
4558 2004-06-26 Fernando Perez <fperez@colorado.edu>
4555
4559
4556 * IPython/Logger.py (Logger.log): fix to handle correctly empty
4560 * IPython/Logger.py (Logger.log): fix to handle correctly empty
4557 continue prompts.
4561 continue prompts.
4558
4562
4559 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
4563 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
4560 function (basically a big docstring) and a few more things here to
4564 function (basically a big docstring) and a few more things here to
4561 speedup startup. pysh.py is now very lightweight. We want because
4565 speedup startup. pysh.py is now very lightweight. We want because
4562 it gets execfile'd, while InterpreterExec gets imported, so
4566 it gets execfile'd, while InterpreterExec gets imported, so
4563 byte-compilation saves time.
4567 byte-compilation saves time.
4564
4568
4565 2004-06-25 Fernando Perez <fperez@colorado.edu>
4569 2004-06-25 Fernando Perez <fperez@colorado.edu>
4566
4570
4567 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
4571 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
4568 -NUM', which was recently broken.
4572 -NUM', which was recently broken.
4569
4573
4570 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
4574 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
4571 in multi-line input (but not !!, which doesn't make sense there).
4575 in multi-line input (but not !!, which doesn't make sense there).
4572
4576
4573 * IPython/UserConfig/ipythonrc: made autoindent on by default.
4577 * IPython/UserConfig/ipythonrc: made autoindent on by default.
4574 It's just too useful, and people can turn it off in the less
4578 It's just too useful, and people can turn it off in the less
4575 common cases where it's a problem.
4579 common cases where it's a problem.
4576
4580
4577 2004-06-24 Fernando Perez <fperez@colorado.edu>
4581 2004-06-24 Fernando Perez <fperez@colorado.edu>
4578
4582
4579 * IPython/iplib.py (InteractiveShell._prefilter): big change -
4583 * IPython/iplib.py (InteractiveShell._prefilter): big change -
4580 special syntaxes (like alias calling) is now allied in multi-line
4584 special syntaxes (like alias calling) is now allied in multi-line
4581 input. This is still _very_ experimental, but it's necessary for
4585 input. This is still _very_ experimental, but it's necessary for
4582 efficient shell usage combining python looping syntax with system
4586 efficient shell usage combining python looping syntax with system
4583 calls. For now it's restricted to aliases, I don't think it
4587 calls. For now it's restricted to aliases, I don't think it
4584 really even makes sense to have this for magics.
4588 really even makes sense to have this for magics.
4585
4589
4586 2004-06-23 Fernando Perez <fperez@colorado.edu>
4590 2004-06-23 Fernando Perez <fperez@colorado.edu>
4587
4591
4588 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
4592 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
4589 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
4593 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
4590
4594
4591 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
4595 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
4592 extensions under Windows (after code sent by Gary Bishop). The
4596 extensions under Windows (after code sent by Gary Bishop). The
4593 extensions considered 'executable' are stored in IPython's rc
4597 extensions considered 'executable' are stored in IPython's rc
4594 structure as win_exec_ext.
4598 structure as win_exec_ext.
4595
4599
4596 * IPython/genutils.py (shell): new function, like system() but
4600 * IPython/genutils.py (shell): new function, like system() but
4597 without return value. Very useful for interactive shell work.
4601 without return value. Very useful for interactive shell work.
4598
4602
4599 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
4603 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
4600 delete aliases.
4604 delete aliases.
4601
4605
4602 * IPython/iplib.py (InteractiveShell.alias_table_update): make
4606 * IPython/iplib.py (InteractiveShell.alias_table_update): make
4603 sure that the alias table doesn't contain python keywords.
4607 sure that the alias table doesn't contain python keywords.
4604
4608
4605 2004-06-21 Fernando Perez <fperez@colorado.edu>
4609 2004-06-21 Fernando Perez <fperez@colorado.edu>
4606
4610
4607 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
4611 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
4608 non-existent items are found in $PATH. Reported by Thorsten.
4612 non-existent items are found in $PATH. Reported by Thorsten.
4609
4613
4610 2004-06-20 Fernando Perez <fperez@colorado.edu>
4614 2004-06-20 Fernando Perez <fperez@colorado.edu>
4611
4615
4612 * IPython/iplib.py (complete): modified the completer so that the
4616 * IPython/iplib.py (complete): modified the completer so that the
4613 order of priorities can be easily changed at runtime.
4617 order of priorities can be easily changed at runtime.
4614
4618
4615 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
4619 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
4616 Modified to auto-execute all lines beginning with '~', '/' or '.'.
4620 Modified to auto-execute all lines beginning with '~', '/' or '.'.
4617
4621
4618 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
4622 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
4619 expand Python variables prepended with $ in all system calls. The
4623 expand Python variables prepended with $ in all system calls. The
4620 same was done to InteractiveShell.handle_shell_escape. Now all
4624 same was done to InteractiveShell.handle_shell_escape. Now all
4621 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
4625 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
4622 expansion of python variables and expressions according to the
4626 expansion of python variables and expressions according to the
4623 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
4627 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
4624
4628
4625 Though PEP-215 has been rejected, a similar (but simpler) one
4629 Though PEP-215 has been rejected, a similar (but simpler) one
4626 seems like it will go into Python 2.4, PEP-292 -
4630 seems like it will go into Python 2.4, PEP-292 -
4627 http://www.python.org/peps/pep-0292.html.
4631 http://www.python.org/peps/pep-0292.html.
4628
4632
4629 I'll keep the full syntax of PEP-215, since IPython has since the
4633 I'll keep the full syntax of PEP-215, since IPython has since the
4630 start used Ka-Ping Yee's reference implementation discussed there
4634 start used Ka-Ping Yee's reference implementation discussed there
4631 (Itpl), and I actually like the powerful semantics it offers.
4635 (Itpl), and I actually like the powerful semantics it offers.
4632
4636
4633 In order to access normal shell variables, the $ has to be escaped
4637 In order to access normal shell variables, the $ has to be escaped
4634 via an extra $. For example:
4638 via an extra $. For example:
4635
4639
4636 In [7]: PATH='a python variable'
4640 In [7]: PATH='a python variable'
4637
4641
4638 In [8]: !echo $PATH
4642 In [8]: !echo $PATH
4639 a python variable
4643 a python variable
4640
4644
4641 In [9]: !echo $$PATH
4645 In [9]: !echo $$PATH
4642 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
4646 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
4643
4647
4644 (Magic.parse_options): escape $ so the shell doesn't evaluate
4648 (Magic.parse_options): escape $ so the shell doesn't evaluate
4645 things prematurely.
4649 things prematurely.
4646
4650
4647 * IPython/iplib.py (InteractiveShell.call_alias): added the
4651 * IPython/iplib.py (InteractiveShell.call_alias): added the
4648 ability for aliases to expand python variables via $.
4652 ability for aliases to expand python variables via $.
4649
4653
4650 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
4654 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
4651 system, now there's a @rehash/@rehashx pair of magics. These work
4655 system, now there's a @rehash/@rehashx pair of magics. These work
4652 like the csh rehash command, and can be invoked at any time. They
4656 like the csh rehash command, and can be invoked at any time. They
4653 build a table of aliases to everything in the user's $PATH
4657 build a table of aliases to everything in the user's $PATH
4654 (@rehash uses everything, @rehashx is slower but only adds
4658 (@rehash uses everything, @rehashx is slower but only adds
4655 executable files). With this, the pysh.py-based shell profile can
4659 executable files). With this, the pysh.py-based shell profile can
4656 now simply call rehash upon startup, and full access to all
4660 now simply call rehash upon startup, and full access to all
4657 programs in the user's path is obtained.
4661 programs in the user's path is obtained.
4658
4662
4659 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
4663 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
4660 functionality is now fully in place. I removed the old dynamic
4664 functionality is now fully in place. I removed the old dynamic
4661 code generation based approach, in favor of a much lighter one
4665 code generation based approach, in favor of a much lighter one
4662 based on a simple dict. The advantage is that this allows me to
4666 based on a simple dict. The advantage is that this allows me to
4663 now have thousands of aliases with negligible cost (unthinkable
4667 now have thousands of aliases with negligible cost (unthinkable
4664 with the old system).
4668 with the old system).
4665
4669
4666 2004-06-19 Fernando Perez <fperez@colorado.edu>
4670 2004-06-19 Fernando Perez <fperez@colorado.edu>
4667
4671
4668 * IPython/iplib.py (__init__): extended MagicCompleter class to
4672 * IPython/iplib.py (__init__): extended MagicCompleter class to
4669 also complete (last in priority) on user aliases.
4673 also complete (last in priority) on user aliases.
4670
4674
4671 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
4675 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
4672 call to eval.
4676 call to eval.
4673 (ItplNS.__init__): Added a new class which functions like Itpl,
4677 (ItplNS.__init__): Added a new class which functions like Itpl,
4674 but allows configuring the namespace for the evaluation to occur
4678 but allows configuring the namespace for the evaluation to occur
4675 in.
4679 in.
4676
4680
4677 2004-06-18 Fernando Perez <fperez@colorado.edu>
4681 2004-06-18 Fernando Perez <fperez@colorado.edu>
4678
4682
4679 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
4683 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
4680 better message when 'exit' or 'quit' are typed (a common newbie
4684 better message when 'exit' or 'quit' are typed (a common newbie
4681 confusion).
4685 confusion).
4682
4686
4683 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
4687 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
4684 check for Windows users.
4688 check for Windows users.
4685
4689
4686 * IPython/iplib.py (InteractiveShell.user_setup): removed
4690 * IPython/iplib.py (InteractiveShell.user_setup): removed
4687 disabling of colors for Windows. I'll test at runtime and issue a
4691 disabling of colors for Windows. I'll test at runtime and issue a
4688 warning if Gary's readline isn't found, as to nudge users to
4692 warning if Gary's readline isn't found, as to nudge users to
4689 download it.
4693 download it.
4690
4694
4691 2004-06-16 Fernando Perez <fperez@colorado.edu>
4695 2004-06-16 Fernando Perez <fperez@colorado.edu>
4692
4696
4693 * IPython/genutils.py (Stream.__init__): changed to print errors
4697 * IPython/genutils.py (Stream.__init__): changed to print errors
4694 to sys.stderr. I had a circular dependency here. Now it's
4698 to sys.stderr. I had a circular dependency here. Now it's
4695 possible to run ipython as IDLE's shell (consider this pre-alpha,
4699 possible to run ipython as IDLE's shell (consider this pre-alpha,
4696 since true stdout things end up in the starting terminal instead
4700 since true stdout things end up in the starting terminal instead
4697 of IDLE's out).
4701 of IDLE's out).
4698
4702
4699 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
4703 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
4700 users who haven't # updated their prompt_in2 definitions. Remove
4704 users who haven't # updated their prompt_in2 definitions. Remove
4701 eventually.
4705 eventually.
4702 (multiple_replace): added credit to original ASPN recipe.
4706 (multiple_replace): added credit to original ASPN recipe.
4703
4707
4704 2004-06-15 Fernando Perez <fperez@colorado.edu>
4708 2004-06-15 Fernando Perez <fperez@colorado.edu>
4705
4709
4706 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
4710 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
4707 list of auto-defined aliases.
4711 list of auto-defined aliases.
4708
4712
4709 2004-06-13 Fernando Perez <fperez@colorado.edu>
4713 2004-06-13 Fernando Perez <fperez@colorado.edu>
4710
4714
4711 * setup.py (scriptfiles): Don't trigger win_post_install unless an
4715 * setup.py (scriptfiles): Don't trigger win_post_install unless an
4712 install was really requested (so setup.py can be used for other
4716 install was really requested (so setup.py can be used for other
4713 things under Windows).
4717 things under Windows).
4714
4718
4715 2004-06-10 Fernando Perez <fperez@colorado.edu>
4719 2004-06-10 Fernando Perez <fperez@colorado.edu>
4716
4720
4717 * IPython/Logger.py (Logger.create_log): Manually remove any old
4721 * IPython/Logger.py (Logger.create_log): Manually remove any old
4718 backup, since os.remove may fail under Windows. Fixes bug
4722 backup, since os.remove may fail under Windows. Fixes bug
4719 reported by Thorsten.
4723 reported by Thorsten.
4720
4724
4721 2004-06-09 Fernando Perez <fperez@colorado.edu>
4725 2004-06-09 Fernando Perez <fperez@colorado.edu>
4722
4726
4723 * examples/example-embed.py: fixed all references to %n (replaced
4727 * examples/example-embed.py: fixed all references to %n (replaced
4724 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
4728 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
4725 for all examples and the manual as well.
4729 for all examples and the manual as well.
4726
4730
4727 2004-06-08 Fernando Perez <fperez@colorado.edu>
4731 2004-06-08 Fernando Perez <fperez@colorado.edu>
4728
4732
4729 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
4733 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
4730 alignment and color management. All 3 prompt subsystems now
4734 alignment and color management. All 3 prompt subsystems now
4731 inherit from BasePrompt.
4735 inherit from BasePrompt.
4732
4736
4733 * tools/release: updates for windows installer build and tag rpms
4737 * tools/release: updates for windows installer build and tag rpms
4734 with python version (since paths are fixed).
4738 with python version (since paths are fixed).
4735
4739
4736 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
4740 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
4737 which will become eventually obsolete. Also fixed the default
4741 which will become eventually obsolete. Also fixed the default
4738 prompt_in2 to use \D, so at least new users start with the correct
4742 prompt_in2 to use \D, so at least new users start with the correct
4739 defaults.
4743 defaults.
4740 WARNING: Users with existing ipythonrc files will need to apply
4744 WARNING: Users with existing ipythonrc files will need to apply
4741 this fix manually!
4745 this fix manually!
4742
4746
4743 * setup.py: make windows installer (.exe). This is finally the
4747 * setup.py: make windows installer (.exe). This is finally the
4744 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
4748 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
4745 which I hadn't included because it required Python 2.3 (or recent
4749 which I hadn't included because it required Python 2.3 (or recent
4746 distutils).
4750 distutils).
4747
4751
4748 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
4752 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
4749 usage of new '\D' escape.
4753 usage of new '\D' escape.
4750
4754
4751 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
4755 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
4752 lacks os.getuid())
4756 lacks os.getuid())
4753 (CachedOutput.set_colors): Added the ability to turn coloring
4757 (CachedOutput.set_colors): Added the ability to turn coloring
4754 on/off with @colors even for manually defined prompt colors. It
4758 on/off with @colors even for manually defined prompt colors. It
4755 uses a nasty global, but it works safely and via the generic color
4759 uses a nasty global, but it works safely and via the generic color
4756 handling mechanism.
4760 handling mechanism.
4757 (Prompt2.__init__): Introduced new escape '\D' for continuation
4761 (Prompt2.__init__): Introduced new escape '\D' for continuation
4758 prompts. It represents the counter ('\#') as dots.
4762 prompts. It represents the counter ('\#') as dots.
4759 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
4763 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
4760 need to update their ipythonrc files and replace '%n' with '\D' in
4764 need to update their ipythonrc files and replace '%n' with '\D' in
4761 their prompt_in2 settings everywhere. Sorry, but there's
4765 their prompt_in2 settings everywhere. Sorry, but there's
4762 otherwise no clean way to get all prompts to properly align. The
4766 otherwise no clean way to get all prompts to properly align. The
4763 ipythonrc shipped with IPython has been updated.
4767 ipythonrc shipped with IPython has been updated.
4764
4768
4765 2004-06-07 Fernando Perez <fperez@colorado.edu>
4769 2004-06-07 Fernando Perez <fperez@colorado.edu>
4766
4770
4767 * setup.py (isfile): Pass local_icons option to latex2html, so the
4771 * setup.py (isfile): Pass local_icons option to latex2html, so the
4768 resulting HTML file is self-contained. Thanks to
4772 resulting HTML file is self-contained. Thanks to
4769 dryice-AT-liu.com.cn for the tip.
4773 dryice-AT-liu.com.cn for the tip.
4770
4774
4771 * pysh.py: I created a new profile 'shell', which implements a
4775 * pysh.py: I created a new profile 'shell', which implements a
4772 _rudimentary_ IPython-based shell. This is in NO WAY a realy
4776 _rudimentary_ IPython-based shell. This is in NO WAY a realy
4773 system shell, nor will it become one anytime soon. It's mainly
4777 system shell, nor will it become one anytime soon. It's mainly
4774 meant to illustrate the use of the new flexible bash-like prompts.
4778 meant to illustrate the use of the new flexible bash-like prompts.
4775 I guess it could be used by hardy souls for true shell management,
4779 I guess it could be used by hardy souls for true shell management,
4776 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
4780 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
4777 profile. This uses the InterpreterExec extension provided by
4781 profile. This uses the InterpreterExec extension provided by
4778 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
4782 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
4779
4783
4780 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4784 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4781 auto-align itself with the length of the previous input prompt
4785 auto-align itself with the length of the previous input prompt
4782 (taking into account the invisible color escapes).
4786 (taking into account the invisible color escapes).
4783 (CachedOutput.__init__): Large restructuring of this class. Now
4787 (CachedOutput.__init__): Large restructuring of this class. Now
4784 all three prompts (primary1, primary2, output) are proper objects,
4788 all three prompts (primary1, primary2, output) are proper objects,
4785 managed by the 'parent' CachedOutput class. The code is still a
4789 managed by the 'parent' CachedOutput class. The code is still a
4786 bit hackish (all prompts share state via a pointer to the cache),
4790 bit hackish (all prompts share state via a pointer to the cache),
4787 but it's overall far cleaner than before.
4791 but it's overall far cleaner than before.
4788
4792
4789 * IPython/genutils.py (getoutputerror): modified to add verbose,
4793 * IPython/genutils.py (getoutputerror): modified to add verbose,
4790 debug and header options. This makes the interface of all getout*
4794 debug and header options. This makes the interface of all getout*
4791 functions uniform.
4795 functions uniform.
4792 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4796 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4793
4797
4794 * IPython/Magic.py (Magic.default_option): added a function to
4798 * IPython/Magic.py (Magic.default_option): added a function to
4795 allow registering default options for any magic command. This
4799 allow registering default options for any magic command. This
4796 makes it easy to have profiles which customize the magics globally
4800 makes it easy to have profiles which customize the magics globally
4797 for a certain use. The values set through this function are
4801 for a certain use. The values set through this function are
4798 picked up by the parse_options() method, which all magics should
4802 picked up by the parse_options() method, which all magics should
4799 use to parse their options.
4803 use to parse their options.
4800
4804
4801 * IPython/genutils.py (warn): modified the warnings framework to
4805 * IPython/genutils.py (warn): modified the warnings framework to
4802 use the Term I/O class. I'm trying to slowly unify all of
4806 use the Term I/O class. I'm trying to slowly unify all of
4803 IPython's I/O operations to pass through Term.
4807 IPython's I/O operations to pass through Term.
4804
4808
4805 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4809 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4806 the secondary prompt to correctly match the length of the primary
4810 the secondary prompt to correctly match the length of the primary
4807 one for any prompt. Now multi-line code will properly line up
4811 one for any prompt. Now multi-line code will properly line up
4808 even for path dependent prompts, such as the new ones available
4812 even for path dependent prompts, such as the new ones available
4809 via the prompt_specials.
4813 via the prompt_specials.
4810
4814
4811 2004-06-06 Fernando Perez <fperez@colorado.edu>
4815 2004-06-06 Fernando Perez <fperez@colorado.edu>
4812
4816
4813 * IPython/Prompts.py (prompt_specials): Added the ability to have
4817 * IPython/Prompts.py (prompt_specials): Added the ability to have
4814 bash-like special sequences in the prompts, which get
4818 bash-like special sequences in the prompts, which get
4815 automatically expanded. Things like hostname, current working
4819 automatically expanded. Things like hostname, current working
4816 directory and username are implemented already, but it's easy to
4820 directory and username are implemented already, but it's easy to
4817 add more in the future. Thanks to a patch by W.J. van der Laan
4821 add more in the future. Thanks to a patch by W.J. van der Laan
4818 <gnufnork-AT-hetdigitalegat.nl>
4822 <gnufnork-AT-hetdigitalegat.nl>
4819 (prompt_specials): Added color support for prompt strings, so
4823 (prompt_specials): Added color support for prompt strings, so
4820 users can define arbitrary color setups for their prompts.
4824 users can define arbitrary color setups for their prompts.
4821
4825
4822 2004-06-05 Fernando Perez <fperez@colorado.edu>
4826 2004-06-05 Fernando Perez <fperez@colorado.edu>
4823
4827
4824 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4828 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4825 code to load Gary Bishop's readline and configure it
4829 code to load Gary Bishop's readline and configure it
4826 automatically. Thanks to Gary for help on this.
4830 automatically. Thanks to Gary for help on this.
4827
4831
4828 2004-06-01 Fernando Perez <fperez@colorado.edu>
4832 2004-06-01 Fernando Perez <fperez@colorado.edu>
4829
4833
4830 * IPython/Logger.py (Logger.create_log): fix bug for logging
4834 * IPython/Logger.py (Logger.create_log): fix bug for logging
4831 with no filename (previous fix was incomplete).
4835 with no filename (previous fix was incomplete).
4832
4836
4833 2004-05-25 Fernando Perez <fperez@colorado.edu>
4837 2004-05-25 Fernando Perez <fperez@colorado.edu>
4834
4838
4835 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4839 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4836 parens would get passed to the shell.
4840 parens would get passed to the shell.
4837
4841
4838 2004-05-20 Fernando Perez <fperez@colorado.edu>
4842 2004-05-20 Fernando Perez <fperez@colorado.edu>
4839
4843
4840 * IPython/Magic.py (Magic.magic_prun): changed default profile
4844 * IPython/Magic.py (Magic.magic_prun): changed default profile
4841 sort order to 'time' (the more common profiling need).
4845 sort order to 'time' (the more common profiling need).
4842
4846
4843 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4847 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4844 so that source code shown is guaranteed in sync with the file on
4848 so that source code shown is guaranteed in sync with the file on
4845 disk (also changed in psource). Similar fix to the one for
4849 disk (also changed in psource). Similar fix to the one for
4846 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4850 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4847 <yann.ledu-AT-noos.fr>.
4851 <yann.ledu-AT-noos.fr>.
4848
4852
4849 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4853 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4850 with a single option would not be correctly parsed. Closes
4854 with a single option would not be correctly parsed. Closes
4851 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4855 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4852 introduced in 0.6.0 (on 2004-05-06).
4856 introduced in 0.6.0 (on 2004-05-06).
4853
4857
4854 2004-05-13 *** Released version 0.6.0
4858 2004-05-13 *** Released version 0.6.0
4855
4859
4856 2004-05-13 Fernando Perez <fperez@colorado.edu>
4860 2004-05-13 Fernando Perez <fperez@colorado.edu>
4857
4861
4858 * debian/: Added debian/ directory to CVS, so that debian support
4862 * debian/: Added debian/ directory to CVS, so that debian support
4859 is publicly accessible. The debian package is maintained by Jack
4863 is publicly accessible. The debian package is maintained by Jack
4860 Moffit <jack-AT-xiph.org>.
4864 Moffit <jack-AT-xiph.org>.
4861
4865
4862 * Documentation: included the notes about an ipython-based system
4866 * Documentation: included the notes about an ipython-based system
4863 shell (the hypothetical 'pysh') into the new_design.pdf document,
4867 shell (the hypothetical 'pysh') into the new_design.pdf document,
4864 so that these ideas get distributed to users along with the
4868 so that these ideas get distributed to users along with the
4865 official documentation.
4869 official documentation.
4866
4870
4867 2004-05-10 Fernando Perez <fperez@colorado.edu>
4871 2004-05-10 Fernando Perez <fperez@colorado.edu>
4868
4872
4869 * IPython/Logger.py (Logger.create_log): fix recently introduced
4873 * IPython/Logger.py (Logger.create_log): fix recently introduced
4870 bug (misindented line) where logstart would fail when not given an
4874 bug (misindented line) where logstart would fail when not given an
4871 explicit filename.
4875 explicit filename.
4872
4876
4873 2004-05-09 Fernando Perez <fperez@colorado.edu>
4877 2004-05-09 Fernando Perez <fperez@colorado.edu>
4874
4878
4875 * IPython/Magic.py (Magic.parse_options): skip system call when
4879 * IPython/Magic.py (Magic.parse_options): skip system call when
4876 there are no options to look for. Faster, cleaner for the common
4880 there are no options to look for. Faster, cleaner for the common
4877 case.
4881 case.
4878
4882
4879 * Documentation: many updates to the manual: describing Windows
4883 * Documentation: many updates to the manual: describing Windows
4880 support better, Gnuplot updates, credits, misc small stuff. Also
4884 support better, Gnuplot updates, credits, misc small stuff. Also
4881 updated the new_design doc a bit.
4885 updated the new_design doc a bit.
4882
4886
4883 2004-05-06 *** Released version 0.6.0.rc1
4887 2004-05-06 *** Released version 0.6.0.rc1
4884
4888
4885 2004-05-06 Fernando Perez <fperez@colorado.edu>
4889 2004-05-06 Fernando Perez <fperez@colorado.edu>
4886
4890
4887 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4891 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4888 operations to use the vastly more efficient list/''.join() method.
4892 operations to use the vastly more efficient list/''.join() method.
4889 (FormattedTB.text): Fix
4893 (FormattedTB.text): Fix
4890 http://www.scipy.net/roundup/ipython/issue12 - exception source
4894 http://www.scipy.net/roundup/ipython/issue12 - exception source
4891 extract not updated after reload. Thanks to Mike Salib
4895 extract not updated after reload. Thanks to Mike Salib
4892 <msalib-AT-mit.edu> for pinning the source of the problem.
4896 <msalib-AT-mit.edu> for pinning the source of the problem.
4893 Fortunately, the solution works inside ipython and doesn't require
4897 Fortunately, the solution works inside ipython and doesn't require
4894 any changes to python proper.
4898 any changes to python proper.
4895
4899
4896 * IPython/Magic.py (Magic.parse_options): Improved to process the
4900 * IPython/Magic.py (Magic.parse_options): Improved to process the
4897 argument list as a true shell would (by actually using the
4901 argument list as a true shell would (by actually using the
4898 underlying system shell). This way, all @magics automatically get
4902 underlying system shell). This way, all @magics automatically get
4899 shell expansion for variables. Thanks to a comment by Alex
4903 shell expansion for variables. Thanks to a comment by Alex
4900 Schmolck.
4904 Schmolck.
4901
4905
4902 2004-04-04 Fernando Perez <fperez@colorado.edu>
4906 2004-04-04 Fernando Perez <fperez@colorado.edu>
4903
4907
4904 * IPython/iplib.py (InteractiveShell.interact): Added a special
4908 * IPython/iplib.py (InteractiveShell.interact): Added a special
4905 trap for a debugger quit exception, which is basically impossible
4909 trap for a debugger quit exception, which is basically impossible
4906 to handle by normal mechanisms, given what pdb does to the stack.
4910 to handle by normal mechanisms, given what pdb does to the stack.
4907 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4911 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4908
4912
4909 2004-04-03 Fernando Perez <fperez@colorado.edu>
4913 2004-04-03 Fernando Perez <fperez@colorado.edu>
4910
4914
4911 * IPython/genutils.py (Term): Standardized the names of the Term
4915 * IPython/genutils.py (Term): Standardized the names of the Term
4912 class streams to cin/cout/cerr, following C++ naming conventions
4916 class streams to cin/cout/cerr, following C++ naming conventions
4913 (I can't use in/out/err because 'in' is not a valid attribute
4917 (I can't use in/out/err because 'in' is not a valid attribute
4914 name).
4918 name).
4915
4919
4916 * IPython/iplib.py (InteractiveShell.interact): don't increment
4920 * IPython/iplib.py (InteractiveShell.interact): don't increment
4917 the prompt if there's no user input. By Daniel 'Dang' Griffith
4921 the prompt if there's no user input. By Daniel 'Dang' Griffith
4918 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4922 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4919 Francois Pinard.
4923 Francois Pinard.
4920
4924
4921 2004-04-02 Fernando Perez <fperez@colorado.edu>
4925 2004-04-02 Fernando Perez <fperez@colorado.edu>
4922
4926
4923 * IPython/genutils.py (Stream.__init__): Modified to survive at
4927 * IPython/genutils.py (Stream.__init__): Modified to survive at
4924 least importing in contexts where stdin/out/err aren't true file
4928 least importing in contexts where stdin/out/err aren't true file
4925 objects, such as PyCrust (they lack fileno() and mode). However,
4929 objects, such as PyCrust (they lack fileno() and mode). However,
4926 the recovery facilities which rely on these things existing will
4930 the recovery facilities which rely on these things existing will
4927 not work.
4931 not work.
4928
4932
4929 2004-04-01 Fernando Perez <fperez@colorado.edu>
4933 2004-04-01 Fernando Perez <fperez@colorado.edu>
4930
4934
4931 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4935 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4932 use the new getoutputerror() function, so it properly
4936 use the new getoutputerror() function, so it properly
4933 distinguishes stdout/err.
4937 distinguishes stdout/err.
4934
4938
4935 * IPython/genutils.py (getoutputerror): added a function to
4939 * IPython/genutils.py (getoutputerror): added a function to
4936 capture separately the standard output and error of a command.
4940 capture separately the standard output and error of a command.
4937 After a comment from dang on the mailing lists. This code is
4941 After a comment from dang on the mailing lists. This code is
4938 basically a modified version of commands.getstatusoutput(), from
4942 basically a modified version of commands.getstatusoutput(), from
4939 the standard library.
4943 the standard library.
4940
4944
4941 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4945 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4942 '!!' as a special syntax (shorthand) to access @sx.
4946 '!!' as a special syntax (shorthand) to access @sx.
4943
4947
4944 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4948 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4945 command and return its output as a list split on '\n'.
4949 command and return its output as a list split on '\n'.
4946
4950
4947 2004-03-31 Fernando Perez <fperez@colorado.edu>
4951 2004-03-31 Fernando Perez <fperez@colorado.edu>
4948
4952
4949 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4953 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4950 method to dictionaries used as FakeModule instances if they lack
4954 method to dictionaries used as FakeModule instances if they lack
4951 it. At least pydoc in python2.3 breaks for runtime-defined
4955 it. At least pydoc in python2.3 breaks for runtime-defined
4952 functions without this hack. At some point I need to _really_
4956 functions without this hack. At some point I need to _really_
4953 understand what FakeModule is doing, because it's a gross hack.
4957 understand what FakeModule is doing, because it's a gross hack.
4954 But it solves Arnd's problem for now...
4958 But it solves Arnd's problem for now...
4955
4959
4956 2004-02-27 Fernando Perez <fperez@colorado.edu>
4960 2004-02-27 Fernando Perez <fperez@colorado.edu>
4957
4961
4958 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4962 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4959 mode would behave erratically. Also increased the number of
4963 mode would behave erratically. Also increased the number of
4960 possible logs in rotate mod to 999. Thanks to Rod Holland
4964 possible logs in rotate mod to 999. Thanks to Rod Holland
4961 <rhh@StructureLABS.com> for the report and fixes.
4965 <rhh@StructureLABS.com> for the report and fixes.
4962
4966
4963 2004-02-26 Fernando Perez <fperez@colorado.edu>
4967 2004-02-26 Fernando Perez <fperez@colorado.edu>
4964
4968
4965 * IPython/genutils.py (page): Check that the curses module really
4969 * IPython/genutils.py (page): Check that the curses module really
4966 has the initscr attribute before trying to use it. For some
4970 has the initscr attribute before trying to use it. For some
4967 reason, the Solaris curses module is missing this. I think this
4971 reason, the Solaris curses module is missing this. I think this
4968 should be considered a Solaris python bug, but I'm not sure.
4972 should be considered a Solaris python bug, but I'm not sure.
4969
4973
4970 2004-01-17 Fernando Perez <fperez@colorado.edu>
4974 2004-01-17 Fernando Perez <fperez@colorado.edu>
4971
4975
4972 * IPython/genutils.py (Stream.__init__): Changes to try to make
4976 * IPython/genutils.py (Stream.__init__): Changes to try to make
4973 ipython robust against stdin/out/err being closed by the user.
4977 ipython robust against stdin/out/err being closed by the user.
4974 This is 'user error' (and blocks a normal python session, at least
4978 This is 'user error' (and blocks a normal python session, at least
4975 the stdout case). However, Ipython should be able to survive such
4979 the stdout case). However, Ipython should be able to survive such
4976 instances of abuse as gracefully as possible. To simplify the
4980 instances of abuse as gracefully as possible. To simplify the
4977 coding and maintain compatibility with Gary Bishop's Term
4981 coding and maintain compatibility with Gary Bishop's Term
4978 contributions, I've made use of classmethods for this. I think
4982 contributions, I've made use of classmethods for this. I think
4979 this introduces a dependency on python 2.2.
4983 this introduces a dependency on python 2.2.
4980
4984
4981 2004-01-13 Fernando Perez <fperez@colorado.edu>
4985 2004-01-13 Fernando Perez <fperez@colorado.edu>
4982
4986
4983 * IPython/numutils.py (exp_safe): simplified the code a bit and
4987 * IPython/numutils.py (exp_safe): simplified the code a bit and
4984 removed the need for importing the kinds module altogether.
4988 removed the need for importing the kinds module altogether.
4985
4989
4986 2004-01-06 Fernando Perez <fperez@colorado.edu>
4990 2004-01-06 Fernando Perez <fperez@colorado.edu>
4987
4991
4988 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4992 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4989 a magic function instead, after some community feedback. No
4993 a magic function instead, after some community feedback. No
4990 special syntax will exist for it, but its name is deliberately
4994 special syntax will exist for it, but its name is deliberately
4991 very short.
4995 very short.
4992
4996
4993 2003-12-20 Fernando Perez <fperez@colorado.edu>
4997 2003-12-20 Fernando Perez <fperez@colorado.edu>
4994
4998
4995 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4999 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4996 new functionality, to automagically assign the result of a shell
5000 new functionality, to automagically assign the result of a shell
4997 command to a variable. I'll solicit some community feedback on
5001 command to a variable. I'll solicit some community feedback on
4998 this before making it permanent.
5002 this before making it permanent.
4999
5003
5000 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
5004 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
5001 requested about callables for which inspect couldn't obtain a
5005 requested about callables for which inspect couldn't obtain a
5002 proper argspec. Thanks to a crash report sent by Etienne
5006 proper argspec. Thanks to a crash report sent by Etienne
5003 Posthumus <etienne-AT-apple01.cs.vu.nl>.
5007 Posthumus <etienne-AT-apple01.cs.vu.nl>.
5004
5008
5005 2003-12-09 Fernando Perez <fperez@colorado.edu>
5009 2003-12-09 Fernando Perez <fperez@colorado.edu>
5006
5010
5007 * IPython/genutils.py (page): patch for the pager to work across
5011 * IPython/genutils.py (page): patch for the pager to work across
5008 various versions of Windows. By Gary Bishop.
5012 various versions of Windows. By Gary Bishop.
5009
5013
5010 2003-12-04 Fernando Perez <fperez@colorado.edu>
5014 2003-12-04 Fernando Perez <fperez@colorado.edu>
5011
5015
5012 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
5016 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
5013 Gnuplot.py version 1.7, whose internal names changed quite a bit.
5017 Gnuplot.py version 1.7, whose internal names changed quite a bit.
5014 While I tested this and it looks ok, there may still be corner
5018 While I tested this and it looks ok, there may still be corner
5015 cases I've missed.
5019 cases I've missed.
5016
5020
5017 2003-12-01 Fernando Perez <fperez@colorado.edu>
5021 2003-12-01 Fernando Perez <fperez@colorado.edu>
5018
5022
5019 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
5023 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
5020 where a line like 'p,q=1,2' would fail because the automagic
5024 where a line like 'p,q=1,2' would fail because the automagic
5021 system would be triggered for @p.
5025 system would be triggered for @p.
5022
5026
5023 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
5027 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
5024 cleanups, code unmodified.
5028 cleanups, code unmodified.
5025
5029
5026 * IPython/genutils.py (Term): added a class for IPython to handle
5030 * IPython/genutils.py (Term): added a class for IPython to handle
5027 output. In most cases it will just be a proxy for stdout/err, but
5031 output. In most cases it will just be a proxy for stdout/err, but
5028 having this allows modifications to be made for some platforms,
5032 having this allows modifications to be made for some platforms,
5029 such as handling color escapes under Windows. All of this code
5033 such as handling color escapes under Windows. All of this code
5030 was contributed by Gary Bishop, with minor modifications by me.
5034 was contributed by Gary Bishop, with minor modifications by me.
5031 The actual changes affect many files.
5035 The actual changes affect many files.
5032
5036
5033 2003-11-30 Fernando Perez <fperez@colorado.edu>
5037 2003-11-30 Fernando Perez <fperez@colorado.edu>
5034
5038
5035 * IPython/iplib.py (file_matches): new completion code, courtesy
5039 * IPython/iplib.py (file_matches): new completion code, courtesy
5036 of Jeff Collins. This enables filename completion again under
5040 of Jeff Collins. This enables filename completion again under
5037 python 2.3, which disabled it at the C level.
5041 python 2.3, which disabled it at the C level.
5038
5042
5039 2003-11-11 Fernando Perez <fperez@colorado.edu>
5043 2003-11-11 Fernando Perez <fperez@colorado.edu>
5040
5044
5041 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
5045 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
5042 for Numeric.array(map(...)), but often convenient.
5046 for Numeric.array(map(...)), but often convenient.
5043
5047
5044 2003-11-05 Fernando Perez <fperez@colorado.edu>
5048 2003-11-05 Fernando Perez <fperez@colorado.edu>
5045
5049
5046 * IPython/numutils.py (frange): Changed a call from int() to
5050 * IPython/numutils.py (frange): Changed a call from int() to
5047 int(round()) to prevent a problem reported with arange() in the
5051 int(round()) to prevent a problem reported with arange() in the
5048 numpy list.
5052 numpy list.
5049
5053
5050 2003-10-06 Fernando Perez <fperez@colorado.edu>
5054 2003-10-06 Fernando Perez <fperez@colorado.edu>
5051
5055
5052 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
5056 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
5053 prevent crashes if sys lacks an argv attribute (it happens with
5057 prevent crashes if sys lacks an argv attribute (it happens with
5054 embedded interpreters which build a bare-bones sys module).
5058 embedded interpreters which build a bare-bones sys module).
5055 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
5059 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
5056
5060
5057 2003-09-24 Fernando Perez <fperez@colorado.edu>
5061 2003-09-24 Fernando Perez <fperez@colorado.edu>
5058
5062
5059 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
5063 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
5060 to protect against poorly written user objects where __getattr__
5064 to protect against poorly written user objects where __getattr__
5061 raises exceptions other than AttributeError. Thanks to a bug
5065 raises exceptions other than AttributeError. Thanks to a bug
5062 report by Oliver Sander <osander-AT-gmx.de>.
5066 report by Oliver Sander <osander-AT-gmx.de>.
5063
5067
5064 * IPython/FakeModule.py (FakeModule.__repr__): this method was
5068 * IPython/FakeModule.py (FakeModule.__repr__): this method was
5065 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
5069 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
5066
5070
5067 2003-09-09 Fernando Perez <fperez@colorado.edu>
5071 2003-09-09 Fernando Perez <fperez@colorado.edu>
5068
5072
5069 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
5073 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
5070 unpacking a list whith a callable as first element would
5074 unpacking a list whith a callable as first element would
5071 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
5075 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
5072 Collins.
5076 Collins.
5073
5077
5074 2003-08-25 *** Released version 0.5.0
5078 2003-08-25 *** Released version 0.5.0
5075
5079
5076 2003-08-22 Fernando Perez <fperez@colorado.edu>
5080 2003-08-22 Fernando Perez <fperez@colorado.edu>
5077
5081
5078 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
5082 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
5079 improperly defined user exceptions. Thanks to feedback from Mark
5083 improperly defined user exceptions. Thanks to feedback from Mark
5080 Russell <mrussell-AT-verio.net>.
5084 Russell <mrussell-AT-verio.net>.
5081
5085
5082 2003-08-20 Fernando Perez <fperez@colorado.edu>
5086 2003-08-20 Fernando Perez <fperez@colorado.edu>
5083
5087
5084 * IPython/OInspect.py (Inspector.pinfo): changed String Form
5088 * IPython/OInspect.py (Inspector.pinfo): changed String Form
5085 printing so that it would print multi-line string forms starting
5089 printing so that it would print multi-line string forms starting
5086 with a new line. This way the formatting is better respected for
5090 with a new line. This way the formatting is better respected for
5087 objects which work hard to make nice string forms.
5091 objects which work hard to make nice string forms.
5088
5092
5089 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
5093 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
5090 autocall would overtake data access for objects with both
5094 autocall would overtake data access for objects with both
5091 __getitem__ and __call__.
5095 __getitem__ and __call__.
5092
5096
5093 2003-08-19 *** Released version 0.5.0-rc1
5097 2003-08-19 *** Released version 0.5.0-rc1
5094
5098
5095 2003-08-19 Fernando Perez <fperez@colorado.edu>
5099 2003-08-19 Fernando Perez <fperez@colorado.edu>
5096
5100
5097 * IPython/deep_reload.py (load_tail): single tiny change here
5101 * IPython/deep_reload.py (load_tail): single tiny change here
5098 seems to fix the long-standing bug of dreload() failing to work
5102 seems to fix the long-standing bug of dreload() failing to work
5099 for dotted names. But this module is pretty tricky, so I may have
5103 for dotted names. But this module is pretty tricky, so I may have
5100 missed some subtlety. Needs more testing!.
5104 missed some subtlety. Needs more testing!.
5101
5105
5102 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
5106 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
5103 exceptions which have badly implemented __str__ methods.
5107 exceptions which have badly implemented __str__ methods.
5104 (VerboseTB.text): harden against inspect.getinnerframes crashing,
5108 (VerboseTB.text): harden against inspect.getinnerframes crashing,
5105 which I've been getting reports about from Python 2.3 users. I
5109 which I've been getting reports about from Python 2.3 users. I
5106 wish I had a simple test case to reproduce the problem, so I could
5110 wish I had a simple test case to reproduce the problem, so I could
5107 either write a cleaner workaround or file a bug report if
5111 either write a cleaner workaround or file a bug report if
5108 necessary.
5112 necessary.
5109
5113
5110 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
5114 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
5111 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
5115 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
5112 a bug report by Tjabo Kloppenburg.
5116 a bug report by Tjabo Kloppenburg.
5113
5117
5114 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
5118 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
5115 crashes. Wrapped the pdb call in a blanket try/except, since pdb
5119 crashes. Wrapped the pdb call in a blanket try/except, since pdb
5116 seems rather unstable. Thanks to a bug report by Tjabo
5120 seems rather unstable. Thanks to a bug report by Tjabo
5117 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
5121 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
5118
5122
5119 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
5123 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
5120 this out soon because of the critical fixes in the inner loop for
5124 this out soon because of the critical fixes in the inner loop for
5121 generators.
5125 generators.
5122
5126
5123 * IPython/Magic.py (Magic.getargspec): removed. This (and
5127 * IPython/Magic.py (Magic.getargspec): removed. This (and
5124 _get_def) have been obsoleted by OInspect for a long time, I
5128 _get_def) have been obsoleted by OInspect for a long time, I
5125 hadn't noticed that they were dead code.
5129 hadn't noticed that they were dead code.
5126 (Magic._ofind): restored _ofind functionality for a few literals
5130 (Magic._ofind): restored _ofind functionality for a few literals
5127 (those in ["''",'""','[]','{}','()']). But it won't work anymore
5131 (those in ["''",'""','[]','{}','()']). But it won't work anymore
5128 for things like "hello".capitalize?, since that would require a
5132 for things like "hello".capitalize?, since that would require a
5129 potentially dangerous eval() again.
5133 potentially dangerous eval() again.
5130
5134
5131 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
5135 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
5132 logic a bit more to clean up the escapes handling and minimize the
5136 logic a bit more to clean up the escapes handling and minimize the
5133 use of _ofind to only necessary cases. The interactive 'feel' of
5137 use of _ofind to only necessary cases. The interactive 'feel' of
5134 IPython should have improved quite a bit with the changes in
5138 IPython should have improved quite a bit with the changes in
5135 _prefilter and _ofind (besides being far safer than before).
5139 _prefilter and _ofind (besides being far safer than before).
5136
5140
5137 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
5141 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
5138 obscure, never reported). Edit would fail to find the object to
5142 obscure, never reported). Edit would fail to find the object to
5139 edit under some circumstances.
5143 edit under some circumstances.
5140 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
5144 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
5141 which were causing double-calling of generators. Those eval calls
5145 which were causing double-calling of generators. Those eval calls
5142 were _very_ dangerous, since code with side effects could be
5146 were _very_ dangerous, since code with side effects could be
5143 triggered. As they say, 'eval is evil'... These were the
5147 triggered. As they say, 'eval is evil'... These were the
5144 nastiest evals in IPython. Besides, _ofind is now far simpler,
5148 nastiest evals in IPython. Besides, _ofind is now far simpler,
5145 and it should also be quite a bit faster. Its use of inspect is
5149 and it should also be quite a bit faster. Its use of inspect is
5146 also safer, so perhaps some of the inspect-related crashes I've
5150 also safer, so perhaps some of the inspect-related crashes I've
5147 seen lately with Python 2.3 might be taken care of. That will
5151 seen lately with Python 2.3 might be taken care of. That will
5148 need more testing.
5152 need more testing.
5149
5153
5150 2003-08-17 Fernando Perez <fperez@colorado.edu>
5154 2003-08-17 Fernando Perez <fperez@colorado.edu>
5151
5155
5152 * IPython/iplib.py (InteractiveShell._prefilter): significant
5156 * IPython/iplib.py (InteractiveShell._prefilter): significant
5153 simplifications to the logic for handling user escapes. Faster
5157 simplifications to the logic for handling user escapes. Faster
5154 and simpler code.
5158 and simpler code.
5155
5159
5156 2003-08-14 Fernando Perez <fperez@colorado.edu>
5160 2003-08-14 Fernando Perez <fperez@colorado.edu>
5157
5161
5158 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
5162 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
5159 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
5163 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
5160 but it should be quite a bit faster. And the recursive version
5164 but it should be quite a bit faster. And the recursive version
5161 generated O(log N) intermediate storage for all rank>1 arrays,
5165 generated O(log N) intermediate storage for all rank>1 arrays,
5162 even if they were contiguous.
5166 even if they were contiguous.
5163 (l1norm): Added this function.
5167 (l1norm): Added this function.
5164 (norm): Added this function for arbitrary norms (including
5168 (norm): Added this function for arbitrary norms (including
5165 l-infinity). l1 and l2 are still special cases for convenience
5169 l-infinity). l1 and l2 are still special cases for convenience
5166 and speed.
5170 and speed.
5167
5171
5168 2003-08-03 Fernando Perez <fperez@colorado.edu>
5172 2003-08-03 Fernando Perez <fperez@colorado.edu>
5169
5173
5170 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
5174 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
5171 exceptions, which now raise PendingDeprecationWarnings in Python
5175 exceptions, which now raise PendingDeprecationWarnings in Python
5172 2.3. There were some in Magic and some in Gnuplot2.
5176 2.3. There were some in Magic and some in Gnuplot2.
5173
5177
5174 2003-06-30 Fernando Perez <fperez@colorado.edu>
5178 2003-06-30 Fernando Perez <fperez@colorado.edu>
5175
5179
5176 * IPython/genutils.py (page): modified to call curses only for
5180 * IPython/genutils.py (page): modified to call curses only for
5177 terminals where TERM=='xterm'. After problems under many other
5181 terminals where TERM=='xterm'. After problems under many other
5178 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
5182 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
5179
5183
5180 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
5184 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
5181 would be triggered when readline was absent. This was just an old
5185 would be triggered when readline was absent. This was just an old
5182 debugging statement I'd forgotten to take out.
5186 debugging statement I'd forgotten to take out.
5183
5187
5184 2003-06-20 Fernando Perez <fperez@colorado.edu>
5188 2003-06-20 Fernando Perez <fperez@colorado.edu>
5185
5189
5186 * IPython/genutils.py (clock): modified to return only user time
5190 * IPython/genutils.py (clock): modified to return only user time
5187 (not counting system time), after a discussion on scipy. While
5191 (not counting system time), after a discussion on scipy. While
5188 system time may be a useful quantity occasionally, it may much
5192 system time may be a useful quantity occasionally, it may much
5189 more easily be skewed by occasional swapping or other similar
5193 more easily be skewed by occasional swapping or other similar
5190 activity.
5194 activity.
5191
5195
5192 2003-06-05 Fernando Perez <fperez@colorado.edu>
5196 2003-06-05 Fernando Perez <fperez@colorado.edu>
5193
5197
5194 * IPython/numutils.py (identity): new function, for building
5198 * IPython/numutils.py (identity): new function, for building
5195 arbitrary rank Kronecker deltas (mostly backwards compatible with
5199 arbitrary rank Kronecker deltas (mostly backwards compatible with
5196 Numeric.identity)
5200 Numeric.identity)
5197
5201
5198 2003-06-03 Fernando Perez <fperez@colorado.edu>
5202 2003-06-03 Fernando Perez <fperez@colorado.edu>
5199
5203
5200 * IPython/iplib.py (InteractiveShell.handle_magic): protect
5204 * IPython/iplib.py (InteractiveShell.handle_magic): protect
5201 arguments passed to magics with spaces, to allow trailing '\' to
5205 arguments passed to magics with spaces, to allow trailing '\' to
5202 work normally (mainly for Windows users).
5206 work normally (mainly for Windows users).
5203
5207
5204 2003-05-29 Fernando Perez <fperez@colorado.edu>
5208 2003-05-29 Fernando Perez <fperez@colorado.edu>
5205
5209
5206 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
5210 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
5207 instead of pydoc.help. This fixes a bizarre behavior where
5211 instead of pydoc.help. This fixes a bizarre behavior where
5208 printing '%s' % locals() would trigger the help system. Now
5212 printing '%s' % locals() would trigger the help system. Now
5209 ipython behaves like normal python does.
5213 ipython behaves like normal python does.
5210
5214
5211 Note that if one does 'from pydoc import help', the bizarre
5215 Note that if one does 'from pydoc import help', the bizarre
5212 behavior returns, but this will also happen in normal python, so
5216 behavior returns, but this will also happen in normal python, so
5213 it's not an ipython bug anymore (it has to do with how pydoc.help
5217 it's not an ipython bug anymore (it has to do with how pydoc.help
5214 is implemented).
5218 is implemented).
5215
5219
5216 2003-05-22 Fernando Perez <fperez@colorado.edu>
5220 2003-05-22 Fernando Perez <fperez@colorado.edu>
5217
5221
5218 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
5222 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
5219 return [] instead of None when nothing matches, also match to end
5223 return [] instead of None when nothing matches, also match to end
5220 of line. Patch by Gary Bishop.
5224 of line. Patch by Gary Bishop.
5221
5225
5222 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
5226 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
5223 protection as before, for files passed on the command line. This
5227 protection as before, for files passed on the command line. This
5224 prevents the CrashHandler from kicking in if user files call into
5228 prevents the CrashHandler from kicking in if user files call into
5225 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
5229 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
5226 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
5230 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
5227
5231
5228 2003-05-20 *** Released version 0.4.0
5232 2003-05-20 *** Released version 0.4.0
5229
5233
5230 2003-05-20 Fernando Perez <fperez@colorado.edu>
5234 2003-05-20 Fernando Perez <fperez@colorado.edu>
5231
5235
5232 * setup.py: added support for manpages. It's a bit hackish b/c of
5236 * setup.py: added support for manpages. It's a bit hackish b/c of
5233 a bug in the way the bdist_rpm distutils target handles gzipped
5237 a bug in the way the bdist_rpm distutils target handles gzipped
5234 manpages, but it works. After a patch by Jack.
5238 manpages, but it works. After a patch by Jack.
5235
5239
5236 2003-05-19 Fernando Perez <fperez@colorado.edu>
5240 2003-05-19 Fernando Perez <fperez@colorado.edu>
5237
5241
5238 * IPython/numutils.py: added a mockup of the kinds module, since
5242 * IPython/numutils.py: added a mockup of the kinds module, since
5239 it was recently removed from Numeric. This way, numutils will
5243 it was recently removed from Numeric. This way, numutils will
5240 work for all users even if they are missing kinds.
5244 work for all users even if they are missing kinds.
5241
5245
5242 * IPython/Magic.py (Magic._ofind): Harden against an inspect
5246 * IPython/Magic.py (Magic._ofind): Harden against an inspect
5243 failure, which can occur with SWIG-wrapped extensions. After a
5247 failure, which can occur with SWIG-wrapped extensions. After a
5244 crash report from Prabhu.
5248 crash report from Prabhu.
5245
5249
5246 2003-05-16 Fernando Perez <fperez@colorado.edu>
5250 2003-05-16 Fernando Perez <fperez@colorado.edu>
5247
5251
5248 * IPython/iplib.py (InteractiveShell.excepthook): New method to
5252 * IPython/iplib.py (InteractiveShell.excepthook): New method to
5249 protect ipython from user code which may call directly
5253 protect ipython from user code which may call directly
5250 sys.excepthook (this looks like an ipython crash to the user, even
5254 sys.excepthook (this looks like an ipython crash to the user, even
5251 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
5255 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
5252 This is especially important to help users of WxWindows, but may
5256 This is especially important to help users of WxWindows, but may
5253 also be useful in other cases.
5257 also be useful in other cases.
5254
5258
5255 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
5259 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
5256 an optional tb_offset to be specified, and to preserve exception
5260 an optional tb_offset to be specified, and to preserve exception
5257 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
5261 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
5258
5262
5259 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
5263 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
5260
5264
5261 2003-05-15 Fernando Perez <fperez@colorado.edu>
5265 2003-05-15 Fernando Perez <fperez@colorado.edu>
5262
5266
5263 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
5267 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
5264 installing for a new user under Windows.
5268 installing for a new user under Windows.
5265
5269
5266 2003-05-12 Fernando Perez <fperez@colorado.edu>
5270 2003-05-12 Fernando Perez <fperez@colorado.edu>
5267
5271
5268 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
5272 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
5269 handler for Emacs comint-based lines. Currently it doesn't do
5273 handler for Emacs comint-based lines. Currently it doesn't do
5270 much (but importantly, it doesn't update the history cache). In
5274 much (but importantly, it doesn't update the history cache). In
5271 the future it may be expanded if Alex needs more functionality
5275 the future it may be expanded if Alex needs more functionality
5272 there.
5276 there.
5273
5277
5274 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
5278 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
5275 info to crash reports.
5279 info to crash reports.
5276
5280
5277 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
5281 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
5278 just like Python's -c. Also fixed crash with invalid -color
5282 just like Python's -c. Also fixed crash with invalid -color
5279 option value at startup. Thanks to Will French
5283 option value at startup. Thanks to Will French
5280 <wfrench-AT-bestweb.net> for the bug report.
5284 <wfrench-AT-bestweb.net> for the bug report.
5281
5285
5282 2003-05-09 Fernando Perez <fperez@colorado.edu>
5286 2003-05-09 Fernando Perez <fperez@colorado.edu>
5283
5287
5284 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
5288 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
5285 to EvalDict (it's a mapping, after all) and simplified its code
5289 to EvalDict (it's a mapping, after all) and simplified its code
5286 quite a bit, after a nice discussion on c.l.py where Gustavo
5290 quite a bit, after a nice discussion on c.l.py where Gustavo
5287 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
5291 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
5288
5292
5289 2003-04-30 Fernando Perez <fperez@colorado.edu>
5293 2003-04-30 Fernando Perez <fperez@colorado.edu>
5290
5294
5291 * IPython/genutils.py (timings_out): modified it to reduce its
5295 * IPython/genutils.py (timings_out): modified it to reduce its
5292 overhead in the common reps==1 case.
5296 overhead in the common reps==1 case.
5293
5297
5294 2003-04-29 Fernando Perez <fperez@colorado.edu>
5298 2003-04-29 Fernando Perez <fperez@colorado.edu>
5295
5299
5296 * IPython/genutils.py (timings_out): Modified to use the resource
5300 * IPython/genutils.py (timings_out): Modified to use the resource
5297 module, which avoids the wraparound problems of time.clock().
5301 module, which avoids the wraparound problems of time.clock().
5298
5302
5299 2003-04-17 *** Released version 0.2.15pre4
5303 2003-04-17 *** Released version 0.2.15pre4
5300
5304
5301 2003-04-17 Fernando Perez <fperez@colorado.edu>
5305 2003-04-17 Fernando Perez <fperez@colorado.edu>
5302
5306
5303 * setup.py (scriptfiles): Split windows-specific stuff over to a
5307 * setup.py (scriptfiles): Split windows-specific stuff over to a
5304 separate file, in an attempt to have a Windows GUI installer.
5308 separate file, in an attempt to have a Windows GUI installer.
5305 That didn't work, but part of the groundwork is done.
5309 That didn't work, but part of the groundwork is done.
5306
5310
5307 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
5311 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
5308 indent/unindent with 4 spaces. Particularly useful in combination
5312 indent/unindent with 4 spaces. Particularly useful in combination
5309 with the new auto-indent option.
5313 with the new auto-indent option.
5310
5314
5311 2003-04-16 Fernando Perez <fperez@colorado.edu>
5315 2003-04-16 Fernando Perez <fperez@colorado.edu>
5312
5316
5313 * IPython/Magic.py: various replacements of self.rc for
5317 * IPython/Magic.py: various replacements of self.rc for
5314 self.shell.rc. A lot more remains to be done to fully disentangle
5318 self.shell.rc. A lot more remains to be done to fully disentangle
5315 this class from the main Shell class.
5319 this class from the main Shell class.
5316
5320
5317 * IPython/GnuplotRuntime.py: added checks for mouse support so
5321 * IPython/GnuplotRuntime.py: added checks for mouse support so
5318 that we don't try to enable it if the current gnuplot doesn't
5322 that we don't try to enable it if the current gnuplot doesn't
5319 really support it. Also added checks so that we don't try to
5323 really support it. Also added checks so that we don't try to
5320 enable persist under Windows (where Gnuplot doesn't recognize the
5324 enable persist under Windows (where Gnuplot doesn't recognize the
5321 option).
5325 option).
5322
5326
5323 * IPython/iplib.py (InteractiveShell.interact): Added optional
5327 * IPython/iplib.py (InteractiveShell.interact): Added optional
5324 auto-indenting code, after a patch by King C. Shu
5328 auto-indenting code, after a patch by King C. Shu
5325 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
5329 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
5326 get along well with pasting indented code. If I ever figure out
5330 get along well with pasting indented code. If I ever figure out
5327 how to make that part go well, it will become on by default.
5331 how to make that part go well, it will become on by default.
5328
5332
5329 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
5333 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
5330 crash ipython if there was an unmatched '%' in the user's prompt
5334 crash ipython if there was an unmatched '%' in the user's prompt
5331 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5335 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5332
5336
5333 * IPython/iplib.py (InteractiveShell.interact): removed the
5337 * IPython/iplib.py (InteractiveShell.interact): removed the
5334 ability to ask the user whether he wants to crash or not at the
5338 ability to ask the user whether he wants to crash or not at the
5335 'last line' exception handler. Calling functions at that point
5339 'last line' exception handler. Calling functions at that point
5336 changes the stack, and the error reports would have incorrect
5340 changes the stack, and the error reports would have incorrect
5337 tracebacks.
5341 tracebacks.
5338
5342
5339 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
5343 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
5340 pass through a peger a pretty-printed form of any object. After a
5344 pass through a peger a pretty-printed form of any object. After a
5341 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
5345 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
5342
5346
5343 2003-04-14 Fernando Perez <fperez@colorado.edu>
5347 2003-04-14 Fernando Perez <fperez@colorado.edu>
5344
5348
5345 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
5349 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
5346 all files in ~ would be modified at first install (instead of
5350 all files in ~ would be modified at first install (instead of
5347 ~/.ipython). This could be potentially disastrous, as the
5351 ~/.ipython). This could be potentially disastrous, as the
5348 modification (make line-endings native) could damage binary files.
5352 modification (make line-endings native) could damage binary files.
5349
5353
5350 2003-04-10 Fernando Perez <fperez@colorado.edu>
5354 2003-04-10 Fernando Perez <fperez@colorado.edu>
5351
5355
5352 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
5356 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
5353 handle only lines which are invalid python. This now means that
5357 handle only lines which are invalid python. This now means that
5354 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
5358 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
5355 for the bug report.
5359 for the bug report.
5356
5360
5357 2003-04-01 Fernando Perez <fperez@colorado.edu>
5361 2003-04-01 Fernando Perez <fperez@colorado.edu>
5358
5362
5359 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
5363 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
5360 where failing to set sys.last_traceback would crash pdb.pm().
5364 where failing to set sys.last_traceback would crash pdb.pm().
5361 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
5365 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
5362 report.
5366 report.
5363
5367
5364 2003-03-25 Fernando Perez <fperez@colorado.edu>
5368 2003-03-25 Fernando Perez <fperez@colorado.edu>
5365
5369
5366 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
5370 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
5367 before printing it (it had a lot of spurious blank lines at the
5371 before printing it (it had a lot of spurious blank lines at the
5368 end).
5372 end).
5369
5373
5370 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
5374 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
5371 output would be sent 21 times! Obviously people don't use this
5375 output would be sent 21 times! Obviously people don't use this
5372 too often, or I would have heard about it.
5376 too often, or I would have heard about it.
5373
5377
5374 2003-03-24 Fernando Perez <fperez@colorado.edu>
5378 2003-03-24 Fernando Perez <fperez@colorado.edu>
5375
5379
5376 * setup.py (scriptfiles): renamed the data_files parameter from
5380 * setup.py (scriptfiles): renamed the data_files parameter from
5377 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
5381 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
5378 for the patch.
5382 for the patch.
5379
5383
5380 2003-03-20 Fernando Perez <fperez@colorado.edu>
5384 2003-03-20 Fernando Perez <fperez@colorado.edu>
5381
5385
5382 * IPython/genutils.py (error): added error() and fatal()
5386 * IPython/genutils.py (error): added error() and fatal()
5383 functions.
5387 functions.
5384
5388
5385 2003-03-18 *** Released version 0.2.15pre3
5389 2003-03-18 *** Released version 0.2.15pre3
5386
5390
5387 2003-03-18 Fernando Perez <fperez@colorado.edu>
5391 2003-03-18 Fernando Perez <fperez@colorado.edu>
5388
5392
5389 * setupext/install_data_ext.py
5393 * setupext/install_data_ext.py
5390 (install_data_ext.initialize_options): Class contributed by Jack
5394 (install_data_ext.initialize_options): Class contributed by Jack
5391 Moffit for fixing the old distutils hack. He is sending this to
5395 Moffit for fixing the old distutils hack. He is sending this to
5392 the distutils folks so in the future we may not need it as a
5396 the distutils folks so in the future we may not need it as a
5393 private fix.
5397 private fix.
5394
5398
5395 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
5399 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
5396 changes for Debian packaging. See his patch for full details.
5400 changes for Debian packaging. See his patch for full details.
5397 The old distutils hack of making the ipythonrc* files carry a
5401 The old distutils hack of making the ipythonrc* files carry a
5398 bogus .py extension is gone, at last. Examples were moved to a
5402 bogus .py extension is gone, at last. Examples were moved to a
5399 separate subdir under doc/, and the separate executable scripts
5403 separate subdir under doc/, and the separate executable scripts
5400 now live in their own directory. Overall a great cleanup. The
5404 now live in their own directory. Overall a great cleanup. The
5401 manual was updated to use the new files, and setup.py has been
5405 manual was updated to use the new files, and setup.py has been
5402 fixed for this setup.
5406 fixed for this setup.
5403
5407
5404 * IPython/PyColorize.py (Parser.usage): made non-executable and
5408 * IPython/PyColorize.py (Parser.usage): made non-executable and
5405 created a pycolor wrapper around it to be included as a script.
5409 created a pycolor wrapper around it to be included as a script.
5406
5410
5407 2003-03-12 *** Released version 0.2.15pre2
5411 2003-03-12 *** Released version 0.2.15pre2
5408
5412
5409 2003-03-12 Fernando Perez <fperez@colorado.edu>
5413 2003-03-12 Fernando Perez <fperez@colorado.edu>
5410
5414
5411 * IPython/ColorANSI.py (make_color_table): Finally fixed the
5415 * IPython/ColorANSI.py (make_color_table): Finally fixed the
5412 long-standing problem with garbage characters in some terminals.
5416 long-standing problem with garbage characters in some terminals.
5413 The issue was really that the \001 and \002 escapes must _only_ be
5417 The issue was really that the \001 and \002 escapes must _only_ be
5414 passed to input prompts (which call readline), but _never_ to
5418 passed to input prompts (which call readline), but _never_ to
5415 normal text to be printed on screen. I changed ColorANSI to have
5419 normal text to be printed on screen. I changed ColorANSI to have
5416 two classes: TermColors and InputTermColors, each with the
5420 two classes: TermColors and InputTermColors, each with the
5417 appropriate escapes for input prompts or normal text. The code in
5421 appropriate escapes for input prompts or normal text. The code in
5418 Prompts.py got slightly more complicated, but this very old and
5422 Prompts.py got slightly more complicated, but this very old and
5419 annoying bug is finally fixed.
5423 annoying bug is finally fixed.
5420
5424
5421 All the credit for nailing down the real origin of this problem
5425 All the credit for nailing down the real origin of this problem
5422 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
5426 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
5423 *Many* thanks to him for spending quite a bit of effort on this.
5427 *Many* thanks to him for spending quite a bit of effort on this.
5424
5428
5425 2003-03-05 *** Released version 0.2.15pre1
5429 2003-03-05 *** Released version 0.2.15pre1
5426
5430
5427 2003-03-03 Fernando Perez <fperez@colorado.edu>
5431 2003-03-03 Fernando Perez <fperez@colorado.edu>
5428
5432
5429 * IPython/FakeModule.py: Moved the former _FakeModule to a
5433 * IPython/FakeModule.py: Moved the former _FakeModule to a
5430 separate file, because it's also needed by Magic (to fix a similar
5434 separate file, because it's also needed by Magic (to fix a similar
5431 pickle-related issue in @run).
5435 pickle-related issue in @run).
5432
5436
5433 2003-03-02 Fernando Perez <fperez@colorado.edu>
5437 2003-03-02 Fernando Perez <fperez@colorado.edu>
5434
5438
5435 * IPython/Magic.py (Magic.magic_autocall): new magic to control
5439 * IPython/Magic.py (Magic.magic_autocall): new magic to control
5436 the autocall option at runtime.
5440 the autocall option at runtime.
5437 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
5441 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
5438 across Magic.py to start separating Magic from InteractiveShell.
5442 across Magic.py to start separating Magic from InteractiveShell.
5439 (Magic._ofind): Fixed to return proper namespace for dotted
5443 (Magic._ofind): Fixed to return proper namespace for dotted
5440 names. Before, a dotted name would always return 'not currently
5444 names. Before, a dotted name would always return 'not currently
5441 defined', because it would find the 'parent'. s.x would be found,
5445 defined', because it would find the 'parent'. s.x would be found,
5442 but since 'x' isn't defined by itself, it would get confused.
5446 but since 'x' isn't defined by itself, it would get confused.
5443 (Magic.magic_run): Fixed pickling problems reported by Ralf
5447 (Magic.magic_run): Fixed pickling problems reported by Ralf
5444 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
5448 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
5445 that I'd used when Mike Heeter reported similar issues at the
5449 that I'd used when Mike Heeter reported similar issues at the
5446 top-level, but now for @run. It boils down to injecting the
5450 top-level, but now for @run. It boils down to injecting the
5447 namespace where code is being executed with something that looks
5451 namespace where code is being executed with something that looks
5448 enough like a module to fool pickle.dump(). Since a pickle stores
5452 enough like a module to fool pickle.dump(). Since a pickle stores
5449 a named reference to the importing module, we need this for
5453 a named reference to the importing module, we need this for
5450 pickles to save something sensible.
5454 pickles to save something sensible.
5451
5455
5452 * IPython/ipmaker.py (make_IPython): added an autocall option.
5456 * IPython/ipmaker.py (make_IPython): added an autocall option.
5453
5457
5454 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
5458 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
5455 the auto-eval code. Now autocalling is an option, and the code is
5459 the auto-eval code. Now autocalling is an option, and the code is
5456 also vastly safer. There is no more eval() involved at all.
5460 also vastly safer. There is no more eval() involved at all.
5457
5461
5458 2003-03-01 Fernando Perez <fperez@colorado.edu>
5462 2003-03-01 Fernando Perez <fperez@colorado.edu>
5459
5463
5460 * IPython/Magic.py (Magic._ofind): Changed interface to return a
5464 * IPython/Magic.py (Magic._ofind): Changed interface to return a
5461 dict with named keys instead of a tuple.
5465 dict with named keys instead of a tuple.
5462
5466
5463 * IPython: Started using CVS for IPython as of 0.2.15pre1.
5467 * IPython: Started using CVS for IPython as of 0.2.15pre1.
5464
5468
5465 * setup.py (make_shortcut): Fixed message about directories
5469 * setup.py (make_shortcut): Fixed message about directories
5466 created during Windows installation (the directories were ok, just
5470 created during Windows installation (the directories were ok, just
5467 the printed message was misleading). Thanks to Chris Liechti
5471 the printed message was misleading). Thanks to Chris Liechti
5468 <cliechti-AT-gmx.net> for the heads up.
5472 <cliechti-AT-gmx.net> for the heads up.
5469
5473
5470 2003-02-21 Fernando Perez <fperez@colorado.edu>
5474 2003-02-21 Fernando Perez <fperez@colorado.edu>
5471
5475
5472 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
5476 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
5473 of ValueError exception when checking for auto-execution. This
5477 of ValueError exception when checking for auto-execution. This
5474 one is raised by things like Numeric arrays arr.flat when the
5478 one is raised by things like Numeric arrays arr.flat when the
5475 array is non-contiguous.
5479 array is non-contiguous.
5476
5480
5477 2003-01-31 Fernando Perez <fperez@colorado.edu>
5481 2003-01-31 Fernando Perez <fperez@colorado.edu>
5478
5482
5479 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
5483 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
5480 not return any value at all (even though the command would get
5484 not return any value at all (even though the command would get
5481 executed).
5485 executed).
5482 (xsys): Flush stdout right after printing the command to ensure
5486 (xsys): Flush stdout right after printing the command to ensure
5483 proper ordering of commands and command output in the total
5487 proper ordering of commands and command output in the total
5484 output.
5488 output.
5485 (SystemExec/xsys/bq): Switched the names of xsys/bq and
5489 (SystemExec/xsys/bq): Switched the names of xsys/bq and
5486 system/getoutput as defaults. The old ones are kept for
5490 system/getoutput as defaults. The old ones are kept for
5487 compatibility reasons, so no code which uses this library needs
5491 compatibility reasons, so no code which uses this library needs
5488 changing.
5492 changing.
5489
5493
5490 2003-01-27 *** Released version 0.2.14
5494 2003-01-27 *** Released version 0.2.14
5491
5495
5492 2003-01-25 Fernando Perez <fperez@colorado.edu>
5496 2003-01-25 Fernando Perez <fperez@colorado.edu>
5493
5497
5494 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
5498 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
5495 functions defined in previous edit sessions could not be re-edited
5499 functions defined in previous edit sessions could not be re-edited
5496 (because the temp files were immediately removed). Now temp files
5500 (because the temp files were immediately removed). Now temp files
5497 are removed only at IPython's exit.
5501 are removed only at IPython's exit.
5498 (Magic.magic_run): Improved @run to perform shell-like expansions
5502 (Magic.magic_run): Improved @run to perform shell-like expansions
5499 on its arguments (~users and $VARS). With this, @run becomes more
5503 on its arguments (~users and $VARS). With this, @run becomes more
5500 like a normal command-line.
5504 like a normal command-line.
5501
5505
5502 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
5506 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
5503 bugs related to embedding and cleaned up that code. A fairly
5507 bugs related to embedding and cleaned up that code. A fairly
5504 important one was the impossibility to access the global namespace
5508 important one was the impossibility to access the global namespace
5505 through the embedded IPython (only local variables were visible).
5509 through the embedded IPython (only local variables were visible).
5506
5510
5507 2003-01-14 Fernando Perez <fperez@colorado.edu>
5511 2003-01-14 Fernando Perez <fperez@colorado.edu>
5508
5512
5509 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
5513 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
5510 auto-calling to be a bit more conservative. Now it doesn't get
5514 auto-calling to be a bit more conservative. Now it doesn't get
5511 triggered if any of '!=()<>' are in the rest of the input line, to
5515 triggered if any of '!=()<>' are in the rest of the input line, to
5512 allow comparing callables. Thanks to Alex for the heads up.
5516 allow comparing callables. Thanks to Alex for the heads up.
5513
5517
5514 2003-01-07 Fernando Perez <fperez@colorado.edu>
5518 2003-01-07 Fernando Perez <fperez@colorado.edu>
5515
5519
5516 * IPython/genutils.py (page): fixed estimation of the number of
5520 * IPython/genutils.py (page): fixed estimation of the number of
5517 lines in a string to be paged to simply count newlines. This
5521 lines in a string to be paged to simply count newlines. This
5518 prevents over-guessing due to embedded escape sequences. A better
5522 prevents over-guessing due to embedded escape sequences. A better
5519 long-term solution would involve stripping out the control chars
5523 long-term solution would involve stripping out the control chars
5520 for the count, but it's potentially so expensive I just don't
5524 for the count, but it's potentially so expensive I just don't
5521 think it's worth doing.
5525 think it's worth doing.
5522
5526
5523 2002-12-19 *** Released version 0.2.14pre50
5527 2002-12-19 *** Released version 0.2.14pre50
5524
5528
5525 2002-12-19 Fernando Perez <fperez@colorado.edu>
5529 2002-12-19 Fernando Perez <fperez@colorado.edu>
5526
5530
5527 * tools/release (version): Changed release scripts to inform
5531 * tools/release (version): Changed release scripts to inform
5528 Andrea and build a NEWS file with a list of recent changes.
5532 Andrea and build a NEWS file with a list of recent changes.
5529
5533
5530 * IPython/ColorANSI.py (__all__): changed terminal detection
5534 * IPython/ColorANSI.py (__all__): changed terminal detection
5531 code. Seems to work better for xterms without breaking
5535 code. Seems to work better for xterms without breaking
5532 konsole. Will need more testing to determine if WinXP and Mac OSX
5536 konsole. Will need more testing to determine if WinXP and Mac OSX
5533 also work ok.
5537 also work ok.
5534
5538
5535 2002-12-18 *** Released version 0.2.14pre49
5539 2002-12-18 *** Released version 0.2.14pre49
5536
5540
5537 2002-12-18 Fernando Perez <fperez@colorado.edu>
5541 2002-12-18 Fernando Perez <fperez@colorado.edu>
5538
5542
5539 * Docs: added new info about Mac OSX, from Andrea.
5543 * Docs: added new info about Mac OSX, from Andrea.
5540
5544
5541 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
5545 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
5542 allow direct plotting of python strings whose format is the same
5546 allow direct plotting of python strings whose format is the same
5543 of gnuplot data files.
5547 of gnuplot data files.
5544
5548
5545 2002-12-16 Fernando Perez <fperez@colorado.edu>
5549 2002-12-16 Fernando Perez <fperez@colorado.edu>
5546
5550
5547 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
5551 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
5548 value of exit question to be acknowledged.
5552 value of exit question to be acknowledged.
5549
5553
5550 2002-12-03 Fernando Perez <fperez@colorado.edu>
5554 2002-12-03 Fernando Perez <fperez@colorado.edu>
5551
5555
5552 * IPython/ipmaker.py: removed generators, which had been added
5556 * IPython/ipmaker.py: removed generators, which had been added
5553 by mistake in an earlier debugging run. This was causing trouble
5557 by mistake in an earlier debugging run. This was causing trouble
5554 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
5558 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
5555 for pointing this out.
5559 for pointing this out.
5556
5560
5557 2002-11-17 Fernando Perez <fperez@colorado.edu>
5561 2002-11-17 Fernando Perez <fperez@colorado.edu>
5558
5562
5559 * Manual: updated the Gnuplot section.
5563 * Manual: updated the Gnuplot section.
5560
5564
5561 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
5565 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
5562 a much better split of what goes in Runtime and what goes in
5566 a much better split of what goes in Runtime and what goes in
5563 Interactive.
5567 Interactive.
5564
5568
5565 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
5569 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
5566 being imported from iplib.
5570 being imported from iplib.
5567
5571
5568 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
5572 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
5569 for command-passing. Now the global Gnuplot instance is called
5573 for command-passing. Now the global Gnuplot instance is called
5570 'gp' instead of 'g', which was really a far too fragile and
5574 'gp' instead of 'g', which was really a far too fragile and
5571 common name.
5575 common name.
5572
5576
5573 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
5577 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
5574 bounding boxes generated by Gnuplot for square plots.
5578 bounding boxes generated by Gnuplot for square plots.
5575
5579
5576 * IPython/genutils.py (popkey): new function added. I should
5580 * IPython/genutils.py (popkey): new function added. I should
5577 suggest this on c.l.py as a dict method, it seems useful.
5581 suggest this on c.l.py as a dict method, it seems useful.
5578
5582
5579 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
5583 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
5580 to transparently handle PostScript generation. MUCH better than
5584 to transparently handle PostScript generation. MUCH better than
5581 the previous plot_eps/replot_eps (which I removed now). The code
5585 the previous plot_eps/replot_eps (which I removed now). The code
5582 is also fairly clean and well documented now (including
5586 is also fairly clean and well documented now (including
5583 docstrings).
5587 docstrings).
5584
5588
5585 2002-11-13 Fernando Perez <fperez@colorado.edu>
5589 2002-11-13 Fernando Perez <fperez@colorado.edu>
5586
5590
5587 * IPython/Magic.py (Magic.magic_edit): fixed docstring
5591 * IPython/Magic.py (Magic.magic_edit): fixed docstring
5588 (inconsistent with options).
5592 (inconsistent with options).
5589
5593
5590 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
5594 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
5591 manually disabled, I don't know why. Fixed it.
5595 manually disabled, I don't know why. Fixed it.
5592 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
5596 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
5593 eps output.
5597 eps output.
5594
5598
5595 2002-11-12 Fernando Perez <fperez@colorado.edu>
5599 2002-11-12 Fernando Perez <fperez@colorado.edu>
5596
5600
5597 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
5601 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
5598 don't propagate up to caller. Fixes crash reported by François
5602 don't propagate up to caller. Fixes crash reported by François
5599 Pinard.
5603 Pinard.
5600
5604
5601 2002-11-09 Fernando Perez <fperez@colorado.edu>
5605 2002-11-09 Fernando Perez <fperez@colorado.edu>
5602
5606
5603 * IPython/ipmaker.py (make_IPython): fixed problem with writing
5607 * IPython/ipmaker.py (make_IPython): fixed problem with writing
5604 history file for new users.
5608 history file for new users.
5605 (make_IPython): fixed bug where initial install would leave the
5609 (make_IPython): fixed bug where initial install would leave the
5606 user running in the .ipython dir.
5610 user running in the .ipython dir.
5607 (make_IPython): fixed bug where config dir .ipython would be
5611 (make_IPython): fixed bug where config dir .ipython would be
5608 created regardless of the given -ipythondir option. Thanks to Cory
5612 created regardless of the given -ipythondir option. Thanks to Cory
5609 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
5613 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
5610
5614
5611 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
5615 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
5612 type confirmations. Will need to use it in all of IPython's code
5616 type confirmations. Will need to use it in all of IPython's code
5613 consistently.
5617 consistently.
5614
5618
5615 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
5619 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
5616 context to print 31 lines instead of the default 5. This will make
5620 context to print 31 lines instead of the default 5. This will make
5617 the crash reports extremely detailed in case the problem is in
5621 the crash reports extremely detailed in case the problem is in
5618 libraries I don't have access to.
5622 libraries I don't have access to.
5619
5623
5620 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
5624 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
5621 line of defense' code to still crash, but giving users fair
5625 line of defense' code to still crash, but giving users fair
5622 warning. I don't want internal errors to go unreported: if there's
5626 warning. I don't want internal errors to go unreported: if there's
5623 an internal problem, IPython should crash and generate a full
5627 an internal problem, IPython should crash and generate a full
5624 report.
5628 report.
5625
5629
5626 2002-11-08 Fernando Perez <fperez@colorado.edu>
5630 2002-11-08 Fernando Perez <fperez@colorado.edu>
5627
5631
5628 * IPython/iplib.py (InteractiveShell.interact): added code to trap
5632 * IPython/iplib.py (InteractiveShell.interact): added code to trap
5629 otherwise uncaught exceptions which can appear if people set
5633 otherwise uncaught exceptions which can appear if people set
5630 sys.stdout to something badly broken. Thanks to a crash report
5634 sys.stdout to something badly broken. Thanks to a crash report
5631 from henni-AT-mail.brainbot.com.
5635 from henni-AT-mail.brainbot.com.
5632
5636
5633 2002-11-04 Fernando Perez <fperez@colorado.edu>
5637 2002-11-04 Fernando Perez <fperez@colorado.edu>
5634
5638
5635 * IPython/iplib.py (InteractiveShell.interact): added
5639 * IPython/iplib.py (InteractiveShell.interact): added
5636 __IPYTHON__active to the builtins. It's a flag which goes on when
5640 __IPYTHON__active to the builtins. It's a flag which goes on when
5637 the interaction starts and goes off again when it stops. This
5641 the interaction starts and goes off again when it stops. This
5638 allows embedding code to detect being inside IPython. Before this
5642 allows embedding code to detect being inside IPython. Before this
5639 was done via __IPYTHON__, but that only shows that an IPython
5643 was done via __IPYTHON__, but that only shows that an IPython
5640 instance has been created.
5644 instance has been created.
5641
5645
5642 * IPython/Magic.py (Magic.magic_env): I realized that in a
5646 * IPython/Magic.py (Magic.magic_env): I realized that in a
5643 UserDict, instance.data holds the data as a normal dict. So I
5647 UserDict, instance.data holds the data as a normal dict. So I
5644 modified @env to return os.environ.data instead of rebuilding a
5648 modified @env to return os.environ.data instead of rebuilding a
5645 dict by hand.
5649 dict by hand.
5646
5650
5647 2002-11-02 Fernando Perez <fperez@colorado.edu>
5651 2002-11-02 Fernando Perez <fperez@colorado.edu>
5648
5652
5649 * IPython/genutils.py (warn): changed so that level 1 prints no
5653 * IPython/genutils.py (warn): changed so that level 1 prints no
5650 header. Level 2 is now the default (with 'WARNING' header, as
5654 header. Level 2 is now the default (with 'WARNING' header, as
5651 before). I think I tracked all places where changes were needed in
5655 before). I think I tracked all places where changes were needed in
5652 IPython, but outside code using the old level numbering may have
5656 IPython, but outside code using the old level numbering may have
5653 broken.
5657 broken.
5654
5658
5655 * IPython/iplib.py (InteractiveShell.runcode): added this to
5659 * IPython/iplib.py (InteractiveShell.runcode): added this to
5656 handle the tracebacks in SystemExit traps correctly. The previous
5660 handle the tracebacks in SystemExit traps correctly. The previous
5657 code (through interact) was printing more of the stack than
5661 code (through interact) was printing more of the stack than
5658 necessary, showing IPython internal code to the user.
5662 necessary, showing IPython internal code to the user.
5659
5663
5660 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
5664 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
5661 default. Now that the default at the confirmation prompt is yes,
5665 default. Now that the default at the confirmation prompt is yes,
5662 it's not so intrusive. François' argument that ipython sessions
5666 it's not so intrusive. François' argument that ipython sessions
5663 tend to be complex enough not to lose them from an accidental C-d,
5667 tend to be complex enough not to lose them from an accidental C-d,
5664 is a valid one.
5668 is a valid one.
5665
5669
5666 * IPython/iplib.py (InteractiveShell.interact): added a
5670 * IPython/iplib.py (InteractiveShell.interact): added a
5667 showtraceback() call to the SystemExit trap, and modified the exit
5671 showtraceback() call to the SystemExit trap, and modified the exit
5668 confirmation to have yes as the default.
5672 confirmation to have yes as the default.
5669
5673
5670 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
5674 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
5671 this file. It's been gone from the code for a long time, this was
5675 this file. It's been gone from the code for a long time, this was
5672 simply leftover junk.
5676 simply leftover junk.
5673
5677
5674 2002-11-01 Fernando Perez <fperez@colorado.edu>
5678 2002-11-01 Fernando Perez <fperez@colorado.edu>
5675
5679
5676 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
5680 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
5677 added. If set, IPython now traps EOF and asks for
5681 added. If set, IPython now traps EOF and asks for
5678 confirmation. After a request by François Pinard.
5682 confirmation. After a request by François Pinard.
5679
5683
5680 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
5684 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
5681 of @abort, and with a new (better) mechanism for handling the
5685 of @abort, and with a new (better) mechanism for handling the
5682 exceptions.
5686 exceptions.
5683
5687
5684 2002-10-27 Fernando Perez <fperez@colorado.edu>
5688 2002-10-27 Fernando Perez <fperez@colorado.edu>
5685
5689
5686 * IPython/usage.py (__doc__): updated the --help information and
5690 * IPython/usage.py (__doc__): updated the --help information and
5687 the ipythonrc file to indicate that -log generates
5691 the ipythonrc file to indicate that -log generates
5688 ./ipython.log. Also fixed the corresponding info in @logstart.
5692 ./ipython.log. Also fixed the corresponding info in @logstart.
5689 This and several other fixes in the manuals thanks to reports by
5693 This and several other fixes in the manuals thanks to reports by
5690 François Pinard <pinard-AT-iro.umontreal.ca>.
5694 François Pinard <pinard-AT-iro.umontreal.ca>.
5691
5695
5692 * IPython/Logger.py (Logger.switch_log): Fixed error message to
5696 * IPython/Logger.py (Logger.switch_log): Fixed error message to
5693 refer to @logstart (instead of @log, which doesn't exist).
5697 refer to @logstart (instead of @log, which doesn't exist).
5694
5698
5695 * IPython/iplib.py (InteractiveShell._prefilter): fixed
5699 * IPython/iplib.py (InteractiveShell._prefilter): fixed
5696 AttributeError crash. Thanks to Christopher Armstrong
5700 AttributeError crash. Thanks to Christopher Armstrong
5697 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
5701 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
5698 introduced recently (in 0.2.14pre37) with the fix to the eval
5702 introduced recently (in 0.2.14pre37) with the fix to the eval
5699 problem mentioned below.
5703 problem mentioned below.
5700
5704
5701 2002-10-17 Fernando Perez <fperez@colorado.edu>
5705 2002-10-17 Fernando Perez <fperez@colorado.edu>
5702
5706
5703 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
5707 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
5704 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
5708 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
5705
5709
5706 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
5710 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
5707 this function to fix a problem reported by Alex Schmolck. He saw
5711 this function to fix a problem reported by Alex Schmolck. He saw
5708 it with list comprehensions and generators, which were getting
5712 it with list comprehensions and generators, which were getting
5709 called twice. The real problem was an 'eval' call in testing for
5713 called twice. The real problem was an 'eval' call in testing for
5710 automagic which was evaluating the input line silently.
5714 automagic which was evaluating the input line silently.
5711
5715
5712 This is a potentially very nasty bug, if the input has side
5716 This is a potentially very nasty bug, if the input has side
5713 effects which must not be repeated. The code is much cleaner now,
5717 effects which must not be repeated. The code is much cleaner now,
5714 without any blanket 'except' left and with a regexp test for
5718 without any blanket 'except' left and with a regexp test for
5715 actual function names.
5719 actual function names.
5716
5720
5717 But an eval remains, which I'm not fully comfortable with. I just
5721 But an eval remains, which I'm not fully comfortable with. I just
5718 don't know how to find out if an expression could be a callable in
5722 don't know how to find out if an expression could be a callable in
5719 the user's namespace without doing an eval on the string. However
5723 the user's namespace without doing an eval on the string. However
5720 that string is now much more strictly checked so that no code
5724 that string is now much more strictly checked so that no code
5721 slips by, so the eval should only happen for things that can
5725 slips by, so the eval should only happen for things that can
5722 really be only function/method names.
5726 really be only function/method names.
5723
5727
5724 2002-10-15 Fernando Perez <fperez@colorado.edu>
5728 2002-10-15 Fernando Perez <fperez@colorado.edu>
5725
5729
5726 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
5730 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
5727 OSX information to main manual, removed README_Mac_OSX file from
5731 OSX information to main manual, removed README_Mac_OSX file from
5728 distribution. Also updated credits for recent additions.
5732 distribution. Also updated credits for recent additions.
5729
5733
5730 2002-10-10 Fernando Perez <fperez@colorado.edu>
5734 2002-10-10 Fernando Perez <fperez@colorado.edu>
5731
5735
5732 * README_Mac_OSX: Added a README for Mac OSX users for fixing
5736 * README_Mac_OSX: Added a README for Mac OSX users for fixing
5733 terminal-related issues. Many thanks to Andrea Riciputi
5737 terminal-related issues. Many thanks to Andrea Riciputi
5734 <andrea.riciputi-AT-libero.it> for writing it.
5738 <andrea.riciputi-AT-libero.it> for writing it.
5735
5739
5736 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
5740 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
5737 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5741 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5738
5742
5739 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
5743 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
5740 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
5744 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
5741 <syver-en-AT-online.no> who both submitted patches for this problem.
5745 <syver-en-AT-online.no> who both submitted patches for this problem.
5742
5746
5743 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
5747 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
5744 global embedding to make sure that things don't overwrite user
5748 global embedding to make sure that things don't overwrite user
5745 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
5749 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
5746
5750
5747 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
5751 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
5748 compatibility. Thanks to Hayden Callow
5752 compatibility. Thanks to Hayden Callow
5749 <h.callow-AT-elec.canterbury.ac.nz>
5753 <h.callow-AT-elec.canterbury.ac.nz>
5750
5754
5751 2002-10-04 Fernando Perez <fperez@colorado.edu>
5755 2002-10-04 Fernando Perez <fperez@colorado.edu>
5752
5756
5753 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
5757 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
5754 Gnuplot.File objects.
5758 Gnuplot.File objects.
5755
5759
5756 2002-07-23 Fernando Perez <fperez@colorado.edu>
5760 2002-07-23 Fernando Perez <fperez@colorado.edu>
5757
5761
5758 * IPython/genutils.py (timing): Added timings() and timing() for
5762 * IPython/genutils.py (timing): Added timings() and timing() for
5759 quick access to the most commonly needed data, the execution
5763 quick access to the most commonly needed data, the execution
5760 times. Old timing() renamed to timings_out().
5764 times. Old timing() renamed to timings_out().
5761
5765
5762 2002-07-18 Fernando Perez <fperez@colorado.edu>
5766 2002-07-18 Fernando Perez <fperez@colorado.edu>
5763
5767
5764 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
5768 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
5765 bug with nested instances disrupting the parent's tab completion.
5769 bug with nested instances disrupting the parent's tab completion.
5766
5770
5767 * IPython/iplib.py (all_completions): Added Alex Schmolck's
5771 * IPython/iplib.py (all_completions): Added Alex Schmolck's
5768 all_completions code to begin the emacs integration.
5772 all_completions code to begin the emacs integration.
5769
5773
5770 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
5774 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
5771 argument to allow titling individual arrays when plotting.
5775 argument to allow titling individual arrays when plotting.
5772
5776
5773 2002-07-15 Fernando Perez <fperez@colorado.edu>
5777 2002-07-15 Fernando Perez <fperez@colorado.edu>
5774
5778
5775 * setup.py (make_shortcut): changed to retrieve the value of
5779 * setup.py (make_shortcut): changed to retrieve the value of
5776 'Program Files' directory from the registry (this value changes in
5780 'Program Files' directory from the registry (this value changes in
5777 non-english versions of Windows). Thanks to Thomas Fanslau
5781 non-english versions of Windows). Thanks to Thomas Fanslau
5778 <tfanslau-AT-gmx.de> for the report.
5782 <tfanslau-AT-gmx.de> for the report.
5779
5783
5780 2002-07-10 Fernando Perez <fperez@colorado.edu>
5784 2002-07-10 Fernando Perez <fperez@colorado.edu>
5781
5785
5782 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5786 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5783 a bug in pdb, which crashes if a line with only whitespace is
5787 a bug in pdb, which crashes if a line with only whitespace is
5784 entered. Bug report submitted to sourceforge.
5788 entered. Bug report submitted to sourceforge.
5785
5789
5786 2002-07-09 Fernando Perez <fperez@colorado.edu>
5790 2002-07-09 Fernando Perez <fperez@colorado.edu>
5787
5791
5788 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5792 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5789 reporting exceptions (it's a bug in inspect.py, I just set a
5793 reporting exceptions (it's a bug in inspect.py, I just set a
5790 workaround).
5794 workaround).
5791
5795
5792 2002-07-08 Fernando Perez <fperez@colorado.edu>
5796 2002-07-08 Fernando Perez <fperez@colorado.edu>
5793
5797
5794 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5798 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5795 __IPYTHON__ in __builtins__ to show up in user_ns.
5799 __IPYTHON__ in __builtins__ to show up in user_ns.
5796
5800
5797 2002-07-03 Fernando Perez <fperez@colorado.edu>
5801 2002-07-03 Fernando Perez <fperez@colorado.edu>
5798
5802
5799 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5803 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5800 name from @gp_set_instance to @gp_set_default.
5804 name from @gp_set_instance to @gp_set_default.
5801
5805
5802 * IPython/ipmaker.py (make_IPython): default editor value set to
5806 * IPython/ipmaker.py (make_IPython): default editor value set to
5803 '0' (a string), to match the rc file. Otherwise will crash when
5807 '0' (a string), to match the rc file. Otherwise will crash when
5804 .strip() is called on it.
5808 .strip() is called on it.
5805
5809
5806
5810
5807 2002-06-28 Fernando Perez <fperez@colorado.edu>
5811 2002-06-28 Fernando Perez <fperez@colorado.edu>
5808
5812
5809 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5813 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5810 of files in current directory when a file is executed via
5814 of files in current directory when a file is executed via
5811 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5815 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5812
5816
5813 * setup.py (manfiles): fix for rpm builds, submitted by RA
5817 * setup.py (manfiles): fix for rpm builds, submitted by RA
5814 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5818 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5815
5819
5816 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5820 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5817 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5821 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5818 string!). A. Schmolck caught this one.
5822 string!). A. Schmolck caught this one.
5819
5823
5820 2002-06-27 Fernando Perez <fperez@colorado.edu>
5824 2002-06-27 Fernando Perez <fperez@colorado.edu>
5821
5825
5822 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5826 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5823 defined files at the cmd line. __name__ wasn't being set to
5827 defined files at the cmd line. __name__ wasn't being set to
5824 __main__.
5828 __main__.
5825
5829
5826 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5830 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5827 regular lists and tuples besides Numeric arrays.
5831 regular lists and tuples besides Numeric arrays.
5828
5832
5829 * IPython/Prompts.py (CachedOutput.__call__): Added output
5833 * IPython/Prompts.py (CachedOutput.__call__): Added output
5830 supression for input ending with ';'. Similar to Mathematica and
5834 supression for input ending with ';'. Similar to Mathematica and
5831 Matlab. The _* vars and Out[] list are still updated, just like
5835 Matlab. The _* vars and Out[] list are still updated, just like
5832 Mathematica behaves.
5836 Mathematica behaves.
5833
5837
5834 2002-06-25 Fernando Perez <fperez@colorado.edu>
5838 2002-06-25 Fernando Perez <fperez@colorado.edu>
5835
5839
5836 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5840 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5837 .ini extensions for profiels under Windows.
5841 .ini extensions for profiels under Windows.
5838
5842
5839 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5843 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5840 string form. Fix contributed by Alexander Schmolck
5844 string form. Fix contributed by Alexander Schmolck
5841 <a.schmolck-AT-gmx.net>
5845 <a.schmolck-AT-gmx.net>
5842
5846
5843 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5847 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5844 pre-configured Gnuplot instance.
5848 pre-configured Gnuplot instance.
5845
5849
5846 2002-06-21 Fernando Perez <fperez@colorado.edu>
5850 2002-06-21 Fernando Perez <fperez@colorado.edu>
5847
5851
5848 * IPython/numutils.py (exp_safe): new function, works around the
5852 * IPython/numutils.py (exp_safe): new function, works around the
5849 underflow problems in Numeric.
5853 underflow problems in Numeric.
5850 (log2): New fn. Safe log in base 2: returns exact integer answer
5854 (log2): New fn. Safe log in base 2: returns exact integer answer
5851 for exact integer powers of 2.
5855 for exact integer powers of 2.
5852
5856
5853 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5857 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5854 properly.
5858 properly.
5855
5859
5856 2002-06-20 Fernando Perez <fperez@colorado.edu>
5860 2002-06-20 Fernando Perez <fperez@colorado.edu>
5857
5861
5858 * IPython/genutils.py (timing): new function like
5862 * IPython/genutils.py (timing): new function like
5859 Mathematica's. Similar to time_test, but returns more info.
5863 Mathematica's. Similar to time_test, but returns more info.
5860
5864
5861 2002-06-18 Fernando Perez <fperez@colorado.edu>
5865 2002-06-18 Fernando Perez <fperez@colorado.edu>
5862
5866
5863 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5867 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5864 according to Mike Heeter's suggestions.
5868 according to Mike Heeter's suggestions.
5865
5869
5866 2002-06-16 Fernando Perez <fperez@colorado.edu>
5870 2002-06-16 Fernando Perez <fperez@colorado.edu>
5867
5871
5868 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5872 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5869 system. GnuplotMagic is gone as a user-directory option. New files
5873 system. GnuplotMagic is gone as a user-directory option. New files
5870 make it easier to use all the gnuplot stuff both from external
5874 make it easier to use all the gnuplot stuff both from external
5871 programs as well as from IPython. Had to rewrite part of
5875 programs as well as from IPython. Had to rewrite part of
5872 hardcopy() b/c of a strange bug: often the ps files simply don't
5876 hardcopy() b/c of a strange bug: often the ps files simply don't
5873 get created, and require a repeat of the command (often several
5877 get created, and require a repeat of the command (often several
5874 times).
5878 times).
5875
5879
5876 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5880 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5877 resolve output channel at call time, so that if sys.stderr has
5881 resolve output channel at call time, so that if sys.stderr has
5878 been redirected by user this gets honored.
5882 been redirected by user this gets honored.
5879
5883
5880 2002-06-13 Fernando Perez <fperez@colorado.edu>
5884 2002-06-13 Fernando Perez <fperez@colorado.edu>
5881
5885
5882 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5886 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5883 IPShell. Kept a copy with the old names to avoid breaking people's
5887 IPShell. Kept a copy with the old names to avoid breaking people's
5884 embedded code.
5888 embedded code.
5885
5889
5886 * IPython/ipython: simplified it to the bare minimum after
5890 * IPython/ipython: simplified it to the bare minimum after
5887 Holger's suggestions. Added info about how to use it in
5891 Holger's suggestions. Added info about how to use it in
5888 PYTHONSTARTUP.
5892 PYTHONSTARTUP.
5889
5893
5890 * IPython/Shell.py (IPythonShell): changed the options passing
5894 * IPython/Shell.py (IPythonShell): changed the options passing
5891 from a string with funky %s replacements to a straight list. Maybe
5895 from a string with funky %s replacements to a straight list. Maybe
5892 a bit more typing, but it follows sys.argv conventions, so there's
5896 a bit more typing, but it follows sys.argv conventions, so there's
5893 less special-casing to remember.
5897 less special-casing to remember.
5894
5898
5895 2002-06-12 Fernando Perez <fperez@colorado.edu>
5899 2002-06-12 Fernando Perez <fperez@colorado.edu>
5896
5900
5897 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5901 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5898 command. Thanks to a suggestion by Mike Heeter.
5902 command. Thanks to a suggestion by Mike Heeter.
5899 (Magic.magic_pfile): added behavior to look at filenames if given
5903 (Magic.magic_pfile): added behavior to look at filenames if given
5900 arg is not a defined object.
5904 arg is not a defined object.
5901 (Magic.magic_save): New @save function to save code snippets. Also
5905 (Magic.magic_save): New @save function to save code snippets. Also
5902 a Mike Heeter idea.
5906 a Mike Heeter idea.
5903
5907
5904 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5908 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5905 plot() and replot(). Much more convenient now, especially for
5909 plot() and replot(). Much more convenient now, especially for
5906 interactive use.
5910 interactive use.
5907
5911
5908 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5912 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5909 filenames.
5913 filenames.
5910
5914
5911 2002-06-02 Fernando Perez <fperez@colorado.edu>
5915 2002-06-02 Fernando Perez <fperez@colorado.edu>
5912
5916
5913 * IPython/Struct.py (Struct.__init__): modified to admit
5917 * IPython/Struct.py (Struct.__init__): modified to admit
5914 initialization via another struct.
5918 initialization via another struct.
5915
5919
5916 * IPython/genutils.py (SystemExec.__init__): New stateful
5920 * IPython/genutils.py (SystemExec.__init__): New stateful
5917 interface to xsys and bq. Useful for writing system scripts.
5921 interface to xsys and bq. Useful for writing system scripts.
5918
5922
5919 2002-05-30 Fernando Perez <fperez@colorado.edu>
5923 2002-05-30 Fernando Perez <fperez@colorado.edu>
5920
5924
5921 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5925 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5922 documents. This will make the user download smaller (it's getting
5926 documents. This will make the user download smaller (it's getting
5923 too big).
5927 too big).
5924
5928
5925 2002-05-29 Fernando Perez <fperez@colorado.edu>
5929 2002-05-29 Fernando Perez <fperez@colorado.edu>
5926
5930
5927 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5931 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5928 fix problems with shelve and pickle. Seems to work, but I don't
5932 fix problems with shelve and pickle. Seems to work, but I don't
5929 know if corner cases break it. Thanks to Mike Heeter
5933 know if corner cases break it. Thanks to Mike Heeter
5930 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5934 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5931
5935
5932 2002-05-24 Fernando Perez <fperez@colorado.edu>
5936 2002-05-24 Fernando Perez <fperez@colorado.edu>
5933
5937
5934 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5938 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5935 macros having broken.
5939 macros having broken.
5936
5940
5937 2002-05-21 Fernando Perez <fperez@colorado.edu>
5941 2002-05-21 Fernando Perez <fperez@colorado.edu>
5938
5942
5939 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5943 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5940 introduced logging bug: all history before logging started was
5944 introduced logging bug: all history before logging started was
5941 being written one character per line! This came from the redesign
5945 being written one character per line! This came from the redesign
5942 of the input history as a special list which slices to strings,
5946 of the input history as a special list which slices to strings,
5943 not to lists.
5947 not to lists.
5944
5948
5945 2002-05-20 Fernando Perez <fperez@colorado.edu>
5949 2002-05-20 Fernando Perez <fperez@colorado.edu>
5946
5950
5947 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5951 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5948 be an attribute of all classes in this module. The design of these
5952 be an attribute of all classes in this module. The design of these
5949 classes needs some serious overhauling.
5953 classes needs some serious overhauling.
5950
5954
5951 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5955 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5952 which was ignoring '_' in option names.
5956 which was ignoring '_' in option names.
5953
5957
5954 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5958 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5955 'Verbose_novars' to 'Context' and made it the new default. It's a
5959 'Verbose_novars' to 'Context' and made it the new default. It's a
5956 bit more readable and also safer than verbose.
5960 bit more readable and also safer than verbose.
5957
5961
5958 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5962 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5959 triple-quoted strings.
5963 triple-quoted strings.
5960
5964
5961 * IPython/OInspect.py (__all__): new module exposing the object
5965 * IPython/OInspect.py (__all__): new module exposing the object
5962 introspection facilities. Now the corresponding magics are dummy
5966 introspection facilities. Now the corresponding magics are dummy
5963 wrappers around this. Having this module will make it much easier
5967 wrappers around this. Having this module will make it much easier
5964 to put these functions into our modified pdb.
5968 to put these functions into our modified pdb.
5965 This new object inspector system uses the new colorizing module,
5969 This new object inspector system uses the new colorizing module,
5966 so source code and other things are nicely syntax highlighted.
5970 so source code and other things are nicely syntax highlighted.
5967
5971
5968 2002-05-18 Fernando Perez <fperez@colorado.edu>
5972 2002-05-18 Fernando Perez <fperez@colorado.edu>
5969
5973
5970 * IPython/ColorANSI.py: Split the coloring tools into a separate
5974 * IPython/ColorANSI.py: Split the coloring tools into a separate
5971 module so I can use them in other code easier (they were part of
5975 module so I can use them in other code easier (they were part of
5972 ultraTB).
5976 ultraTB).
5973
5977
5974 2002-05-17 Fernando Perez <fperez@colorado.edu>
5978 2002-05-17 Fernando Perez <fperez@colorado.edu>
5975
5979
5976 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5980 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5977 fixed it to set the global 'g' also to the called instance, as
5981 fixed it to set the global 'g' also to the called instance, as
5978 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5982 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5979 user's 'g' variables).
5983 user's 'g' variables).
5980
5984
5981 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5985 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5982 global variables (aliases to _ih,_oh) so that users which expect
5986 global variables (aliases to _ih,_oh) so that users which expect
5983 In[5] or Out[7] to work aren't unpleasantly surprised.
5987 In[5] or Out[7] to work aren't unpleasantly surprised.
5984 (InputList.__getslice__): new class to allow executing slices of
5988 (InputList.__getslice__): new class to allow executing slices of
5985 input history directly. Very simple class, complements the use of
5989 input history directly. Very simple class, complements the use of
5986 macros.
5990 macros.
5987
5991
5988 2002-05-16 Fernando Perez <fperez@colorado.edu>
5992 2002-05-16 Fernando Perez <fperez@colorado.edu>
5989
5993
5990 * setup.py (docdirbase): make doc directory be just doc/IPython
5994 * setup.py (docdirbase): make doc directory be just doc/IPython
5991 without version numbers, it will reduce clutter for users.
5995 without version numbers, it will reduce clutter for users.
5992
5996
5993 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5997 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5994 execfile call to prevent possible memory leak. See for details:
5998 execfile call to prevent possible memory leak. See for details:
5995 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5999 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5996
6000
5997 2002-05-15 Fernando Perez <fperez@colorado.edu>
6001 2002-05-15 Fernando Perez <fperez@colorado.edu>
5998
6002
5999 * IPython/Magic.py (Magic.magic_psource): made the object
6003 * IPython/Magic.py (Magic.magic_psource): made the object
6000 introspection names be more standard: pdoc, pdef, pfile and
6004 introspection names be more standard: pdoc, pdef, pfile and
6001 psource. They all print/page their output, and it makes
6005 psource. They all print/page their output, and it makes
6002 remembering them easier. Kept old names for compatibility as
6006 remembering them easier. Kept old names for compatibility as
6003 aliases.
6007 aliases.
6004
6008
6005 2002-05-14 Fernando Perez <fperez@colorado.edu>
6009 2002-05-14 Fernando Perez <fperez@colorado.edu>
6006
6010
6007 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
6011 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
6008 what the mouse problem was. The trick is to use gnuplot with temp
6012 what the mouse problem was. The trick is to use gnuplot with temp
6009 files and NOT with pipes (for data communication), because having
6013 files and NOT with pipes (for data communication), because having
6010 both pipes and the mouse on is bad news.
6014 both pipes and the mouse on is bad news.
6011
6015
6012 2002-05-13 Fernando Perez <fperez@colorado.edu>
6016 2002-05-13 Fernando Perez <fperez@colorado.edu>
6013
6017
6014 * IPython/Magic.py (Magic._ofind): fixed namespace order search
6018 * IPython/Magic.py (Magic._ofind): fixed namespace order search
6015 bug. Information would be reported about builtins even when
6019 bug. Information would be reported about builtins even when
6016 user-defined functions overrode them.
6020 user-defined functions overrode them.
6017
6021
6018 2002-05-11 Fernando Perez <fperez@colorado.edu>
6022 2002-05-11 Fernando Perez <fperez@colorado.edu>
6019
6023
6020 * IPython/__init__.py (__all__): removed FlexCompleter from
6024 * IPython/__init__.py (__all__): removed FlexCompleter from
6021 __all__ so that things don't fail in platforms without readline.
6025 __all__ so that things don't fail in platforms without readline.
6022
6026
6023 2002-05-10 Fernando Perez <fperez@colorado.edu>
6027 2002-05-10 Fernando Perez <fperez@colorado.edu>
6024
6028
6025 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
6029 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
6026 it requires Numeric, effectively making Numeric a dependency for
6030 it requires Numeric, effectively making Numeric a dependency for
6027 IPython.
6031 IPython.
6028
6032
6029 * Released 0.2.13
6033 * Released 0.2.13
6030
6034
6031 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
6035 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
6032 profiler interface. Now all the major options from the profiler
6036 profiler interface. Now all the major options from the profiler
6033 module are directly supported in IPython, both for single
6037 module are directly supported in IPython, both for single
6034 expressions (@prun) and for full programs (@run -p).
6038 expressions (@prun) and for full programs (@run -p).
6035
6039
6036 2002-05-09 Fernando Perez <fperez@colorado.edu>
6040 2002-05-09 Fernando Perez <fperez@colorado.edu>
6037
6041
6038 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
6042 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
6039 magic properly formatted for screen.
6043 magic properly formatted for screen.
6040
6044
6041 * setup.py (make_shortcut): Changed things to put pdf version in
6045 * setup.py (make_shortcut): Changed things to put pdf version in
6042 doc/ instead of doc/manual (had to change lyxport a bit).
6046 doc/ instead of doc/manual (had to change lyxport a bit).
6043
6047
6044 * IPython/Magic.py (Profile.string_stats): made profile runs go
6048 * IPython/Magic.py (Profile.string_stats): made profile runs go
6045 through pager (they are long and a pager allows searching, saving,
6049 through pager (they are long and a pager allows searching, saving,
6046 etc.)
6050 etc.)
6047
6051
6048 2002-05-08 Fernando Perez <fperez@colorado.edu>
6052 2002-05-08 Fernando Perez <fperez@colorado.edu>
6049
6053
6050 * Released 0.2.12
6054 * Released 0.2.12
6051
6055
6052 2002-05-06 Fernando Perez <fperez@colorado.edu>
6056 2002-05-06 Fernando Perez <fperez@colorado.edu>
6053
6057
6054 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
6058 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
6055 introduced); 'hist n1 n2' was broken.
6059 introduced); 'hist n1 n2' was broken.
6056 (Magic.magic_pdb): added optional on/off arguments to @pdb
6060 (Magic.magic_pdb): added optional on/off arguments to @pdb
6057 (Magic.magic_run): added option -i to @run, which executes code in
6061 (Magic.magic_run): added option -i to @run, which executes code in
6058 the IPython namespace instead of a clean one. Also added @irun as
6062 the IPython namespace instead of a clean one. Also added @irun as
6059 an alias to @run -i.
6063 an alias to @run -i.
6060
6064
6061 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
6065 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
6062 fixed (it didn't really do anything, the namespaces were wrong).
6066 fixed (it didn't really do anything, the namespaces were wrong).
6063
6067
6064 * IPython/Debugger.py (__init__): Added workaround for python 2.1
6068 * IPython/Debugger.py (__init__): Added workaround for python 2.1
6065
6069
6066 * IPython/__init__.py (__all__): Fixed package namespace, now
6070 * IPython/__init__.py (__all__): Fixed package namespace, now
6067 'import IPython' does give access to IPython.<all> as
6071 'import IPython' does give access to IPython.<all> as
6068 expected. Also renamed __release__ to Release.
6072 expected. Also renamed __release__ to Release.
6069
6073
6070 * IPython/Debugger.py (__license__): created new Pdb class which
6074 * IPython/Debugger.py (__license__): created new Pdb class which
6071 functions like a drop-in for the normal pdb.Pdb but does NOT
6075 functions like a drop-in for the normal pdb.Pdb but does NOT
6072 import readline by default. This way it doesn't muck up IPython's
6076 import readline by default. This way it doesn't muck up IPython's
6073 readline handling, and now tab-completion finally works in the
6077 readline handling, and now tab-completion finally works in the
6074 debugger -- sort of. It completes things globally visible, but the
6078 debugger -- sort of. It completes things globally visible, but the
6075 completer doesn't track the stack as pdb walks it. That's a bit
6079 completer doesn't track the stack as pdb walks it. That's a bit
6076 tricky, and I'll have to implement it later.
6080 tricky, and I'll have to implement it later.
6077
6081
6078 2002-05-05 Fernando Perez <fperez@colorado.edu>
6082 2002-05-05 Fernando Perez <fperez@colorado.edu>
6079
6083
6080 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
6084 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
6081 magic docstrings when printed via ? (explicit \'s were being
6085 magic docstrings when printed via ? (explicit \'s were being
6082 printed).
6086 printed).
6083
6087
6084 * IPython/ipmaker.py (make_IPython): fixed namespace
6088 * IPython/ipmaker.py (make_IPython): fixed namespace
6085 identification bug. Now variables loaded via logs or command-line
6089 identification bug. Now variables loaded via logs or command-line
6086 files are recognized in the interactive namespace by @who.
6090 files are recognized in the interactive namespace by @who.
6087
6091
6088 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
6092 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
6089 log replay system stemming from the string form of Structs.
6093 log replay system stemming from the string form of Structs.
6090
6094
6091 * IPython/Magic.py (Macro.__init__): improved macros to properly
6095 * IPython/Magic.py (Macro.__init__): improved macros to properly
6092 handle magic commands in them.
6096 handle magic commands in them.
6093 (Magic.magic_logstart): usernames are now expanded so 'logstart
6097 (Magic.magic_logstart): usernames are now expanded so 'logstart
6094 ~/mylog' now works.
6098 ~/mylog' now works.
6095
6099
6096 * IPython/iplib.py (complete): fixed bug where paths starting with
6100 * IPython/iplib.py (complete): fixed bug where paths starting with
6097 '/' would be completed as magic names.
6101 '/' would be completed as magic names.
6098
6102
6099 2002-05-04 Fernando Perez <fperez@colorado.edu>
6103 2002-05-04 Fernando Perez <fperez@colorado.edu>
6100
6104
6101 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
6105 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
6102 allow running full programs under the profiler's control.
6106 allow running full programs under the profiler's control.
6103
6107
6104 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
6108 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
6105 mode to report exceptions verbosely but without formatting
6109 mode to report exceptions verbosely but without formatting
6106 variables. This addresses the issue of ipython 'freezing' (it's
6110 variables. This addresses the issue of ipython 'freezing' (it's
6107 not frozen, but caught in an expensive formatting loop) when huge
6111 not frozen, but caught in an expensive formatting loop) when huge
6108 variables are in the context of an exception.
6112 variables are in the context of an exception.
6109 (VerboseTB.text): Added '--->' markers at line where exception was
6113 (VerboseTB.text): Added '--->' markers at line where exception was
6110 triggered. Much clearer to read, especially in NoColor modes.
6114 triggered. Much clearer to read, especially in NoColor modes.
6111
6115
6112 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
6116 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
6113 implemented in reverse when changing to the new parse_options().
6117 implemented in reverse when changing to the new parse_options().
6114
6118
6115 2002-05-03 Fernando Perez <fperez@colorado.edu>
6119 2002-05-03 Fernando Perez <fperez@colorado.edu>
6116
6120
6117 * IPython/Magic.py (Magic.parse_options): new function so that
6121 * IPython/Magic.py (Magic.parse_options): new function so that
6118 magics can parse options easier.
6122 magics can parse options easier.
6119 (Magic.magic_prun): new function similar to profile.run(),
6123 (Magic.magic_prun): new function similar to profile.run(),
6120 suggested by Chris Hart.
6124 suggested by Chris Hart.
6121 (Magic.magic_cd): fixed behavior so that it only changes if
6125 (Magic.magic_cd): fixed behavior so that it only changes if
6122 directory actually is in history.
6126 directory actually is in history.
6123
6127
6124 * IPython/usage.py (__doc__): added information about potential
6128 * IPython/usage.py (__doc__): added information about potential
6125 slowness of Verbose exception mode when there are huge data
6129 slowness of Verbose exception mode when there are huge data
6126 structures to be formatted (thanks to Archie Paulson).
6130 structures to be formatted (thanks to Archie Paulson).
6127
6131
6128 * IPython/ipmaker.py (make_IPython): Changed default logging
6132 * IPython/ipmaker.py (make_IPython): Changed default logging
6129 (when simply called with -log) to use curr_dir/ipython.log in
6133 (when simply called with -log) to use curr_dir/ipython.log in
6130 rotate mode. Fixed crash which was occuring with -log before
6134 rotate mode. Fixed crash which was occuring with -log before
6131 (thanks to Jim Boyle).
6135 (thanks to Jim Boyle).
6132
6136
6133 2002-05-01 Fernando Perez <fperez@colorado.edu>
6137 2002-05-01 Fernando Perez <fperez@colorado.edu>
6134
6138
6135 * Released 0.2.11 for these fixes (mainly the ultraTB one which
6139 * Released 0.2.11 for these fixes (mainly the ultraTB one which
6136 was nasty -- though somewhat of a corner case).
6140 was nasty -- though somewhat of a corner case).
6137
6141
6138 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
6142 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
6139 text (was a bug).
6143 text (was a bug).
6140
6144
6141 2002-04-30 Fernando Perez <fperez@colorado.edu>
6145 2002-04-30 Fernando Perez <fperez@colorado.edu>
6142
6146
6143 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
6147 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
6144 a print after ^D or ^C from the user so that the In[] prompt
6148 a print after ^D or ^C from the user so that the In[] prompt
6145 doesn't over-run the gnuplot one.
6149 doesn't over-run the gnuplot one.
6146
6150
6147 2002-04-29 Fernando Perez <fperez@colorado.edu>
6151 2002-04-29 Fernando Perez <fperez@colorado.edu>
6148
6152
6149 * Released 0.2.10
6153 * Released 0.2.10
6150
6154
6151 * IPython/__release__.py (version): get date dynamically.
6155 * IPython/__release__.py (version): get date dynamically.
6152
6156
6153 * Misc. documentation updates thanks to Arnd's comments. Also ran
6157 * Misc. documentation updates thanks to Arnd's comments. Also ran
6154 a full spellcheck on the manual (hadn't been done in a while).
6158 a full spellcheck on the manual (hadn't been done in a while).
6155
6159
6156 2002-04-27 Fernando Perez <fperez@colorado.edu>
6160 2002-04-27 Fernando Perez <fperez@colorado.edu>
6157
6161
6158 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
6162 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
6159 starting a log in mid-session would reset the input history list.
6163 starting a log in mid-session would reset the input history list.
6160
6164
6161 2002-04-26 Fernando Perez <fperez@colorado.edu>
6165 2002-04-26 Fernando Perez <fperez@colorado.edu>
6162
6166
6163 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
6167 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
6164 all files were being included in an update. Now anything in
6168 all files were being included in an update. Now anything in
6165 UserConfig that matches [A-Za-z]*.py will go (this excludes
6169 UserConfig that matches [A-Za-z]*.py will go (this excludes
6166 __init__.py)
6170 __init__.py)
6167
6171
6168 2002-04-25 Fernando Perez <fperez@colorado.edu>
6172 2002-04-25 Fernando Perez <fperez@colorado.edu>
6169
6173
6170 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
6174 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
6171 to __builtins__ so that any form of embedded or imported code can
6175 to __builtins__ so that any form of embedded or imported code can
6172 test for being inside IPython.
6176 test for being inside IPython.
6173
6177
6174 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
6178 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
6175 changed to GnuplotMagic because it's now an importable module,
6179 changed to GnuplotMagic because it's now an importable module,
6176 this makes the name follow that of the standard Gnuplot module.
6180 this makes the name follow that of the standard Gnuplot module.
6177 GnuplotMagic can now be loaded at any time in mid-session.
6181 GnuplotMagic can now be loaded at any time in mid-session.
6178
6182
6179 2002-04-24 Fernando Perez <fperez@colorado.edu>
6183 2002-04-24 Fernando Perez <fperez@colorado.edu>
6180
6184
6181 * IPython/numutils.py: removed SIUnits. It doesn't properly set
6185 * IPython/numutils.py: removed SIUnits. It doesn't properly set
6182 the globals (IPython has its own namespace) and the
6186 the globals (IPython has its own namespace) and the
6183 PhysicalQuantity stuff is much better anyway.
6187 PhysicalQuantity stuff is much better anyway.
6184
6188
6185 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
6189 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
6186 embedding example to standard user directory for
6190 embedding example to standard user directory for
6187 distribution. Also put it in the manual.
6191 distribution. Also put it in the manual.
6188
6192
6189 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
6193 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
6190 instance as first argument (so it doesn't rely on some obscure
6194 instance as first argument (so it doesn't rely on some obscure
6191 hidden global).
6195 hidden global).
6192
6196
6193 * IPython/UserConfig/ipythonrc.py: put () back in accepted
6197 * IPython/UserConfig/ipythonrc.py: put () back in accepted
6194 delimiters. While it prevents ().TAB from working, it allows
6198 delimiters. While it prevents ().TAB from working, it allows
6195 completions in open (... expressions. This is by far a more common
6199 completions in open (... expressions. This is by far a more common
6196 case.
6200 case.
6197
6201
6198 2002-04-23 Fernando Perez <fperez@colorado.edu>
6202 2002-04-23 Fernando Perez <fperez@colorado.edu>
6199
6203
6200 * IPython/Extensions/InterpreterPasteInput.py: new
6204 * IPython/Extensions/InterpreterPasteInput.py: new
6201 syntax-processing module for pasting lines with >>> or ... at the
6205 syntax-processing module for pasting lines with >>> or ... at the
6202 start.
6206 start.
6203
6207
6204 * IPython/Extensions/PhysicalQ_Interactive.py
6208 * IPython/Extensions/PhysicalQ_Interactive.py
6205 (PhysicalQuantityInteractive.__int__): fixed to work with either
6209 (PhysicalQuantityInteractive.__int__): fixed to work with either
6206 Numeric or math.
6210 Numeric or math.
6207
6211
6208 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
6212 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
6209 provided profiles. Now we have:
6213 provided profiles. Now we have:
6210 -math -> math module as * and cmath with its own namespace.
6214 -math -> math module as * and cmath with its own namespace.
6211 -numeric -> Numeric as *, plus gnuplot & grace
6215 -numeric -> Numeric as *, plus gnuplot & grace
6212 -physics -> same as before
6216 -physics -> same as before
6213
6217
6214 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
6218 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
6215 user-defined magics wouldn't be found by @magic if they were
6219 user-defined magics wouldn't be found by @magic if they were
6216 defined as class methods. Also cleaned up the namespace search
6220 defined as class methods. Also cleaned up the namespace search
6217 logic and the string building (to use %s instead of many repeated
6221 logic and the string building (to use %s instead of many repeated
6218 string adds).
6222 string adds).
6219
6223
6220 * IPython/UserConfig/example-magic.py (magic_foo): updated example
6224 * IPython/UserConfig/example-magic.py (magic_foo): updated example
6221 of user-defined magics to operate with class methods (cleaner, in
6225 of user-defined magics to operate with class methods (cleaner, in
6222 line with the gnuplot code).
6226 line with the gnuplot code).
6223
6227
6224 2002-04-22 Fernando Perez <fperez@colorado.edu>
6228 2002-04-22 Fernando Perez <fperez@colorado.edu>
6225
6229
6226 * setup.py: updated dependency list so that manual is updated when
6230 * setup.py: updated dependency list so that manual is updated when
6227 all included files change.
6231 all included files change.
6228
6232
6229 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
6233 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
6230 the delimiter removal option (the fix is ugly right now).
6234 the delimiter removal option (the fix is ugly right now).
6231
6235
6232 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
6236 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
6233 all of the math profile (quicker loading, no conflict between
6237 all of the math profile (quicker loading, no conflict between
6234 g-9.8 and g-gnuplot).
6238 g-9.8 and g-gnuplot).
6235
6239
6236 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
6240 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
6237 name of post-mortem files to IPython_crash_report.txt.
6241 name of post-mortem files to IPython_crash_report.txt.
6238
6242
6239 * Cleanup/update of the docs. Added all the new readline info and
6243 * Cleanup/update of the docs. Added all the new readline info and
6240 formatted all lists as 'real lists'.
6244 formatted all lists as 'real lists'.
6241
6245
6242 * IPython/ipmaker.py (make_IPython): removed now-obsolete
6246 * IPython/ipmaker.py (make_IPython): removed now-obsolete
6243 tab-completion options, since the full readline parse_and_bind is
6247 tab-completion options, since the full readline parse_and_bind is
6244 now accessible.
6248 now accessible.
6245
6249
6246 * IPython/iplib.py (InteractiveShell.init_readline): Changed
6250 * IPython/iplib.py (InteractiveShell.init_readline): Changed
6247 handling of readline options. Now users can specify any string to
6251 handling of readline options. Now users can specify any string to
6248 be passed to parse_and_bind(), as well as the delimiters to be
6252 be passed to parse_and_bind(), as well as the delimiters to be
6249 removed.
6253 removed.
6250 (InteractiveShell.__init__): Added __name__ to the global
6254 (InteractiveShell.__init__): Added __name__ to the global
6251 namespace so that things like Itpl which rely on its existence
6255 namespace so that things like Itpl which rely on its existence
6252 don't crash.
6256 don't crash.
6253 (InteractiveShell._prefilter): Defined the default with a _ so
6257 (InteractiveShell._prefilter): Defined the default with a _ so
6254 that prefilter() is easier to override, while the default one
6258 that prefilter() is easier to override, while the default one
6255 remains available.
6259 remains available.
6256
6260
6257 2002-04-18 Fernando Perez <fperez@colorado.edu>
6261 2002-04-18 Fernando Perez <fperez@colorado.edu>
6258
6262
6259 * Added information about pdb in the docs.
6263 * Added information about pdb in the docs.
6260
6264
6261 2002-04-17 Fernando Perez <fperez@colorado.edu>
6265 2002-04-17 Fernando Perez <fperez@colorado.edu>
6262
6266
6263 * IPython/ipmaker.py (make_IPython): added rc_override option to
6267 * IPython/ipmaker.py (make_IPython): added rc_override option to
6264 allow passing config options at creation time which may override
6268 allow passing config options at creation time which may override
6265 anything set in the config files or command line. This is
6269 anything set in the config files or command line. This is
6266 particularly useful for configuring embedded instances.
6270 particularly useful for configuring embedded instances.
6267
6271
6268 2002-04-15 Fernando Perez <fperez@colorado.edu>
6272 2002-04-15 Fernando Perez <fperez@colorado.edu>
6269
6273
6270 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
6274 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
6271 crash embedded instances because of the input cache falling out of
6275 crash embedded instances because of the input cache falling out of
6272 sync with the output counter.
6276 sync with the output counter.
6273
6277
6274 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
6278 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
6275 mode which calls pdb after an uncaught exception in IPython itself.
6279 mode which calls pdb after an uncaught exception in IPython itself.
6276
6280
6277 2002-04-14 Fernando Perez <fperez@colorado.edu>
6281 2002-04-14 Fernando Perez <fperez@colorado.edu>
6278
6282
6279 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
6283 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
6280 readline, fix it back after each call.
6284 readline, fix it back after each call.
6281
6285
6282 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
6286 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
6283 method to force all access via __call__(), which guarantees that
6287 method to force all access via __call__(), which guarantees that
6284 traceback references are properly deleted.
6288 traceback references are properly deleted.
6285
6289
6286 * IPython/Prompts.py (CachedOutput._display): minor fixes to
6290 * IPython/Prompts.py (CachedOutput._display): minor fixes to
6287 improve printing when pprint is in use.
6291 improve printing when pprint is in use.
6288
6292
6289 2002-04-13 Fernando Perez <fperez@colorado.edu>
6293 2002-04-13 Fernando Perez <fperez@colorado.edu>
6290
6294
6291 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
6295 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
6292 exceptions aren't caught anymore. If the user triggers one, he
6296 exceptions aren't caught anymore. If the user triggers one, he
6293 should know why he's doing it and it should go all the way up,
6297 should know why he's doing it and it should go all the way up,
6294 just like any other exception. So now @abort will fully kill the
6298 just like any other exception. So now @abort will fully kill the
6295 embedded interpreter and the embedding code (unless that happens
6299 embedded interpreter and the embedding code (unless that happens
6296 to catch SystemExit).
6300 to catch SystemExit).
6297
6301
6298 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
6302 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
6299 and a debugger() method to invoke the interactive pdb debugger
6303 and a debugger() method to invoke the interactive pdb debugger
6300 after printing exception information. Also added the corresponding
6304 after printing exception information. Also added the corresponding
6301 -pdb option and @pdb magic to control this feature, and updated
6305 -pdb option and @pdb magic to control this feature, and updated
6302 the docs. After a suggestion from Christopher Hart
6306 the docs. After a suggestion from Christopher Hart
6303 (hart-AT-caltech.edu).
6307 (hart-AT-caltech.edu).
6304
6308
6305 2002-04-12 Fernando Perez <fperez@colorado.edu>
6309 2002-04-12 Fernando Perez <fperez@colorado.edu>
6306
6310
6307 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
6311 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
6308 the exception handlers defined by the user (not the CrashHandler)
6312 the exception handlers defined by the user (not the CrashHandler)
6309 so that user exceptions don't trigger an ipython bug report.
6313 so that user exceptions don't trigger an ipython bug report.
6310
6314
6311 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
6315 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
6312 configurable (it should have always been so).
6316 configurable (it should have always been so).
6313
6317
6314 2002-03-26 Fernando Perez <fperez@colorado.edu>
6318 2002-03-26 Fernando Perez <fperez@colorado.edu>
6315
6319
6316 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
6320 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
6317 and there to fix embedding namespace issues. This should all be
6321 and there to fix embedding namespace issues. This should all be
6318 done in a more elegant way.
6322 done in a more elegant way.
6319
6323
6320 2002-03-25 Fernando Perez <fperez@colorado.edu>
6324 2002-03-25 Fernando Perez <fperez@colorado.edu>
6321
6325
6322 * IPython/genutils.py (get_home_dir): Try to make it work under
6326 * IPython/genutils.py (get_home_dir): Try to make it work under
6323 win9x also.
6327 win9x also.
6324
6328
6325 2002-03-20 Fernando Perez <fperez@colorado.edu>
6329 2002-03-20 Fernando Perez <fperez@colorado.edu>
6326
6330
6327 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
6331 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
6328 sys.displayhook untouched upon __init__.
6332 sys.displayhook untouched upon __init__.
6329
6333
6330 2002-03-19 Fernando Perez <fperez@colorado.edu>
6334 2002-03-19 Fernando Perez <fperez@colorado.edu>
6331
6335
6332 * Released 0.2.9 (for embedding bug, basically).
6336 * Released 0.2.9 (for embedding bug, basically).
6333
6337
6334 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
6338 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
6335 exceptions so that enclosing shell's state can be restored.
6339 exceptions so that enclosing shell's state can be restored.
6336
6340
6337 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
6341 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
6338 naming conventions in the .ipython/ dir.
6342 naming conventions in the .ipython/ dir.
6339
6343
6340 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
6344 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
6341 from delimiters list so filenames with - in them get expanded.
6345 from delimiters list so filenames with - in them get expanded.
6342
6346
6343 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
6347 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
6344 sys.displayhook not being properly restored after an embedded call.
6348 sys.displayhook not being properly restored after an embedded call.
6345
6349
6346 2002-03-18 Fernando Perez <fperez@colorado.edu>
6350 2002-03-18 Fernando Perez <fperez@colorado.edu>
6347
6351
6348 * Released 0.2.8
6352 * Released 0.2.8
6349
6353
6350 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
6354 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
6351 some files weren't being included in a -upgrade.
6355 some files weren't being included in a -upgrade.
6352 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
6356 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
6353 on' so that the first tab completes.
6357 on' so that the first tab completes.
6354 (InteractiveShell.handle_magic): fixed bug with spaces around
6358 (InteractiveShell.handle_magic): fixed bug with spaces around
6355 quotes breaking many magic commands.
6359 quotes breaking many magic commands.
6356
6360
6357 * setup.py: added note about ignoring the syntax error messages at
6361 * setup.py: added note about ignoring the syntax error messages at
6358 installation.
6362 installation.
6359
6363
6360 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
6364 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
6361 streamlining the gnuplot interface, now there's only one magic @gp.
6365 streamlining the gnuplot interface, now there's only one magic @gp.
6362
6366
6363 2002-03-17 Fernando Perez <fperez@colorado.edu>
6367 2002-03-17 Fernando Perez <fperez@colorado.edu>
6364
6368
6365 * IPython/UserConfig/magic_gnuplot.py: new name for the
6369 * IPython/UserConfig/magic_gnuplot.py: new name for the
6366 example-magic_pm.py file. Much enhanced system, now with a shell
6370 example-magic_pm.py file. Much enhanced system, now with a shell
6367 for communicating directly with gnuplot, one command at a time.
6371 for communicating directly with gnuplot, one command at a time.
6368
6372
6369 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
6373 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
6370 setting __name__=='__main__'.
6374 setting __name__=='__main__'.
6371
6375
6372 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
6376 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
6373 mini-shell for accessing gnuplot from inside ipython. Should
6377 mini-shell for accessing gnuplot from inside ipython. Should
6374 extend it later for grace access too. Inspired by Arnd's
6378 extend it later for grace access too. Inspired by Arnd's
6375 suggestion.
6379 suggestion.
6376
6380
6377 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
6381 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
6378 calling magic functions with () in their arguments. Thanks to Arnd
6382 calling magic functions with () in their arguments. Thanks to Arnd
6379 Baecker for pointing this to me.
6383 Baecker for pointing this to me.
6380
6384
6381 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
6385 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
6382 infinitely for integer or complex arrays (only worked with floats).
6386 infinitely for integer or complex arrays (only worked with floats).
6383
6387
6384 2002-03-16 Fernando Perez <fperez@colorado.edu>
6388 2002-03-16 Fernando Perez <fperez@colorado.edu>
6385
6389
6386 * setup.py: Merged setup and setup_windows into a single script
6390 * setup.py: Merged setup and setup_windows into a single script
6387 which properly handles things for windows users.
6391 which properly handles things for windows users.
6388
6392
6389 2002-03-15 Fernando Perez <fperez@colorado.edu>
6393 2002-03-15 Fernando Perez <fperez@colorado.edu>
6390
6394
6391 * Big change to the manual: now the magics are all automatically
6395 * Big change to the manual: now the magics are all automatically
6392 documented. This information is generated from their docstrings
6396 documented. This information is generated from their docstrings
6393 and put in a latex file included by the manual lyx file. This way
6397 and put in a latex file included by the manual lyx file. This way
6394 we get always up to date information for the magics. The manual
6398 we get always up to date information for the magics. The manual
6395 now also has proper version information, also auto-synced.
6399 now also has proper version information, also auto-synced.
6396
6400
6397 For this to work, an undocumented --magic_docstrings option was added.
6401 For this to work, an undocumented --magic_docstrings option was added.
6398
6402
6399 2002-03-13 Fernando Perez <fperez@colorado.edu>
6403 2002-03-13 Fernando Perez <fperez@colorado.edu>
6400
6404
6401 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
6405 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
6402 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
6406 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
6403
6407
6404 2002-03-12 Fernando Perez <fperez@colorado.edu>
6408 2002-03-12 Fernando Perez <fperez@colorado.edu>
6405
6409
6406 * IPython/ultraTB.py (TermColors): changed color escapes again to
6410 * IPython/ultraTB.py (TermColors): changed color escapes again to
6407 fix the (old, reintroduced) line-wrapping bug. Basically, if
6411 fix the (old, reintroduced) line-wrapping bug. Basically, if
6408 \001..\002 aren't given in the color escapes, lines get wrapped
6412 \001..\002 aren't given in the color escapes, lines get wrapped
6409 weirdly. But giving those screws up old xterms and emacs terms. So
6413 weirdly. But giving those screws up old xterms and emacs terms. So
6410 I added some logic for emacs terms to be ok, but I can't identify old
6414 I added some logic for emacs terms to be ok, but I can't identify old
6411 xterms separately ($TERM=='xterm' for many terminals, like konsole).
6415 xterms separately ($TERM=='xterm' for many terminals, like konsole).
6412
6416
6413 2002-03-10 Fernando Perez <fperez@colorado.edu>
6417 2002-03-10 Fernando Perez <fperez@colorado.edu>
6414
6418
6415 * IPython/usage.py (__doc__): Various documentation cleanups and
6419 * IPython/usage.py (__doc__): Various documentation cleanups and
6416 updates, both in usage docstrings and in the manual.
6420 updates, both in usage docstrings and in the manual.
6417
6421
6418 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
6422 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
6419 handling of caching. Set minimum acceptabe value for having a
6423 handling of caching. Set minimum acceptabe value for having a
6420 cache at 20 values.
6424 cache at 20 values.
6421
6425
6422 * IPython/iplib.py (InteractiveShell.user_setup): moved the
6426 * IPython/iplib.py (InteractiveShell.user_setup): moved the
6423 install_first_time function to a method, renamed it and added an
6427 install_first_time function to a method, renamed it and added an
6424 'upgrade' mode. Now people can update their config directory with
6428 'upgrade' mode. Now people can update their config directory with
6425 a simple command line switch (-upgrade, also new).
6429 a simple command line switch (-upgrade, also new).
6426
6430
6427 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
6431 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
6428 @file (convenient for automagic users under Python >= 2.2).
6432 @file (convenient for automagic users under Python >= 2.2).
6429 Removed @files (it seemed more like a plural than an abbrev. of
6433 Removed @files (it seemed more like a plural than an abbrev. of
6430 'file show').
6434 'file show').
6431
6435
6432 * IPython/iplib.py (install_first_time): Fixed crash if there were
6436 * IPython/iplib.py (install_first_time): Fixed crash if there were
6433 backup files ('~') in .ipython/ install directory.
6437 backup files ('~') in .ipython/ install directory.
6434
6438
6435 * IPython/ipmaker.py (make_IPython): fixes for new prompt
6439 * IPython/ipmaker.py (make_IPython): fixes for new prompt
6436 system. Things look fine, but these changes are fairly
6440 system. Things look fine, but these changes are fairly
6437 intrusive. Test them for a few days.
6441 intrusive. Test them for a few days.
6438
6442
6439 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
6443 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
6440 the prompts system. Now all in/out prompt strings are user
6444 the prompts system. Now all in/out prompt strings are user
6441 controllable. This is particularly useful for embedding, as one
6445 controllable. This is particularly useful for embedding, as one
6442 can tag embedded instances with particular prompts.
6446 can tag embedded instances with particular prompts.
6443
6447
6444 Also removed global use of sys.ps1/2, which now allows nested
6448 Also removed global use of sys.ps1/2, which now allows nested
6445 embeddings without any problems. Added command-line options for
6449 embeddings without any problems. Added command-line options for
6446 the prompt strings.
6450 the prompt strings.
6447
6451
6448 2002-03-08 Fernando Perez <fperez@colorado.edu>
6452 2002-03-08 Fernando Perez <fperez@colorado.edu>
6449
6453
6450 * IPython/UserConfig/example-embed-short.py (ipshell): added
6454 * IPython/UserConfig/example-embed-short.py (ipshell): added
6451 example file with the bare minimum code for embedding.
6455 example file with the bare minimum code for embedding.
6452
6456
6453 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
6457 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
6454 functionality for the embeddable shell to be activated/deactivated
6458 functionality for the embeddable shell to be activated/deactivated
6455 either globally or at each call.
6459 either globally or at each call.
6456
6460
6457 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
6461 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
6458 rewriting the prompt with '--->' for auto-inputs with proper
6462 rewriting the prompt with '--->' for auto-inputs with proper
6459 coloring. Now the previous UGLY hack in handle_auto() is gone, and
6463 coloring. Now the previous UGLY hack in handle_auto() is gone, and
6460 this is handled by the prompts class itself, as it should.
6464 this is handled by the prompts class itself, as it should.
6461
6465
6462 2002-03-05 Fernando Perez <fperez@colorado.edu>
6466 2002-03-05 Fernando Perez <fperez@colorado.edu>
6463
6467
6464 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
6468 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
6465 @logstart to avoid name clashes with the math log function.
6469 @logstart to avoid name clashes with the math log function.
6466
6470
6467 * Big updates to X/Emacs section of the manual.
6471 * Big updates to X/Emacs section of the manual.
6468
6472
6469 * Removed ipython_emacs. Milan explained to me how to pass
6473 * Removed ipython_emacs. Milan explained to me how to pass
6470 arguments to ipython through Emacs. Some day I'm going to end up
6474 arguments to ipython through Emacs. Some day I'm going to end up
6471 learning some lisp...
6475 learning some lisp...
6472
6476
6473 2002-03-04 Fernando Perez <fperez@colorado.edu>
6477 2002-03-04 Fernando Perez <fperez@colorado.edu>
6474
6478
6475 * IPython/ipython_emacs: Created script to be used as the
6479 * IPython/ipython_emacs: Created script to be used as the
6476 py-python-command Emacs variable so we can pass IPython
6480 py-python-command Emacs variable so we can pass IPython
6477 parameters. I can't figure out how to tell Emacs directly to pass
6481 parameters. I can't figure out how to tell Emacs directly to pass
6478 parameters to IPython, so a dummy shell script will do it.
6482 parameters to IPython, so a dummy shell script will do it.
6479
6483
6480 Other enhancements made for things to work better under Emacs'
6484 Other enhancements made for things to work better under Emacs'
6481 various types of terminals. Many thanks to Milan Zamazal
6485 various types of terminals. Many thanks to Milan Zamazal
6482 <pdm-AT-zamazal.org> for all the suggestions and pointers.
6486 <pdm-AT-zamazal.org> for all the suggestions and pointers.
6483
6487
6484 2002-03-01 Fernando Perez <fperez@colorado.edu>
6488 2002-03-01 Fernando Perez <fperez@colorado.edu>
6485
6489
6486 * IPython/ipmaker.py (make_IPython): added a --readline! option so
6490 * IPython/ipmaker.py (make_IPython): added a --readline! option so
6487 that loading of readline is now optional. This gives better
6491 that loading of readline is now optional. This gives better
6488 control to emacs users.
6492 control to emacs users.
6489
6493
6490 * IPython/ultraTB.py (__date__): Modified color escape sequences
6494 * IPython/ultraTB.py (__date__): Modified color escape sequences
6491 and now things work fine under xterm and in Emacs' term buffers
6495 and now things work fine under xterm and in Emacs' term buffers
6492 (though not shell ones). Well, in emacs you get colors, but all
6496 (though not shell ones). Well, in emacs you get colors, but all
6493 seem to be 'light' colors (no difference between dark and light
6497 seem to be 'light' colors (no difference between dark and light
6494 ones). But the garbage chars are gone, and also in xterms. It
6498 ones). But the garbage chars are gone, and also in xterms. It
6495 seems that now I'm using 'cleaner' ansi sequences.
6499 seems that now I'm using 'cleaner' ansi sequences.
6496
6500
6497 2002-02-21 Fernando Perez <fperez@colorado.edu>
6501 2002-02-21 Fernando Perez <fperez@colorado.edu>
6498
6502
6499 * Released 0.2.7 (mainly to publish the scoping fix).
6503 * Released 0.2.7 (mainly to publish the scoping fix).
6500
6504
6501 * IPython/Logger.py (Logger.logstate): added. A corresponding
6505 * IPython/Logger.py (Logger.logstate): added. A corresponding
6502 @logstate magic was created.
6506 @logstate magic was created.
6503
6507
6504 * IPython/Magic.py: fixed nested scoping problem under Python
6508 * IPython/Magic.py: fixed nested scoping problem under Python
6505 2.1.x (automagic wasn't working).
6509 2.1.x (automagic wasn't working).
6506
6510
6507 2002-02-20 Fernando Perez <fperez@colorado.edu>
6511 2002-02-20 Fernando Perez <fperez@colorado.edu>
6508
6512
6509 * Released 0.2.6.
6513 * Released 0.2.6.
6510
6514
6511 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
6515 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
6512 option so that logs can come out without any headers at all.
6516 option so that logs can come out without any headers at all.
6513
6517
6514 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
6518 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
6515 SciPy.
6519 SciPy.
6516
6520
6517 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
6521 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
6518 that embedded IPython calls don't require vars() to be explicitly
6522 that embedded IPython calls don't require vars() to be explicitly
6519 passed. Now they are extracted from the caller's frame (code
6523 passed. Now they are extracted from the caller's frame (code
6520 snatched from Eric Jones' weave). Added better documentation to
6524 snatched from Eric Jones' weave). Added better documentation to
6521 the section on embedding and the example file.
6525 the section on embedding and the example file.
6522
6526
6523 * IPython/genutils.py (page): Changed so that under emacs, it just
6527 * IPython/genutils.py (page): Changed so that under emacs, it just
6524 prints the string. You can then page up and down in the emacs
6528 prints the string. You can then page up and down in the emacs
6525 buffer itself. This is how the builtin help() works.
6529 buffer itself. This is how the builtin help() works.
6526
6530
6527 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
6531 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
6528 macro scoping: macros need to be executed in the user's namespace
6532 macro scoping: macros need to be executed in the user's namespace
6529 to work as if they had been typed by the user.
6533 to work as if they had been typed by the user.
6530
6534
6531 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
6535 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
6532 execute automatically (no need to type 'exec...'). They then
6536 execute automatically (no need to type 'exec...'). They then
6533 behave like 'true macros'. The printing system was also modified
6537 behave like 'true macros'. The printing system was also modified
6534 for this to work.
6538 for this to work.
6535
6539
6536 2002-02-19 Fernando Perez <fperez@colorado.edu>
6540 2002-02-19 Fernando Perez <fperez@colorado.edu>
6537
6541
6538 * IPython/genutils.py (page_file): new function for paging files
6542 * IPython/genutils.py (page_file): new function for paging files
6539 in an OS-independent way. Also necessary for file viewing to work
6543 in an OS-independent way. Also necessary for file viewing to work
6540 well inside Emacs buffers.
6544 well inside Emacs buffers.
6541 (page): Added checks for being in an emacs buffer.
6545 (page): Added checks for being in an emacs buffer.
6542 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
6546 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
6543 same bug in iplib.
6547 same bug in iplib.
6544
6548
6545 2002-02-18 Fernando Perez <fperez@colorado.edu>
6549 2002-02-18 Fernando Perez <fperez@colorado.edu>
6546
6550
6547 * IPython/iplib.py (InteractiveShell.init_readline): modified use
6551 * IPython/iplib.py (InteractiveShell.init_readline): modified use
6548 of readline so that IPython can work inside an Emacs buffer.
6552 of readline so that IPython can work inside an Emacs buffer.
6549
6553
6550 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
6554 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
6551 method signatures (they weren't really bugs, but it looks cleaner
6555 method signatures (they weren't really bugs, but it looks cleaner
6552 and keeps PyChecker happy).
6556 and keeps PyChecker happy).
6553
6557
6554 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
6558 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
6555 for implementing various user-defined hooks. Currently only
6559 for implementing various user-defined hooks. Currently only
6556 display is done.
6560 display is done.
6557
6561
6558 * IPython/Prompts.py (CachedOutput._display): changed display
6562 * IPython/Prompts.py (CachedOutput._display): changed display
6559 functions so that they can be dynamically changed by users easily.
6563 functions so that they can be dynamically changed by users easily.
6560
6564
6561 * IPython/Extensions/numeric_formats.py (num_display): added an
6565 * IPython/Extensions/numeric_formats.py (num_display): added an
6562 extension for printing NumPy arrays in flexible manners. It
6566 extension for printing NumPy arrays in flexible manners. It
6563 doesn't do anything yet, but all the structure is in
6567 doesn't do anything yet, but all the structure is in
6564 place. Ultimately the plan is to implement output format control
6568 place. Ultimately the plan is to implement output format control
6565 like in Octave.
6569 like in Octave.
6566
6570
6567 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
6571 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
6568 methods are found at run-time by all the automatic machinery.
6572 methods are found at run-time by all the automatic machinery.
6569
6573
6570 2002-02-17 Fernando Perez <fperez@colorado.edu>
6574 2002-02-17 Fernando Perez <fperez@colorado.edu>
6571
6575
6572 * setup_Windows.py (make_shortcut): documented. Cleaned up the
6576 * setup_Windows.py (make_shortcut): documented. Cleaned up the
6573 whole file a little.
6577 whole file a little.
6574
6578
6575 * ToDo: closed this document. Now there's a new_design.lyx
6579 * ToDo: closed this document. Now there's a new_design.lyx
6576 document for all new ideas. Added making a pdf of it for the
6580 document for all new ideas. Added making a pdf of it for the
6577 end-user distro.
6581 end-user distro.
6578
6582
6579 * IPython/Logger.py (Logger.switch_log): Created this to replace
6583 * IPython/Logger.py (Logger.switch_log): Created this to replace
6580 logon() and logoff(). It also fixes a nasty crash reported by
6584 logon() and logoff(). It also fixes a nasty crash reported by
6581 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
6585 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
6582
6586
6583 * IPython/iplib.py (complete): got auto-completion to work with
6587 * IPython/iplib.py (complete): got auto-completion to work with
6584 automagic (I had wanted this for a long time).
6588 automagic (I had wanted this for a long time).
6585
6589
6586 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
6590 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
6587 to @file, since file() is now a builtin and clashes with automagic
6591 to @file, since file() is now a builtin and clashes with automagic
6588 for @file.
6592 for @file.
6589
6593
6590 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
6594 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
6591 of this was previously in iplib, which had grown to more than 2000
6595 of this was previously in iplib, which had grown to more than 2000
6592 lines, way too long. No new functionality, but it makes managing
6596 lines, way too long. No new functionality, but it makes managing
6593 the code a bit easier.
6597 the code a bit easier.
6594
6598
6595 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
6599 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
6596 information to crash reports.
6600 information to crash reports.
6597
6601
6598 2002-02-12 Fernando Perez <fperez@colorado.edu>
6602 2002-02-12 Fernando Perez <fperez@colorado.edu>
6599
6603
6600 * Released 0.2.5.
6604 * Released 0.2.5.
6601
6605
6602 2002-02-11 Fernando Perez <fperez@colorado.edu>
6606 2002-02-11 Fernando Perez <fperez@colorado.edu>
6603
6607
6604 * Wrote a relatively complete Windows installer. It puts
6608 * Wrote a relatively complete Windows installer. It puts
6605 everything in place, creates Start Menu entries and fixes the
6609 everything in place, creates Start Menu entries and fixes the
6606 color issues. Nothing fancy, but it works.
6610 color issues. Nothing fancy, but it works.
6607
6611
6608 2002-02-10 Fernando Perez <fperez@colorado.edu>
6612 2002-02-10 Fernando Perez <fperez@colorado.edu>
6609
6613
6610 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
6614 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
6611 os.path.expanduser() call so that we can type @run ~/myfile.py and
6615 os.path.expanduser() call so that we can type @run ~/myfile.py and
6612 have thigs work as expected.
6616 have thigs work as expected.
6613
6617
6614 * IPython/genutils.py (page): fixed exception handling so things
6618 * IPython/genutils.py (page): fixed exception handling so things
6615 work both in Unix and Windows correctly. Quitting a pager triggers
6619 work both in Unix and Windows correctly. Quitting a pager triggers
6616 an IOError/broken pipe in Unix, and in windows not finding a pager
6620 an IOError/broken pipe in Unix, and in windows not finding a pager
6617 is also an IOError, so I had to actually look at the return value
6621 is also an IOError, so I had to actually look at the return value
6618 of the exception, not just the exception itself. Should be ok now.
6622 of the exception, not just the exception itself. Should be ok now.
6619
6623
6620 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
6624 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
6621 modified to allow case-insensitive color scheme changes.
6625 modified to allow case-insensitive color scheme changes.
6622
6626
6623 2002-02-09 Fernando Perez <fperez@colorado.edu>
6627 2002-02-09 Fernando Perez <fperez@colorado.edu>
6624
6628
6625 * IPython/genutils.py (native_line_ends): new function to leave
6629 * IPython/genutils.py (native_line_ends): new function to leave
6626 user config files with os-native line-endings.
6630 user config files with os-native line-endings.
6627
6631
6628 * README and manual updates.
6632 * README and manual updates.
6629
6633
6630 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
6634 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
6631 instead of StringType to catch Unicode strings.
6635 instead of StringType to catch Unicode strings.
6632
6636
6633 * IPython/genutils.py (filefind): fixed bug for paths with
6637 * IPython/genutils.py (filefind): fixed bug for paths with
6634 embedded spaces (very common in Windows).
6638 embedded spaces (very common in Windows).
6635
6639
6636 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
6640 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
6637 files under Windows, so that they get automatically associated
6641 files under Windows, so that they get automatically associated
6638 with a text editor. Windows makes it a pain to handle
6642 with a text editor. Windows makes it a pain to handle
6639 extension-less files.
6643 extension-less files.
6640
6644
6641 * IPython/iplib.py (InteractiveShell.init_readline): Made the
6645 * IPython/iplib.py (InteractiveShell.init_readline): Made the
6642 warning about readline only occur for Posix. In Windows there's no
6646 warning about readline only occur for Posix. In Windows there's no
6643 way to get readline, so why bother with the warning.
6647 way to get readline, so why bother with the warning.
6644
6648
6645 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
6649 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
6646 for __str__ instead of dir(self), since dir() changed in 2.2.
6650 for __str__ instead of dir(self), since dir() changed in 2.2.
6647
6651
6648 * Ported to Windows! Tested on XP, I suspect it should work fine
6652 * Ported to Windows! Tested on XP, I suspect it should work fine
6649 on NT/2000, but I don't think it will work on 98 et al. That
6653 on NT/2000, but I don't think it will work on 98 et al. That
6650 series of Windows is such a piece of junk anyway that I won't try
6654 series of Windows is such a piece of junk anyway that I won't try
6651 porting it there. The XP port was straightforward, showed a few
6655 porting it there. The XP port was straightforward, showed a few
6652 bugs here and there (fixed all), in particular some string
6656 bugs here and there (fixed all), in particular some string
6653 handling stuff which required considering Unicode strings (which
6657 handling stuff which required considering Unicode strings (which
6654 Windows uses). This is good, but hasn't been too tested :) No
6658 Windows uses). This is good, but hasn't been too tested :) No
6655 fancy installer yet, I'll put a note in the manual so people at
6659 fancy installer yet, I'll put a note in the manual so people at
6656 least make manually a shortcut.
6660 least make manually a shortcut.
6657
6661
6658 * IPython/iplib.py (Magic.magic_colors): Unified the color options
6662 * IPython/iplib.py (Magic.magic_colors): Unified the color options
6659 into a single one, "colors". This now controls both prompt and
6663 into a single one, "colors". This now controls both prompt and
6660 exception color schemes, and can be changed both at startup
6664 exception color schemes, and can be changed both at startup
6661 (either via command-line switches or via ipythonrc files) and at
6665 (either via command-line switches or via ipythonrc files) and at
6662 runtime, with @colors.
6666 runtime, with @colors.
6663 (Magic.magic_run): renamed @prun to @run and removed the old
6667 (Magic.magic_run): renamed @prun to @run and removed the old
6664 @run. The two were too similar to warrant keeping both.
6668 @run. The two were too similar to warrant keeping both.
6665
6669
6666 2002-02-03 Fernando Perez <fperez@colorado.edu>
6670 2002-02-03 Fernando Perez <fperez@colorado.edu>
6667
6671
6668 * IPython/iplib.py (install_first_time): Added comment on how to
6672 * IPython/iplib.py (install_first_time): Added comment on how to
6669 configure the color options for first-time users. Put a <return>
6673 configure the color options for first-time users. Put a <return>
6670 request at the end so that small-terminal users get a chance to
6674 request at the end so that small-terminal users get a chance to
6671 read the startup info.
6675 read the startup info.
6672
6676
6673 2002-01-23 Fernando Perez <fperez@colorado.edu>
6677 2002-01-23 Fernando Perez <fperez@colorado.edu>
6674
6678
6675 * IPython/iplib.py (CachedOutput.update): Changed output memory
6679 * IPython/iplib.py (CachedOutput.update): Changed output memory
6676 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
6680 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
6677 input history we still use _i. Did this b/c these variable are
6681 input history we still use _i. Did this b/c these variable are
6678 very commonly used in interactive work, so the less we need to
6682 very commonly used in interactive work, so the less we need to
6679 type the better off we are.
6683 type the better off we are.
6680 (Magic.magic_prun): updated @prun to better handle the namespaces
6684 (Magic.magic_prun): updated @prun to better handle the namespaces
6681 the file will run in, including a fix for __name__ not being set
6685 the file will run in, including a fix for __name__ not being set
6682 before.
6686 before.
6683
6687
6684 2002-01-20 Fernando Perez <fperez@colorado.edu>
6688 2002-01-20 Fernando Perez <fperez@colorado.edu>
6685
6689
6686 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
6690 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
6687 extra garbage for Python 2.2. Need to look more carefully into
6691 extra garbage for Python 2.2. Need to look more carefully into
6688 this later.
6692 this later.
6689
6693
6690 2002-01-19 Fernando Perez <fperez@colorado.edu>
6694 2002-01-19 Fernando Perez <fperez@colorado.edu>
6691
6695
6692 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
6696 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
6693 display SyntaxError exceptions properly formatted when they occur
6697 display SyntaxError exceptions properly formatted when they occur
6694 (they can be triggered by imported code).
6698 (they can be triggered by imported code).
6695
6699
6696 2002-01-18 Fernando Perez <fperez@colorado.edu>
6700 2002-01-18 Fernando Perez <fperez@colorado.edu>
6697
6701
6698 * IPython/iplib.py (InteractiveShell.safe_execfile): now
6702 * IPython/iplib.py (InteractiveShell.safe_execfile): now
6699 SyntaxError exceptions are reported nicely formatted, instead of
6703 SyntaxError exceptions are reported nicely formatted, instead of
6700 spitting out only offset information as before.
6704 spitting out only offset information as before.
6701 (Magic.magic_prun): Added the @prun function for executing
6705 (Magic.magic_prun): Added the @prun function for executing
6702 programs with command line args inside IPython.
6706 programs with command line args inside IPython.
6703
6707
6704 2002-01-16 Fernando Perez <fperez@colorado.edu>
6708 2002-01-16 Fernando Perez <fperez@colorado.edu>
6705
6709
6706 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
6710 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
6707 to *not* include the last item given in a range. This brings their
6711 to *not* include the last item given in a range. This brings their
6708 behavior in line with Python's slicing:
6712 behavior in line with Python's slicing:
6709 a[n1:n2] -> a[n1]...a[n2-1]
6713 a[n1:n2] -> a[n1]...a[n2-1]
6710 It may be a bit less convenient, but I prefer to stick to Python's
6714 It may be a bit less convenient, but I prefer to stick to Python's
6711 conventions *everywhere*, so users never have to wonder.
6715 conventions *everywhere*, so users never have to wonder.
6712 (Magic.magic_macro): Added @macro function to ease the creation of
6716 (Magic.magic_macro): Added @macro function to ease the creation of
6713 macros.
6717 macros.
6714
6718
6715 2002-01-05 Fernando Perez <fperez@colorado.edu>
6719 2002-01-05 Fernando Perez <fperez@colorado.edu>
6716
6720
6717 * Released 0.2.4.
6721 * Released 0.2.4.
6718
6722
6719 * IPython/iplib.py (Magic.magic_pdef):
6723 * IPython/iplib.py (Magic.magic_pdef):
6720 (InteractiveShell.safe_execfile): report magic lines and error
6724 (InteractiveShell.safe_execfile): report magic lines and error
6721 lines without line numbers so one can easily copy/paste them for
6725 lines without line numbers so one can easily copy/paste them for
6722 re-execution.
6726 re-execution.
6723
6727
6724 * Updated manual with recent changes.
6728 * Updated manual with recent changes.
6725
6729
6726 * IPython/iplib.py (Magic.magic_oinfo): added constructor
6730 * IPython/iplib.py (Magic.magic_oinfo): added constructor
6727 docstring printing when class? is called. Very handy for knowing
6731 docstring printing when class? is called. Very handy for knowing
6728 how to create class instances (as long as __init__ is well
6732 how to create class instances (as long as __init__ is well
6729 documented, of course :)
6733 documented, of course :)
6730 (Magic.magic_doc): print both class and constructor docstrings.
6734 (Magic.magic_doc): print both class and constructor docstrings.
6731 (Magic.magic_pdef): give constructor info if passed a class and
6735 (Magic.magic_pdef): give constructor info if passed a class and
6732 __call__ info for callable object instances.
6736 __call__ info for callable object instances.
6733
6737
6734 2002-01-04 Fernando Perez <fperez@colorado.edu>
6738 2002-01-04 Fernando Perez <fperez@colorado.edu>
6735
6739
6736 * Made deep_reload() off by default. It doesn't always work
6740 * Made deep_reload() off by default. It doesn't always work
6737 exactly as intended, so it's probably safer to have it off. It's
6741 exactly as intended, so it's probably safer to have it off. It's
6738 still available as dreload() anyway, so nothing is lost.
6742 still available as dreload() anyway, so nothing is lost.
6739
6743
6740 2002-01-02 Fernando Perez <fperez@colorado.edu>
6744 2002-01-02 Fernando Perez <fperez@colorado.edu>
6741
6745
6742 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
6746 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
6743 so I wanted an updated release).
6747 so I wanted an updated release).
6744
6748
6745 2001-12-27 Fernando Perez <fperez@colorado.edu>
6749 2001-12-27 Fernando Perez <fperez@colorado.edu>
6746
6750
6747 * IPython/iplib.py (InteractiveShell.interact): Added the original
6751 * IPython/iplib.py (InteractiveShell.interact): Added the original
6748 code from 'code.py' for this module in order to change the
6752 code from 'code.py' for this module in order to change the
6749 handling of a KeyboardInterrupt. This was necessary b/c otherwise
6753 handling of a KeyboardInterrupt. This was necessary b/c otherwise
6750 the history cache would break when the user hit Ctrl-C, and
6754 the history cache would break when the user hit Ctrl-C, and
6751 interact() offers no way to add any hooks to it.
6755 interact() offers no way to add any hooks to it.
6752
6756
6753 2001-12-23 Fernando Perez <fperez@colorado.edu>
6757 2001-12-23 Fernando Perez <fperez@colorado.edu>
6754
6758
6755 * setup.py: added check for 'MANIFEST' before trying to remove
6759 * setup.py: added check for 'MANIFEST' before trying to remove
6756 it. Thanks to Sean Reifschneider.
6760 it. Thanks to Sean Reifschneider.
6757
6761
6758 2001-12-22 Fernando Perez <fperez@colorado.edu>
6762 2001-12-22 Fernando Perez <fperez@colorado.edu>
6759
6763
6760 * Released 0.2.2.
6764 * Released 0.2.2.
6761
6765
6762 * Finished (reasonably) writing the manual. Later will add the
6766 * Finished (reasonably) writing the manual. Later will add the
6763 python-standard navigation stylesheets, but for the time being
6767 python-standard navigation stylesheets, but for the time being
6764 it's fairly complete. Distribution will include html and pdf
6768 it's fairly complete. Distribution will include html and pdf
6765 versions.
6769 versions.
6766
6770
6767 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
6771 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
6768 (MayaVi author).
6772 (MayaVi author).
6769
6773
6770 2001-12-21 Fernando Perez <fperez@colorado.edu>
6774 2001-12-21 Fernando Perez <fperez@colorado.edu>
6771
6775
6772 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
6776 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
6773 good public release, I think (with the manual and the distutils
6777 good public release, I think (with the manual and the distutils
6774 installer). The manual can use some work, but that can go
6778 installer). The manual can use some work, but that can go
6775 slowly. Otherwise I think it's quite nice for end users. Next
6779 slowly. Otherwise I think it's quite nice for end users. Next
6776 summer, rewrite the guts of it...
6780 summer, rewrite the guts of it...
6777
6781
6778 * Changed format of ipythonrc files to use whitespace as the
6782 * Changed format of ipythonrc files to use whitespace as the
6779 separator instead of an explicit '='. Cleaner.
6783 separator instead of an explicit '='. Cleaner.
6780
6784
6781 2001-12-20 Fernando Perez <fperez@colorado.edu>
6785 2001-12-20 Fernando Perez <fperez@colorado.edu>
6782
6786
6783 * Started a manual in LyX. For now it's just a quick merge of the
6787 * Started a manual in LyX. For now it's just a quick merge of the
6784 various internal docstrings and READMEs. Later it may grow into a
6788 various internal docstrings and READMEs. Later it may grow into a
6785 nice, full-blown manual.
6789 nice, full-blown manual.
6786
6790
6787 * Set up a distutils based installer. Installation should now be
6791 * Set up a distutils based installer. Installation should now be
6788 trivially simple for end-users.
6792 trivially simple for end-users.
6789
6793
6790 2001-12-11 Fernando Perez <fperez@colorado.edu>
6794 2001-12-11 Fernando Perez <fperez@colorado.edu>
6791
6795
6792 * Released 0.2.0. First public release, announced it at
6796 * Released 0.2.0. First public release, announced it at
6793 comp.lang.python. From now on, just bugfixes...
6797 comp.lang.python. From now on, just bugfixes...
6794
6798
6795 * Went through all the files, set copyright/license notices and
6799 * Went through all the files, set copyright/license notices and
6796 cleaned up things. Ready for release.
6800 cleaned up things. Ready for release.
6797
6801
6798 2001-12-10 Fernando Perez <fperez@colorado.edu>
6802 2001-12-10 Fernando Perez <fperez@colorado.edu>
6799
6803
6800 * Changed the first-time installer not to use tarfiles. It's more
6804 * Changed the first-time installer not to use tarfiles. It's more
6801 robust now and less unix-dependent. Also makes it easier for
6805 robust now and less unix-dependent. Also makes it easier for
6802 people to later upgrade versions.
6806 people to later upgrade versions.
6803
6807
6804 * Changed @exit to @abort to reflect the fact that it's pretty
6808 * Changed @exit to @abort to reflect the fact that it's pretty
6805 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6809 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6806 becomes significant only when IPyhton is embedded: in that case,
6810 becomes significant only when IPyhton is embedded: in that case,
6807 C-D closes IPython only, but @abort kills the enclosing program
6811 C-D closes IPython only, but @abort kills the enclosing program
6808 too (unless it had called IPython inside a try catching
6812 too (unless it had called IPython inside a try catching
6809 SystemExit).
6813 SystemExit).
6810
6814
6811 * Created Shell module which exposes the actuall IPython Shell
6815 * Created Shell module which exposes the actuall IPython Shell
6812 classes, currently the normal and the embeddable one. This at
6816 classes, currently the normal and the embeddable one. This at
6813 least offers a stable interface we won't need to change when
6817 least offers a stable interface we won't need to change when
6814 (later) the internals are rewritten. That rewrite will be confined
6818 (later) the internals are rewritten. That rewrite will be confined
6815 to iplib and ipmaker, but the Shell interface should remain as is.
6819 to iplib and ipmaker, but the Shell interface should remain as is.
6816
6820
6817 * Added embed module which offers an embeddable IPShell object,
6821 * Added embed module which offers an embeddable IPShell object,
6818 useful to fire up IPython *inside* a running program. Great for
6822 useful to fire up IPython *inside* a running program. Great for
6819 debugging or dynamical data analysis.
6823 debugging or dynamical data analysis.
6820
6824
6821 2001-12-08 Fernando Perez <fperez@colorado.edu>
6825 2001-12-08 Fernando Perez <fperez@colorado.edu>
6822
6826
6823 * Fixed small bug preventing seeing info from methods of defined
6827 * Fixed small bug preventing seeing info from methods of defined
6824 objects (incorrect namespace in _ofind()).
6828 objects (incorrect namespace in _ofind()).
6825
6829
6826 * Documentation cleanup. Moved the main usage docstrings to a
6830 * Documentation cleanup. Moved the main usage docstrings to a
6827 separate file, usage.py (cleaner to maintain, and hopefully in the
6831 separate file, usage.py (cleaner to maintain, and hopefully in the
6828 future some perlpod-like way of producing interactive, man and
6832 future some perlpod-like way of producing interactive, man and
6829 html docs out of it will be found).
6833 html docs out of it will be found).
6830
6834
6831 * Added @profile to see your profile at any time.
6835 * Added @profile to see your profile at any time.
6832
6836
6833 * Added @p as an alias for 'print'. It's especially convenient if
6837 * Added @p as an alias for 'print'. It's especially convenient if
6834 using automagic ('p x' prints x).
6838 using automagic ('p x' prints x).
6835
6839
6836 * Small cleanups and fixes after a pychecker run.
6840 * Small cleanups and fixes after a pychecker run.
6837
6841
6838 * Changed the @cd command to handle @cd - and @cd -<n> for
6842 * Changed the @cd command to handle @cd - and @cd -<n> for
6839 visiting any directory in _dh.
6843 visiting any directory in _dh.
6840
6844
6841 * Introduced _dh, a history of visited directories. @dhist prints
6845 * Introduced _dh, a history of visited directories. @dhist prints
6842 it out with numbers.
6846 it out with numbers.
6843
6847
6844 2001-12-07 Fernando Perez <fperez@colorado.edu>
6848 2001-12-07 Fernando Perez <fperez@colorado.edu>
6845
6849
6846 * Released 0.1.22
6850 * Released 0.1.22
6847
6851
6848 * Made initialization a bit more robust against invalid color
6852 * Made initialization a bit more robust against invalid color
6849 options in user input (exit, not traceback-crash).
6853 options in user input (exit, not traceback-crash).
6850
6854
6851 * Changed the bug crash reporter to write the report only in the
6855 * Changed the bug crash reporter to write the report only in the
6852 user's .ipython directory. That way IPython won't litter people's
6856 user's .ipython directory. That way IPython won't litter people's
6853 hard disks with crash files all over the place. Also print on
6857 hard disks with crash files all over the place. Also print on
6854 screen the necessary mail command.
6858 screen the necessary mail command.
6855
6859
6856 * With the new ultraTB, implemented LightBG color scheme for light
6860 * With the new ultraTB, implemented LightBG color scheme for light
6857 background terminals. A lot of people like white backgrounds, so I
6861 background terminals. A lot of people like white backgrounds, so I
6858 guess we should at least give them something readable.
6862 guess we should at least give them something readable.
6859
6863
6860 2001-12-06 Fernando Perez <fperez@colorado.edu>
6864 2001-12-06 Fernando Perez <fperez@colorado.edu>
6861
6865
6862 * Modified the structure of ultraTB. Now there's a proper class
6866 * Modified the structure of ultraTB. Now there's a proper class
6863 for tables of color schemes which allow adding schemes easily and
6867 for tables of color schemes which allow adding schemes easily and
6864 switching the active scheme without creating a new instance every
6868 switching the active scheme without creating a new instance every
6865 time (which was ridiculous). The syntax for creating new schemes
6869 time (which was ridiculous). The syntax for creating new schemes
6866 is also cleaner. I think ultraTB is finally done, with a clean
6870 is also cleaner. I think ultraTB is finally done, with a clean
6867 class structure. Names are also much cleaner (now there's proper
6871 class structure. Names are also much cleaner (now there's proper
6868 color tables, no need for every variable to also have 'color' in
6872 color tables, no need for every variable to also have 'color' in
6869 its name).
6873 its name).
6870
6874
6871 * Broke down genutils into separate files. Now genutils only
6875 * Broke down genutils into separate files. Now genutils only
6872 contains utility functions, and classes have been moved to their
6876 contains utility functions, and classes have been moved to their
6873 own files (they had enough independent functionality to warrant
6877 own files (they had enough independent functionality to warrant
6874 it): ConfigLoader, OutputTrap, Struct.
6878 it): ConfigLoader, OutputTrap, Struct.
6875
6879
6876 2001-12-05 Fernando Perez <fperez@colorado.edu>
6880 2001-12-05 Fernando Perez <fperez@colorado.edu>
6877
6881
6878 * IPython turns 21! Released version 0.1.21, as a candidate for
6882 * IPython turns 21! Released version 0.1.21, as a candidate for
6879 public consumption. If all goes well, release in a few days.
6883 public consumption. If all goes well, release in a few days.
6880
6884
6881 * Fixed path bug (files in Extensions/ directory wouldn't be found
6885 * Fixed path bug (files in Extensions/ directory wouldn't be found
6882 unless IPython/ was explicitly in sys.path).
6886 unless IPython/ was explicitly in sys.path).
6883
6887
6884 * Extended the FlexCompleter class as MagicCompleter to allow
6888 * Extended the FlexCompleter class as MagicCompleter to allow
6885 completion of @-starting lines.
6889 completion of @-starting lines.
6886
6890
6887 * Created __release__.py file as a central repository for release
6891 * Created __release__.py file as a central repository for release
6888 info that other files can read from.
6892 info that other files can read from.
6889
6893
6890 * Fixed small bug in logging: when logging was turned on in
6894 * Fixed small bug in logging: when logging was turned on in
6891 mid-session, old lines with special meanings (!@?) were being
6895 mid-session, old lines with special meanings (!@?) were being
6892 logged without the prepended comment, which is necessary since
6896 logged without the prepended comment, which is necessary since
6893 they are not truly valid python syntax. This should make session
6897 they are not truly valid python syntax. This should make session
6894 restores produce less errors.
6898 restores produce less errors.
6895
6899
6896 * The namespace cleanup forced me to make a FlexCompleter class
6900 * The namespace cleanup forced me to make a FlexCompleter class
6897 which is nothing but a ripoff of rlcompleter, but with selectable
6901 which is nothing but a ripoff of rlcompleter, but with selectable
6898 namespace (rlcompleter only works in __main__.__dict__). I'll try
6902 namespace (rlcompleter only works in __main__.__dict__). I'll try
6899 to submit a note to the authors to see if this change can be
6903 to submit a note to the authors to see if this change can be
6900 incorporated in future rlcompleter releases (Dec.6: done)
6904 incorporated in future rlcompleter releases (Dec.6: done)
6901
6905
6902 * More fixes to namespace handling. It was a mess! Now all
6906 * More fixes to namespace handling. It was a mess! Now all
6903 explicit references to __main__.__dict__ are gone (except when
6907 explicit references to __main__.__dict__ are gone (except when
6904 really needed) and everything is handled through the namespace
6908 really needed) and everything is handled through the namespace
6905 dicts in the IPython instance. We seem to be getting somewhere
6909 dicts in the IPython instance. We seem to be getting somewhere
6906 with this, finally...
6910 with this, finally...
6907
6911
6908 * Small documentation updates.
6912 * Small documentation updates.
6909
6913
6910 * Created the Extensions directory under IPython (with an
6914 * Created the Extensions directory under IPython (with an
6911 __init__.py). Put the PhysicalQ stuff there. This directory should
6915 __init__.py). Put the PhysicalQ stuff there. This directory should
6912 be used for all special-purpose extensions.
6916 be used for all special-purpose extensions.
6913
6917
6914 * File renaming:
6918 * File renaming:
6915 ipythonlib --> ipmaker
6919 ipythonlib --> ipmaker
6916 ipplib --> iplib
6920 ipplib --> iplib
6917 This makes a bit more sense in terms of what these files actually do.
6921 This makes a bit more sense in terms of what these files actually do.
6918
6922
6919 * Moved all the classes and functions in ipythonlib to ipplib, so
6923 * Moved all the classes and functions in ipythonlib to ipplib, so
6920 now ipythonlib only has make_IPython(). This will ease up its
6924 now ipythonlib only has make_IPython(). This will ease up its
6921 splitting in smaller functional chunks later.
6925 splitting in smaller functional chunks later.
6922
6926
6923 * Cleaned up (done, I think) output of @whos. Better column
6927 * Cleaned up (done, I think) output of @whos. Better column
6924 formatting, and now shows str(var) for as much as it can, which is
6928 formatting, and now shows str(var) for as much as it can, which is
6925 typically what one gets with a 'print var'.
6929 typically what one gets with a 'print var'.
6926
6930
6927 2001-12-04 Fernando Perez <fperez@colorado.edu>
6931 2001-12-04 Fernando Perez <fperez@colorado.edu>
6928
6932
6929 * Fixed namespace problems. Now builtin/IPyhton/user names get
6933 * Fixed namespace problems. Now builtin/IPyhton/user names get
6930 properly reported in their namespace. Internal namespace handling
6934 properly reported in their namespace. Internal namespace handling
6931 is finally getting decent (not perfect yet, but much better than
6935 is finally getting decent (not perfect yet, but much better than
6932 the ad-hoc mess we had).
6936 the ad-hoc mess we had).
6933
6937
6934 * Removed -exit option. If people just want to run a python
6938 * Removed -exit option. If people just want to run a python
6935 script, that's what the normal interpreter is for. Less
6939 script, that's what the normal interpreter is for. Less
6936 unnecessary options, less chances for bugs.
6940 unnecessary options, less chances for bugs.
6937
6941
6938 * Added a crash handler which generates a complete post-mortem if
6942 * Added a crash handler which generates a complete post-mortem if
6939 IPython crashes. This will help a lot in tracking bugs down the
6943 IPython crashes. This will help a lot in tracking bugs down the
6940 road.
6944 road.
6941
6945
6942 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6946 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6943 which were boud to functions being reassigned would bypass the
6947 which were boud to functions being reassigned would bypass the
6944 logger, breaking the sync of _il with the prompt counter. This
6948 logger, breaking the sync of _il with the prompt counter. This
6945 would then crash IPython later when a new line was logged.
6949 would then crash IPython later when a new line was logged.
6946
6950
6947 2001-12-02 Fernando Perez <fperez@colorado.edu>
6951 2001-12-02 Fernando Perez <fperez@colorado.edu>
6948
6952
6949 * Made IPython a package. This means people don't have to clutter
6953 * Made IPython a package. This means people don't have to clutter
6950 their sys.path with yet another directory. Changed the INSTALL
6954 their sys.path with yet another directory. Changed the INSTALL
6951 file accordingly.
6955 file accordingly.
6952
6956
6953 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6957 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6954 sorts its output (so @who shows it sorted) and @whos formats the
6958 sorts its output (so @who shows it sorted) and @whos formats the
6955 table according to the width of the first column. Nicer, easier to
6959 table according to the width of the first column. Nicer, easier to
6956 read. Todo: write a generic table_format() which takes a list of
6960 read. Todo: write a generic table_format() which takes a list of
6957 lists and prints it nicely formatted, with optional row/column
6961 lists and prints it nicely formatted, with optional row/column
6958 separators and proper padding and justification.
6962 separators and proper padding and justification.
6959
6963
6960 * Released 0.1.20
6964 * Released 0.1.20
6961
6965
6962 * Fixed bug in @log which would reverse the inputcache list (a
6966 * Fixed bug in @log which would reverse the inputcache list (a
6963 copy operation was missing).
6967 copy operation was missing).
6964
6968
6965 * Code cleanup. @config was changed to use page(). Better, since
6969 * Code cleanup. @config was changed to use page(). Better, since
6966 its output is always quite long.
6970 its output is always quite long.
6967
6971
6968 * Itpl is back as a dependency. I was having too many problems
6972 * Itpl is back as a dependency. I was having too many problems
6969 getting the parametric aliases to work reliably, and it's just
6973 getting the parametric aliases to work reliably, and it's just
6970 easier to code weird string operations with it than playing %()s
6974 easier to code weird string operations with it than playing %()s
6971 games. It's only ~6k, so I don't think it's too big a deal.
6975 games. It's only ~6k, so I don't think it's too big a deal.
6972
6976
6973 * Found (and fixed) a very nasty bug with history. !lines weren't
6977 * Found (and fixed) a very nasty bug with history. !lines weren't
6974 getting cached, and the out of sync caches would crash
6978 getting cached, and the out of sync caches would crash
6975 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6979 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6976 division of labor a bit better. Bug fixed, cleaner structure.
6980 division of labor a bit better. Bug fixed, cleaner structure.
6977
6981
6978 2001-12-01 Fernando Perez <fperez@colorado.edu>
6982 2001-12-01 Fernando Perez <fperez@colorado.edu>
6979
6983
6980 * Released 0.1.19
6984 * Released 0.1.19
6981
6985
6982 * Added option -n to @hist to prevent line number printing. Much
6986 * Added option -n to @hist to prevent line number printing. Much
6983 easier to copy/paste code this way.
6987 easier to copy/paste code this way.
6984
6988
6985 * Created global _il to hold the input list. Allows easy
6989 * Created global _il to hold the input list. Allows easy
6986 re-execution of blocks of code by slicing it (inspired by Janko's
6990 re-execution of blocks of code by slicing it (inspired by Janko's
6987 comment on 'macros').
6991 comment on 'macros').
6988
6992
6989 * Small fixes and doc updates.
6993 * Small fixes and doc updates.
6990
6994
6991 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6995 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6992 much too fragile with automagic. Handles properly multi-line
6996 much too fragile with automagic. Handles properly multi-line
6993 statements and takes parameters.
6997 statements and takes parameters.
6994
6998
6995 2001-11-30 Fernando Perez <fperez@colorado.edu>
6999 2001-11-30 Fernando Perez <fperez@colorado.edu>
6996
7000
6997 * Version 0.1.18 released.
7001 * Version 0.1.18 released.
6998
7002
6999 * Fixed nasty namespace bug in initial module imports.
7003 * Fixed nasty namespace bug in initial module imports.
7000
7004
7001 * Added copyright/license notes to all code files (except
7005 * Added copyright/license notes to all code files (except
7002 DPyGetOpt). For the time being, LGPL. That could change.
7006 DPyGetOpt). For the time being, LGPL. That could change.
7003
7007
7004 * Rewrote a much nicer README, updated INSTALL, cleaned up
7008 * Rewrote a much nicer README, updated INSTALL, cleaned up
7005 ipythonrc-* samples.
7009 ipythonrc-* samples.
7006
7010
7007 * Overall code/documentation cleanup. Basically ready for
7011 * Overall code/documentation cleanup. Basically ready for
7008 release. Only remaining thing: licence decision (LGPL?).
7012 release. Only remaining thing: licence decision (LGPL?).
7009
7013
7010 * Converted load_config to a class, ConfigLoader. Now recursion
7014 * Converted load_config to a class, ConfigLoader. Now recursion
7011 control is better organized. Doesn't include the same file twice.
7015 control is better organized. Doesn't include the same file twice.
7012
7016
7013 2001-11-29 Fernando Perez <fperez@colorado.edu>
7017 2001-11-29 Fernando Perez <fperez@colorado.edu>
7014
7018
7015 * Got input history working. Changed output history variables from
7019 * Got input history working. Changed output history variables from
7016 _p to _o so that _i is for input and _o for output. Just cleaner
7020 _p to _o so that _i is for input and _o for output. Just cleaner
7017 convention.
7021 convention.
7018
7022
7019 * Implemented parametric aliases. This pretty much allows the
7023 * Implemented parametric aliases. This pretty much allows the
7020 alias system to offer full-blown shell convenience, I think.
7024 alias system to offer full-blown shell convenience, I think.
7021
7025
7022 * Version 0.1.17 released, 0.1.18 opened.
7026 * Version 0.1.17 released, 0.1.18 opened.
7023
7027
7024 * dot_ipython/ipythonrc (alias): added documentation.
7028 * dot_ipython/ipythonrc (alias): added documentation.
7025 (xcolor): Fixed small bug (xcolors -> xcolor)
7029 (xcolor): Fixed small bug (xcolors -> xcolor)
7026
7030
7027 * Changed the alias system. Now alias is a magic command to define
7031 * Changed the alias system. Now alias is a magic command to define
7028 aliases just like the shell. Rationale: the builtin magics should
7032 aliases just like the shell. Rationale: the builtin magics should
7029 be there for things deeply connected to IPython's
7033 be there for things deeply connected to IPython's
7030 architecture. And this is a much lighter system for what I think
7034 architecture. And this is a much lighter system for what I think
7031 is the really important feature: allowing users to define quickly
7035 is the really important feature: allowing users to define quickly
7032 magics that will do shell things for them, so they can customize
7036 magics that will do shell things for them, so they can customize
7033 IPython easily to match their work habits. If someone is really
7037 IPython easily to match their work habits. If someone is really
7034 desperate to have another name for a builtin alias, they can
7038 desperate to have another name for a builtin alias, they can
7035 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
7039 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
7036 works.
7040 works.
7037
7041
7038 2001-11-28 Fernando Perez <fperez@colorado.edu>
7042 2001-11-28 Fernando Perez <fperez@colorado.edu>
7039
7043
7040 * Changed @file so that it opens the source file at the proper
7044 * Changed @file so that it opens the source file at the proper
7041 line. Since it uses less, if your EDITOR environment is
7045 line. Since it uses less, if your EDITOR environment is
7042 configured, typing v will immediately open your editor of choice
7046 configured, typing v will immediately open your editor of choice
7043 right at the line where the object is defined. Not as quick as
7047 right at the line where the object is defined. Not as quick as
7044 having a direct @edit command, but for all intents and purposes it
7048 having a direct @edit command, but for all intents and purposes it
7045 works. And I don't have to worry about writing @edit to deal with
7049 works. And I don't have to worry about writing @edit to deal with
7046 all the editors, less does that.
7050 all the editors, less does that.
7047
7051
7048 * Version 0.1.16 released, 0.1.17 opened.
7052 * Version 0.1.16 released, 0.1.17 opened.
7049
7053
7050 * Fixed some nasty bugs in the page/page_dumb combo that could
7054 * Fixed some nasty bugs in the page/page_dumb combo that could
7051 crash IPython.
7055 crash IPython.
7052
7056
7053 2001-11-27 Fernando Perez <fperez@colorado.edu>
7057 2001-11-27 Fernando Perez <fperez@colorado.edu>
7054
7058
7055 * Version 0.1.15 released, 0.1.16 opened.
7059 * Version 0.1.15 released, 0.1.16 opened.
7056
7060
7057 * Finally got ? and ?? to work for undefined things: now it's
7061 * Finally got ? and ?? to work for undefined things: now it's
7058 possible to type {}.get? and get information about the get method
7062 possible to type {}.get? and get information about the get method
7059 of dicts, or os.path? even if only os is defined (so technically
7063 of dicts, or os.path? even if only os is defined (so technically
7060 os.path isn't). Works at any level. For example, after import os,
7064 os.path isn't). Works at any level. For example, after import os,
7061 os?, os.path?, os.path.abspath? all work. This is great, took some
7065 os?, os.path?, os.path.abspath? all work. This is great, took some
7062 work in _ofind.
7066 work in _ofind.
7063
7067
7064 * Fixed more bugs with logging. The sanest way to do it was to add
7068 * Fixed more bugs with logging. The sanest way to do it was to add
7065 to @log a 'mode' parameter. Killed two in one shot (this mode
7069 to @log a 'mode' parameter. Killed two in one shot (this mode
7066 option was a request of Janko's). I think it's finally clean
7070 option was a request of Janko's). I think it's finally clean
7067 (famous last words).
7071 (famous last words).
7068
7072
7069 * Added a page_dumb() pager which does a decent job of paging on
7073 * Added a page_dumb() pager which does a decent job of paging on
7070 screen, if better things (like less) aren't available. One less
7074 screen, if better things (like less) aren't available. One less
7071 unix dependency (someday maybe somebody will port this to
7075 unix dependency (someday maybe somebody will port this to
7072 windows).
7076 windows).
7073
7077
7074 * Fixed problem in magic_log: would lock of logging out if log
7078 * Fixed problem in magic_log: would lock of logging out if log
7075 creation failed (because it would still think it had succeeded).
7079 creation failed (because it would still think it had succeeded).
7076
7080
7077 * Improved the page() function using curses to auto-detect screen
7081 * Improved the page() function using curses to auto-detect screen
7078 size. Now it can make a much better decision on whether to print
7082 size. Now it can make a much better decision on whether to print
7079 or page a string. Option screen_length was modified: a value 0
7083 or page a string. Option screen_length was modified: a value 0
7080 means auto-detect, and that's the default now.
7084 means auto-detect, and that's the default now.
7081
7085
7082 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
7086 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
7083 go out. I'll test it for a few days, then talk to Janko about
7087 go out. I'll test it for a few days, then talk to Janko about
7084 licences and announce it.
7088 licences and announce it.
7085
7089
7086 * Fixed the length of the auto-generated ---> prompt which appears
7090 * Fixed the length of the auto-generated ---> prompt which appears
7087 for auto-parens and auto-quotes. Getting this right isn't trivial,
7091 for auto-parens and auto-quotes. Getting this right isn't trivial,
7088 with all the color escapes, different prompt types and optional
7092 with all the color escapes, different prompt types and optional
7089 separators. But it seems to be working in all the combinations.
7093 separators. But it seems to be working in all the combinations.
7090
7094
7091 2001-11-26 Fernando Perez <fperez@colorado.edu>
7095 2001-11-26 Fernando Perez <fperez@colorado.edu>
7092
7096
7093 * Wrote a regexp filter to get option types from the option names
7097 * Wrote a regexp filter to get option types from the option names
7094 string. This eliminates the need to manually keep two duplicate
7098 string. This eliminates the need to manually keep two duplicate
7095 lists.
7099 lists.
7096
7100
7097 * Removed the unneeded check_option_names. Now options are handled
7101 * Removed the unneeded check_option_names. Now options are handled
7098 in a much saner manner and it's easy to visually check that things
7102 in a much saner manner and it's easy to visually check that things
7099 are ok.
7103 are ok.
7100
7104
7101 * Updated version numbers on all files I modified to carry a
7105 * Updated version numbers on all files I modified to carry a
7102 notice so Janko and Nathan have clear version markers.
7106 notice so Janko and Nathan have clear version markers.
7103
7107
7104 * Updated docstring for ultraTB with my changes. I should send
7108 * Updated docstring for ultraTB with my changes. I should send
7105 this to Nathan.
7109 this to Nathan.
7106
7110
7107 * Lots of small fixes. Ran everything through pychecker again.
7111 * Lots of small fixes. Ran everything through pychecker again.
7108
7112
7109 * Made loading of deep_reload an cmd line option. If it's not too
7113 * Made loading of deep_reload an cmd line option. If it's not too
7110 kosher, now people can just disable it. With -nodeep_reload it's
7114 kosher, now people can just disable it. With -nodeep_reload it's
7111 still available as dreload(), it just won't overwrite reload().
7115 still available as dreload(), it just won't overwrite reload().
7112
7116
7113 * Moved many options to the no| form (-opt and -noopt
7117 * Moved many options to the no| form (-opt and -noopt
7114 accepted). Cleaner.
7118 accepted). Cleaner.
7115
7119
7116 * Changed magic_log so that if called with no parameters, it uses
7120 * Changed magic_log so that if called with no parameters, it uses
7117 'rotate' mode. That way auto-generated logs aren't automatically
7121 'rotate' mode. That way auto-generated logs aren't automatically
7118 over-written. For normal logs, now a backup is made if it exists
7122 over-written. For normal logs, now a backup is made if it exists
7119 (only 1 level of backups). A new 'backup' mode was added to the
7123 (only 1 level of backups). A new 'backup' mode was added to the
7120 Logger class to support this. This was a request by Janko.
7124 Logger class to support this. This was a request by Janko.
7121
7125
7122 * Added @logoff/@logon to stop/restart an active log.
7126 * Added @logoff/@logon to stop/restart an active log.
7123
7127
7124 * Fixed a lot of bugs in log saving/replay. It was pretty
7128 * Fixed a lot of bugs in log saving/replay. It was pretty
7125 broken. Now special lines (!@,/) appear properly in the command
7129 broken. Now special lines (!@,/) appear properly in the command
7126 history after a log replay.
7130 history after a log replay.
7127
7131
7128 * Tried and failed to implement full session saving via pickle. My
7132 * Tried and failed to implement full session saving via pickle. My
7129 idea was to pickle __main__.__dict__, but modules can't be
7133 idea was to pickle __main__.__dict__, but modules can't be
7130 pickled. This would be a better alternative to replaying logs, but
7134 pickled. This would be a better alternative to replaying logs, but
7131 seems quite tricky to get to work. Changed -session to be called
7135 seems quite tricky to get to work. Changed -session to be called
7132 -logplay, which more accurately reflects what it does. And if we
7136 -logplay, which more accurately reflects what it does. And if we
7133 ever get real session saving working, -session is now available.
7137 ever get real session saving working, -session is now available.
7134
7138
7135 * Implemented color schemes for prompts also. As for tracebacks,
7139 * Implemented color schemes for prompts also. As for tracebacks,
7136 currently only NoColor and Linux are supported. But now the
7140 currently only NoColor and Linux are supported. But now the
7137 infrastructure is in place, based on a generic ColorScheme
7141 infrastructure is in place, based on a generic ColorScheme
7138 class. So writing and activating new schemes both for the prompts
7142 class. So writing and activating new schemes both for the prompts
7139 and the tracebacks should be straightforward.
7143 and the tracebacks should be straightforward.
7140
7144
7141 * Version 0.1.13 released, 0.1.14 opened.
7145 * Version 0.1.13 released, 0.1.14 opened.
7142
7146
7143 * Changed handling of options for output cache. Now counter is
7147 * Changed handling of options for output cache. Now counter is
7144 hardwired starting at 1 and one specifies the maximum number of
7148 hardwired starting at 1 and one specifies the maximum number of
7145 entries *in the outcache* (not the max prompt counter). This is
7149 entries *in the outcache* (not the max prompt counter). This is
7146 much better, since many statements won't increase the cache
7150 much better, since many statements won't increase the cache
7147 count. It also eliminated some confusing options, now there's only
7151 count. It also eliminated some confusing options, now there's only
7148 one: cache_size.
7152 one: cache_size.
7149
7153
7150 * Added 'alias' magic function and magic_alias option in the
7154 * Added 'alias' magic function and magic_alias option in the
7151 ipythonrc file. Now the user can easily define whatever names he
7155 ipythonrc file. Now the user can easily define whatever names he
7152 wants for the magic functions without having to play weird
7156 wants for the magic functions without having to play weird
7153 namespace games. This gives IPython a real shell-like feel.
7157 namespace games. This gives IPython a real shell-like feel.
7154
7158
7155 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
7159 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
7156 @ or not).
7160 @ or not).
7157
7161
7158 This was one of the last remaining 'visible' bugs (that I know
7162 This was one of the last remaining 'visible' bugs (that I know
7159 of). I think if I can clean up the session loading so it works
7163 of). I think if I can clean up the session loading so it works
7160 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
7164 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
7161 about licensing).
7165 about licensing).
7162
7166
7163 2001-11-25 Fernando Perez <fperez@colorado.edu>
7167 2001-11-25 Fernando Perez <fperez@colorado.edu>
7164
7168
7165 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
7169 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
7166 there's a cleaner distinction between what ? and ?? show.
7170 there's a cleaner distinction between what ? and ?? show.
7167
7171
7168 * Added screen_length option. Now the user can define his own
7172 * Added screen_length option. Now the user can define his own
7169 screen size for page() operations.
7173 screen size for page() operations.
7170
7174
7171 * Implemented magic shell-like functions with automatic code
7175 * Implemented magic shell-like functions with automatic code
7172 generation. Now adding another function is just a matter of adding
7176 generation. Now adding another function is just a matter of adding
7173 an entry to a dict, and the function is dynamically generated at
7177 an entry to a dict, and the function is dynamically generated at
7174 run-time. Python has some really cool features!
7178 run-time. Python has some really cool features!
7175
7179
7176 * Renamed many options to cleanup conventions a little. Now all
7180 * Renamed many options to cleanup conventions a little. Now all
7177 are lowercase, and only underscores where needed. Also in the code
7181 are lowercase, and only underscores where needed. Also in the code
7178 option name tables are clearer.
7182 option name tables are clearer.
7179
7183
7180 * Changed prompts a little. Now input is 'In [n]:' instead of
7184 * Changed prompts a little. Now input is 'In [n]:' instead of
7181 'In[n]:='. This allows it the numbers to be aligned with the
7185 'In[n]:='. This allows it the numbers to be aligned with the
7182 Out[n] numbers, and removes usage of ':=' which doesn't exist in
7186 Out[n] numbers, and removes usage of ':=' which doesn't exist in
7183 Python (it was a Mathematica thing). The '...' continuation prompt
7187 Python (it was a Mathematica thing). The '...' continuation prompt
7184 was also changed a little to align better.
7188 was also changed a little to align better.
7185
7189
7186 * Fixed bug when flushing output cache. Not all _p<n> variables
7190 * Fixed bug when flushing output cache. Not all _p<n> variables
7187 exist, so their deletion needs to be wrapped in a try:
7191 exist, so their deletion needs to be wrapped in a try:
7188
7192
7189 * Figured out how to properly use inspect.formatargspec() (it
7193 * Figured out how to properly use inspect.formatargspec() (it
7190 requires the args preceded by *). So I removed all the code from
7194 requires the args preceded by *). So I removed all the code from
7191 _get_pdef in Magic, which was just replicating that.
7195 _get_pdef in Magic, which was just replicating that.
7192
7196
7193 * Added test to prefilter to allow redefining magic function names
7197 * Added test to prefilter to allow redefining magic function names
7194 as variables. This is ok, since the @ form is always available,
7198 as variables. This is ok, since the @ form is always available,
7195 but whe should allow the user to define a variable called 'ls' if
7199 but whe should allow the user to define a variable called 'ls' if
7196 he needs it.
7200 he needs it.
7197
7201
7198 * Moved the ToDo information from README into a separate ToDo.
7202 * Moved the ToDo information from README into a separate ToDo.
7199
7203
7200 * General code cleanup and small bugfixes. I think it's close to a
7204 * General code cleanup and small bugfixes. I think it's close to a
7201 state where it can be released, obviously with a big 'beta'
7205 state where it can be released, obviously with a big 'beta'
7202 warning on it.
7206 warning on it.
7203
7207
7204 * Got the magic function split to work. Now all magics are defined
7208 * Got the magic function split to work. Now all magics are defined
7205 in a separate class. It just organizes things a bit, and now
7209 in a separate class. It just organizes things a bit, and now
7206 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
7210 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
7207 was too long).
7211 was too long).
7208
7212
7209 * Changed @clear to @reset to avoid potential confusions with
7213 * Changed @clear to @reset to avoid potential confusions with
7210 the shell command clear. Also renamed @cl to @clear, which does
7214 the shell command clear. Also renamed @cl to @clear, which does
7211 exactly what people expect it to from their shell experience.
7215 exactly what people expect it to from their shell experience.
7212
7216
7213 Added a check to the @reset command (since it's so
7217 Added a check to the @reset command (since it's so
7214 destructive, it's probably a good idea to ask for confirmation).
7218 destructive, it's probably a good idea to ask for confirmation).
7215 But now reset only works for full namespace resetting. Since the
7219 But now reset only works for full namespace resetting. Since the
7216 del keyword is already there for deleting a few specific
7220 del keyword is already there for deleting a few specific
7217 variables, I don't see the point of having a redundant magic
7221 variables, I don't see the point of having a redundant magic
7218 function for the same task.
7222 function for the same task.
7219
7223
7220 2001-11-24 Fernando Perez <fperez@colorado.edu>
7224 2001-11-24 Fernando Perez <fperez@colorado.edu>
7221
7225
7222 * Updated the builtin docs (esp. the ? ones).
7226 * Updated the builtin docs (esp. the ? ones).
7223
7227
7224 * Ran all the code through pychecker. Not terribly impressed with
7228 * Ran all the code through pychecker. Not terribly impressed with
7225 it: lots of spurious warnings and didn't really find anything of
7229 it: lots of spurious warnings and didn't really find anything of
7226 substance (just a few modules being imported and not used).
7230 substance (just a few modules being imported and not used).
7227
7231
7228 * Implemented the new ultraTB functionality into IPython. New
7232 * Implemented the new ultraTB functionality into IPython. New
7229 option: xcolors. This chooses color scheme. xmode now only selects
7233 option: xcolors. This chooses color scheme. xmode now only selects
7230 between Plain and Verbose. Better orthogonality.
7234 between Plain and Verbose. Better orthogonality.
7231
7235
7232 * Large rewrite of ultraTB. Much cleaner now, with a separation of
7236 * Large rewrite of ultraTB. Much cleaner now, with a separation of
7233 mode and color scheme for the exception handlers. Now it's
7237 mode and color scheme for the exception handlers. Now it's
7234 possible to have the verbose traceback with no coloring.
7238 possible to have the verbose traceback with no coloring.
7235
7239
7236 2001-11-23 Fernando Perez <fperez@colorado.edu>
7240 2001-11-23 Fernando Perez <fperez@colorado.edu>
7237
7241
7238 * Version 0.1.12 released, 0.1.13 opened.
7242 * Version 0.1.12 released, 0.1.13 opened.
7239
7243
7240 * Removed option to set auto-quote and auto-paren escapes by
7244 * Removed option to set auto-quote and auto-paren escapes by
7241 user. The chances of breaking valid syntax are just too high. If
7245 user. The chances of breaking valid syntax are just too high. If
7242 someone *really* wants, they can always dig into the code.
7246 someone *really* wants, they can always dig into the code.
7243
7247
7244 * Made prompt separators configurable.
7248 * Made prompt separators configurable.
7245
7249
7246 2001-11-22 Fernando Perez <fperez@colorado.edu>
7250 2001-11-22 Fernando Perez <fperez@colorado.edu>
7247
7251
7248 * Small bugfixes in many places.
7252 * Small bugfixes in many places.
7249
7253
7250 * Removed the MyCompleter class from ipplib. It seemed redundant
7254 * Removed the MyCompleter class from ipplib. It seemed redundant
7251 with the C-p,C-n history search functionality. Less code to
7255 with the C-p,C-n history search functionality. Less code to
7252 maintain.
7256 maintain.
7253
7257
7254 * Moved all the original ipython.py code into ipythonlib.py. Right
7258 * Moved all the original ipython.py code into ipythonlib.py. Right
7255 now it's just one big dump into a function called make_IPython, so
7259 now it's just one big dump into a function called make_IPython, so
7256 no real modularity has been gained. But at least it makes the
7260 no real modularity has been gained. But at least it makes the
7257 wrapper script tiny, and since ipythonlib is a module, it gets
7261 wrapper script tiny, and since ipythonlib is a module, it gets
7258 compiled and startup is much faster.
7262 compiled and startup is much faster.
7259
7263
7260 This is a reasobably 'deep' change, so we should test it for a
7264 This is a reasobably 'deep' change, so we should test it for a
7261 while without messing too much more with the code.
7265 while without messing too much more with the code.
7262
7266
7263 2001-11-21 Fernando Perez <fperez@colorado.edu>
7267 2001-11-21 Fernando Perez <fperez@colorado.edu>
7264
7268
7265 * Version 0.1.11 released, 0.1.12 opened for further work.
7269 * Version 0.1.11 released, 0.1.12 opened for further work.
7266
7270
7267 * Removed dependency on Itpl. It was only needed in one place. It
7271 * Removed dependency on Itpl. It was only needed in one place. It
7268 would be nice if this became part of python, though. It makes life
7272 would be nice if this became part of python, though. It makes life
7269 *a lot* easier in some cases.
7273 *a lot* easier in some cases.
7270
7274
7271 * Simplified the prefilter code a bit. Now all handlers are
7275 * Simplified the prefilter code a bit. Now all handlers are
7272 expected to explicitly return a value (at least a blank string).
7276 expected to explicitly return a value (at least a blank string).
7273
7277
7274 * Heavy edits in ipplib. Removed the help system altogether. Now
7278 * Heavy edits in ipplib. Removed the help system altogether. Now
7275 obj?/?? is used for inspecting objects, a magic @doc prints
7279 obj?/?? is used for inspecting objects, a magic @doc prints
7276 docstrings, and full-blown Python help is accessed via the 'help'
7280 docstrings, and full-blown Python help is accessed via the 'help'
7277 keyword. This cleans up a lot of code (less to maintain) and does
7281 keyword. This cleans up a lot of code (less to maintain) and does
7278 the job. Since 'help' is now a standard Python component, might as
7282 the job. Since 'help' is now a standard Python component, might as
7279 well use it and remove duplicate functionality.
7283 well use it and remove duplicate functionality.
7280
7284
7281 Also removed the option to use ipplib as a standalone program. By
7285 Also removed the option to use ipplib as a standalone program. By
7282 now it's too dependent on other parts of IPython to function alone.
7286 now it's too dependent on other parts of IPython to function alone.
7283
7287
7284 * Fixed bug in genutils.pager. It would crash if the pager was
7288 * Fixed bug in genutils.pager. It would crash if the pager was
7285 exited immediately after opening (broken pipe).
7289 exited immediately after opening (broken pipe).
7286
7290
7287 * Trimmed down the VerboseTB reporting a little. The header is
7291 * Trimmed down the VerboseTB reporting a little. The header is
7288 much shorter now and the repeated exception arguments at the end
7292 much shorter now and the repeated exception arguments at the end
7289 have been removed. For interactive use the old header seemed a bit
7293 have been removed. For interactive use the old header seemed a bit
7290 excessive.
7294 excessive.
7291
7295
7292 * Fixed small bug in output of @whos for variables with multi-word
7296 * Fixed small bug in output of @whos for variables with multi-word
7293 types (only first word was displayed).
7297 types (only first word was displayed).
7294
7298
7295 2001-11-17 Fernando Perez <fperez@colorado.edu>
7299 2001-11-17 Fernando Perez <fperez@colorado.edu>
7296
7300
7297 * Version 0.1.10 released, 0.1.11 opened for further work.
7301 * Version 0.1.10 released, 0.1.11 opened for further work.
7298
7302
7299 * Modified dirs and friends. dirs now *returns* the stack (not
7303 * Modified dirs and friends. dirs now *returns* the stack (not
7300 prints), so one can manipulate it as a variable. Convenient to
7304 prints), so one can manipulate it as a variable. Convenient to
7301 travel along many directories.
7305 travel along many directories.
7302
7306
7303 * Fixed bug in magic_pdef: would only work with functions with
7307 * Fixed bug in magic_pdef: would only work with functions with
7304 arguments with default values.
7308 arguments with default values.
7305
7309
7306 2001-11-14 Fernando Perez <fperez@colorado.edu>
7310 2001-11-14 Fernando Perez <fperez@colorado.edu>
7307
7311
7308 * Added the PhysicsInput stuff to dot_ipython so it ships as an
7312 * Added the PhysicsInput stuff to dot_ipython so it ships as an
7309 example with IPython. Various other minor fixes and cleanups.
7313 example with IPython. Various other minor fixes and cleanups.
7310
7314
7311 * Version 0.1.9 released, 0.1.10 opened for further work.
7315 * Version 0.1.9 released, 0.1.10 opened for further work.
7312
7316
7313 * Added sys.path to the list of directories searched in the
7317 * Added sys.path to the list of directories searched in the
7314 execfile= option. It used to be the current directory and the
7318 execfile= option. It used to be the current directory and the
7315 user's IPYTHONDIR only.
7319 user's IPYTHONDIR only.
7316
7320
7317 2001-11-13 Fernando Perez <fperez@colorado.edu>
7321 2001-11-13 Fernando Perez <fperez@colorado.edu>
7318
7322
7319 * Reinstated the raw_input/prefilter separation that Janko had
7323 * Reinstated the raw_input/prefilter separation that Janko had
7320 initially. This gives a more convenient setup for extending the
7324 initially. This gives a more convenient setup for extending the
7321 pre-processor from the outside: raw_input always gets a string,
7325 pre-processor from the outside: raw_input always gets a string,
7322 and prefilter has to process it. We can then redefine prefilter
7326 and prefilter has to process it. We can then redefine prefilter
7323 from the outside and implement extensions for special
7327 from the outside and implement extensions for special
7324 purposes.
7328 purposes.
7325
7329
7326 Today I got one for inputting PhysicalQuantity objects
7330 Today I got one for inputting PhysicalQuantity objects
7327 (from Scientific) without needing any function calls at
7331 (from Scientific) without needing any function calls at
7328 all. Extremely convenient, and it's all done as a user-level
7332 all. Extremely convenient, and it's all done as a user-level
7329 extension (no IPython code was touched). Now instead of:
7333 extension (no IPython code was touched). Now instead of:
7330 a = PhysicalQuantity(4.2,'m/s**2')
7334 a = PhysicalQuantity(4.2,'m/s**2')
7331 one can simply say
7335 one can simply say
7332 a = 4.2 m/s**2
7336 a = 4.2 m/s**2
7333 or even
7337 or even
7334 a = 4.2 m/s^2
7338 a = 4.2 m/s^2
7335
7339
7336 I use this, but it's also a proof of concept: IPython really is
7340 I use this, but it's also a proof of concept: IPython really is
7337 fully user-extensible, even at the level of the parsing of the
7341 fully user-extensible, even at the level of the parsing of the
7338 command line. It's not trivial, but it's perfectly doable.
7342 command line. It's not trivial, but it's perfectly doable.
7339
7343
7340 * Added 'add_flip' method to inclusion conflict resolver. Fixes
7344 * Added 'add_flip' method to inclusion conflict resolver. Fixes
7341 the problem of modules being loaded in the inverse order in which
7345 the problem of modules being loaded in the inverse order in which
7342 they were defined in
7346 they were defined in
7343
7347
7344 * Version 0.1.8 released, 0.1.9 opened for further work.
7348 * Version 0.1.8 released, 0.1.9 opened for further work.
7345
7349
7346 * Added magics pdef, source and file. They respectively show the
7350 * Added magics pdef, source and file. They respectively show the
7347 definition line ('prototype' in C), source code and full python
7351 definition line ('prototype' in C), source code and full python
7348 file for any callable object. The object inspector oinfo uses
7352 file for any callable object. The object inspector oinfo uses
7349 these to show the same information.
7353 these to show the same information.
7350
7354
7351 * Version 0.1.7 released, 0.1.8 opened for further work.
7355 * Version 0.1.7 released, 0.1.8 opened for further work.
7352
7356
7353 * Separated all the magic functions into a class called Magic. The
7357 * Separated all the magic functions into a class called Magic. The
7354 InteractiveShell class was becoming too big for Xemacs to handle
7358 InteractiveShell class was becoming too big for Xemacs to handle
7355 (de-indenting a line would lock it up for 10 seconds while it
7359 (de-indenting a line would lock it up for 10 seconds while it
7356 backtracked on the whole class!)
7360 backtracked on the whole class!)
7357
7361
7358 FIXME: didn't work. It can be done, but right now namespaces are
7362 FIXME: didn't work. It can be done, but right now namespaces are
7359 all messed up. Do it later (reverted it for now, so at least
7363 all messed up. Do it later (reverted it for now, so at least
7360 everything works as before).
7364 everything works as before).
7361
7365
7362 * Got the object introspection system (magic_oinfo) working! I
7366 * Got the object introspection system (magic_oinfo) working! I
7363 think this is pretty much ready for release to Janko, so he can
7367 think this is pretty much ready for release to Janko, so he can
7364 test it for a while and then announce it. Pretty much 100% of what
7368 test it for a while and then announce it. Pretty much 100% of what
7365 I wanted for the 'phase 1' release is ready. Happy, tired.
7369 I wanted for the 'phase 1' release is ready. Happy, tired.
7366
7370
7367 2001-11-12 Fernando Perez <fperez@colorado.edu>
7371 2001-11-12 Fernando Perez <fperez@colorado.edu>
7368
7372
7369 * Version 0.1.6 released, 0.1.7 opened for further work.
7373 * Version 0.1.6 released, 0.1.7 opened for further work.
7370
7374
7371 * Fixed bug in printing: it used to test for truth before
7375 * Fixed bug in printing: it used to test for truth before
7372 printing, so 0 wouldn't print. Now checks for None.
7376 printing, so 0 wouldn't print. Now checks for None.
7373
7377
7374 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
7378 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
7375 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
7379 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
7376 reaches by hand into the outputcache. Think of a better way to do
7380 reaches by hand into the outputcache. Think of a better way to do
7377 this later.
7381 this later.
7378
7382
7379 * Various small fixes thanks to Nathan's comments.
7383 * Various small fixes thanks to Nathan's comments.
7380
7384
7381 * Changed magic_pprint to magic_Pprint. This way it doesn't
7385 * Changed magic_pprint to magic_Pprint. This way it doesn't
7382 collide with pprint() and the name is consistent with the command
7386 collide with pprint() and the name is consistent with the command
7383 line option.
7387 line option.
7384
7388
7385 * Changed prompt counter behavior to be fully like
7389 * Changed prompt counter behavior to be fully like
7386 Mathematica's. That is, even input that doesn't return a result
7390 Mathematica's. That is, even input that doesn't return a result
7387 raises the prompt counter. The old behavior was kind of confusing
7391 raises the prompt counter. The old behavior was kind of confusing
7388 (getting the same prompt number several times if the operation
7392 (getting the same prompt number several times if the operation
7389 didn't return a result).
7393 didn't return a result).
7390
7394
7391 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
7395 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
7392
7396
7393 * Fixed -Classic mode (wasn't working anymore).
7397 * Fixed -Classic mode (wasn't working anymore).
7394
7398
7395 * Added colored prompts using Nathan's new code. Colors are
7399 * Added colored prompts using Nathan's new code. Colors are
7396 currently hardwired, they can be user-configurable. For
7400 currently hardwired, they can be user-configurable. For
7397 developers, they can be chosen in file ipythonlib.py, at the
7401 developers, they can be chosen in file ipythonlib.py, at the
7398 beginning of the CachedOutput class def.
7402 beginning of the CachedOutput class def.
7399
7403
7400 2001-11-11 Fernando Perez <fperez@colorado.edu>
7404 2001-11-11 Fernando Perez <fperez@colorado.edu>
7401
7405
7402 * Version 0.1.5 released, 0.1.6 opened for further work.
7406 * Version 0.1.5 released, 0.1.6 opened for further work.
7403
7407
7404 * Changed magic_env to *return* the environment as a dict (not to
7408 * Changed magic_env to *return* the environment as a dict (not to
7405 print it). This way it prints, but it can also be processed.
7409 print it). This way it prints, but it can also be processed.
7406
7410
7407 * Added Verbose exception reporting to interactive
7411 * Added Verbose exception reporting to interactive
7408 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
7412 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
7409 traceback. Had to make some changes to the ultraTB file. This is
7413 traceback. Had to make some changes to the ultraTB file. This is
7410 probably the last 'big' thing in my mental todo list. This ties
7414 probably the last 'big' thing in my mental todo list. This ties
7411 in with the next entry:
7415 in with the next entry:
7412
7416
7413 * Changed -Xi and -Xf to a single -xmode option. Now all the user
7417 * Changed -Xi and -Xf to a single -xmode option. Now all the user
7414 has to specify is Plain, Color or Verbose for all exception
7418 has to specify is Plain, Color or Verbose for all exception
7415 handling.
7419 handling.
7416
7420
7417 * Removed ShellServices option. All this can really be done via
7421 * Removed ShellServices option. All this can really be done via
7418 the magic system. It's easier to extend, cleaner and has automatic
7422 the magic system. It's easier to extend, cleaner and has automatic
7419 namespace protection and documentation.
7423 namespace protection and documentation.
7420
7424
7421 2001-11-09 Fernando Perez <fperez@colorado.edu>
7425 2001-11-09 Fernando Perez <fperez@colorado.edu>
7422
7426
7423 * Fixed bug in output cache flushing (missing parameter to
7427 * Fixed bug in output cache flushing (missing parameter to
7424 __init__). Other small bugs fixed (found using pychecker).
7428 __init__). Other small bugs fixed (found using pychecker).
7425
7429
7426 * Version 0.1.4 opened for bugfixing.
7430 * Version 0.1.4 opened for bugfixing.
7427
7431
7428 2001-11-07 Fernando Perez <fperez@colorado.edu>
7432 2001-11-07 Fernando Perez <fperez@colorado.edu>
7429
7433
7430 * Version 0.1.3 released, mainly because of the raw_input bug.
7434 * Version 0.1.3 released, mainly because of the raw_input bug.
7431
7435
7432 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
7436 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
7433 and when testing for whether things were callable, a call could
7437 and when testing for whether things were callable, a call could
7434 actually be made to certain functions. They would get called again
7438 actually be made to certain functions. They would get called again
7435 once 'really' executed, with a resulting double call. A disaster
7439 once 'really' executed, with a resulting double call. A disaster
7436 in many cases (list.reverse() would never work!).
7440 in many cases (list.reverse() would never work!).
7437
7441
7438 * Removed prefilter() function, moved its code to raw_input (which
7442 * Removed prefilter() function, moved its code to raw_input (which
7439 after all was just a near-empty caller for prefilter). This saves
7443 after all was just a near-empty caller for prefilter). This saves
7440 a function call on every prompt, and simplifies the class a tiny bit.
7444 a function call on every prompt, and simplifies the class a tiny bit.
7441
7445
7442 * Fix _ip to __ip name in magic example file.
7446 * Fix _ip to __ip name in magic example file.
7443
7447
7444 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
7448 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
7445 work with non-gnu versions of tar.
7449 work with non-gnu versions of tar.
7446
7450
7447 2001-11-06 Fernando Perez <fperez@colorado.edu>
7451 2001-11-06 Fernando Perez <fperez@colorado.edu>
7448
7452
7449 * Version 0.1.2. Just to keep track of the recent changes.
7453 * Version 0.1.2. Just to keep track of the recent changes.
7450
7454
7451 * Fixed nasty bug in output prompt routine. It used to check 'if
7455 * Fixed nasty bug in output prompt routine. It used to check 'if
7452 arg != None...'. Problem is, this fails if arg implements a
7456 arg != None...'. Problem is, this fails if arg implements a
7453 special comparison (__cmp__) which disallows comparing to
7457 special comparison (__cmp__) which disallows comparing to
7454 None. Found it when trying to use the PhysicalQuantity module from
7458 None. Found it when trying to use the PhysicalQuantity module from
7455 ScientificPython.
7459 ScientificPython.
7456
7460
7457 2001-11-05 Fernando Perez <fperez@colorado.edu>
7461 2001-11-05 Fernando Perez <fperez@colorado.edu>
7458
7462
7459 * Also added dirs. Now the pushd/popd/dirs family functions
7463 * Also added dirs. Now the pushd/popd/dirs family functions
7460 basically like the shell, with the added convenience of going home
7464 basically like the shell, with the added convenience of going home
7461 when called with no args.
7465 when called with no args.
7462
7466
7463 * pushd/popd slightly modified to mimic shell behavior more
7467 * pushd/popd slightly modified to mimic shell behavior more
7464 closely.
7468 closely.
7465
7469
7466 * Added env,pushd,popd from ShellServices as magic functions. I
7470 * Added env,pushd,popd from ShellServices as magic functions. I
7467 think the cleanest will be to port all desired functions from
7471 think the cleanest will be to port all desired functions from
7468 ShellServices as magics and remove ShellServices altogether. This
7472 ShellServices as magics and remove ShellServices altogether. This
7469 will provide a single, clean way of adding functionality
7473 will provide a single, clean way of adding functionality
7470 (shell-type or otherwise) to IP.
7474 (shell-type or otherwise) to IP.
7471
7475
7472 2001-11-04 Fernando Perez <fperez@colorado.edu>
7476 2001-11-04 Fernando Perez <fperez@colorado.edu>
7473
7477
7474 * Added .ipython/ directory to sys.path. This way users can keep
7478 * Added .ipython/ directory to sys.path. This way users can keep
7475 customizations there and access them via import.
7479 customizations there and access them via import.
7476
7480
7477 2001-11-03 Fernando Perez <fperez@colorado.edu>
7481 2001-11-03 Fernando Perez <fperez@colorado.edu>
7478
7482
7479 * Opened version 0.1.1 for new changes.
7483 * Opened version 0.1.1 for new changes.
7480
7484
7481 * Changed version number to 0.1.0: first 'public' release, sent to
7485 * Changed version number to 0.1.0: first 'public' release, sent to
7482 Nathan and Janko.
7486 Nathan and Janko.
7483
7487
7484 * Lots of small fixes and tweaks.
7488 * Lots of small fixes and tweaks.
7485
7489
7486 * Minor changes to whos format. Now strings are shown, snipped if
7490 * Minor changes to whos format. Now strings are shown, snipped if
7487 too long.
7491 too long.
7488
7492
7489 * Changed ShellServices to work on __main__ so they show up in @who
7493 * Changed ShellServices to work on __main__ so they show up in @who
7490
7494
7491 * Help also works with ? at the end of a line:
7495 * Help also works with ? at the end of a line:
7492 ?sin and sin?
7496 ?sin and sin?
7493 both produce the same effect. This is nice, as often I use the
7497 both produce the same effect. This is nice, as often I use the
7494 tab-complete to find the name of a method, but I used to then have
7498 tab-complete to find the name of a method, but I used to then have
7495 to go to the beginning of the line to put a ? if I wanted more
7499 to go to the beginning of the line to put a ? if I wanted more
7496 info. Now I can just add the ? and hit return. Convenient.
7500 info. Now I can just add the ? and hit return. Convenient.
7497
7501
7498 2001-11-02 Fernando Perez <fperez@colorado.edu>
7502 2001-11-02 Fernando Perez <fperez@colorado.edu>
7499
7503
7500 * Python version check (>=2.1) added.
7504 * Python version check (>=2.1) added.
7501
7505
7502 * Added LazyPython documentation. At this point the docs are quite
7506 * Added LazyPython documentation. At this point the docs are quite
7503 a mess. A cleanup is in order.
7507 a mess. A cleanup is in order.
7504
7508
7505 * Auto-installer created. For some bizarre reason, the zipfiles
7509 * Auto-installer created. For some bizarre reason, the zipfiles
7506 module isn't working on my system. So I made a tar version
7510 module isn't working on my system. So I made a tar version
7507 (hopefully the command line options in various systems won't kill
7511 (hopefully the command line options in various systems won't kill
7508 me).
7512 me).
7509
7513
7510 * Fixes to Struct in genutils. Now all dictionary-like methods are
7514 * Fixes to Struct in genutils. Now all dictionary-like methods are
7511 protected (reasonably).
7515 protected (reasonably).
7512
7516
7513 * Added pager function to genutils and changed ? to print usage
7517 * Added pager function to genutils and changed ? to print usage
7514 note through it (it was too long).
7518 note through it (it was too long).
7515
7519
7516 * Added the LazyPython functionality. Works great! I changed the
7520 * Added the LazyPython functionality. Works great! I changed the
7517 auto-quote escape to ';', it's on home row and next to '. But
7521 auto-quote escape to ';', it's on home row and next to '. But
7518 both auto-quote and auto-paren (still /) escapes are command-line
7522 both auto-quote and auto-paren (still /) escapes are command-line
7519 parameters.
7523 parameters.
7520
7524
7521
7525
7522 2001-11-01 Fernando Perez <fperez@colorado.edu>
7526 2001-11-01 Fernando Perez <fperez@colorado.edu>
7523
7527
7524 * Version changed to 0.0.7. Fairly large change: configuration now
7528 * Version changed to 0.0.7. Fairly large change: configuration now
7525 is all stored in a directory, by default .ipython. There, all
7529 is all stored in a directory, by default .ipython. There, all
7526 config files have normal looking names (not .names)
7530 config files have normal looking names (not .names)
7527
7531
7528 * Version 0.0.6 Released first to Lucas and Archie as a test
7532 * Version 0.0.6 Released first to Lucas and Archie as a test
7529 run. Since it's the first 'semi-public' release, change version to
7533 run. Since it's the first 'semi-public' release, change version to
7530 > 0.0.6 for any changes now.
7534 > 0.0.6 for any changes now.
7531
7535
7532 * Stuff I had put in the ipplib.py changelog:
7536 * Stuff I had put in the ipplib.py changelog:
7533
7537
7534 Changes to InteractiveShell:
7538 Changes to InteractiveShell:
7535
7539
7536 - Made the usage message a parameter.
7540 - Made the usage message a parameter.
7537
7541
7538 - Require the name of the shell variable to be given. It's a bit
7542 - Require the name of the shell variable to be given. It's a bit
7539 of a hack, but allows the name 'shell' not to be hardwired in the
7543 of a hack, but allows the name 'shell' not to be hardwired in the
7540 magic (@) handler, which is problematic b/c it requires
7544 magic (@) handler, which is problematic b/c it requires
7541 polluting the global namespace with 'shell'. This in turn is
7545 polluting the global namespace with 'shell'. This in turn is
7542 fragile: if a user redefines a variable called shell, things
7546 fragile: if a user redefines a variable called shell, things
7543 break.
7547 break.
7544
7548
7545 - magic @: all functions available through @ need to be defined
7549 - magic @: all functions available through @ need to be defined
7546 as magic_<name>, even though they can be called simply as
7550 as magic_<name>, even though they can be called simply as
7547 @<name>. This allows the special command @magic to gather
7551 @<name>. This allows the special command @magic to gather
7548 information automatically about all existing magic functions,
7552 information automatically about all existing magic functions,
7549 even if they are run-time user extensions, by parsing the shell
7553 even if they are run-time user extensions, by parsing the shell
7550 instance __dict__ looking for special magic_ names.
7554 instance __dict__ looking for special magic_ names.
7551
7555
7552 - mainloop: added *two* local namespace parameters. This allows
7556 - mainloop: added *two* local namespace parameters. This allows
7553 the class to differentiate between parameters which were there
7557 the class to differentiate between parameters which were there
7554 before and after command line initialization was processed. This
7558 before and after command line initialization was processed. This
7555 way, later @who can show things loaded at startup by the
7559 way, later @who can show things loaded at startup by the
7556 user. This trick was necessary to make session saving/reloading
7560 user. This trick was necessary to make session saving/reloading
7557 really work: ideally after saving/exiting/reloading a session,
7561 really work: ideally after saving/exiting/reloading a session,
7558 *everything* should look the same, including the output of @who. I
7562 *everything* should look the same, including the output of @who. I
7559 was only able to make this work with this double namespace
7563 was only able to make this work with this double namespace
7560 trick.
7564 trick.
7561
7565
7562 - added a header to the logfile which allows (almost) full
7566 - added a header to the logfile which allows (almost) full
7563 session restoring.
7567 session restoring.
7564
7568
7565 - prepend lines beginning with @ or !, with a and log
7569 - prepend lines beginning with @ or !, with a and log
7566 them. Why? !lines: may be useful to know what you did @lines:
7570 them. Why? !lines: may be useful to know what you did @lines:
7567 they may affect session state. So when restoring a session, at
7571 they may affect session state. So when restoring a session, at
7568 least inform the user of their presence. I couldn't quite get
7572 least inform the user of their presence. I couldn't quite get
7569 them to properly re-execute, but at least the user is warned.
7573 them to properly re-execute, but at least the user is warned.
7570
7574
7571 * Started ChangeLog.
7575 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now