##// END OF EJS Templates
SList.grep()
vivainio -
Show More
@@ -1,1896 +1,1911 b''
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 2661 2007-08-22 20:43:34Z vivainio $"""
8 $Id: genutils.py 2726 2007-09-07 15:07:17Z 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 os
25 import os
26 import re
26 import re
27 import shlex
27 import shlex
28 import shutil
28 import shutil
29 import sys
29 import sys
30 import tempfile
30 import tempfile
31 import time
31 import time
32 import types
32 import types
33 import warnings
33 import warnings
34
34
35 # Other IPython utilities
35 # Other IPython utilities
36 import IPython
36 import IPython
37 from IPython.Itpl import Itpl,itpl,printpl
37 from IPython.Itpl import Itpl,itpl,printpl
38 from IPython import DPyGetOpt, platutils
38 from IPython import DPyGetOpt, platutils
39 from IPython.generics import result_display
39 from IPython.generics import result_display
40 from path import path
40 from path import path
41 if os.name == "nt":
41 if os.name == "nt":
42 from IPython.winconsole import get_console_size
42 from IPython.winconsole import get_console_size
43
43
44 #****************************************************************************
44 #****************************************************************************
45 # Exceptions
45 # Exceptions
46 class Error(Exception):
46 class Error(Exception):
47 """Base class for exceptions in this module."""
47 """Base class for exceptions in this module."""
48 pass
48 pass
49
49
50 #----------------------------------------------------------------------------
50 #----------------------------------------------------------------------------
51 class IOStream:
51 class IOStream:
52 def __init__(self,stream,fallback):
52 def __init__(self,stream,fallback):
53 if not hasattr(stream,'write') or not hasattr(stream,'flush'):
53 if not hasattr(stream,'write') or not hasattr(stream,'flush'):
54 stream = fallback
54 stream = fallback
55 self.stream = stream
55 self.stream = stream
56 self._swrite = stream.write
56 self._swrite = stream.write
57 self.flush = stream.flush
57 self.flush = stream.flush
58
58
59 def write(self,data):
59 def write(self,data):
60 try:
60 try:
61 self._swrite(data)
61 self._swrite(data)
62 except:
62 except:
63 try:
63 try:
64 # print handles some unicode issues which may trip a plain
64 # print handles some unicode issues which may trip a plain
65 # write() call. Attempt to emulate write() by using a
65 # write() call. Attempt to emulate write() by using a
66 # trailing comma
66 # trailing comma
67 print >> self.stream, data,
67 print >> self.stream, data,
68 except:
68 except:
69 # if we get here, something is seriously broken.
69 # if we get here, something is seriously broken.
70 print >> sys.stderr, \
70 print >> sys.stderr, \
71 'ERROR - failed to write data to stream:', self.stream
71 'ERROR - failed to write data to stream:', self.stream
72
72
73 def close(self):
73 def close(self):
74 pass
74 pass
75
75
76
76
77 class IOTerm:
77 class IOTerm:
78 """ Term holds the file or file-like objects for handling I/O operations.
78 """ Term holds the file or file-like objects for handling I/O operations.
79
79
80 These are normally just sys.stdin, sys.stdout and sys.stderr but for
80 These are normally just sys.stdin, sys.stdout and sys.stderr but for
81 Windows they can can replaced to allow editing the strings before they are
81 Windows they can can replaced to allow editing the strings before they are
82 displayed."""
82 displayed."""
83
83
84 # In the future, having IPython channel all its I/O operations through
84 # In the future, having IPython channel all its I/O operations through
85 # this class will make it easier to embed it into other environments which
85 # this class will make it easier to embed it into other environments which
86 # are not a normal terminal (such as a GUI-based shell)
86 # are not a normal terminal (such as a GUI-based shell)
87 def __init__(self,cin=None,cout=None,cerr=None):
87 def __init__(self,cin=None,cout=None,cerr=None):
88 self.cin = IOStream(cin,sys.stdin)
88 self.cin = IOStream(cin,sys.stdin)
89 self.cout = IOStream(cout,sys.stdout)
89 self.cout = IOStream(cout,sys.stdout)
90 self.cerr = IOStream(cerr,sys.stderr)
90 self.cerr = IOStream(cerr,sys.stderr)
91
91
92 # Global variable to be used for all I/O
92 # Global variable to be used for all I/O
93 Term = IOTerm()
93 Term = IOTerm()
94
94
95 import IPython.rlineimpl as readline
95 import IPython.rlineimpl as readline
96 # Remake Term to use the readline i/o facilities
96 # Remake Term to use the readline i/o facilities
97 if sys.platform == 'win32' and readline.have_readline:
97 if sys.platform == 'win32' and readline.have_readline:
98
98
99 Term = IOTerm(cout=readline._outputfile,cerr=readline._outputfile)
99 Term = IOTerm(cout=readline._outputfile,cerr=readline._outputfile)
100
100
101
101
102 #****************************************************************************
102 #****************************************************************************
103 # Generic warning/error printer, used by everything else
103 # Generic warning/error printer, used by everything else
104 def warn(msg,level=2,exit_val=1):
104 def warn(msg,level=2,exit_val=1):
105 """Standard warning printer. Gives formatting consistency.
105 """Standard warning printer. Gives formatting consistency.
106
106
107 Output is sent to Term.cerr (sys.stderr by default).
107 Output is sent to Term.cerr (sys.stderr by default).
108
108
109 Options:
109 Options:
110
110
111 -level(2): allows finer control:
111 -level(2): allows finer control:
112 0 -> Do nothing, dummy function.
112 0 -> Do nothing, dummy function.
113 1 -> Print message.
113 1 -> Print message.
114 2 -> Print 'WARNING:' + message. (Default level).
114 2 -> Print 'WARNING:' + message. (Default level).
115 3 -> Print 'ERROR:' + message.
115 3 -> Print 'ERROR:' + message.
116 4 -> Print 'FATAL ERROR:' + message and trigger a sys.exit(exit_val).
116 4 -> Print 'FATAL ERROR:' + message and trigger a sys.exit(exit_val).
117
117
118 -exit_val (1): exit value returned by sys.exit() for a level 4
118 -exit_val (1): exit value returned by sys.exit() for a level 4
119 warning. Ignored for all other levels."""
119 warning. Ignored for all other levels."""
120
120
121 if level>0:
121 if level>0:
122 header = ['','','WARNING: ','ERROR: ','FATAL ERROR: ']
122 header = ['','','WARNING: ','ERROR: ','FATAL ERROR: ']
123 print >> Term.cerr, '%s%s' % (header[level],msg)
123 print >> Term.cerr, '%s%s' % (header[level],msg)
124 if level == 4:
124 if level == 4:
125 print >> Term.cerr,'Exiting.\n'
125 print >> Term.cerr,'Exiting.\n'
126 sys.exit(exit_val)
126 sys.exit(exit_val)
127
127
128 def info(msg):
128 def info(msg):
129 """Equivalent to warn(msg,level=1)."""
129 """Equivalent to warn(msg,level=1)."""
130
130
131 warn(msg,level=1)
131 warn(msg,level=1)
132
132
133 def error(msg):
133 def error(msg):
134 """Equivalent to warn(msg,level=3)."""
134 """Equivalent to warn(msg,level=3)."""
135
135
136 warn(msg,level=3)
136 warn(msg,level=3)
137
137
138 def fatal(msg,exit_val=1):
138 def fatal(msg,exit_val=1):
139 """Equivalent to warn(msg,exit_val=exit_val,level=4)."""
139 """Equivalent to warn(msg,exit_val=exit_val,level=4)."""
140
140
141 warn(msg,exit_val=exit_val,level=4)
141 warn(msg,exit_val=exit_val,level=4)
142
142
143 #---------------------------------------------------------------------------
143 #---------------------------------------------------------------------------
144 # Debugging routines
144 # Debugging routines
145 #
145 #
146 def debugx(expr,pre_msg=''):
146 def debugx(expr,pre_msg=''):
147 """Print the value of an expression from the caller's frame.
147 """Print the value of an expression from the caller's frame.
148
148
149 Takes an expression, evaluates it in the caller's frame and prints both
149 Takes an expression, evaluates it in the caller's frame and prints both
150 the given expression and the resulting value (as well as a debug mark
150 the given expression and the resulting value (as well as a debug mark
151 indicating the name of the calling function. The input must be of a form
151 indicating the name of the calling function. The input must be of a form
152 suitable for eval().
152 suitable for eval().
153
153
154 An optional message can be passed, which will be prepended to the printed
154 An optional message can be passed, which will be prepended to the printed
155 expr->value pair."""
155 expr->value pair."""
156
156
157 cf = sys._getframe(1)
157 cf = sys._getframe(1)
158 print '[DBG:%s] %s%s -> %r' % (cf.f_code.co_name,pre_msg,expr,
158 print '[DBG:%s] %s%s -> %r' % (cf.f_code.co_name,pre_msg,expr,
159 eval(expr,cf.f_globals,cf.f_locals))
159 eval(expr,cf.f_globals,cf.f_locals))
160
160
161 # deactivate it by uncommenting the following line, which makes it a no-op
161 # deactivate it by uncommenting the following line, which makes it a no-op
162 #def debugx(expr,pre_msg=''): pass
162 #def debugx(expr,pre_msg=''): pass
163
163
164 #----------------------------------------------------------------------------
164 #----------------------------------------------------------------------------
165 StringTypes = types.StringTypes
165 StringTypes = types.StringTypes
166
166
167 # Basic timing functionality
167 # Basic timing functionality
168
168
169 # If possible (Unix), use the resource module instead of time.clock()
169 # If possible (Unix), use the resource module instead of time.clock()
170 try:
170 try:
171 import resource
171 import resource
172 def clocku():
172 def clocku():
173 """clocku() -> floating point number
173 """clocku() -> floating point number
174
174
175 Return the *USER* CPU time in seconds since the start of the process.
175 Return the *USER* CPU time in seconds since the start of the process.
176 This is done via a call to resource.getrusage, so it avoids the
176 This is done via a call to resource.getrusage, so it avoids the
177 wraparound problems in time.clock()."""
177 wraparound problems in time.clock()."""
178
178
179 return resource.getrusage(resource.RUSAGE_SELF)[0]
179 return resource.getrusage(resource.RUSAGE_SELF)[0]
180
180
181 def clocks():
181 def clocks():
182 """clocks() -> floating point number
182 """clocks() -> floating point number
183
183
184 Return the *SYSTEM* CPU time in seconds since the start of the process.
184 Return the *SYSTEM* CPU time in seconds since the start of the process.
185 This is done via a call to resource.getrusage, so it avoids the
185 This is done via a call to resource.getrusage, so it avoids the
186 wraparound problems in time.clock()."""
186 wraparound problems in time.clock()."""
187
187
188 return resource.getrusage(resource.RUSAGE_SELF)[1]
188 return resource.getrusage(resource.RUSAGE_SELF)[1]
189
189
190 def clock():
190 def clock():
191 """clock() -> floating point number
191 """clock() -> floating point number
192
192
193 Return the *TOTAL USER+SYSTEM* CPU time in seconds since the start of
193 Return the *TOTAL USER+SYSTEM* CPU time in seconds since the start of
194 the process. This is done via a call to resource.getrusage, so it
194 the process. This is done via a call to resource.getrusage, so it
195 avoids the wraparound problems in time.clock()."""
195 avoids the wraparound problems in time.clock()."""
196
196
197 u,s = resource.getrusage(resource.RUSAGE_SELF)[:2]
197 u,s = resource.getrusage(resource.RUSAGE_SELF)[:2]
198 return u+s
198 return u+s
199
199
200 def clock2():
200 def clock2():
201 """clock2() -> (t_user,t_system)
201 """clock2() -> (t_user,t_system)
202
202
203 Similar to clock(), but return a tuple of user/system times."""
203 Similar to clock(), but return a tuple of user/system times."""
204 return resource.getrusage(resource.RUSAGE_SELF)[:2]
204 return resource.getrusage(resource.RUSAGE_SELF)[:2]
205
205
206 except ImportError:
206 except ImportError:
207 # There is no distinction of user/system time under windows, so we just use
207 # There is no distinction of user/system time under windows, so we just use
208 # time.clock() for everything...
208 # time.clock() for everything...
209 clocku = clocks = clock = time.clock
209 clocku = clocks = clock = time.clock
210 def clock2():
210 def clock2():
211 """Under windows, system CPU time can't be measured.
211 """Under windows, system CPU time can't be measured.
212
212
213 This just returns clock() and zero."""
213 This just returns clock() and zero."""
214 return time.clock(),0.0
214 return time.clock(),0.0
215
215
216 def timings_out(reps,func,*args,**kw):
216 def timings_out(reps,func,*args,**kw):
217 """timings_out(reps,func,*args,**kw) -> (t_total,t_per_call,output)
217 """timings_out(reps,func,*args,**kw) -> (t_total,t_per_call,output)
218
218
219 Execute a function reps times, return a tuple with the elapsed total
219 Execute a function reps times, return a tuple with the elapsed total
220 CPU time in seconds, the time per call and the function's output.
220 CPU time in seconds, the time per call and the function's output.
221
221
222 Under Unix, the return value is the sum of user+system time consumed by
222 Under Unix, the return value is the sum of user+system time consumed by
223 the process, computed via the resource module. This prevents problems
223 the process, computed via the resource module. This prevents problems
224 related to the wraparound effect which the time.clock() function has.
224 related to the wraparound effect which the time.clock() function has.
225
225
226 Under Windows the return value is in wall clock seconds. See the
226 Under Windows the return value is in wall clock seconds. See the
227 documentation for the time module for more details."""
227 documentation for the time module for more details."""
228
228
229 reps = int(reps)
229 reps = int(reps)
230 assert reps >=1, 'reps must be >= 1'
230 assert reps >=1, 'reps must be >= 1'
231 if reps==1:
231 if reps==1:
232 start = clock()
232 start = clock()
233 out = func(*args,**kw)
233 out = func(*args,**kw)
234 tot_time = clock()-start
234 tot_time = clock()-start
235 else:
235 else:
236 rng = xrange(reps-1) # the last time is executed separately to store output
236 rng = xrange(reps-1) # the last time is executed separately to store output
237 start = clock()
237 start = clock()
238 for dummy in rng: func(*args,**kw)
238 for dummy in rng: func(*args,**kw)
239 out = func(*args,**kw) # one last time
239 out = func(*args,**kw) # one last time
240 tot_time = clock()-start
240 tot_time = clock()-start
241 av_time = tot_time / reps
241 av_time = tot_time / reps
242 return tot_time,av_time,out
242 return tot_time,av_time,out
243
243
244 def timings(reps,func,*args,**kw):
244 def timings(reps,func,*args,**kw):
245 """timings(reps,func,*args,**kw) -> (t_total,t_per_call)
245 """timings(reps,func,*args,**kw) -> (t_total,t_per_call)
246
246
247 Execute a function reps times, return a tuple with the elapsed total CPU
247 Execute a function reps times, return a tuple with the elapsed total CPU
248 time in seconds and the time per call. These are just the first two values
248 time in seconds and the time per call. These are just the first two values
249 in timings_out()."""
249 in timings_out()."""
250
250
251 return timings_out(reps,func,*args,**kw)[0:2]
251 return timings_out(reps,func,*args,**kw)[0:2]
252
252
253 def timing(func,*args,**kw):
253 def timing(func,*args,**kw):
254 """timing(func,*args,**kw) -> t_total
254 """timing(func,*args,**kw) -> t_total
255
255
256 Execute a function once, return the elapsed total CPU time in
256 Execute a function once, return the elapsed total CPU time in
257 seconds. This is just the first value in timings_out()."""
257 seconds. This is just the first value in timings_out()."""
258
258
259 return timings_out(1,func,*args,**kw)[0]
259 return timings_out(1,func,*args,**kw)[0]
260
260
261 #****************************************************************************
261 #****************************************************************************
262 # file and system
262 # file and system
263
263
264 def arg_split(s,posix=False):
264 def arg_split(s,posix=False):
265 """Split a command line's arguments in a shell-like manner.
265 """Split a command line's arguments in a shell-like manner.
266
266
267 This is a modified version of the standard library's shlex.split()
267 This is a modified version of the standard library's shlex.split()
268 function, but with a default of posix=False for splitting, so that quotes
268 function, but with a default of posix=False for splitting, so that quotes
269 in inputs are respected."""
269 in inputs are respected."""
270
270
271 # XXX - there may be unicode-related problems here!!! I'm not sure that
271 # XXX - there may be unicode-related problems here!!! I'm not sure that
272 # shlex is truly unicode-safe, so it might be necessary to do
272 # shlex is truly unicode-safe, so it might be necessary to do
273 #
273 #
274 # s = s.encode(sys.stdin.encoding)
274 # s = s.encode(sys.stdin.encoding)
275 #
275 #
276 # first, to ensure that shlex gets a normal string. Input from anyone who
276 # first, to ensure that shlex gets a normal string. Input from anyone who
277 # knows more about unicode and shlex than I would be good to have here...
277 # knows more about unicode and shlex than I would be good to have here...
278 lex = shlex.shlex(s, posix=posix)
278 lex = shlex.shlex(s, posix=posix)
279 lex.whitespace_split = True
279 lex.whitespace_split = True
280 return list(lex)
280 return list(lex)
281
281
282 def system(cmd,verbose=0,debug=0,header=''):
282 def system(cmd,verbose=0,debug=0,header=''):
283 """Execute a system command, return its exit status.
283 """Execute a system command, return its exit status.
284
284
285 Options:
285 Options:
286
286
287 - verbose (0): print the command to be executed.
287 - verbose (0): print the command to be executed.
288
288
289 - debug (0): only print, do not actually execute.
289 - debug (0): only print, do not actually execute.
290
290
291 - header (''): Header to print on screen prior to the executed command (it
291 - header (''): Header to print on screen prior to the executed command (it
292 is only prepended to the command, no newlines are added).
292 is only prepended to the command, no newlines are added).
293
293
294 Note: a stateful version of this function is available through the
294 Note: a stateful version of this function is available through the
295 SystemExec class."""
295 SystemExec class."""
296
296
297 stat = 0
297 stat = 0
298 if verbose or debug: print header+cmd
298 if verbose or debug: print header+cmd
299 sys.stdout.flush()
299 sys.stdout.flush()
300 if not debug: stat = os.system(cmd)
300 if not debug: stat = os.system(cmd)
301 return stat
301 return stat
302
302
303 def abbrev_cwd():
303 def abbrev_cwd():
304 """ Return abbreviated version of cwd, e.g. d:mydir """
304 """ Return abbreviated version of cwd, e.g. d:mydir """
305 cwd = os.getcwd()
305 cwd = os.getcwd()
306 drivepart = ''
306 drivepart = ''
307 if sys.platform == 'win32':
307 if sys.platform == 'win32':
308 if len(cwd) < 4:
308 if len(cwd) < 4:
309 return cwd
309 return cwd
310 drivepart = os.path.splitdrive(cwd)[0]
310 drivepart = os.path.splitdrive(cwd)[0]
311 return (drivepart + (
311 return (drivepart + (
312 cwd == '/' and '/' or \
312 cwd == '/' and '/' or \
313 os.path.basename(cwd)))
313 os.path.basename(cwd)))
314
314
315
315
316 # This function is used by ipython in a lot of places to make system calls.
316 # This function is used by ipython in a lot of places to make system calls.
317 # We need it to be slightly different under win32, due to the vagaries of
317 # We need it to be slightly different under win32, due to the vagaries of
318 # 'network shares'. A win32 override is below.
318 # 'network shares'. A win32 override is below.
319
319
320 def shell(cmd,verbose=0,debug=0,header=''):
320 def shell(cmd,verbose=0,debug=0,header=''):
321 """Execute a command in the system shell, always return None.
321 """Execute a command in the system shell, always return None.
322
322
323 Options:
323 Options:
324
324
325 - verbose (0): print the command to be executed.
325 - verbose (0): print the command to be executed.
326
326
327 - debug (0): only print, do not actually execute.
327 - debug (0): only print, do not actually execute.
328
328
329 - header (''): Header to print on screen prior to the executed command (it
329 - header (''): Header to print on screen prior to the executed command (it
330 is only prepended to the command, no newlines are added).
330 is only prepended to the command, no newlines are added).
331
331
332 Note: this is similar to genutils.system(), but it returns None so it can
332 Note: this is similar to genutils.system(), but it returns None so it can
333 be conveniently used in interactive loops without getting the return value
333 be conveniently used in interactive loops without getting the return value
334 (typically 0) printed many times."""
334 (typically 0) printed many times."""
335
335
336 stat = 0
336 stat = 0
337 if verbose or debug: print header+cmd
337 if verbose or debug: print header+cmd
338 # flush stdout so we don't mangle python's buffering
338 # flush stdout so we don't mangle python's buffering
339 sys.stdout.flush()
339 sys.stdout.flush()
340
340
341 if not debug:
341 if not debug:
342 platutils.set_term_title("IPy " + cmd)
342 platutils.set_term_title("IPy " + cmd)
343 os.system(cmd)
343 os.system(cmd)
344 platutils.set_term_title("IPy " + abbrev_cwd())
344 platutils.set_term_title("IPy " + abbrev_cwd())
345
345
346 # override shell() for win32 to deal with network shares
346 # override shell() for win32 to deal with network shares
347 if os.name in ('nt','dos'):
347 if os.name in ('nt','dos'):
348
348
349 shell_ori = shell
349 shell_ori = shell
350
350
351 def shell(cmd,verbose=0,debug=0,header=''):
351 def shell(cmd,verbose=0,debug=0,header=''):
352 if os.getcwd().startswith(r"\\"):
352 if os.getcwd().startswith(r"\\"):
353 path = os.getcwd()
353 path = os.getcwd()
354 # change to c drive (cannot be on UNC-share when issuing os.system,
354 # change to c drive (cannot be on UNC-share when issuing os.system,
355 # as cmd.exe cannot handle UNC addresses)
355 # as cmd.exe cannot handle UNC addresses)
356 os.chdir("c:")
356 os.chdir("c:")
357 # issue pushd to the UNC-share and then run the command
357 # issue pushd to the UNC-share and then run the command
358 try:
358 try:
359 shell_ori('"pushd %s&&"'%path+cmd,verbose,debug,header)
359 shell_ori('"pushd %s&&"'%path+cmd,verbose,debug,header)
360 finally:
360 finally:
361 os.chdir(path)
361 os.chdir(path)
362 else:
362 else:
363 shell_ori(cmd,verbose,debug,header)
363 shell_ori(cmd,verbose,debug,header)
364
364
365 shell.__doc__ = shell_ori.__doc__
365 shell.__doc__ = shell_ori.__doc__
366
366
367 def getoutput(cmd,verbose=0,debug=0,header='',split=0):
367 def getoutput(cmd,verbose=0,debug=0,header='',split=0):
368 """Dummy substitute for perl's backquotes.
368 """Dummy substitute for perl's backquotes.
369
369
370 Executes a command and returns the output.
370 Executes a command and returns the output.
371
371
372 Accepts the same arguments as system(), plus:
372 Accepts the same arguments as system(), plus:
373
373
374 - split(0): if true, the output is returned as a list split on newlines.
374 - split(0): if true, the output is returned as a list split on newlines.
375
375
376 Note: a stateful version of this function is available through the
376 Note: a stateful version of this function is available through the
377 SystemExec class.
377 SystemExec class.
378
378
379 This is pretty much deprecated and rarely used,
379 This is pretty much deprecated and rarely used,
380 genutils.getoutputerror may be what you need.
380 genutils.getoutputerror may be what you need.
381
381
382 """
382 """
383
383
384 if verbose or debug: print header+cmd
384 if verbose or debug: print header+cmd
385 if not debug:
385 if not debug:
386 output = os.popen(cmd).read()
386 output = os.popen(cmd).read()
387 # stipping last \n is here for backwards compat.
387 # stipping last \n is here for backwards compat.
388 if output.endswith('\n'):
388 if output.endswith('\n'):
389 output = output[:-1]
389 output = output[:-1]
390 if split:
390 if split:
391 return output.split('\n')
391 return output.split('\n')
392 else:
392 else:
393 return output
393 return output
394
394
395 def getoutputerror(cmd,verbose=0,debug=0,header='',split=0):
395 def getoutputerror(cmd,verbose=0,debug=0,header='',split=0):
396 """Return (standard output,standard error) of executing cmd in a shell.
396 """Return (standard output,standard error) of executing cmd in a shell.
397
397
398 Accepts the same arguments as system(), plus:
398 Accepts the same arguments as system(), plus:
399
399
400 - split(0): if true, each of stdout/err is returned as a list split on
400 - split(0): if true, each of stdout/err is returned as a list split on
401 newlines.
401 newlines.
402
402
403 Note: a stateful version of this function is available through the
403 Note: a stateful version of this function is available through the
404 SystemExec class."""
404 SystemExec class."""
405
405
406 if verbose or debug: print header+cmd
406 if verbose or debug: print header+cmd
407 if not cmd:
407 if not cmd:
408 if split:
408 if split:
409 return [],[]
409 return [],[]
410 else:
410 else:
411 return '',''
411 return '',''
412 if not debug:
412 if not debug:
413 pin,pout,perr = os.popen3(cmd)
413 pin,pout,perr = os.popen3(cmd)
414 tout = pout.read().rstrip()
414 tout = pout.read().rstrip()
415 terr = perr.read().rstrip()
415 terr = perr.read().rstrip()
416 pin.close()
416 pin.close()
417 pout.close()
417 pout.close()
418 perr.close()
418 perr.close()
419 if split:
419 if split:
420 return tout.split('\n'),terr.split('\n')
420 return tout.split('\n'),terr.split('\n')
421 else:
421 else:
422 return tout,terr
422 return tout,terr
423
423
424 # for compatibility with older naming conventions
424 # for compatibility with older naming conventions
425 xsys = system
425 xsys = system
426 bq = getoutput
426 bq = getoutput
427
427
428 class SystemExec:
428 class SystemExec:
429 """Access the system and getoutput functions through a stateful interface.
429 """Access the system and getoutput functions through a stateful interface.
430
430
431 Note: here we refer to the system and getoutput functions from this
431 Note: here we refer to the system and getoutput functions from this
432 library, not the ones from the standard python library.
432 library, not the ones from the standard python library.
433
433
434 This class offers the system and getoutput functions as methods, but the
434 This class offers the system and getoutput functions as methods, but the
435 verbose, debug and header parameters can be set for the instance (at
435 verbose, debug and header parameters can be set for the instance (at
436 creation time or later) so that they don't need to be specified on each
436 creation time or later) so that they don't need to be specified on each
437 call.
437 call.
438
438
439 For efficiency reasons, there's no way to override the parameters on a
439 For efficiency reasons, there's no way to override the parameters on a
440 per-call basis other than by setting instance attributes. If you need
440 per-call basis other than by setting instance attributes. If you need
441 local overrides, it's best to directly call system() or getoutput().
441 local overrides, it's best to directly call system() or getoutput().
442
442
443 The following names are provided as alternate options:
443 The following names are provided as alternate options:
444 - xsys: alias to system
444 - xsys: alias to system
445 - bq: alias to getoutput
445 - bq: alias to getoutput
446
446
447 An instance can then be created as:
447 An instance can then be created as:
448 >>> sysexec = SystemExec(verbose=1,debug=0,header='Calling: ')
448 >>> sysexec = SystemExec(verbose=1,debug=0,header='Calling: ')
449
449
450 And used as:
450 And used as:
451 >>> sysexec.xsys('pwd')
451 >>> sysexec.xsys('pwd')
452 >>> dirlist = sysexec.bq('ls -l')
452 >>> dirlist = sysexec.bq('ls -l')
453 """
453 """
454
454
455 def __init__(self,verbose=0,debug=0,header='',split=0):
455 def __init__(self,verbose=0,debug=0,header='',split=0):
456 """Specify the instance's values for verbose, debug and header."""
456 """Specify the instance's values for verbose, debug and header."""
457 setattr_list(self,'verbose debug header split')
457 setattr_list(self,'verbose debug header split')
458
458
459 def system(self,cmd):
459 def system(self,cmd):
460 """Stateful interface to system(), with the same keyword parameters."""
460 """Stateful interface to system(), with the same keyword parameters."""
461
461
462 system(cmd,self.verbose,self.debug,self.header)
462 system(cmd,self.verbose,self.debug,self.header)
463
463
464 def shell(self,cmd):
464 def shell(self,cmd):
465 """Stateful interface to shell(), with the same keyword parameters."""
465 """Stateful interface to shell(), with the same keyword parameters."""
466
466
467 shell(cmd,self.verbose,self.debug,self.header)
467 shell(cmd,self.verbose,self.debug,self.header)
468
468
469 xsys = system # alias
469 xsys = system # alias
470
470
471 def getoutput(self,cmd):
471 def getoutput(self,cmd):
472 """Stateful interface to getoutput()."""
472 """Stateful interface to getoutput()."""
473
473
474 return getoutput(cmd,self.verbose,self.debug,self.header,self.split)
474 return getoutput(cmd,self.verbose,self.debug,self.header,self.split)
475
475
476 def getoutputerror(self,cmd):
476 def getoutputerror(self,cmd):
477 """Stateful interface to getoutputerror()."""
477 """Stateful interface to getoutputerror()."""
478
478
479 return getoutputerror(cmd,self.verbose,self.debug,self.header,self.split)
479 return getoutputerror(cmd,self.verbose,self.debug,self.header,self.split)
480
480
481 bq = getoutput # alias
481 bq = getoutput # alias
482
482
483 #-----------------------------------------------------------------------------
483 #-----------------------------------------------------------------------------
484 def mutex_opts(dict,ex_op):
484 def mutex_opts(dict,ex_op):
485 """Check for presence of mutually exclusive keys in a dict.
485 """Check for presence of mutually exclusive keys in a dict.
486
486
487 Call: mutex_opts(dict,[[op1a,op1b],[op2a,op2b]...]"""
487 Call: mutex_opts(dict,[[op1a,op1b],[op2a,op2b]...]"""
488 for op1,op2 in ex_op:
488 for op1,op2 in ex_op:
489 if op1 in dict and op2 in dict:
489 if op1 in dict and op2 in dict:
490 raise ValueError,'\n*** ERROR in Arguments *** '\
490 raise ValueError,'\n*** ERROR in Arguments *** '\
491 'Options '+op1+' and '+op2+' are mutually exclusive.'
491 'Options '+op1+' and '+op2+' are mutually exclusive.'
492
492
493 #-----------------------------------------------------------------------------
493 #-----------------------------------------------------------------------------
494 def get_py_filename(name):
494 def get_py_filename(name):
495 """Return a valid python filename in the current directory.
495 """Return a valid python filename in the current directory.
496
496
497 If the given name is not a file, it adds '.py' and searches again.
497 If the given name is not a file, it adds '.py' and searches again.
498 Raises IOError with an informative message if the file isn't found."""
498 Raises IOError with an informative message if the file isn't found."""
499
499
500 name = os.path.expanduser(name)
500 name = os.path.expanduser(name)
501 if not os.path.isfile(name) and not name.endswith('.py'):
501 if not os.path.isfile(name) and not name.endswith('.py'):
502 name += '.py'
502 name += '.py'
503 if os.path.isfile(name):
503 if os.path.isfile(name):
504 return name
504 return name
505 else:
505 else:
506 raise IOError,'File `%s` not found.' % name
506 raise IOError,'File `%s` not found.' % name
507
507
508 #-----------------------------------------------------------------------------
508 #-----------------------------------------------------------------------------
509 def filefind(fname,alt_dirs = None):
509 def filefind(fname,alt_dirs = None):
510 """Return the given filename either in the current directory, if it
510 """Return the given filename either in the current directory, if it
511 exists, or in a specified list of directories.
511 exists, or in a specified list of directories.
512
512
513 ~ expansion is done on all file and directory names.
513 ~ expansion is done on all file and directory names.
514
514
515 Upon an unsuccessful search, raise an IOError exception."""
515 Upon an unsuccessful search, raise an IOError exception."""
516
516
517 if alt_dirs is None:
517 if alt_dirs is None:
518 try:
518 try:
519 alt_dirs = get_home_dir()
519 alt_dirs = get_home_dir()
520 except HomeDirError:
520 except HomeDirError:
521 alt_dirs = os.getcwd()
521 alt_dirs = os.getcwd()
522 search = [fname] + list_strings(alt_dirs)
522 search = [fname] + list_strings(alt_dirs)
523 search = map(os.path.expanduser,search)
523 search = map(os.path.expanduser,search)
524 #print 'search list for',fname,'list:',search # dbg
524 #print 'search list for',fname,'list:',search # dbg
525 fname = search[0]
525 fname = search[0]
526 if os.path.isfile(fname):
526 if os.path.isfile(fname):
527 return fname
527 return fname
528 for direc in search[1:]:
528 for direc in search[1:]:
529 testname = os.path.join(direc,fname)
529 testname = os.path.join(direc,fname)
530 #print 'testname',testname # dbg
530 #print 'testname',testname # dbg
531 if os.path.isfile(testname):
531 if os.path.isfile(testname):
532 return testname
532 return testname
533 raise IOError,'File' + `fname` + \
533 raise IOError,'File' + `fname` + \
534 ' not found in current or supplied directories:' + `alt_dirs`
534 ' not found in current or supplied directories:' + `alt_dirs`
535
535
536 #----------------------------------------------------------------------------
536 #----------------------------------------------------------------------------
537 def file_read(filename):
537 def file_read(filename):
538 """Read a file and close it. Returns the file source."""
538 """Read a file and close it. Returns the file source."""
539 fobj = open(filename,'r');
539 fobj = open(filename,'r');
540 source = fobj.read();
540 source = fobj.read();
541 fobj.close()
541 fobj.close()
542 return source
542 return source
543
543
544 def file_readlines(filename):
544 def file_readlines(filename):
545 """Read a file and close it. Returns the file source using readlines()."""
545 """Read a file and close it. Returns the file source using readlines()."""
546 fobj = open(filename,'r');
546 fobj = open(filename,'r');
547 lines = fobj.readlines();
547 lines = fobj.readlines();
548 fobj.close()
548 fobj.close()
549 return lines
549 return lines
550
550
551 #----------------------------------------------------------------------------
551 #----------------------------------------------------------------------------
552 def target_outdated(target,deps):
552 def target_outdated(target,deps):
553 """Determine whether a target is out of date.
553 """Determine whether a target is out of date.
554
554
555 target_outdated(target,deps) -> 1/0
555 target_outdated(target,deps) -> 1/0
556
556
557 deps: list of filenames which MUST exist.
557 deps: list of filenames which MUST exist.
558 target: single filename which may or may not exist.
558 target: single filename which may or may not exist.
559
559
560 If target doesn't exist or is older than any file listed in deps, return
560 If target doesn't exist or is older than any file listed in deps, return
561 true, otherwise return false.
561 true, otherwise return false.
562 """
562 """
563 try:
563 try:
564 target_time = os.path.getmtime(target)
564 target_time = os.path.getmtime(target)
565 except os.error:
565 except os.error:
566 return 1
566 return 1
567 for dep in deps:
567 for dep in deps:
568 dep_time = os.path.getmtime(dep)
568 dep_time = os.path.getmtime(dep)
569 if dep_time > target_time:
569 if dep_time > target_time:
570 #print "For target",target,"Dep failed:",dep # dbg
570 #print "For target",target,"Dep failed:",dep # dbg
571 #print "times (dep,tar):",dep_time,target_time # dbg
571 #print "times (dep,tar):",dep_time,target_time # dbg
572 return 1
572 return 1
573 return 0
573 return 0
574
574
575 #-----------------------------------------------------------------------------
575 #-----------------------------------------------------------------------------
576 def target_update(target,deps,cmd):
576 def target_update(target,deps,cmd):
577 """Update a target with a given command given a list of dependencies.
577 """Update a target with a given command given a list of dependencies.
578
578
579 target_update(target,deps,cmd) -> runs cmd if target is outdated.
579 target_update(target,deps,cmd) -> runs cmd if target is outdated.
580
580
581 This is just a wrapper around target_outdated() which calls the given
581 This is just a wrapper around target_outdated() which calls the given
582 command if target is outdated."""
582 command if target is outdated."""
583
583
584 if target_outdated(target,deps):
584 if target_outdated(target,deps):
585 xsys(cmd)
585 xsys(cmd)
586
586
587 #----------------------------------------------------------------------------
587 #----------------------------------------------------------------------------
588 def unquote_ends(istr):
588 def unquote_ends(istr):
589 """Remove a single pair of quotes from the endpoints of a string."""
589 """Remove a single pair of quotes from the endpoints of a string."""
590
590
591 if not istr:
591 if not istr:
592 return istr
592 return istr
593 if (istr[0]=="'" and istr[-1]=="'") or \
593 if (istr[0]=="'" and istr[-1]=="'") or \
594 (istr[0]=='"' and istr[-1]=='"'):
594 (istr[0]=='"' and istr[-1]=='"'):
595 return istr[1:-1]
595 return istr[1:-1]
596 else:
596 else:
597 return istr
597 return istr
598
598
599 #----------------------------------------------------------------------------
599 #----------------------------------------------------------------------------
600 def process_cmdline(argv,names=[],defaults={},usage=''):
600 def process_cmdline(argv,names=[],defaults={},usage=''):
601 """ Process command-line options and arguments.
601 """ Process command-line options and arguments.
602
602
603 Arguments:
603 Arguments:
604
604
605 - argv: list of arguments, typically sys.argv.
605 - argv: list of arguments, typically sys.argv.
606
606
607 - names: list of option names. See DPyGetOpt docs for details on options
607 - names: list of option names. See DPyGetOpt docs for details on options
608 syntax.
608 syntax.
609
609
610 - defaults: dict of default values.
610 - defaults: dict of default values.
611
611
612 - usage: optional usage notice to print if a wrong argument is passed.
612 - usage: optional usage notice to print if a wrong argument is passed.
613
613
614 Return a dict of options and a list of free arguments."""
614 Return a dict of options and a list of free arguments."""
615
615
616 getopt = DPyGetOpt.DPyGetOpt()
616 getopt = DPyGetOpt.DPyGetOpt()
617 getopt.setIgnoreCase(0)
617 getopt.setIgnoreCase(0)
618 getopt.parseConfiguration(names)
618 getopt.parseConfiguration(names)
619
619
620 try:
620 try:
621 getopt.processArguments(argv)
621 getopt.processArguments(argv)
622 except:
622 except:
623 print usage
623 print usage
624 warn(`sys.exc_value`,level=4)
624 warn(`sys.exc_value`,level=4)
625
625
626 defaults.update(getopt.optionValues)
626 defaults.update(getopt.optionValues)
627 args = getopt.freeValues
627 args = getopt.freeValues
628
628
629 return defaults,args
629 return defaults,args
630
630
631 #----------------------------------------------------------------------------
631 #----------------------------------------------------------------------------
632 def optstr2types(ostr):
632 def optstr2types(ostr):
633 """Convert a string of option names to a dict of type mappings.
633 """Convert a string of option names to a dict of type mappings.
634
634
635 optstr2types(str) -> {None:'string_opts',int:'int_opts',float:'float_opts'}
635 optstr2types(str) -> {None:'string_opts',int:'int_opts',float:'float_opts'}
636
636
637 This is used to get the types of all the options in a string formatted
637 This is used to get the types of all the options in a string formatted
638 with the conventions of DPyGetOpt. The 'type' None is used for options
638 with the conventions of DPyGetOpt. The 'type' None is used for options
639 which are strings (they need no further conversion). This function's main
639 which are strings (they need no further conversion). This function's main
640 use is to get a typemap for use with read_dict().
640 use is to get a typemap for use with read_dict().
641 """
641 """
642
642
643 typeconv = {None:'',int:'',float:''}
643 typeconv = {None:'',int:'',float:''}
644 typemap = {'s':None,'i':int,'f':float}
644 typemap = {'s':None,'i':int,'f':float}
645 opt_re = re.compile(r'([\w]*)([^:=]*:?=?)([sif]?)')
645 opt_re = re.compile(r'([\w]*)([^:=]*:?=?)([sif]?)')
646
646
647 for w in ostr.split():
647 for w in ostr.split():
648 oname,alias,otype = opt_re.match(w).groups()
648 oname,alias,otype = opt_re.match(w).groups()
649 if otype == '' or alias == '!': # simple switches are integers too
649 if otype == '' or alias == '!': # simple switches are integers too
650 otype = 'i'
650 otype = 'i'
651 typeconv[typemap[otype]] += oname + ' '
651 typeconv[typemap[otype]] += oname + ' '
652 return typeconv
652 return typeconv
653
653
654 #----------------------------------------------------------------------------
654 #----------------------------------------------------------------------------
655 def read_dict(filename,type_conv=None,**opt):
655 def read_dict(filename,type_conv=None,**opt):
656
656
657 """Read a dictionary of key=value pairs from an input file, optionally
657 """Read a dictionary of key=value pairs from an input file, optionally
658 performing conversions on the resulting values.
658 performing conversions on the resulting values.
659
659
660 read_dict(filename,type_conv,**opt) -> dict
660 read_dict(filename,type_conv,**opt) -> dict
661
661
662 Only one value per line is accepted, the format should be
662 Only one value per line is accepted, the format should be
663 # optional comments are ignored
663 # optional comments are ignored
664 key value\n
664 key value\n
665
665
666 Args:
666 Args:
667
667
668 - type_conv: A dictionary specifying which keys need to be converted to
668 - type_conv: A dictionary specifying which keys need to be converted to
669 which types. By default all keys are read as strings. This dictionary
669 which types. By default all keys are read as strings. This dictionary
670 should have as its keys valid conversion functions for strings
670 should have as its keys valid conversion functions for strings
671 (int,long,float,complex, or your own). The value for each key
671 (int,long,float,complex, or your own). The value for each key
672 (converter) should be a whitespace separated string containing the names
672 (converter) should be a whitespace separated string containing the names
673 of all the entries in the file to be converted using that function. For
673 of all the entries in the file to be converted using that function. For
674 keys to be left alone, use None as the conversion function (only needed
674 keys to be left alone, use None as the conversion function (only needed
675 with purge=1, see below).
675 with purge=1, see below).
676
676
677 - opt: dictionary with extra options as below (default in parens)
677 - opt: dictionary with extra options as below (default in parens)
678
678
679 purge(0): if set to 1, all keys *not* listed in type_conv are purged out
679 purge(0): if set to 1, all keys *not* listed in type_conv are purged out
680 of the dictionary to be returned. If purge is going to be used, the
680 of the dictionary to be returned. If purge is going to be used, the
681 set of keys to be left as strings also has to be explicitly specified
681 set of keys to be left as strings also has to be explicitly specified
682 using the (non-existent) conversion function None.
682 using the (non-existent) conversion function None.
683
683
684 fs(None): field separator. This is the key/value separator to be used
684 fs(None): field separator. This is the key/value separator to be used
685 when parsing the file. The None default means any whitespace [behavior
685 when parsing the file. The None default means any whitespace [behavior
686 of string.split()].
686 of string.split()].
687
687
688 strip(0): if 1, strip string values of leading/trailinig whitespace.
688 strip(0): if 1, strip string values of leading/trailinig whitespace.
689
689
690 warn(1): warning level if requested keys are not found in file.
690 warn(1): warning level if requested keys are not found in file.
691 - 0: silently ignore.
691 - 0: silently ignore.
692 - 1: inform but proceed.
692 - 1: inform but proceed.
693 - 2: raise KeyError exception.
693 - 2: raise KeyError exception.
694
694
695 no_empty(0): if 1, remove keys with whitespace strings as a value.
695 no_empty(0): if 1, remove keys with whitespace strings as a value.
696
696
697 unique([]): list of keys (or space separated string) which can't be
697 unique([]): list of keys (or space separated string) which can't be
698 repeated. If one such key is found in the file, each new instance
698 repeated. If one such key is found in the file, each new instance
699 overwrites the previous one. For keys not listed here, the behavior is
699 overwrites the previous one. For keys not listed here, the behavior is
700 to make a list of all appearances.
700 to make a list of all appearances.
701
701
702 Example:
702 Example:
703 If the input file test.ini has:
703 If the input file test.ini has:
704 i 3
704 i 3
705 x 4.5
705 x 4.5
706 y 5.5
706 y 5.5
707 s hi ho
707 s hi ho
708 Then:
708 Then:
709
709
710 >>> type_conv={int:'i',float:'x',None:'s'}
710 >>> type_conv={int:'i',float:'x',None:'s'}
711 >>> read_dict('test.ini')
711 >>> read_dict('test.ini')
712 {'i': '3', 's': 'hi ho', 'x': '4.5', 'y': '5.5'}
712 {'i': '3', 's': 'hi ho', 'x': '4.5', 'y': '5.5'}
713 >>> read_dict('test.ini',type_conv)
713 >>> read_dict('test.ini',type_conv)
714 {'i': 3, 's': 'hi ho', 'x': 4.5, 'y': '5.5'}
714 {'i': 3, 's': 'hi ho', 'x': 4.5, 'y': '5.5'}
715 >>> read_dict('test.ini',type_conv,purge=1)
715 >>> read_dict('test.ini',type_conv,purge=1)
716 {'i': 3, 's': 'hi ho', 'x': 4.5}
716 {'i': 3, 's': 'hi ho', 'x': 4.5}
717 """
717 """
718
718
719 # starting config
719 # starting config
720 opt.setdefault('purge',0)
720 opt.setdefault('purge',0)
721 opt.setdefault('fs',None) # field sep defaults to any whitespace
721 opt.setdefault('fs',None) # field sep defaults to any whitespace
722 opt.setdefault('strip',0)
722 opt.setdefault('strip',0)
723 opt.setdefault('warn',1)
723 opt.setdefault('warn',1)
724 opt.setdefault('no_empty',0)
724 opt.setdefault('no_empty',0)
725 opt.setdefault('unique','')
725 opt.setdefault('unique','')
726 if type(opt['unique']) in StringTypes:
726 if type(opt['unique']) in StringTypes:
727 unique_keys = qw(opt['unique'])
727 unique_keys = qw(opt['unique'])
728 elif type(opt['unique']) in (types.TupleType,types.ListType):
728 elif type(opt['unique']) in (types.TupleType,types.ListType):
729 unique_keys = opt['unique']
729 unique_keys = opt['unique']
730 else:
730 else:
731 raise ValueError, 'Unique keys must be given as a string, List or Tuple'
731 raise ValueError, 'Unique keys must be given as a string, List or Tuple'
732
732
733 dict = {}
733 dict = {}
734 # first read in table of values as strings
734 # first read in table of values as strings
735 file = open(filename,'r')
735 file = open(filename,'r')
736 for line in file.readlines():
736 for line in file.readlines():
737 line = line.strip()
737 line = line.strip()
738 if len(line) and line[0]=='#': continue
738 if len(line) and line[0]=='#': continue
739 if len(line)>0:
739 if len(line)>0:
740 lsplit = line.split(opt['fs'],1)
740 lsplit = line.split(opt['fs'],1)
741 try:
741 try:
742 key,val = lsplit
742 key,val = lsplit
743 except ValueError:
743 except ValueError:
744 key,val = lsplit[0],''
744 key,val = lsplit[0],''
745 key = key.strip()
745 key = key.strip()
746 if opt['strip']: val = val.strip()
746 if opt['strip']: val = val.strip()
747 if val == "''" or val == '""': val = ''
747 if val == "''" or val == '""': val = ''
748 if opt['no_empty'] and (val=='' or val.isspace()):
748 if opt['no_empty'] and (val=='' or val.isspace()):
749 continue
749 continue
750 # if a key is found more than once in the file, build a list
750 # if a key is found more than once in the file, build a list
751 # unless it's in the 'unique' list. In that case, last found in file
751 # unless it's in the 'unique' list. In that case, last found in file
752 # takes precedence. User beware.
752 # takes precedence. User beware.
753 try:
753 try:
754 if dict[key] and key in unique_keys:
754 if dict[key] and key in unique_keys:
755 dict[key] = val
755 dict[key] = val
756 elif type(dict[key]) is types.ListType:
756 elif type(dict[key]) is types.ListType:
757 dict[key].append(val)
757 dict[key].append(val)
758 else:
758 else:
759 dict[key] = [dict[key],val]
759 dict[key] = [dict[key],val]
760 except KeyError:
760 except KeyError:
761 dict[key] = val
761 dict[key] = val
762 # purge if requested
762 # purge if requested
763 if opt['purge']:
763 if opt['purge']:
764 accepted_keys = qwflat(type_conv.values())
764 accepted_keys = qwflat(type_conv.values())
765 for key in dict.keys():
765 for key in dict.keys():
766 if key in accepted_keys: continue
766 if key in accepted_keys: continue
767 del(dict[key])
767 del(dict[key])
768 # now convert if requested
768 # now convert if requested
769 if type_conv==None: return dict
769 if type_conv==None: return dict
770 conversions = type_conv.keys()
770 conversions = type_conv.keys()
771 try: conversions.remove(None)
771 try: conversions.remove(None)
772 except: pass
772 except: pass
773 for convert in conversions:
773 for convert in conversions:
774 for val in qw(type_conv[convert]):
774 for val in qw(type_conv[convert]):
775 try:
775 try:
776 dict[val] = convert(dict[val])
776 dict[val] = convert(dict[val])
777 except KeyError,e:
777 except KeyError,e:
778 if opt['warn'] == 0:
778 if opt['warn'] == 0:
779 pass
779 pass
780 elif opt['warn'] == 1:
780 elif opt['warn'] == 1:
781 print >>sys.stderr, 'Warning: key',val,\
781 print >>sys.stderr, 'Warning: key',val,\
782 'not found in file',filename
782 'not found in file',filename
783 elif opt['warn'] == 2:
783 elif opt['warn'] == 2:
784 raise KeyError,e
784 raise KeyError,e
785 else:
785 else:
786 raise ValueError,'Warning level must be 0,1 or 2'
786 raise ValueError,'Warning level must be 0,1 or 2'
787
787
788 return dict
788 return dict
789
789
790 #----------------------------------------------------------------------------
790 #----------------------------------------------------------------------------
791 def flag_calls(func):
791 def flag_calls(func):
792 """Wrap a function to detect and flag when it gets called.
792 """Wrap a function to detect and flag when it gets called.
793
793
794 This is a decorator which takes a function and wraps it in a function with
794 This is a decorator which takes a function and wraps it in a function with
795 a 'called' attribute. wrapper.called is initialized to False.
795 a 'called' attribute. wrapper.called is initialized to False.
796
796
797 The wrapper.called attribute is set to False right before each call to the
797 The wrapper.called attribute is set to False right before each call to the
798 wrapped function, so if the call fails it remains False. After the call
798 wrapped function, so if the call fails it remains False. After the call
799 completes, wrapper.called is set to True and the output is returned.
799 completes, wrapper.called is set to True and the output is returned.
800
800
801 Testing for truth in wrapper.called allows you to determine if a call to
801 Testing for truth in wrapper.called allows you to determine if a call to
802 func() was attempted and succeeded."""
802 func() was attempted and succeeded."""
803
803
804 def wrapper(*args,**kw):
804 def wrapper(*args,**kw):
805 wrapper.called = False
805 wrapper.called = False
806 out = func(*args,**kw)
806 out = func(*args,**kw)
807 wrapper.called = True
807 wrapper.called = True
808 return out
808 return out
809
809
810 wrapper.called = False
810 wrapper.called = False
811 wrapper.__doc__ = func.__doc__
811 wrapper.__doc__ = func.__doc__
812 return wrapper
812 return wrapper
813
813
814 #----------------------------------------------------------------------------
814 #----------------------------------------------------------------------------
815 def dhook_wrap(func,*a,**k):
815 def dhook_wrap(func,*a,**k):
816 """Wrap a function call in a sys.displayhook controller.
816 """Wrap a function call in a sys.displayhook controller.
817
817
818 Returns a wrapper around func which calls func, with all its arguments and
818 Returns a wrapper around func which calls func, with all its arguments and
819 keywords unmodified, using the default sys.displayhook. Since IPython
819 keywords unmodified, using the default sys.displayhook. Since IPython
820 modifies sys.displayhook, it breaks the behavior of certain systems that
820 modifies sys.displayhook, it breaks the behavior of certain systems that
821 rely on the default behavior, notably doctest.
821 rely on the default behavior, notably doctest.
822 """
822 """
823
823
824 def f(*a,**k):
824 def f(*a,**k):
825
825
826 dhook_s = sys.displayhook
826 dhook_s = sys.displayhook
827 sys.displayhook = sys.__displayhook__
827 sys.displayhook = sys.__displayhook__
828 try:
828 try:
829 out = func(*a,**k)
829 out = func(*a,**k)
830 finally:
830 finally:
831 sys.displayhook = dhook_s
831 sys.displayhook = dhook_s
832
832
833 return out
833 return out
834
834
835 f.__doc__ = func.__doc__
835 f.__doc__ = func.__doc__
836 return f
836 return f
837
837
838 #----------------------------------------------------------------------------
838 #----------------------------------------------------------------------------
839 class HomeDirError(Error):
839 class HomeDirError(Error):
840 pass
840 pass
841
841
842 def get_home_dir():
842 def get_home_dir():
843 """Return the closest possible equivalent to a 'home' directory.
843 """Return the closest possible equivalent to a 'home' directory.
844
844
845 We first try $HOME. Absent that, on NT it's $HOMEDRIVE\$HOMEPATH.
845 We first try $HOME. Absent that, on NT it's $HOMEDRIVE\$HOMEPATH.
846
846
847 Currently only Posix and NT are implemented, a HomeDirError exception is
847 Currently only Posix and NT are implemented, a HomeDirError exception is
848 raised for all other OSes. """
848 raised for all other OSes. """
849
849
850 isdir = os.path.isdir
850 isdir = os.path.isdir
851 env = os.environ
851 env = os.environ
852
852
853 # first, check py2exe distribution root directory for _ipython.
853 # first, check py2exe distribution root directory for _ipython.
854 # This overrides all. Normally does not exist.
854 # This overrides all. Normally does not exist.
855
855
856 if '\\library.zip\\' in IPython.__file__.lower():
856 if '\\library.zip\\' in IPython.__file__.lower():
857 root, rest = IPython.__file__.lower().split('library.zip')
857 root, rest = IPython.__file__.lower().split('library.zip')
858 if isdir(root + '_ipython'):
858 if isdir(root + '_ipython'):
859 os.environ["IPYKITROOT"] = root.rstrip('\\')
859 os.environ["IPYKITROOT"] = root.rstrip('\\')
860 return root
860 return root
861
861
862 try:
862 try:
863 homedir = env['HOME']
863 homedir = env['HOME']
864 if not isdir(homedir):
864 if not isdir(homedir):
865 # in case a user stuck some string which does NOT resolve to a
865 # in case a user stuck some string which does NOT resolve to a
866 # valid path, it's as good as if we hadn't foud it
866 # valid path, it's as good as if we hadn't foud it
867 raise KeyError
867 raise KeyError
868 return homedir
868 return homedir
869 except KeyError:
869 except KeyError:
870 if os.name == 'posix':
870 if os.name == 'posix':
871 raise HomeDirError,'undefined $HOME, IPython can not proceed.'
871 raise HomeDirError,'undefined $HOME, IPython can not proceed.'
872 elif os.name == 'nt':
872 elif os.name == 'nt':
873 # For some strange reason, win9x returns 'nt' for os.name.
873 # For some strange reason, win9x returns 'nt' for os.name.
874 try:
874 try:
875 homedir = os.path.join(env['HOMEDRIVE'],env['HOMEPATH'])
875 homedir = os.path.join(env['HOMEDRIVE'],env['HOMEPATH'])
876 if not isdir(homedir):
876 if not isdir(homedir):
877 homedir = os.path.join(env['USERPROFILE'])
877 homedir = os.path.join(env['USERPROFILE'])
878 if not isdir(homedir):
878 if not isdir(homedir):
879 raise HomeDirError
879 raise HomeDirError
880 return homedir
880 return homedir
881 except:
881 except:
882 try:
882 try:
883 # Use the registry to get the 'My Documents' folder.
883 # Use the registry to get the 'My Documents' folder.
884 import _winreg as wreg
884 import _winreg as wreg
885 key = wreg.OpenKey(wreg.HKEY_CURRENT_USER,
885 key = wreg.OpenKey(wreg.HKEY_CURRENT_USER,
886 "Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders")
886 "Software\Microsoft\Windows\CurrentVersion\Explorer\Shell Folders")
887 homedir = wreg.QueryValueEx(key,'Personal')[0]
887 homedir = wreg.QueryValueEx(key,'Personal')[0]
888 key.Close()
888 key.Close()
889 if not isdir(homedir):
889 if not isdir(homedir):
890 e = ('Invalid "Personal" folder registry key '
890 e = ('Invalid "Personal" folder registry key '
891 'typically "My Documents".\n'
891 'typically "My Documents".\n'
892 'Value: %s\n'
892 'Value: %s\n'
893 'This is not a valid directory on your system.' %
893 'This is not a valid directory on your system.' %
894 homedir)
894 homedir)
895 raise HomeDirError(e)
895 raise HomeDirError(e)
896 return homedir
896 return homedir
897 except HomeDirError:
897 except HomeDirError:
898 raise
898 raise
899 except:
899 except:
900 return 'C:\\'
900 return 'C:\\'
901 elif os.name == 'dos':
901 elif os.name == 'dos':
902 # Desperate, may do absurd things in classic MacOS. May work under DOS.
902 # Desperate, may do absurd things in classic MacOS. May work under DOS.
903 return 'C:\\'
903 return 'C:\\'
904 else:
904 else:
905 raise HomeDirError,'support for your operating system not implemented.'
905 raise HomeDirError,'support for your operating system not implemented.'
906
906
907 #****************************************************************************
907 #****************************************************************************
908 # strings and text
908 # strings and text
909
909
910 class LSString(str):
910 class LSString(str):
911 """String derivative with a special access attributes.
911 """String derivative with a special access attributes.
912
912
913 These are normal strings, but with the special attributes:
913 These are normal strings, but with the special attributes:
914
914
915 .l (or .list) : value as list (split on newlines).
915 .l (or .list) : value as list (split on newlines).
916 .n (or .nlstr): original value (the string itself).
916 .n (or .nlstr): original value (the string itself).
917 .s (or .spstr): value as whitespace-separated string.
917 .s (or .spstr): value as whitespace-separated string.
918 .p (or .paths): list of path objects
918 .p (or .paths): list of path objects
919
919
920 Any values which require transformations are computed only once and
920 Any values which require transformations are computed only once and
921 cached.
921 cached.
922
922
923 Such strings are very useful to efficiently interact with the shell, which
923 Such strings are very useful to efficiently interact with the shell, which
924 typically only understands whitespace-separated options for commands."""
924 typically only understands whitespace-separated options for commands."""
925
925
926 def get_list(self):
926 def get_list(self):
927 try:
927 try:
928 return self.__list
928 return self.__list
929 except AttributeError:
929 except AttributeError:
930 self.__list = self.split('\n')
930 self.__list = self.split('\n')
931 return self.__list
931 return self.__list
932
932
933 l = list = property(get_list)
933 l = list = property(get_list)
934
934
935 def get_spstr(self):
935 def get_spstr(self):
936 try:
936 try:
937 return self.__spstr
937 return self.__spstr
938 except AttributeError:
938 except AttributeError:
939 self.__spstr = self.replace('\n',' ')
939 self.__spstr = self.replace('\n',' ')
940 return self.__spstr
940 return self.__spstr
941
941
942 s = spstr = property(get_spstr)
942 s = spstr = property(get_spstr)
943
943
944 def get_nlstr(self):
944 def get_nlstr(self):
945 return self
945 return self
946
946
947 n = nlstr = property(get_nlstr)
947 n = nlstr = property(get_nlstr)
948
948
949 def get_paths(self):
949 def get_paths(self):
950 try:
950 try:
951 return self.__paths
951 return self.__paths
952 except AttributeError:
952 except AttributeError:
953 self.__paths = [path(p) for p in self.split('\n') if os.path.exists(p)]
953 self.__paths = [path(p) for p in self.split('\n') if os.path.exists(p)]
954 return self.__paths
954 return self.__paths
955
955
956 p = paths = property(get_paths)
956 p = paths = property(get_paths)
957
957
958 def print_lsstring(arg):
958 def print_lsstring(arg):
959 """ Prettier (non-repr-like) and more informative printer for LSString """
959 """ Prettier (non-repr-like) and more informative printer for LSString """
960 print "LSString (.p, .n, .l, .s available). Value:"
960 print "LSString (.p, .n, .l, .s available). Value:"
961 print arg
961 print arg
962
962
963 print_lsstring = result_display.when_type(LSString)(print_lsstring)
963 print_lsstring = result_display.when_type(LSString)(print_lsstring)
964
964
965 #----------------------------------------------------------------------------
965 #----------------------------------------------------------------------------
966 class SList(list):
966 class SList(list):
967 """List derivative with a special access attributes.
967 """List derivative with a special access attributes.
968
968
969 These are normal lists, but with the special attributes:
969 These are normal lists, but with the special attributes:
970
970
971 .l (or .list) : value as list (the list itself).
971 .l (or .list) : value as list (the list itself).
972 .n (or .nlstr): value as a string, joined on newlines.
972 .n (or .nlstr): value as a string, joined on newlines.
973 .s (or .spstr): value as a string, joined on spaces.
973 .s (or .spstr): value as a string, joined on spaces.
974 .p (or .paths): list of path objects
974 .p (or .paths): list of path objects
975
975
976 Any values which require transformations are computed only once and
976 Any values which require transformations are computed only once and
977 cached."""
977 cached."""
978
978
979 def get_list(self):
979 def get_list(self):
980 return self
980 return self
981
981
982 l = list = property(get_list)
982 l = list = property(get_list)
983
983
984 def get_spstr(self):
984 def get_spstr(self):
985 try:
985 try:
986 return self.__spstr
986 return self.__spstr
987 except AttributeError:
987 except AttributeError:
988 self.__spstr = ' '.join(self)
988 self.__spstr = ' '.join(self)
989 return self.__spstr
989 return self.__spstr
990
990
991 s = spstr = property(get_spstr)
991 s = spstr = property(get_spstr)
992
992
993 def get_nlstr(self):
993 def get_nlstr(self):
994 try:
994 try:
995 return self.__nlstr
995 return self.__nlstr
996 except AttributeError:
996 except AttributeError:
997 self.__nlstr = '\n'.join(self)
997 self.__nlstr = '\n'.join(self)
998 return self.__nlstr
998 return self.__nlstr
999
999
1000 n = nlstr = property(get_nlstr)
1000 n = nlstr = property(get_nlstr)
1001
1001
1002 def get_paths(self):
1002 def get_paths(self):
1003 try:
1003 try:
1004 return self.__paths
1004 return self.__paths
1005 except AttributeError:
1005 except AttributeError:
1006 self.__paths = [path(p) for p in self if os.path.exists(p)]
1006 self.__paths = [path(p) for p in self if os.path.exists(p)]
1007 return self.__paths
1007 return self.__paths
1008
1008
1009 p = paths = property(get_paths)
1009 p = paths = property(get_paths)
1010
1010
1011 def grep(self, pattern, prune = False):
1012 """ Return all strings matching 'pattern' (a regex or callable)
1013
1014 This is case-insensitive. If prune is true, return all items
1015 NOT matching the pattern.
1016 """
1017 if isinstance(pattern, basestring):
1018 pred = lambda x : re.search(pattern, x, re.IGNORECASE)
1019 else:
1020 pred = pattern
1021 if not prune:
1022 return SList([el for el in self if pred(el)])
1023 else:
1024 return SList([el for el in self if not pred(el)])
1025
1011 def print_slist(arg):
1026 def print_slist(arg):
1012 """ Prettier (non-repr-like) and more informative printer for SList """
1027 """ Prettier (non-repr-like) and more informative printer for SList """
1013 print "SList (.p, .n, .l, .s available). Value:"
1028 print "SList (.p, .n, .l, .s, .grep() available). Value:"
1014 nlprint(arg)
1029 nlprint(arg)
1015
1030
1016 print_slist = result_display.when_type(SList)(print_slist)
1031 print_slist = result_display.when_type(SList)(print_slist)
1017
1032
1018
1033
1019
1034
1020 #----------------------------------------------------------------------------
1035 #----------------------------------------------------------------------------
1021 def esc_quotes(strng):
1036 def esc_quotes(strng):
1022 """Return the input string with single and double quotes escaped out"""
1037 """Return the input string with single and double quotes escaped out"""
1023
1038
1024 return strng.replace('"','\\"').replace("'","\\'")
1039 return strng.replace('"','\\"').replace("'","\\'")
1025
1040
1026 #----------------------------------------------------------------------------
1041 #----------------------------------------------------------------------------
1027 def make_quoted_expr(s):
1042 def make_quoted_expr(s):
1028 """Return string s in appropriate quotes, using raw string if possible.
1043 """Return string s in appropriate quotes, using raw string if possible.
1029
1044
1030 Effectively this turns string: cd \ao\ao\
1045 Effectively this turns string: cd \ao\ao\
1031 to: r"cd \ao\ao\_"[:-1]
1046 to: r"cd \ao\ao\_"[:-1]
1032
1047
1033 Note the use of raw string and padding at the end to allow trailing backslash.
1048 Note the use of raw string and padding at the end to allow trailing backslash.
1034
1049
1035 """
1050 """
1036
1051
1037 tail = ''
1052 tail = ''
1038 tailpadding = ''
1053 tailpadding = ''
1039 raw = ''
1054 raw = ''
1040 if "\\" in s:
1055 if "\\" in s:
1041 raw = 'r'
1056 raw = 'r'
1042 if s.endswith('\\'):
1057 if s.endswith('\\'):
1043 tail = '[:-1]'
1058 tail = '[:-1]'
1044 tailpadding = '_'
1059 tailpadding = '_'
1045 if '"' not in s:
1060 if '"' not in s:
1046 quote = '"'
1061 quote = '"'
1047 elif "'" not in s:
1062 elif "'" not in s:
1048 quote = "'"
1063 quote = "'"
1049 elif '"""' not in s and not s.endswith('"'):
1064 elif '"""' not in s and not s.endswith('"'):
1050 quote = '"""'
1065 quote = '"""'
1051 elif "'''" not in s and not s.endswith("'"):
1066 elif "'''" not in s and not s.endswith("'"):
1052 quote = "'''"
1067 quote = "'''"
1053 else:
1068 else:
1054 # give up, backslash-escaped string will do
1069 # give up, backslash-escaped string will do
1055 return '"%s"' % esc_quotes(s)
1070 return '"%s"' % esc_quotes(s)
1056 res = itpl("$raw$quote$s$tailpadding$quote$tail")
1071 res = itpl("$raw$quote$s$tailpadding$quote$tail")
1057 return res
1072 return res
1058
1073
1059
1074
1060 #----------------------------------------------------------------------------
1075 #----------------------------------------------------------------------------
1061 def raw_input_multi(header='', ps1='==> ', ps2='..> ',terminate_str = '.'):
1076 def raw_input_multi(header='', ps1='==> ', ps2='..> ',terminate_str = '.'):
1062 """Take multiple lines of input.
1077 """Take multiple lines of input.
1063
1078
1064 A list with each line of input as a separate element is returned when a
1079 A list with each line of input as a separate element is returned when a
1065 termination string is entered (defaults to a single '.'). Input can also
1080 termination string is entered (defaults to a single '.'). Input can also
1066 terminate via EOF (^D in Unix, ^Z-RET in Windows).
1081 terminate via EOF (^D in Unix, ^Z-RET in Windows).
1067
1082
1068 Lines of input which end in \\ are joined into single entries (and a
1083 Lines of input which end in \\ are joined into single entries (and a
1069 secondary continuation prompt is issued as long as the user terminates
1084 secondary continuation prompt is issued as long as the user terminates
1070 lines with \\). This allows entering very long strings which are still
1085 lines with \\). This allows entering very long strings which are still
1071 meant to be treated as single entities.
1086 meant to be treated as single entities.
1072 """
1087 """
1073
1088
1074 try:
1089 try:
1075 if header:
1090 if header:
1076 header += '\n'
1091 header += '\n'
1077 lines = [raw_input(header + ps1)]
1092 lines = [raw_input(header + ps1)]
1078 except EOFError:
1093 except EOFError:
1079 return []
1094 return []
1080 terminate = [terminate_str]
1095 terminate = [terminate_str]
1081 try:
1096 try:
1082 while lines[-1:] != terminate:
1097 while lines[-1:] != terminate:
1083 new_line = raw_input(ps1)
1098 new_line = raw_input(ps1)
1084 while new_line.endswith('\\'):
1099 while new_line.endswith('\\'):
1085 new_line = new_line[:-1] + raw_input(ps2)
1100 new_line = new_line[:-1] + raw_input(ps2)
1086 lines.append(new_line)
1101 lines.append(new_line)
1087
1102
1088 return lines[:-1] # don't return the termination command
1103 return lines[:-1] # don't return the termination command
1089 except EOFError:
1104 except EOFError:
1090 print
1105 print
1091 return lines
1106 return lines
1092
1107
1093 #----------------------------------------------------------------------------
1108 #----------------------------------------------------------------------------
1094 def raw_input_ext(prompt='', ps2='... '):
1109 def raw_input_ext(prompt='', ps2='... '):
1095 """Similar to raw_input(), but accepts extended lines if input ends with \\."""
1110 """Similar to raw_input(), but accepts extended lines if input ends with \\."""
1096
1111
1097 line = raw_input(prompt)
1112 line = raw_input(prompt)
1098 while line.endswith('\\'):
1113 while line.endswith('\\'):
1099 line = line[:-1] + raw_input(ps2)
1114 line = line[:-1] + raw_input(ps2)
1100 return line
1115 return line
1101
1116
1102 #----------------------------------------------------------------------------
1117 #----------------------------------------------------------------------------
1103 def ask_yes_no(prompt,default=None):
1118 def ask_yes_no(prompt,default=None):
1104 """Asks a question and returns a boolean (y/n) answer.
1119 """Asks a question and returns a boolean (y/n) answer.
1105
1120
1106 If default is given (one of 'y','n'), it is used if the user input is
1121 If default is given (one of 'y','n'), it is used if the user input is
1107 empty. Otherwise the question is repeated until an answer is given.
1122 empty. Otherwise the question is repeated until an answer is given.
1108
1123
1109 An EOF is treated as the default answer. If there is no default, an
1124 An EOF is treated as the default answer. If there is no default, an
1110 exception is raised to prevent infinite loops.
1125 exception is raised to prevent infinite loops.
1111
1126
1112 Valid answers are: y/yes/n/no (match is not case sensitive)."""
1127 Valid answers are: y/yes/n/no (match is not case sensitive)."""
1113
1128
1114 answers = {'y':True,'n':False,'yes':True,'no':False}
1129 answers = {'y':True,'n':False,'yes':True,'no':False}
1115 ans = None
1130 ans = None
1116 while ans not in answers.keys():
1131 while ans not in answers.keys():
1117 try:
1132 try:
1118 ans = raw_input(prompt+' ').lower()
1133 ans = raw_input(prompt+' ').lower()
1119 if not ans: # response was an empty string
1134 if not ans: # response was an empty string
1120 ans = default
1135 ans = default
1121 except KeyboardInterrupt:
1136 except KeyboardInterrupt:
1122 pass
1137 pass
1123 except EOFError:
1138 except EOFError:
1124 if default in answers.keys():
1139 if default in answers.keys():
1125 ans = default
1140 ans = default
1126 print
1141 print
1127 else:
1142 else:
1128 raise
1143 raise
1129
1144
1130 return answers[ans]
1145 return answers[ans]
1131
1146
1132 #----------------------------------------------------------------------------
1147 #----------------------------------------------------------------------------
1133 def marquee(txt='',width=78,mark='*'):
1148 def marquee(txt='',width=78,mark='*'):
1134 """Return the input string centered in a 'marquee'."""
1149 """Return the input string centered in a 'marquee'."""
1135 if not txt:
1150 if not txt:
1136 return (mark*width)[:width]
1151 return (mark*width)[:width]
1137 nmark = (width-len(txt)-2)/len(mark)/2
1152 nmark = (width-len(txt)-2)/len(mark)/2
1138 if nmark < 0: nmark =0
1153 if nmark < 0: nmark =0
1139 marks = mark*nmark
1154 marks = mark*nmark
1140 return '%s %s %s' % (marks,txt,marks)
1155 return '%s %s %s' % (marks,txt,marks)
1141
1156
1142 #----------------------------------------------------------------------------
1157 #----------------------------------------------------------------------------
1143 class EvalDict:
1158 class EvalDict:
1144 """
1159 """
1145 Emulate a dict which evaluates its contents in the caller's frame.
1160 Emulate a dict which evaluates its contents in the caller's frame.
1146
1161
1147 Usage:
1162 Usage:
1148 >>>number = 19
1163 >>>number = 19
1149 >>>text = "python"
1164 >>>text = "python"
1150 >>>print "%(text.capitalize())s %(number/9.0).1f rules!" % EvalDict()
1165 >>>print "%(text.capitalize())s %(number/9.0).1f rules!" % EvalDict()
1151 """
1166 """
1152
1167
1153 # This version is due to sismex01@hebmex.com on c.l.py, and is basically a
1168 # This version is due to sismex01@hebmex.com on c.l.py, and is basically a
1154 # modified (shorter) version of:
1169 # modified (shorter) version of:
1155 # http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/66018 by
1170 # http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/66018 by
1156 # Skip Montanaro (skip@pobox.com).
1171 # Skip Montanaro (skip@pobox.com).
1157
1172
1158 def __getitem__(self, name):
1173 def __getitem__(self, name):
1159 frame = sys._getframe(1)
1174 frame = sys._getframe(1)
1160 return eval(name, frame.f_globals, frame.f_locals)
1175 return eval(name, frame.f_globals, frame.f_locals)
1161
1176
1162 EvalString = EvalDict # for backwards compatibility
1177 EvalString = EvalDict # for backwards compatibility
1163 #----------------------------------------------------------------------------
1178 #----------------------------------------------------------------------------
1164 def qw(words,flat=0,sep=None,maxsplit=-1):
1179 def qw(words,flat=0,sep=None,maxsplit=-1):
1165 """Similar to Perl's qw() operator, but with some more options.
1180 """Similar to Perl's qw() operator, but with some more options.
1166
1181
1167 qw(words,flat=0,sep=' ',maxsplit=-1) -> words.split(sep,maxsplit)
1182 qw(words,flat=0,sep=' ',maxsplit=-1) -> words.split(sep,maxsplit)
1168
1183
1169 words can also be a list itself, and with flat=1, the output will be
1184 words can also be a list itself, and with flat=1, the output will be
1170 recursively flattened. Examples:
1185 recursively flattened. Examples:
1171
1186
1172 >>> qw('1 2')
1187 >>> qw('1 2')
1173 ['1', '2']
1188 ['1', '2']
1174 >>> qw(['a b','1 2',['m n','p q']])
1189 >>> qw(['a b','1 2',['m n','p q']])
1175 [['a', 'b'], ['1', '2'], [['m', 'n'], ['p', 'q']]]
1190 [['a', 'b'], ['1', '2'], [['m', 'n'], ['p', 'q']]]
1176 >>> qw(['a b','1 2',['m n','p q']],flat=1)
1191 >>> qw(['a b','1 2',['m n','p q']],flat=1)
1177 ['a', 'b', '1', '2', 'm', 'n', 'p', 'q'] """
1192 ['a', 'b', '1', '2', 'm', 'n', 'p', 'q'] """
1178
1193
1179 if type(words) in StringTypes:
1194 if type(words) in StringTypes:
1180 return [word.strip() for word in words.split(sep,maxsplit)
1195 return [word.strip() for word in words.split(sep,maxsplit)
1181 if word and not word.isspace() ]
1196 if word and not word.isspace() ]
1182 if flat:
1197 if flat:
1183 return flatten(map(qw,words,[1]*len(words)))
1198 return flatten(map(qw,words,[1]*len(words)))
1184 return map(qw,words)
1199 return map(qw,words)
1185
1200
1186 #----------------------------------------------------------------------------
1201 #----------------------------------------------------------------------------
1187 def qwflat(words,sep=None,maxsplit=-1):
1202 def qwflat(words,sep=None,maxsplit=-1):
1188 """Calls qw(words) in flat mode. It's just a convenient shorthand."""
1203 """Calls qw(words) in flat mode. It's just a convenient shorthand."""
1189 return qw(words,1,sep,maxsplit)
1204 return qw(words,1,sep,maxsplit)
1190
1205
1191 #----------------------------------------------------------------------------
1206 #----------------------------------------------------------------------------
1192 def qw_lol(indata):
1207 def qw_lol(indata):
1193 """qw_lol('a b') -> [['a','b']],
1208 """qw_lol('a b') -> [['a','b']],
1194 otherwise it's just a call to qw().
1209 otherwise it's just a call to qw().
1195
1210
1196 We need this to make sure the modules_some keys *always* end up as a
1211 We need this to make sure the modules_some keys *always* end up as a
1197 list of lists."""
1212 list of lists."""
1198
1213
1199 if type(indata) in StringTypes:
1214 if type(indata) in StringTypes:
1200 return [qw(indata)]
1215 return [qw(indata)]
1201 else:
1216 else:
1202 return qw(indata)
1217 return qw(indata)
1203
1218
1204 #-----------------------------------------------------------------------------
1219 #-----------------------------------------------------------------------------
1205 def list_strings(arg):
1220 def list_strings(arg):
1206 """Always return a list of strings, given a string or list of strings
1221 """Always return a list of strings, given a string or list of strings
1207 as input."""
1222 as input."""
1208
1223
1209 if type(arg) in StringTypes: return [arg]
1224 if type(arg) in StringTypes: return [arg]
1210 else: return arg
1225 else: return arg
1211
1226
1212 #----------------------------------------------------------------------------
1227 #----------------------------------------------------------------------------
1213 def grep(pat,list,case=1):
1228 def grep(pat,list,case=1):
1214 """Simple minded grep-like function.
1229 """Simple minded grep-like function.
1215 grep(pat,list) returns occurrences of pat in list, None on failure.
1230 grep(pat,list) returns occurrences of pat in list, None on failure.
1216
1231
1217 It only does simple string matching, with no support for regexps. Use the
1232 It only does simple string matching, with no support for regexps. Use the
1218 option case=0 for case-insensitive matching."""
1233 option case=0 for case-insensitive matching."""
1219
1234
1220 # This is pretty crude. At least it should implement copying only references
1235 # This is pretty crude. At least it should implement copying only references
1221 # to the original data in case it's big. Now it copies the data for output.
1236 # to the original data in case it's big. Now it copies the data for output.
1222 out=[]
1237 out=[]
1223 if case:
1238 if case:
1224 for term in list:
1239 for term in list:
1225 if term.find(pat)>-1: out.append(term)
1240 if term.find(pat)>-1: out.append(term)
1226 else:
1241 else:
1227 lpat=pat.lower()
1242 lpat=pat.lower()
1228 for term in list:
1243 for term in list:
1229 if term.lower().find(lpat)>-1: out.append(term)
1244 if term.lower().find(lpat)>-1: out.append(term)
1230
1245
1231 if len(out): return out
1246 if len(out): return out
1232 else: return None
1247 else: return None
1233
1248
1234 #----------------------------------------------------------------------------
1249 #----------------------------------------------------------------------------
1235 def dgrep(pat,*opts):
1250 def dgrep(pat,*opts):
1236 """Return grep() on dir()+dir(__builtins__).
1251 """Return grep() on dir()+dir(__builtins__).
1237
1252
1238 A very common use of grep() when working interactively."""
1253 A very common use of grep() when working interactively."""
1239
1254
1240 return grep(pat,dir(__main__)+dir(__main__.__builtins__),*opts)
1255 return grep(pat,dir(__main__)+dir(__main__.__builtins__),*opts)
1241
1256
1242 #----------------------------------------------------------------------------
1257 #----------------------------------------------------------------------------
1243 def idgrep(pat):
1258 def idgrep(pat):
1244 """Case-insensitive dgrep()"""
1259 """Case-insensitive dgrep()"""
1245
1260
1246 return dgrep(pat,0)
1261 return dgrep(pat,0)
1247
1262
1248 #----------------------------------------------------------------------------
1263 #----------------------------------------------------------------------------
1249 def igrep(pat,list):
1264 def igrep(pat,list):
1250 """Synonym for case-insensitive grep."""
1265 """Synonym for case-insensitive grep."""
1251
1266
1252 return grep(pat,list,case=0)
1267 return grep(pat,list,case=0)
1253
1268
1254 #----------------------------------------------------------------------------
1269 #----------------------------------------------------------------------------
1255 def indent(str,nspaces=4,ntabs=0):
1270 def indent(str,nspaces=4,ntabs=0):
1256 """Indent a string a given number of spaces or tabstops.
1271 """Indent a string a given number of spaces or tabstops.
1257
1272
1258 indent(str,nspaces=4,ntabs=0) -> indent str by ntabs+nspaces.
1273 indent(str,nspaces=4,ntabs=0) -> indent str by ntabs+nspaces.
1259 """
1274 """
1260 if str is None:
1275 if str is None:
1261 return
1276 return
1262 ind = '\t'*ntabs+' '*nspaces
1277 ind = '\t'*ntabs+' '*nspaces
1263 outstr = '%s%s' % (ind,str.replace(os.linesep,os.linesep+ind))
1278 outstr = '%s%s' % (ind,str.replace(os.linesep,os.linesep+ind))
1264 if outstr.endswith(os.linesep+ind):
1279 if outstr.endswith(os.linesep+ind):
1265 return outstr[:-len(ind)]
1280 return outstr[:-len(ind)]
1266 else:
1281 else:
1267 return outstr
1282 return outstr
1268
1283
1269 #-----------------------------------------------------------------------------
1284 #-----------------------------------------------------------------------------
1270 def native_line_ends(filename,backup=1):
1285 def native_line_ends(filename,backup=1):
1271 """Convert (in-place) a file to line-ends native to the current OS.
1286 """Convert (in-place) a file to line-ends native to the current OS.
1272
1287
1273 If the optional backup argument is given as false, no backup of the
1288 If the optional backup argument is given as false, no backup of the
1274 original file is left. """
1289 original file is left. """
1275
1290
1276 backup_suffixes = {'posix':'~','dos':'.bak','nt':'.bak','mac':'.bak'}
1291 backup_suffixes = {'posix':'~','dos':'.bak','nt':'.bak','mac':'.bak'}
1277
1292
1278 bak_filename = filename + backup_suffixes[os.name]
1293 bak_filename = filename + backup_suffixes[os.name]
1279
1294
1280 original = open(filename).read()
1295 original = open(filename).read()
1281 shutil.copy2(filename,bak_filename)
1296 shutil.copy2(filename,bak_filename)
1282 try:
1297 try:
1283 new = open(filename,'wb')
1298 new = open(filename,'wb')
1284 new.write(os.linesep.join(original.splitlines()))
1299 new.write(os.linesep.join(original.splitlines()))
1285 new.write(os.linesep) # ALWAYS put an eol at the end of the file
1300 new.write(os.linesep) # ALWAYS put an eol at the end of the file
1286 new.close()
1301 new.close()
1287 except:
1302 except:
1288 os.rename(bak_filename,filename)
1303 os.rename(bak_filename,filename)
1289 if not backup:
1304 if not backup:
1290 try:
1305 try:
1291 os.remove(bak_filename)
1306 os.remove(bak_filename)
1292 except:
1307 except:
1293 pass
1308 pass
1294
1309
1295 #----------------------------------------------------------------------------
1310 #----------------------------------------------------------------------------
1296 def get_pager_cmd(pager_cmd = None):
1311 def get_pager_cmd(pager_cmd = None):
1297 """Return a pager command.
1312 """Return a pager command.
1298
1313
1299 Makes some attempts at finding an OS-correct one."""
1314 Makes some attempts at finding an OS-correct one."""
1300
1315
1301 if os.name == 'posix':
1316 if os.name == 'posix':
1302 default_pager_cmd = 'less -r' # -r for color control sequences
1317 default_pager_cmd = 'less -r' # -r for color control sequences
1303 elif os.name in ['nt','dos']:
1318 elif os.name in ['nt','dos']:
1304 default_pager_cmd = 'type'
1319 default_pager_cmd = 'type'
1305
1320
1306 if pager_cmd is None:
1321 if pager_cmd is None:
1307 try:
1322 try:
1308 pager_cmd = os.environ['PAGER']
1323 pager_cmd = os.environ['PAGER']
1309 except:
1324 except:
1310 pager_cmd = default_pager_cmd
1325 pager_cmd = default_pager_cmd
1311 return pager_cmd
1326 return pager_cmd
1312
1327
1313 #-----------------------------------------------------------------------------
1328 #-----------------------------------------------------------------------------
1314 def get_pager_start(pager,start):
1329 def get_pager_start(pager,start):
1315 """Return the string for paging files with an offset.
1330 """Return the string for paging files with an offset.
1316
1331
1317 This is the '+N' argument which less and more (under Unix) accept.
1332 This is the '+N' argument which less and more (under Unix) accept.
1318 """
1333 """
1319
1334
1320 if pager in ['less','more']:
1335 if pager in ['less','more']:
1321 if start:
1336 if start:
1322 start_string = '+' + str(start)
1337 start_string = '+' + str(start)
1323 else:
1338 else:
1324 start_string = ''
1339 start_string = ''
1325 else:
1340 else:
1326 start_string = ''
1341 start_string = ''
1327 return start_string
1342 return start_string
1328
1343
1329 #----------------------------------------------------------------------------
1344 #----------------------------------------------------------------------------
1330 # (X)emacs on W32 doesn't like to be bypassed with msvcrt.getch()
1345 # (X)emacs on W32 doesn't like to be bypassed with msvcrt.getch()
1331 if os.name == 'nt' and os.environ.get('TERM','dumb') != 'emacs':
1346 if os.name == 'nt' and os.environ.get('TERM','dumb') != 'emacs':
1332 import msvcrt
1347 import msvcrt
1333 def page_more():
1348 def page_more():
1334 """ Smart pausing between pages
1349 """ Smart pausing between pages
1335
1350
1336 @return: True if need print more lines, False if quit
1351 @return: True if need print more lines, False if quit
1337 """
1352 """
1338 Term.cout.write('---Return to continue, q to quit--- ')
1353 Term.cout.write('---Return to continue, q to quit--- ')
1339 ans = msvcrt.getch()
1354 ans = msvcrt.getch()
1340 if ans in ("q", "Q"):
1355 if ans in ("q", "Q"):
1341 result = False
1356 result = False
1342 else:
1357 else:
1343 result = True
1358 result = True
1344 Term.cout.write("\b"*37 + " "*37 + "\b"*37)
1359 Term.cout.write("\b"*37 + " "*37 + "\b"*37)
1345 return result
1360 return result
1346 else:
1361 else:
1347 def page_more():
1362 def page_more():
1348 ans = raw_input('---Return to continue, q to quit--- ')
1363 ans = raw_input('---Return to continue, q to quit--- ')
1349 if ans.lower().startswith('q'):
1364 if ans.lower().startswith('q'):
1350 return False
1365 return False
1351 else:
1366 else:
1352 return True
1367 return True
1353
1368
1354 esc_re = re.compile(r"(\x1b[^m]+m)")
1369 esc_re = re.compile(r"(\x1b[^m]+m)")
1355
1370
1356 def page_dumb(strng,start=0,screen_lines=25):
1371 def page_dumb(strng,start=0,screen_lines=25):
1357 """Very dumb 'pager' in Python, for when nothing else works.
1372 """Very dumb 'pager' in Python, for when nothing else works.
1358
1373
1359 Only moves forward, same interface as page(), except for pager_cmd and
1374 Only moves forward, same interface as page(), except for pager_cmd and
1360 mode."""
1375 mode."""
1361
1376
1362 out_ln = strng.splitlines()[start:]
1377 out_ln = strng.splitlines()[start:]
1363 screens = chop(out_ln,screen_lines-1)
1378 screens = chop(out_ln,screen_lines-1)
1364 if len(screens) == 1:
1379 if len(screens) == 1:
1365 print >>Term.cout, os.linesep.join(screens[0])
1380 print >>Term.cout, os.linesep.join(screens[0])
1366 else:
1381 else:
1367 last_escape = ""
1382 last_escape = ""
1368 for scr in screens[0:-1]:
1383 for scr in screens[0:-1]:
1369 hunk = os.linesep.join(scr)
1384 hunk = os.linesep.join(scr)
1370 print >>Term.cout, last_escape + hunk
1385 print >>Term.cout, last_escape + hunk
1371 if not page_more():
1386 if not page_more():
1372 return
1387 return
1373 esc_list = esc_re.findall(hunk)
1388 esc_list = esc_re.findall(hunk)
1374 if len(esc_list) > 0:
1389 if len(esc_list) > 0:
1375 last_escape = esc_list[-1]
1390 last_escape = esc_list[-1]
1376 print >>Term.cout, last_escape + os.linesep.join(screens[-1])
1391 print >>Term.cout, last_escape + os.linesep.join(screens[-1])
1377
1392
1378 #----------------------------------------------------------------------------
1393 #----------------------------------------------------------------------------
1379 def page(strng,start=0,screen_lines=0,pager_cmd = None):
1394 def page(strng,start=0,screen_lines=0,pager_cmd = None):
1380 """Print a string, piping through a pager after a certain length.
1395 """Print a string, piping through a pager after a certain length.
1381
1396
1382 The screen_lines parameter specifies the number of *usable* lines of your
1397 The screen_lines parameter specifies the number of *usable* lines of your
1383 terminal screen (total lines minus lines you need to reserve to show other
1398 terminal screen (total lines minus lines you need to reserve to show other
1384 information).
1399 information).
1385
1400
1386 If you set screen_lines to a number <=0, page() will try to auto-determine
1401 If you set screen_lines to a number <=0, page() will try to auto-determine
1387 your screen size and will only use up to (screen_size+screen_lines) for
1402 your screen size and will only use up to (screen_size+screen_lines) for
1388 printing, paging after that. That is, if you want auto-detection but need
1403 printing, paging after that. That is, if you want auto-detection but need
1389 to reserve the bottom 3 lines of the screen, use screen_lines = -3, and for
1404 to reserve the bottom 3 lines of the screen, use screen_lines = -3, and for
1390 auto-detection without any lines reserved simply use screen_lines = 0.
1405 auto-detection without any lines reserved simply use screen_lines = 0.
1391
1406
1392 If a string won't fit in the allowed lines, it is sent through the
1407 If a string won't fit in the allowed lines, it is sent through the
1393 specified pager command. If none given, look for PAGER in the environment,
1408 specified pager command. If none given, look for PAGER in the environment,
1394 and ultimately default to less.
1409 and ultimately default to less.
1395
1410
1396 If no system pager works, the string is sent through a 'dumb pager'
1411 If no system pager works, the string is sent through a 'dumb pager'
1397 written in python, very simplistic.
1412 written in python, very simplistic.
1398 """
1413 """
1399
1414
1400 # Ugly kludge, but calling curses.initscr() flat out crashes in emacs
1415 # Ugly kludge, but calling curses.initscr() flat out crashes in emacs
1401 TERM = os.environ.get('TERM','dumb')
1416 TERM = os.environ.get('TERM','dumb')
1402 if TERM in ['dumb','emacs'] and os.name != 'nt':
1417 if TERM in ['dumb','emacs'] and os.name != 'nt':
1403 print strng
1418 print strng
1404 return
1419 return
1405 # chop off the topmost part of the string we don't want to see
1420 # chop off the topmost part of the string we don't want to see
1406 str_lines = strng.split(os.linesep)[start:]
1421 str_lines = strng.split(os.linesep)[start:]
1407 str_toprint = os.linesep.join(str_lines)
1422 str_toprint = os.linesep.join(str_lines)
1408 num_newlines = len(str_lines)
1423 num_newlines = len(str_lines)
1409 len_str = len(str_toprint)
1424 len_str = len(str_toprint)
1410
1425
1411 # Dumb heuristics to guesstimate number of on-screen lines the string
1426 # Dumb heuristics to guesstimate number of on-screen lines the string
1412 # takes. Very basic, but good enough for docstrings in reasonable
1427 # takes. Very basic, but good enough for docstrings in reasonable
1413 # terminals. If someone later feels like refining it, it's not hard.
1428 # terminals. If someone later feels like refining it, it's not hard.
1414 numlines = max(num_newlines,int(len_str/80)+1)
1429 numlines = max(num_newlines,int(len_str/80)+1)
1415
1430
1416 if os.name == "nt":
1431 if os.name == "nt":
1417 screen_lines_def = get_console_size(defaulty=25)[1]
1432 screen_lines_def = get_console_size(defaulty=25)[1]
1418 else:
1433 else:
1419 screen_lines_def = 25 # default value if we can't auto-determine
1434 screen_lines_def = 25 # default value if we can't auto-determine
1420
1435
1421 # auto-determine screen size
1436 # auto-determine screen size
1422 if screen_lines <= 0:
1437 if screen_lines <= 0:
1423 if TERM=='xterm':
1438 if TERM=='xterm':
1424 try:
1439 try:
1425 import curses
1440 import curses
1426 if hasattr(curses,'initscr'):
1441 if hasattr(curses,'initscr'):
1427 use_curses = 1
1442 use_curses = 1
1428 else:
1443 else:
1429 use_curses = 0
1444 use_curses = 0
1430 except ImportError:
1445 except ImportError:
1431 use_curses = 0
1446 use_curses = 0
1432 else:
1447 else:
1433 # curses causes problems on many terminals other than xterm.
1448 # curses causes problems on many terminals other than xterm.
1434 use_curses = 0
1449 use_curses = 0
1435 if use_curses:
1450 if use_curses:
1436 scr = curses.initscr()
1451 scr = curses.initscr()
1437 screen_lines_real,screen_cols = scr.getmaxyx()
1452 screen_lines_real,screen_cols = scr.getmaxyx()
1438 curses.endwin()
1453 curses.endwin()
1439 screen_lines += screen_lines_real
1454 screen_lines += screen_lines_real
1440 #print '***Screen size:',screen_lines_real,'lines x',\
1455 #print '***Screen size:',screen_lines_real,'lines x',\
1441 #screen_cols,'columns.' # dbg
1456 #screen_cols,'columns.' # dbg
1442 else:
1457 else:
1443 screen_lines += screen_lines_def
1458 screen_lines += screen_lines_def
1444
1459
1445 #print 'numlines',numlines,'screenlines',screen_lines # dbg
1460 #print 'numlines',numlines,'screenlines',screen_lines # dbg
1446 if numlines <= screen_lines :
1461 if numlines <= screen_lines :
1447 #print '*** normal print' # dbg
1462 #print '*** normal print' # dbg
1448 print >>Term.cout, str_toprint
1463 print >>Term.cout, str_toprint
1449 else:
1464 else:
1450 # Try to open pager and default to internal one if that fails.
1465 # Try to open pager and default to internal one if that fails.
1451 # All failure modes are tagged as 'retval=1', to match the return
1466 # All failure modes are tagged as 'retval=1', to match the return
1452 # value of a failed system command. If any intermediate attempt
1467 # value of a failed system command. If any intermediate attempt
1453 # sets retval to 1, at the end we resort to our own page_dumb() pager.
1468 # sets retval to 1, at the end we resort to our own page_dumb() pager.
1454 pager_cmd = get_pager_cmd(pager_cmd)
1469 pager_cmd = get_pager_cmd(pager_cmd)
1455 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1470 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1456 if os.name == 'nt':
1471 if os.name == 'nt':
1457 if pager_cmd.startswith('type'):
1472 if pager_cmd.startswith('type'):
1458 # The default WinXP 'type' command is failing on complex strings.
1473 # The default WinXP 'type' command is failing on complex strings.
1459 retval = 1
1474 retval = 1
1460 else:
1475 else:
1461 tmpname = tempfile.mktemp('.txt')
1476 tmpname = tempfile.mktemp('.txt')
1462 tmpfile = file(tmpname,'wt')
1477 tmpfile = file(tmpname,'wt')
1463 tmpfile.write(strng)
1478 tmpfile.write(strng)
1464 tmpfile.close()
1479 tmpfile.close()
1465 cmd = "%s < %s" % (pager_cmd,tmpname)
1480 cmd = "%s < %s" % (pager_cmd,tmpname)
1466 if os.system(cmd):
1481 if os.system(cmd):
1467 retval = 1
1482 retval = 1
1468 else:
1483 else:
1469 retval = None
1484 retval = None
1470 os.remove(tmpname)
1485 os.remove(tmpname)
1471 else:
1486 else:
1472 try:
1487 try:
1473 retval = None
1488 retval = None
1474 # if I use popen4, things hang. No idea why.
1489 # if I use popen4, things hang. No idea why.
1475 #pager,shell_out = os.popen4(pager_cmd)
1490 #pager,shell_out = os.popen4(pager_cmd)
1476 pager = os.popen(pager_cmd,'w')
1491 pager = os.popen(pager_cmd,'w')
1477 pager.write(strng)
1492 pager.write(strng)
1478 pager.close()
1493 pager.close()
1479 retval = pager.close() # success returns None
1494 retval = pager.close() # success returns None
1480 except IOError,msg: # broken pipe when user quits
1495 except IOError,msg: # broken pipe when user quits
1481 if msg.args == (32,'Broken pipe'):
1496 if msg.args == (32,'Broken pipe'):
1482 retval = None
1497 retval = None
1483 else:
1498 else:
1484 retval = 1
1499 retval = 1
1485 except OSError:
1500 except OSError:
1486 # Other strange problems, sometimes seen in Win2k/cygwin
1501 # Other strange problems, sometimes seen in Win2k/cygwin
1487 retval = 1
1502 retval = 1
1488 if retval is not None:
1503 if retval is not None:
1489 page_dumb(strng,screen_lines=screen_lines)
1504 page_dumb(strng,screen_lines=screen_lines)
1490
1505
1491 #----------------------------------------------------------------------------
1506 #----------------------------------------------------------------------------
1492 def page_file(fname,start = 0, pager_cmd = None):
1507 def page_file(fname,start = 0, pager_cmd = None):
1493 """Page a file, using an optional pager command and starting line.
1508 """Page a file, using an optional pager command and starting line.
1494 """
1509 """
1495
1510
1496 pager_cmd = get_pager_cmd(pager_cmd)
1511 pager_cmd = get_pager_cmd(pager_cmd)
1497 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1512 pager_cmd += ' ' + get_pager_start(pager_cmd,start)
1498
1513
1499 try:
1514 try:
1500 if os.environ['TERM'] in ['emacs','dumb']:
1515 if os.environ['TERM'] in ['emacs','dumb']:
1501 raise EnvironmentError
1516 raise EnvironmentError
1502 xsys(pager_cmd + ' ' + fname)
1517 xsys(pager_cmd + ' ' + fname)
1503 except:
1518 except:
1504 try:
1519 try:
1505 if start > 0:
1520 if start > 0:
1506 start -= 1
1521 start -= 1
1507 page(open(fname).read(),start)
1522 page(open(fname).read(),start)
1508 except:
1523 except:
1509 print 'Unable to show file',`fname`
1524 print 'Unable to show file',`fname`
1510
1525
1511 #----------------------------------------------------------------------------
1526 #----------------------------------------------------------------------------
1512 def snip_print(str,width = 75,print_full = 0,header = ''):
1527 def snip_print(str,width = 75,print_full = 0,header = ''):
1513 """Print a string snipping the midsection to fit in width.
1528 """Print a string snipping the midsection to fit in width.
1514
1529
1515 print_full: mode control:
1530 print_full: mode control:
1516 - 0: only snip long strings
1531 - 0: only snip long strings
1517 - 1: send to page() directly.
1532 - 1: send to page() directly.
1518 - 2: snip long strings and ask for full length viewing with page()
1533 - 2: snip long strings and ask for full length viewing with page()
1519 Return 1 if snipping was necessary, 0 otherwise."""
1534 Return 1 if snipping was necessary, 0 otherwise."""
1520
1535
1521 if print_full == 1:
1536 if print_full == 1:
1522 page(header+str)
1537 page(header+str)
1523 return 0
1538 return 0
1524
1539
1525 print header,
1540 print header,
1526 if len(str) < width:
1541 if len(str) < width:
1527 print str
1542 print str
1528 snip = 0
1543 snip = 0
1529 else:
1544 else:
1530 whalf = int((width -5)/2)
1545 whalf = int((width -5)/2)
1531 print str[:whalf] + ' <...> ' + str[-whalf:]
1546 print str[:whalf] + ' <...> ' + str[-whalf:]
1532 snip = 1
1547 snip = 1
1533 if snip and print_full == 2:
1548 if snip and print_full == 2:
1534 if raw_input(header+' Snipped. View (y/n)? [N]').lower() == 'y':
1549 if raw_input(header+' Snipped. View (y/n)? [N]').lower() == 'y':
1535 page(str)
1550 page(str)
1536 return snip
1551 return snip
1537
1552
1538 #****************************************************************************
1553 #****************************************************************************
1539 # lists, dicts and structures
1554 # lists, dicts and structures
1540
1555
1541 def belong(candidates,checklist):
1556 def belong(candidates,checklist):
1542 """Check whether a list of items appear in a given list of options.
1557 """Check whether a list of items appear in a given list of options.
1543
1558
1544 Returns a list of 1 and 0, one for each candidate given."""
1559 Returns a list of 1 and 0, one for each candidate given."""
1545
1560
1546 return [x in checklist for x in candidates]
1561 return [x in checklist for x in candidates]
1547
1562
1548 #----------------------------------------------------------------------------
1563 #----------------------------------------------------------------------------
1549 def uniq_stable(elems):
1564 def uniq_stable(elems):
1550 """uniq_stable(elems) -> list
1565 """uniq_stable(elems) -> list
1551
1566
1552 Return from an iterable, a list of all the unique elements in the input,
1567 Return from an iterable, a list of all the unique elements in the input,
1553 but maintaining the order in which they first appear.
1568 but maintaining the order in which they first appear.
1554
1569
1555 A naive solution to this problem which just makes a dictionary with the
1570 A naive solution to this problem which just makes a dictionary with the
1556 elements as keys fails to respect the stability condition, since
1571 elements as keys fails to respect the stability condition, since
1557 dictionaries are unsorted by nature.
1572 dictionaries are unsorted by nature.
1558
1573
1559 Note: All elements in the input must be valid dictionary keys for this
1574 Note: All elements in the input must be valid dictionary keys for this
1560 routine to work, as it internally uses a dictionary for efficiency
1575 routine to work, as it internally uses a dictionary for efficiency
1561 reasons."""
1576 reasons."""
1562
1577
1563 unique = []
1578 unique = []
1564 unique_dict = {}
1579 unique_dict = {}
1565 for nn in elems:
1580 for nn in elems:
1566 if nn not in unique_dict:
1581 if nn not in unique_dict:
1567 unique.append(nn)
1582 unique.append(nn)
1568 unique_dict[nn] = None
1583 unique_dict[nn] = None
1569 return unique
1584 return unique
1570
1585
1571 #----------------------------------------------------------------------------
1586 #----------------------------------------------------------------------------
1572 class NLprinter:
1587 class NLprinter:
1573 """Print an arbitrarily nested list, indicating index numbers.
1588 """Print an arbitrarily nested list, indicating index numbers.
1574
1589
1575 An instance of this class called nlprint is available and callable as a
1590 An instance of this class called nlprint is available and callable as a
1576 function.
1591 function.
1577
1592
1578 nlprint(list,indent=' ',sep=': ') -> prints indenting each level by 'indent'
1593 nlprint(list,indent=' ',sep=': ') -> prints indenting each level by 'indent'
1579 and using 'sep' to separate the index from the value. """
1594 and using 'sep' to separate the index from the value. """
1580
1595
1581 def __init__(self):
1596 def __init__(self):
1582 self.depth = 0
1597 self.depth = 0
1583
1598
1584 def __call__(self,lst,pos='',**kw):
1599 def __call__(self,lst,pos='',**kw):
1585 """Prints the nested list numbering levels."""
1600 """Prints the nested list numbering levels."""
1586 kw.setdefault('indent',' ')
1601 kw.setdefault('indent',' ')
1587 kw.setdefault('sep',': ')
1602 kw.setdefault('sep',': ')
1588 kw.setdefault('start',0)
1603 kw.setdefault('start',0)
1589 kw.setdefault('stop',len(lst))
1604 kw.setdefault('stop',len(lst))
1590 # we need to remove start and stop from kw so they don't propagate
1605 # we need to remove start and stop from kw so they don't propagate
1591 # into a recursive call for a nested list.
1606 # into a recursive call for a nested list.
1592 start = kw['start']; del kw['start']
1607 start = kw['start']; del kw['start']
1593 stop = kw['stop']; del kw['stop']
1608 stop = kw['stop']; del kw['stop']
1594 if self.depth == 0 and 'header' in kw.keys():
1609 if self.depth == 0 and 'header' in kw.keys():
1595 print kw['header']
1610 print kw['header']
1596
1611
1597 for idx in range(start,stop):
1612 for idx in range(start,stop):
1598 elem = lst[idx]
1613 elem = lst[idx]
1599 if type(elem)==type([]):
1614 if type(elem)==type([]):
1600 self.depth += 1
1615 self.depth += 1
1601 self.__call__(elem,itpl('$pos$idx,'),**kw)
1616 self.__call__(elem,itpl('$pos$idx,'),**kw)
1602 self.depth -= 1
1617 self.depth -= 1
1603 else:
1618 else:
1604 printpl(kw['indent']*self.depth+'$pos$idx$kw["sep"]$elem')
1619 printpl(kw['indent']*self.depth+'$pos$idx$kw["sep"]$elem')
1605
1620
1606 nlprint = NLprinter()
1621 nlprint = NLprinter()
1607 #----------------------------------------------------------------------------
1622 #----------------------------------------------------------------------------
1608 def all_belong(candidates,checklist):
1623 def all_belong(candidates,checklist):
1609 """Check whether a list of items ALL appear in a given list of options.
1624 """Check whether a list of items ALL appear in a given list of options.
1610
1625
1611 Returns a single 1 or 0 value."""
1626 Returns a single 1 or 0 value."""
1612
1627
1613 return 1-(0 in [x in checklist for x in candidates])
1628 return 1-(0 in [x in checklist for x in candidates])
1614
1629
1615 #----------------------------------------------------------------------------
1630 #----------------------------------------------------------------------------
1616 def sort_compare(lst1,lst2,inplace = 1):
1631 def sort_compare(lst1,lst2,inplace = 1):
1617 """Sort and compare two lists.
1632 """Sort and compare two lists.
1618
1633
1619 By default it does it in place, thus modifying the lists. Use inplace = 0
1634 By default it does it in place, thus modifying the lists. Use inplace = 0
1620 to avoid that (at the cost of temporary copy creation)."""
1635 to avoid that (at the cost of temporary copy creation)."""
1621 if not inplace:
1636 if not inplace:
1622 lst1 = lst1[:]
1637 lst1 = lst1[:]
1623 lst2 = lst2[:]
1638 lst2 = lst2[:]
1624 lst1.sort(); lst2.sort()
1639 lst1.sort(); lst2.sort()
1625 return lst1 == lst2
1640 return lst1 == lst2
1626
1641
1627 #----------------------------------------------------------------------------
1642 #----------------------------------------------------------------------------
1628 def mkdict(**kwargs):
1643 def mkdict(**kwargs):
1629 """Return a dict from a keyword list.
1644 """Return a dict from a keyword list.
1630
1645
1631 It's just syntactic sugar for making ditcionary creation more convenient:
1646 It's just syntactic sugar for making ditcionary creation more convenient:
1632 # the standard way
1647 # the standard way
1633 >>>data = { 'red' : 1, 'green' : 2, 'blue' : 3 }
1648 >>>data = { 'red' : 1, 'green' : 2, 'blue' : 3 }
1634 # a cleaner way
1649 # a cleaner way
1635 >>>data = dict(red=1, green=2, blue=3)
1650 >>>data = dict(red=1, green=2, blue=3)
1636
1651
1637 If you need more than this, look at the Struct() class."""
1652 If you need more than this, look at the Struct() class."""
1638
1653
1639 return kwargs
1654 return kwargs
1640
1655
1641 #----------------------------------------------------------------------------
1656 #----------------------------------------------------------------------------
1642 def list2dict(lst):
1657 def list2dict(lst):
1643 """Takes a list of (key,value) pairs and turns it into a dict."""
1658 """Takes a list of (key,value) pairs and turns it into a dict."""
1644
1659
1645 dic = {}
1660 dic = {}
1646 for k,v in lst: dic[k] = v
1661 for k,v in lst: dic[k] = v
1647 return dic
1662 return dic
1648
1663
1649 #----------------------------------------------------------------------------
1664 #----------------------------------------------------------------------------
1650 def list2dict2(lst,default=''):
1665 def list2dict2(lst,default=''):
1651 """Takes a list and turns it into a dict.
1666 """Takes a list and turns it into a dict.
1652 Much slower than list2dict, but more versatile. This version can take
1667 Much slower than list2dict, but more versatile. This version can take
1653 lists with sublists of arbitrary length (including sclars)."""
1668 lists with sublists of arbitrary length (including sclars)."""
1654
1669
1655 dic = {}
1670 dic = {}
1656 for elem in lst:
1671 for elem in lst:
1657 if type(elem) in (types.ListType,types.TupleType):
1672 if type(elem) in (types.ListType,types.TupleType):
1658 size = len(elem)
1673 size = len(elem)
1659 if size == 0:
1674 if size == 0:
1660 pass
1675 pass
1661 elif size == 1:
1676 elif size == 1:
1662 dic[elem] = default
1677 dic[elem] = default
1663 else:
1678 else:
1664 k,v = elem[0], elem[1:]
1679 k,v = elem[0], elem[1:]
1665 if len(v) == 1: v = v[0]
1680 if len(v) == 1: v = v[0]
1666 dic[k] = v
1681 dic[k] = v
1667 else:
1682 else:
1668 dic[elem] = default
1683 dic[elem] = default
1669 return dic
1684 return dic
1670
1685
1671 #----------------------------------------------------------------------------
1686 #----------------------------------------------------------------------------
1672 def flatten(seq):
1687 def flatten(seq):
1673 """Flatten a list of lists (NOT recursive, only works for 2d lists)."""
1688 """Flatten a list of lists (NOT recursive, only works for 2d lists)."""
1674
1689
1675 return [x for subseq in seq for x in subseq]
1690 return [x for subseq in seq for x in subseq]
1676
1691
1677 #----------------------------------------------------------------------------
1692 #----------------------------------------------------------------------------
1678 def get_slice(seq,start=0,stop=None,step=1):
1693 def get_slice(seq,start=0,stop=None,step=1):
1679 """Get a slice of a sequence with variable step. Specify start,stop,step."""
1694 """Get a slice of a sequence with variable step. Specify start,stop,step."""
1680 if stop == None:
1695 if stop == None:
1681 stop = len(seq)
1696 stop = len(seq)
1682 item = lambda i: seq[i]
1697 item = lambda i: seq[i]
1683 return map(item,xrange(start,stop,step))
1698 return map(item,xrange(start,stop,step))
1684
1699
1685 #----------------------------------------------------------------------------
1700 #----------------------------------------------------------------------------
1686 def chop(seq,size):
1701 def chop(seq,size):
1687 """Chop a sequence into chunks of the given size."""
1702 """Chop a sequence into chunks of the given size."""
1688 chunk = lambda i: seq[i:i+size]
1703 chunk = lambda i: seq[i:i+size]
1689 return map(chunk,xrange(0,len(seq),size))
1704 return map(chunk,xrange(0,len(seq),size))
1690
1705
1691 #----------------------------------------------------------------------------
1706 #----------------------------------------------------------------------------
1692 # with is a keyword as of python 2.5, so this function is renamed to withobj
1707 # with is a keyword as of python 2.5, so this function is renamed to withobj
1693 # from its old 'with' name.
1708 # from its old 'with' name.
1694 def with_obj(object, **args):
1709 def with_obj(object, **args):
1695 """Set multiple attributes for an object, similar to Pascal's with.
1710 """Set multiple attributes for an object, similar to Pascal's with.
1696
1711
1697 Example:
1712 Example:
1698 with_obj(jim,
1713 with_obj(jim,
1699 born = 1960,
1714 born = 1960,
1700 haircolour = 'Brown',
1715 haircolour = 'Brown',
1701 eyecolour = 'Green')
1716 eyecolour = 'Green')
1702
1717
1703 Credit: Greg Ewing, in
1718 Credit: Greg Ewing, in
1704 http://mail.python.org/pipermail/python-list/2001-May/040703.html.
1719 http://mail.python.org/pipermail/python-list/2001-May/040703.html.
1705
1720
1706 NOTE: up until IPython 0.7.2, this was called simply 'with', but 'with'
1721 NOTE: up until IPython 0.7.2, this was called simply 'with', but 'with'
1707 has become a keyword for Python 2.5, so we had to rename it."""
1722 has become a keyword for Python 2.5, so we had to rename it."""
1708
1723
1709 object.__dict__.update(args)
1724 object.__dict__.update(args)
1710
1725
1711 #----------------------------------------------------------------------------
1726 #----------------------------------------------------------------------------
1712 def setattr_list(obj,alist,nspace = None):
1727 def setattr_list(obj,alist,nspace = None):
1713 """Set a list of attributes for an object taken from a namespace.
1728 """Set a list of attributes for an object taken from a namespace.
1714
1729
1715 setattr_list(obj,alist,nspace) -> sets in obj all the attributes listed in
1730 setattr_list(obj,alist,nspace) -> sets in obj all the attributes listed in
1716 alist with their values taken from nspace, which must be a dict (something
1731 alist with their values taken from nspace, which must be a dict (something
1717 like locals() will often do) If nspace isn't given, locals() of the
1732 like locals() will often do) If nspace isn't given, locals() of the
1718 *caller* is used, so in most cases you can omit it.
1733 *caller* is used, so in most cases you can omit it.
1719
1734
1720 Note that alist can be given as a string, which will be automatically
1735 Note that alist can be given as a string, which will be automatically
1721 split into a list on whitespace. If given as a list, it must be a list of
1736 split into a list on whitespace. If given as a list, it must be a list of
1722 *strings* (the variable names themselves), not of variables."""
1737 *strings* (the variable names themselves), not of variables."""
1723
1738
1724 # this grabs the local variables from the *previous* call frame -- that is
1739 # this grabs the local variables from the *previous* call frame -- that is
1725 # the locals from the function that called setattr_list().
1740 # the locals from the function that called setattr_list().
1726 # - snipped from weave.inline()
1741 # - snipped from weave.inline()
1727 if nspace is None:
1742 if nspace is None:
1728 call_frame = sys._getframe().f_back
1743 call_frame = sys._getframe().f_back
1729 nspace = call_frame.f_locals
1744 nspace = call_frame.f_locals
1730
1745
1731 if type(alist) in StringTypes:
1746 if type(alist) in StringTypes:
1732 alist = alist.split()
1747 alist = alist.split()
1733 for attr in alist:
1748 for attr in alist:
1734 val = eval(attr,nspace)
1749 val = eval(attr,nspace)
1735 setattr(obj,attr,val)
1750 setattr(obj,attr,val)
1736
1751
1737 #----------------------------------------------------------------------------
1752 #----------------------------------------------------------------------------
1738 def getattr_list(obj,alist,*args):
1753 def getattr_list(obj,alist,*args):
1739 """getattr_list(obj,alist[, default]) -> attribute list.
1754 """getattr_list(obj,alist[, default]) -> attribute list.
1740
1755
1741 Get a list of named attributes for an object. When a default argument is
1756 Get a list of named attributes for an object. When a default argument is
1742 given, it is returned when the attribute doesn't exist; without it, an
1757 given, it is returned when the attribute doesn't exist; without it, an
1743 exception is raised in that case.
1758 exception is raised in that case.
1744
1759
1745 Note that alist can be given as a string, which will be automatically
1760 Note that alist can be given as a string, which will be automatically
1746 split into a list on whitespace. If given as a list, it must be a list of
1761 split into a list on whitespace. If given as a list, it must be a list of
1747 *strings* (the variable names themselves), not of variables."""
1762 *strings* (the variable names themselves), not of variables."""
1748
1763
1749 if type(alist) in StringTypes:
1764 if type(alist) in StringTypes:
1750 alist = alist.split()
1765 alist = alist.split()
1751 if args:
1766 if args:
1752 if len(args)==1:
1767 if len(args)==1:
1753 default = args[0]
1768 default = args[0]
1754 return map(lambda attr: getattr(obj,attr,default),alist)
1769 return map(lambda attr: getattr(obj,attr,default),alist)
1755 else:
1770 else:
1756 raise ValueError,'getattr_list() takes only one optional argument'
1771 raise ValueError,'getattr_list() takes only one optional argument'
1757 else:
1772 else:
1758 return map(lambda attr: getattr(obj,attr),alist)
1773 return map(lambda attr: getattr(obj,attr),alist)
1759
1774
1760 #----------------------------------------------------------------------------
1775 #----------------------------------------------------------------------------
1761 def map_method(method,object_list,*argseq,**kw):
1776 def map_method(method,object_list,*argseq,**kw):
1762 """map_method(method,object_list,*args,**kw) -> list
1777 """map_method(method,object_list,*args,**kw) -> list
1763
1778
1764 Return a list of the results of applying the methods to the items of the
1779 Return a list of the results of applying the methods to the items of the
1765 argument sequence(s). If more than one sequence is given, the method is
1780 argument sequence(s). If more than one sequence is given, the method is
1766 called with an argument list consisting of the corresponding item of each
1781 called with an argument list consisting of the corresponding item of each
1767 sequence. All sequences must be of the same length.
1782 sequence. All sequences must be of the same length.
1768
1783
1769 Keyword arguments are passed verbatim to all objects called.
1784 Keyword arguments are passed verbatim to all objects called.
1770
1785
1771 This is Python code, so it's not nearly as fast as the builtin map()."""
1786 This is Python code, so it's not nearly as fast as the builtin map()."""
1772
1787
1773 out_list = []
1788 out_list = []
1774 idx = 0
1789 idx = 0
1775 for object in object_list:
1790 for object in object_list:
1776 try:
1791 try:
1777 handler = getattr(object, method)
1792 handler = getattr(object, method)
1778 except AttributeError:
1793 except AttributeError:
1779 out_list.append(None)
1794 out_list.append(None)
1780 else:
1795 else:
1781 if argseq:
1796 if argseq:
1782 args = map(lambda lst:lst[idx],argseq)
1797 args = map(lambda lst:lst[idx],argseq)
1783 #print 'ob',object,'hand',handler,'ar',args # dbg
1798 #print 'ob',object,'hand',handler,'ar',args # dbg
1784 out_list.append(handler(args,**kw))
1799 out_list.append(handler(args,**kw))
1785 else:
1800 else:
1786 out_list.append(handler(**kw))
1801 out_list.append(handler(**kw))
1787 idx += 1
1802 idx += 1
1788 return out_list
1803 return out_list
1789
1804
1790 #----------------------------------------------------------------------------
1805 #----------------------------------------------------------------------------
1791 def get_class_members(cls):
1806 def get_class_members(cls):
1792 ret = dir(cls)
1807 ret = dir(cls)
1793 if hasattr(cls,'__bases__'):
1808 if hasattr(cls,'__bases__'):
1794 for base in cls.__bases__:
1809 for base in cls.__bases__:
1795 ret.extend(get_class_members(base))
1810 ret.extend(get_class_members(base))
1796 return ret
1811 return ret
1797
1812
1798 #----------------------------------------------------------------------------
1813 #----------------------------------------------------------------------------
1799 def dir2(obj):
1814 def dir2(obj):
1800 """dir2(obj) -> list of strings
1815 """dir2(obj) -> list of strings
1801
1816
1802 Extended version of the Python builtin dir(), which does a few extra
1817 Extended version of the Python builtin dir(), which does a few extra
1803 checks, and supports common objects with unusual internals that confuse
1818 checks, and supports common objects with unusual internals that confuse
1804 dir(), such as Traits and PyCrust.
1819 dir(), such as Traits and PyCrust.
1805
1820
1806 This version is guaranteed to return only a list of true strings, whereas
1821 This version is guaranteed to return only a list of true strings, whereas
1807 dir() returns anything that objects inject into themselves, even if they
1822 dir() returns anything that objects inject into themselves, even if they
1808 are later not really valid for attribute access (many extension libraries
1823 are later not really valid for attribute access (many extension libraries
1809 have such bugs).
1824 have such bugs).
1810 """
1825 """
1811
1826
1812 # Start building the attribute list via dir(), and then complete it
1827 # Start building the attribute list via dir(), and then complete it
1813 # with a few extra special-purpose calls.
1828 # with a few extra special-purpose calls.
1814 words = dir(obj)
1829 words = dir(obj)
1815
1830
1816 if hasattr(obj,'__class__'):
1831 if hasattr(obj,'__class__'):
1817 words.append('__class__')
1832 words.append('__class__')
1818 words.extend(get_class_members(obj.__class__))
1833 words.extend(get_class_members(obj.__class__))
1819 #if '__base__' in words: 1/0
1834 #if '__base__' in words: 1/0
1820
1835
1821 # Some libraries (such as traits) may introduce duplicates, we want to
1836 # Some libraries (such as traits) may introduce duplicates, we want to
1822 # track and clean this up if it happens
1837 # track and clean this up if it happens
1823 may_have_dupes = False
1838 may_have_dupes = False
1824
1839
1825 # this is the 'dir' function for objects with Enthought's traits
1840 # this is the 'dir' function for objects with Enthought's traits
1826 if hasattr(obj, 'trait_names'):
1841 if hasattr(obj, 'trait_names'):
1827 try:
1842 try:
1828 words.extend(obj.trait_names())
1843 words.extend(obj.trait_names())
1829 may_have_dupes = True
1844 may_have_dupes = True
1830 except TypeError:
1845 except TypeError:
1831 # This will happen if `obj` is a class and not an instance.
1846 # This will happen if `obj` is a class and not an instance.
1832 pass
1847 pass
1833
1848
1834 # Support for PyCrust-style _getAttributeNames magic method.
1849 # Support for PyCrust-style _getAttributeNames magic method.
1835 if hasattr(obj, '_getAttributeNames'):
1850 if hasattr(obj, '_getAttributeNames'):
1836 try:
1851 try:
1837 words.extend(obj._getAttributeNames())
1852 words.extend(obj._getAttributeNames())
1838 may_have_dupes = True
1853 may_have_dupes = True
1839 except TypeError:
1854 except TypeError:
1840 # `obj` is a class and not an instance. Ignore
1855 # `obj` is a class and not an instance. Ignore
1841 # this error.
1856 # this error.
1842 pass
1857 pass
1843
1858
1844 if may_have_dupes:
1859 if may_have_dupes:
1845 # eliminate possible duplicates, as some traits may also
1860 # eliminate possible duplicates, as some traits may also
1846 # appear as normal attributes in the dir() call.
1861 # appear as normal attributes in the dir() call.
1847 words = list(set(words))
1862 words = list(set(words))
1848 words.sort()
1863 words.sort()
1849
1864
1850 # filter out non-string attributes which may be stuffed by dir() calls
1865 # filter out non-string attributes which may be stuffed by dir() calls
1851 # and poor coding in third-party modules
1866 # and poor coding in third-party modules
1852 return [w for w in words if isinstance(w, basestring)]
1867 return [w for w in words if isinstance(w, basestring)]
1853
1868
1854 #----------------------------------------------------------------------------
1869 #----------------------------------------------------------------------------
1855 def import_fail_info(mod_name,fns=None):
1870 def import_fail_info(mod_name,fns=None):
1856 """Inform load failure for a module."""
1871 """Inform load failure for a module."""
1857
1872
1858 if fns == None:
1873 if fns == None:
1859 warn("Loading of %s failed.\n" % (mod_name,))
1874 warn("Loading of %s failed.\n" % (mod_name,))
1860 else:
1875 else:
1861 warn("Loading of %s from %s failed.\n" % (fns,mod_name))
1876 warn("Loading of %s from %s failed.\n" % (fns,mod_name))
1862
1877
1863 #----------------------------------------------------------------------------
1878 #----------------------------------------------------------------------------
1864 # Proposed popitem() extension, written as a method
1879 # Proposed popitem() extension, written as a method
1865
1880
1866
1881
1867 class NotGiven: pass
1882 class NotGiven: pass
1868
1883
1869 def popkey(dct,key,default=NotGiven):
1884 def popkey(dct,key,default=NotGiven):
1870 """Return dct[key] and delete dct[key].
1885 """Return dct[key] and delete dct[key].
1871
1886
1872 If default is given, return it if dct[key] doesn't exist, otherwise raise
1887 If default is given, return it if dct[key] doesn't exist, otherwise raise
1873 KeyError. """
1888 KeyError. """
1874
1889
1875 try:
1890 try:
1876 val = dct[key]
1891 val = dct[key]
1877 except KeyError:
1892 except KeyError:
1878 if default is NotGiven:
1893 if default is NotGiven:
1879 raise
1894 raise
1880 else:
1895 else:
1881 return default
1896 return default
1882 else:
1897 else:
1883 del dct[key]
1898 del dct[key]
1884 return val
1899 return val
1885
1900
1886 def wrap_deprecated(func, suggest = '<nothing>'):
1901 def wrap_deprecated(func, suggest = '<nothing>'):
1887 def newFunc(*args, **kwargs):
1902 def newFunc(*args, **kwargs):
1888 warnings.warn("Call to deprecated function %s, use %s instead" %
1903 warnings.warn("Call to deprecated function %s, use %s instead" %
1889 ( func.__name__, suggest),
1904 ( func.__name__, suggest),
1890 category=DeprecationWarning,
1905 category=DeprecationWarning,
1891 stacklevel = 2)
1906 stacklevel = 2)
1892 return func(*args, **kwargs)
1907 return func(*args, **kwargs)
1893 return newFunc
1908 return newFunc
1894
1909
1895 #*************************** end of file <genutils.py> **********************
1910 #*************************** end of file <genutils.py> **********************
1896
1911
@@ -1,7144 +1,7146 b''
1 2007-09-07 Ville Vainio <vivainio@gmail.com>
1 2007-09-07 Ville Vainio <vivainio@gmail.com>
2
2
3 * iplib.py: do not auto-alias "dir", it screws up other dir auto
3 * iplib.py: do not auto-alias "dir", it screws up other dir auto
4 aliases.
4 aliases.
5
5
6 * genutils.py: SList.grep() implemented.
7
6 2007-09-07 Fernando Perez <Fernando.Perez@colorado.edu>
8 2007-09-07 Fernando Perez <Fernando.Perez@colorado.edu>
7
9
8 * IPython/OInspect.py (Inspector.pinfo): fixed bug that was
10 * IPython/OInspect.py (Inspector.pinfo): fixed bug that was
9 preventing source display in certain cases. In reality I think
11 preventing source display in certain cases. In reality I think
10 the problem is with Ubuntu's Python build, but this change works
12 the problem is with Ubuntu's Python build, but this change works
11 around the issue in some cases (not in all, unfortunately). I'd
13 around the issue in some cases (not in all, unfortunately). I'd
12 filed a Python bug on this with more details, but in the change of
14 filed a Python bug on this with more details, but in the change of
13 bug trackers it seems to have been lost.
15 bug trackers it seems to have been lost.
14
16
15 * IPython/Magic.py (magic_dhist): restore %dhist. No, cd -TAB is
17 * IPython/Magic.py (magic_dhist): restore %dhist. No, cd -TAB is
16 not the same, it's not self-documenting, doesn't allow range
18 not the same, it's not self-documenting, doesn't allow range
17 selection, and sorts alphabetically instead of numerically.
19 selection, and sorts alphabetically instead of numerically.
18 (magic_r): restore %r. No, "up + enter. One char magic" is not
20 (magic_r): restore %r. No, "up + enter. One char magic" is not
19 the same thing, since %r takes parameters to allow fast retrieval
21 the same thing, since %r takes parameters to allow fast retrieval
20 of old commands. I've received emails from users who use this a
22 of old commands. I've received emails from users who use this a
21 LOT, so it stays.
23 LOT, so it stays.
22 (magic_automagic): restore %automagic. "use _ip.option.automagic"
24 (magic_automagic): restore %automagic. "use _ip.option.automagic"
23 is not a valid replacement b/c it doesn't provide an complete
25 is not a valid replacement b/c it doesn't provide an complete
24 explanation (which the automagic docstring does).
26 explanation (which the automagic docstring does).
25 (magic_autocall): restore %autocall, with improved docstring.
27 (magic_autocall): restore %autocall, with improved docstring.
26 Same argument as for others, "use _ip.options.autocall" is not a
28 Same argument as for others, "use _ip.options.autocall" is not a
27 valid replacement.
29 valid replacement.
28 (magic_pdef): restore %pdef & friends. Used widely, mentioned in
30 (magic_pdef): restore %pdef & friends. Used widely, mentioned in
29 tutorials and online docs.
31 tutorials and online docs.
30
32
31 2007-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
33 2007-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
32
34
33 * IPython/usage.py (quick_reference): mention magics in quickref,
35 * IPython/usage.py (quick_reference): mention magics in quickref,
34 modified main banner to mention %quickref.
36 modified main banner to mention %quickref.
35
37
36 * IPython/FakeModule.py (FakeModule): fixes for doctest compatibility.
38 * IPython/FakeModule.py (FakeModule): fixes for doctest compatibility.
37
39
38 2007-09-06 Ville Vainio <vivainio@gmail.com>
40 2007-09-06 Ville Vainio <vivainio@gmail.com>
39
41
40 * ipy_rehashdir.py, ipy_workdir.py, ipy_fsops.py, iplib.py:
42 * ipy_rehashdir.py, ipy_workdir.py, ipy_fsops.py, iplib.py:
41 Callable aliases now pass the _ip as first arg. This breaks
43 Callable aliases now pass the _ip as first arg. This breaks
42 compatibility with earlier 0.8.2.svn series! (though they should
44 compatibility with earlier 0.8.2.svn series! (though they should
43 not have been in use yet outside these few extensions)
45 not have been in use yet outside these few extensions)
44
46
45 2007-09-05 Ville Vainio <vivainio@gmail.com>
47 2007-09-05 Ville Vainio <vivainio@gmail.com>
46
48
47 * external/mglob.py: expand('dirname') => ['dirname'], instead
49 * external/mglob.py: expand('dirname') => ['dirname'], instead
48 of ['dirname/foo','dirname/bar', ...].
50 of ['dirname/foo','dirname/bar', ...].
49
51
50 * Extensions/ipy_fsops.py: added, has usefull shell utils for plain
52 * Extensions/ipy_fsops.py: added, has usefull shell utils for plain
51 win32 installations: icp, imv, imkdir, igrep, irm, collect (collect
53 win32 installations: icp, imv, imkdir, igrep, irm, collect (collect
52 is useful for others as well).
54 is useful for others as well).
53
55
54 * iplib.py: on callable aliases (as opposed to old style aliases),
56 * iplib.py: on callable aliases (as opposed to old style aliases),
55 do var_expand() immediately, and use make_quoted_expr instead
57 do var_expand() immediately, and use make_quoted_expr instead
56 of hardcoded r"""
58 of hardcoded r"""
57
59
58 * Extensions/ipy_profile_sh.py: Try to detect cygwin on win32,
60 * Extensions/ipy_profile_sh.py: Try to detect cygwin on win32,
59 if not available load ipy_fsops.py for cp, mv, etc. replacements
61 if not available load ipy_fsops.py for cp, mv, etc. replacements
60
62
61 * OInspect.py, ipy_which.py: improve %which and obj? for callable
63 * OInspect.py, ipy_which.py: improve %which and obj? for callable
62 aliases
64 aliases
63
65
64 2007-09-04 Ville Vainio <vivainio@gmail.com>
66 2007-09-04 Ville Vainio <vivainio@gmail.com>
65
67
66 * ipy_profile_zope.py: add zope profile, by Stefan Eletzhofer.
68 * ipy_profile_zope.py: add zope profile, by Stefan Eletzhofer.
67 Relicensed under BSD with the authors approval.
69 Relicensed under BSD with the authors approval.
68
70
69 * ipmaker.py, usage.py: Remove %magic from default banner, improve
71 * ipmaker.py, usage.py: Remove %magic from default banner, improve
70 %quickref
72 %quickref
71
73
72 2007-09-03 Ville Vainio <vivainio@gmail.com>
74 2007-09-03 Ville Vainio <vivainio@gmail.com>
73
75
74 * Magic.py: %time now passes expression through prefilter,
76 * Magic.py: %time now passes expression through prefilter,
75 allowing IPython syntax.
77 allowing IPython syntax.
76
78
77 2007-09-01 Ville Vainio <vivainio@gmail.com>
79 2007-09-01 Ville Vainio <vivainio@gmail.com>
78
80
79 * ipmaker.py: Always show full traceback when newstyle config fails
81 * ipmaker.py: Always show full traceback when newstyle config fails
80
82
81 2007-08-27 Ville Vainio <vivainio@gmail.com>
83 2007-08-27 Ville Vainio <vivainio@gmail.com>
82
84
83 * Magic.py: fix %cd for nonexistent dir when dhist is empty, close #180
85 * Magic.py: fix %cd for nonexistent dir when dhist is empty, close #180
84
86
85 2007-08-26 Ville Vainio <vivainio@gmail.com>
87 2007-08-26 Ville Vainio <vivainio@gmail.com>
86
88
87 * ipmaker.py: Command line args have the highest priority again
89 * ipmaker.py: Command line args have the highest priority again
88
90
89 * iplib.py, ipmaker.py: -i command line argument now behaves as in
91 * iplib.py, ipmaker.py: -i command line argument now behaves as in
90 normal python, i.e. leaves the IPython session running after -c
92 normal python, i.e. leaves the IPython session running after -c
91 command or running a batch file from command line.
93 command or running a batch file from command line.
92
94
93 2007-08-22 Ville Vainio <vivainio@gmail.com>
95 2007-08-22 Ville Vainio <vivainio@gmail.com>
94
96
95 * iplib.py: no extra empty (last) line in raw hist w/ multiline
97 * iplib.py: no extra empty (last) line in raw hist w/ multiline
96 statements
98 statements
97
99
98 * logger.py: Fix bug where blank lines in history were not
100 * logger.py: Fix bug where blank lines in history were not
99 added until AFTER adding the current line; translated and raw
101 added until AFTER adding the current line; translated and raw
100 history should finally be in sync with prompt now.
102 history should finally be in sync with prompt now.
101
103
102 * ipy_completers.py: quick_completer now makes it easy to create
104 * ipy_completers.py: quick_completer now makes it easy to create
103 trivial custom completers
105 trivial custom completers
104
106
105 * clearcmd.py: shadow history compression & erasing, fixed input hist
107 * clearcmd.py: shadow history compression & erasing, fixed input hist
106 clearing.
108 clearing.
107
109
108 * envpersist.py, history.py: %env (sh profile only), %hist completers
110 * envpersist.py, history.py: %env (sh profile only), %hist completers
109
111
110 * genutils.py, Prompts.py, Magic.py: win32 - prompt (with \yDEPTH) and
112 * genutils.py, Prompts.py, Magic.py: win32 - prompt (with \yDEPTH) and
111 term title now include the drive letter, and always use / instead of
113 term title now include the drive letter, and always use / instead of
112 os.sep (as per recommended approach for win32 ipython in general).
114 os.sep (as per recommended approach for win32 ipython in general).
113
115
114 * ipykit.py, ipy_kitcfg.py: special launcher for ipykit. Allows running
116 * ipykit.py, ipy_kitcfg.py: special launcher for ipykit. Allows running
115 plain python scripts from ipykit command line by running
117 plain python scripts from ipykit command line by running
116 "py myscript.py", even w/o installed python.
118 "py myscript.py", even w/o installed python.
117
119
118 2007-08-21 Ville Vainio <vivainio@gmail.com>
120 2007-08-21 Ville Vainio <vivainio@gmail.com>
119
121
120 * ipmaker.py: finding ipythonrc-PROF now skips ipy_profile_PROF.
122 * ipmaker.py: finding ipythonrc-PROF now skips ipy_profile_PROF.
121 (for backwards compatibility)
123 (for backwards compatibility)
122
124
123 * history.py: switch back to %hist -t from %hist -r as default.
125 * history.py: switch back to %hist -t from %hist -r as default.
124 At least until raw history is fixed for good.
126 At least until raw history is fixed for good.
125
127
126 2007-08-20 Ville Vainio <vivainio@gmail.com>
128 2007-08-20 Ville Vainio <vivainio@gmail.com>
127
129
128 * ipapi.py, iplib.py: DebugTools accessible via _ip.dbg, to catch &
130 * ipapi.py, iplib.py: DebugTools accessible via _ip.dbg, to catch &
129 locate alias redeclarations etc. Also, avoid handling
131 locate alias redeclarations etc. Also, avoid handling
130 _ip.IP.alias_table directly, prefer using _ip.defalias.
132 _ip.IP.alias_table directly, prefer using _ip.defalias.
131
133
132
134
133 2007-08-15 Ville Vainio <vivainio@gmail.com>
135 2007-08-15 Ville Vainio <vivainio@gmail.com>
134
136
135 * prefilter.py: ! is now always served first
137 * prefilter.py: ! is now always served first
136
138
137 2007-08-15 Fernando Perez <Fernando.Perez@colorado.edu>
139 2007-08-15 Fernando Perez <Fernando.Perez@colorado.edu>
138
140
139 * IPython/iplib.py (safe_execfile): fix the SystemExit
141 * IPython/iplib.py (safe_execfile): fix the SystemExit
140 auto-suppression code to work in Python2.4 (the internal structure
142 auto-suppression code to work in Python2.4 (the internal structure
141 of that exception changed and I'd only tested the code with 2.5).
143 of that exception changed and I'd only tested the code with 2.5).
142 Bug reported by a SciPy attendee.
144 Bug reported by a SciPy attendee.
143
145
144 2007-08-13 Ville Vainio <vivainio@gmail.com>
146 2007-08-13 Ville Vainio <vivainio@gmail.com>
145
147
146 * prefilter.py: reverted !c:/bin/foo fix, made % in
148 * prefilter.py: reverted !c:/bin/foo fix, made % in
147 multiline specials work again
149 multiline specials work again
148
150
149 2007-08-13 Ville Vainio <vivainio@gmail.com>
151 2007-08-13 Ville Vainio <vivainio@gmail.com>
150
152
151 * prefilter.py: Take more care to special-case !, so that
153 * prefilter.py: Take more care to special-case !, so that
152 !c:/bin/foo.exe works.
154 !c:/bin/foo.exe works.
153
155
154 * setup.py: if we are building eggs, strip all docs and
156 * setup.py: if we are building eggs, strip all docs and
155 examples (it doesn't make sense to bytecompile examples,
157 examples (it doesn't make sense to bytecompile examples,
156 and docs would be in an awkward place anyway).
158 and docs would be in an awkward place anyway).
157
159
158 * Ryan Krauss' patch fixes start menu shortcuts when IPython
160 * Ryan Krauss' patch fixes start menu shortcuts when IPython
159 is installed into a directory that has spaces in the name.
161 is installed into a directory that has spaces in the name.
160
162
161 2007-08-13 Fernando Perez <Fernando.Perez@colorado.edu>
163 2007-08-13 Fernando Perez <Fernando.Perez@colorado.edu>
162
164
163 * IPython/Magic.py (magic_doctest_mode): fix prompt separators in
165 * IPython/Magic.py (magic_doctest_mode): fix prompt separators in
164 doctest profile and %doctest_mode, so they actually generate the
166 doctest profile and %doctest_mode, so they actually generate the
165 blank lines needed by doctest to separate individual tests.
167 blank lines needed by doctest to separate individual tests.
166
168
167 * IPython/iplib.py (safe_execfile): modify so that running code
169 * IPython/iplib.py (safe_execfile): modify so that running code
168 which calls sys.exit(0) (or equivalently, raise SystemExit(0))
170 which calls sys.exit(0) (or equivalently, raise SystemExit(0))
169 doesn't get a printed traceback. Any other value in sys.exit(),
171 doesn't get a printed traceback. Any other value in sys.exit(),
170 including the empty call, still generates a traceback. This
172 including the empty call, still generates a traceback. This
171 enables use of %run without having to pass '-e' for codes that
173 enables use of %run without having to pass '-e' for codes that
172 correctly set the exit status flag.
174 correctly set the exit status flag.
173
175
174 2007-08-12 Fernando Perez <Fernando.Perez@colorado.edu>
176 2007-08-12 Fernando Perez <Fernando.Perez@colorado.edu>
175
177
176 * IPython/iplib.py (InteractiveShell.post_config_initialization):
178 * IPython/iplib.py (InteractiveShell.post_config_initialization):
177 fix problems with doctests failing when run inside IPython due to
179 fix problems with doctests failing when run inside IPython due to
178 IPython's modifications of sys.displayhook.
180 IPython's modifications of sys.displayhook.
179
181
180 2007-8-9 Fernando Perez <fperez@planck.colorado.edu>
182 2007-8-9 Fernando Perez <fperez@planck.colorado.edu>
181
183
182 * IPython/ipapi.py (to_user_ns): update to accept a dict as well as
184 * IPython/ipapi.py (to_user_ns): update to accept a dict as well as
183 a string with names.
185 a string with names.
184
186
185 2007-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
187 2007-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
186
188
187 * IPython/Magic.py (magic_doctest_mode): added new %doctest_mode
189 * IPython/Magic.py (magic_doctest_mode): added new %doctest_mode
188 magic to toggle on/off the doctest pasting support without having
190 magic to toggle on/off the doctest pasting support without having
189 to leave a session to switch to a separate profile.
191 to leave a session to switch to a separate profile.
190
192
191 2007-08-08 Fernando Perez <Fernando.Perez@colorado.edu>
193 2007-08-08 Fernando Perez <Fernando.Perez@colorado.edu>
192
194
193 * IPython/Extensions/ipy_profile_doctest.py (main): fix prompt to
195 * IPython/Extensions/ipy_profile_doctest.py (main): fix prompt to
194 introduce a blank line between inputs, to conform to doctest
196 introduce a blank line between inputs, to conform to doctest
195 requirements.
197 requirements.
196
198
197 * IPython/OInspect.py (Inspector.pinfo): fix another part where
199 * IPython/OInspect.py (Inspector.pinfo): fix another part where
198 auto-generated docstrings for new-style classes were showing up.
200 auto-generated docstrings for new-style classes were showing up.
199
201
200 2007-08-07 Fernando Perez <Fernando.Perez@colorado.edu>
202 2007-08-07 Fernando Perez <Fernando.Perez@colorado.edu>
201
203
202 * api_changes: Add new file to track backward-incompatible
204 * api_changes: Add new file to track backward-incompatible
203 user-visible changes.
205 user-visible changes.
204
206
205 2007-08-06 Ville Vainio <vivainio@gmail.com>
207 2007-08-06 Ville Vainio <vivainio@gmail.com>
206
208
207 * ipmaker.py: fix bug where user_config_ns didn't exist at all
209 * ipmaker.py: fix bug where user_config_ns didn't exist at all
208 before all the config files were handled.
210 before all the config files were handled.
209
211
210 2007-08-04 Fernando Perez <Fernando.Perez@colorado.edu>
212 2007-08-04 Fernando Perez <Fernando.Perez@colorado.edu>
211
213
212 * IPython/irunner.py (RunnerFactory): Add new factory class for
214 * IPython/irunner.py (RunnerFactory): Add new factory class for
213 creating reusable runners based on filenames.
215 creating reusable runners based on filenames.
214
216
215 * IPython/Extensions/ipy_profile_doctest.py: New profile for
217 * IPython/Extensions/ipy_profile_doctest.py: New profile for
216 doctest support. It sets prompts/exceptions as similar to
218 doctest support. It sets prompts/exceptions as similar to
217 standard Python as possible, so that ipython sessions in this
219 standard Python as possible, so that ipython sessions in this
218 profile can be easily pasted as doctests with minimal
220 profile can be easily pasted as doctests with minimal
219 modifications. It also enables pasting of doctests from external
221 modifications. It also enables pasting of doctests from external
220 sources (even if they have leading whitespace), so that you can
222 sources (even if they have leading whitespace), so that you can
221 rerun doctests from existing sources.
223 rerun doctests from existing sources.
222
224
223 * IPython/iplib.py (_prefilter): fix a buglet where after entering
225 * IPython/iplib.py (_prefilter): fix a buglet where after entering
224 some whitespace, the prompt would become a continuation prompt
226 some whitespace, the prompt would become a continuation prompt
225 with no way of exiting it other than Ctrl-C. This fix brings us
227 with no way of exiting it other than Ctrl-C. This fix brings us
226 into conformity with how the default python prompt works.
228 into conformity with how the default python prompt works.
227
229
228 * IPython/Extensions/InterpreterPasteInput.py (prefilter_paste):
230 * IPython/Extensions/InterpreterPasteInput.py (prefilter_paste):
229 Add support for pasting not only lines that start with '>>>', but
231 Add support for pasting not only lines that start with '>>>', but
230 also with ' >>>'. That is, arbitrary whitespace can now precede
232 also with ' >>>'. That is, arbitrary whitespace can now precede
231 the prompts. This makes the system useful for pasting doctests
233 the prompts. This makes the system useful for pasting doctests
232 from docstrings back into a normal session.
234 from docstrings back into a normal session.
233
235
234 2007-08-02 Fernando Perez <Fernando.Perez@colorado.edu>
236 2007-08-02 Fernando Perez <Fernando.Perez@colorado.edu>
235
237
236 * IPython/Shell.py (IPShellEmbed.__call__): fix bug introduced in
238 * IPython/Shell.py (IPShellEmbed.__call__): fix bug introduced in
237 r1357, which had killed multiple invocations of an embedded
239 r1357, which had killed multiple invocations of an embedded
238 ipython (this means that example-embed has been broken for over 1
240 ipython (this means that example-embed has been broken for over 1
239 year!!!). Rather than possibly breaking the batch stuff for which
241 year!!!). Rather than possibly breaking the batch stuff for which
240 the code in iplib.py/interact was introduced, I worked around the
242 the code in iplib.py/interact was introduced, I worked around the
241 problem in the embedding class in Shell.py. We really need a
243 problem in the embedding class in Shell.py. We really need a
242 bloody test suite for this code, I'm sick of finding stuff that
244 bloody test suite for this code, I'm sick of finding stuff that
243 used to work breaking left and right every time I use an old
245 used to work breaking left and right every time I use an old
244 feature I hadn't touched in a few months.
246 feature I hadn't touched in a few months.
245 (kill_embedded): Add a new magic that only shows up in embedded
247 (kill_embedded): Add a new magic that only shows up in embedded
246 mode, to allow users to permanently deactivate an embedded instance.
248 mode, to allow users to permanently deactivate an embedded instance.
247
249
248 2007-08-01 Ville Vainio <vivainio@gmail.com>
250 2007-08-01 Ville Vainio <vivainio@gmail.com>
249
251
250 * iplib.py, ipy_profile_sh.py (runlines): Fix the bug where raw
252 * iplib.py, ipy_profile_sh.py (runlines): Fix the bug where raw
251 history gets out of sync on runlines (e.g. when running macros).
253 history gets out of sync on runlines (e.g. when running macros).
252
254
253 2007-07-31 Fernando Perez <Fernando.Perez@colorado.edu>
255 2007-07-31 Fernando Perez <Fernando.Perez@colorado.edu>
254
256
255 * IPython/Magic.py (magic_colors): fix win32-related error message
257 * IPython/Magic.py (magic_colors): fix win32-related error message
256 that could appear under *nix when readline was missing. Patch by
258 that could appear under *nix when readline was missing. Patch by
257 Scott Jackson, closes #175.
259 Scott Jackson, closes #175.
258
260
259 2007-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
261 2007-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
260
262
261 * IPython/Extensions/ipy_traits_completer.py: Add a new custom
263 * IPython/Extensions/ipy_traits_completer.py: Add a new custom
262 completer that it traits-aware, so that traits objects don't show
264 completer that it traits-aware, so that traits objects don't show
263 all of their internal attributes all the time.
265 all of their internal attributes all the time.
264
266
265 * IPython/genutils.py (dir2): moved this code from inside
267 * IPython/genutils.py (dir2): moved this code from inside
266 completer.py to expose it publicly, so I could use it in the
268 completer.py to expose it publicly, so I could use it in the
267 wildcards bugfix.
269 wildcards bugfix.
268
270
269 * IPython/wildcard.py (NameSpace.__init__): fix a bug reported by
271 * IPython/wildcard.py (NameSpace.__init__): fix a bug reported by
270 Stefan with Traits.
272 Stefan with Traits.
271
273
272 * IPython/completer.py (Completer.attr_matches): change internal
274 * IPython/completer.py (Completer.attr_matches): change internal
273 var name from 'object' to 'obj', since 'object' is now a builtin
275 var name from 'object' to 'obj', since 'object' is now a builtin
274 and this can lead to weird bugs if reusing this code elsewhere.
276 and this can lead to weird bugs if reusing this code elsewhere.
275
277
276 2007-07-25 Fernando Perez <Fernando.Perez@colorado.edu>
278 2007-07-25 Fernando Perez <Fernando.Perez@colorado.edu>
277
279
278 * IPython/OInspect.py (Inspector.pinfo): fix small glitches in
280 * IPython/OInspect.py (Inspector.pinfo): fix small glitches in
279 'foo?' and update the code to prevent printing of default
281 'foo?' and update the code to prevent printing of default
280 docstrings that started appearing after I added support for
282 docstrings that started appearing after I added support for
281 new-style classes. The approach I'm using isn't ideal (I just
283 new-style classes. The approach I'm using isn't ideal (I just
282 special-case those strings) but I'm not sure how to more robustly
284 special-case those strings) but I'm not sure how to more robustly
283 differentiate between truly user-written strings and Python's
285 differentiate between truly user-written strings and Python's
284 automatic ones.
286 automatic ones.
285
287
286 2007-07-09 Ville Vainio <vivainio@gmail.com>
288 2007-07-09 Ville Vainio <vivainio@gmail.com>
287
289
288 * completer.py: Applied Matthew Neeley's patch:
290 * completer.py: Applied Matthew Neeley's patch:
289 Dynamic attributes from trait_names and _getAttributeNames are added
291 Dynamic attributes from trait_names and _getAttributeNames are added
290 to the list of tab completions, but when this happens, the attribute
292 to the list of tab completions, but when this happens, the attribute
291 list is turned into a set, so the attributes are unordered when
293 list is turned into a set, so the attributes are unordered when
292 printed, which makes it hard to find the right completion. This patch
294 printed, which makes it hard to find the right completion. This patch
293 turns this set back into a list and sort it.
295 turns this set back into a list and sort it.
294
296
295 2007-07-06 Fernando Perez <Fernando.Perez@colorado.edu>
297 2007-07-06 Fernando Perez <Fernando.Perez@colorado.edu>
296
298
297 * IPython/OInspect.py (Inspector.pinfo): Add support for new-style
299 * IPython/OInspect.py (Inspector.pinfo): Add support for new-style
298 classes in various inspector functions.
300 classes in various inspector functions.
299
301
300 2007-06-28 Ville Vainio <vivainio@gmail.com>
302 2007-06-28 Ville Vainio <vivainio@gmail.com>
301
303
302 * shadowns.py, iplib.py, ipapi.py, OInspect.py:
304 * shadowns.py, iplib.py, ipapi.py, OInspect.py:
303 Implement "shadow" namespace, and callable aliases that reside there.
305 Implement "shadow" namespace, and callable aliases that reside there.
304 Use them by:
306 Use them by:
305
307
306 _ip.defalias('foo',myfunc) # creates _sh.foo that points to myfunc
308 _ip.defalias('foo',myfunc) # creates _sh.foo that points to myfunc
307
309
308 foo hello world
310 foo hello world
309 (gets translated to:)
311 (gets translated to:)
310 _sh.foo(r"""hello world""")
312 _sh.foo(r"""hello world""")
311
313
312 In practice, this kind of alias can take the role of a magic function
314 In practice, this kind of alias can take the role of a magic function
313
315
314 * New generic inspect_object, called on obj? and obj??
316 * New generic inspect_object, called on obj? and obj??
315
317
316 2007-06-15 Fernando Perez <Fernando.Perez@colorado.edu>
318 2007-06-15 Fernando Perez <Fernando.Perez@colorado.edu>
317
319
318 * IPython/ultraTB.py (findsource): fix a problem with
320 * IPython/ultraTB.py (findsource): fix a problem with
319 inspect.getfile that can cause crashes during traceback construction.
321 inspect.getfile that can cause crashes during traceback construction.
320
322
321 2007-06-14 Ville Vainio <vivainio@gmail.com>
323 2007-06-14 Ville Vainio <vivainio@gmail.com>
322
324
323 * iplib.py (handle_auto): Try to use ascii for printing "--->"
325 * iplib.py (handle_auto): Try to use ascii for printing "--->"
324 autocall rewrite indication, becausesometimes unicode fails to print
326 autocall rewrite indication, becausesometimes unicode fails to print
325 properly (and you get ' - - - '). Use plain uncoloured ---> for
327 properly (and you get ' - - - '). Use plain uncoloured ---> for
326 unicode.
328 unicode.
327
329
328 * shadow history. Usable through "%hist -g <pat>" and "%rep 0123".
330 * shadow history. Usable through "%hist -g <pat>" and "%rep 0123".
329
331
330 . pickleshare 'hash' commands (hget, hset, hcompress,
332 . pickleshare 'hash' commands (hget, hset, hcompress,
331 hdict) for efficient shadow history storage.
333 hdict) for efficient shadow history storage.
332
334
333 2007-06-13 Ville Vainio <vivainio@gmail.com>
335 2007-06-13 Ville Vainio <vivainio@gmail.com>
334
336
335 * ipapi.py: _ip.to_user_ns(vars, interactive = True).
337 * ipapi.py: _ip.to_user_ns(vars, interactive = True).
336 Added kw arg 'interactive', tell whether vars should be visible
338 Added kw arg 'interactive', tell whether vars should be visible
337 with %whos.
339 with %whos.
338
340
339 2007-06-11 Ville Vainio <vivainio@gmail.com>
341 2007-06-11 Ville Vainio <vivainio@gmail.com>
340
342
341 * pspersistence.py, Magic.py, iplib.py: directory history now saved
343 * pspersistence.py, Magic.py, iplib.py: directory history now saved
342 to db
344 to db
343
345
344 * iplib.py: "ipython -c <cmd>" now passes the command through prefilter.
346 * iplib.py: "ipython -c <cmd>" now passes the command through prefilter.
345 Also, it exits IPython immediately after evaluating the command (just like
347 Also, it exits IPython immediately after evaluating the command (just like
346 std python)
348 std python)
347
349
348 2007-06-05 Walter Doerwald <walter@livinglogic.de>
350 2007-06-05 Walter Doerwald <walter@livinglogic.de>
349
351
350 * IPython/Extensions/ipipe.py: Added a new table icap, which executes a
352 * IPython/Extensions/ipipe.py: Added a new table icap, which executes a
351 Python string and captures the output. (Idea and original patch by
353 Python string and captures the output. (Idea and original patch by
352 Stefan van der Walt)
354 Stefan van der Walt)
353
355
354 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
356 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
355
357
356 * IPython/ultraTB.py (VerboseTB.text): update printing of
358 * IPython/ultraTB.py (VerboseTB.text): update printing of
357 exception types for Python 2.5 (now all exceptions in the stdlib
359 exception types for Python 2.5 (now all exceptions in the stdlib
358 are new-style classes).
360 are new-style classes).
359
361
360 2007-05-31 Walter Doerwald <walter@livinglogic.de>
362 2007-05-31 Walter Doerwald <walter@livinglogic.de>
361
363
362 * IPython/Extensions/igrid.py: Add new commands refresh and
364 * IPython/Extensions/igrid.py: Add new commands refresh and
363 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
365 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
364 the iterator once (refresh) or after every x seconds (refresh_timer).
366 the iterator once (refresh) or after every x seconds (refresh_timer).
365 Add a working implementation of "searchexpression", where the text
367 Add a working implementation of "searchexpression", where the text
366 entered is not the text to search for, but an expression that must
368 entered is not the text to search for, but an expression that must
367 be true. Added display of shortcuts to the menu. Added commands "pickinput"
369 be true. Added display of shortcuts to the menu. Added commands "pickinput"
368 and "pickinputattr" that put the object or attribute under the cursor
370 and "pickinputattr" that put the object or attribute under the cursor
369 in the input line. Split the statusbar to be able to display the currently
371 in the input line. Split the statusbar to be able to display the currently
370 active refresh interval. (Patch by Nik Tautenhahn)
372 active refresh interval. (Patch by Nik Tautenhahn)
371
373
372 2007-05-29 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
374 2007-05-29 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
373
375
374 * fixing set_term_title to use ctypes as default
376 * fixing set_term_title to use ctypes as default
375
377
376 * fixing set_term_title fallback to work when curent dir
378 * fixing set_term_title fallback to work when curent dir
377 is on a windows network share
379 is on a windows network share
378
380
379 2007-05-28 Ville Vainio <vivainio@gmail.com>
381 2007-05-28 Ville Vainio <vivainio@gmail.com>
380
382
381 * %cpaste: strip + with > from left (diffs).
383 * %cpaste: strip + with > from left (diffs).
382
384
383 * iplib.py: Fix crash when readline not installed
385 * iplib.py: Fix crash when readline not installed
384
386
385 2007-05-26 Ville Vainio <vivainio@gmail.com>
387 2007-05-26 Ville Vainio <vivainio@gmail.com>
386
388
387 * generics.py: intruduce easy to extend result_display generic
389 * generics.py: intruduce easy to extend result_display generic
388 function (using simplegeneric.py).
390 function (using simplegeneric.py).
389
391
390 * Fixed the append functionality of %set.
392 * Fixed the append functionality of %set.
391
393
392 2007-05-25 Ville Vainio <vivainio@gmail.com>
394 2007-05-25 Ville Vainio <vivainio@gmail.com>
393
395
394 * New magic: %rep (fetch / run old commands from history)
396 * New magic: %rep (fetch / run old commands from history)
395
397
396 * New extension: mglob (%mglob magic), for powerful glob / find /filter
398 * New extension: mglob (%mglob magic), for powerful glob / find /filter
397 like functionality
399 like functionality
398
400
399 % maghistory.py: %hist -g PATTERM greps the history for pattern
401 % maghistory.py: %hist -g PATTERM greps the history for pattern
400
402
401 2007-05-24 Walter Doerwald <walter@livinglogic.de>
403 2007-05-24 Walter Doerwald <walter@livinglogic.de>
402
404
403 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
405 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
404 browse the IPython input history
406 browse the IPython input history
405
407
406 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
408 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
407 (mapped to "i") can be used to put the object under the curser in the input
409 (mapped to "i") can be used to put the object under the curser in the input
408 line. pickinputattr (mapped to "I") does the same for the attribute under
410 line. pickinputattr (mapped to "I") does the same for the attribute under
409 the cursor.
411 the cursor.
410
412
411 2007-05-24 Ville Vainio <vivainio@gmail.com>
413 2007-05-24 Ville Vainio <vivainio@gmail.com>
412
414
413 * Grand magic cleansing (changeset [2380]):
415 * Grand magic cleansing (changeset [2380]):
414
416
415 * Introduce ipy_legacy.py where the following magics were
417 * Introduce ipy_legacy.py where the following magics were
416 moved:
418 moved:
417
419
418 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
420 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
419
421
420 If you need them, either use default profile or "import ipy_legacy"
422 If you need them, either use default profile or "import ipy_legacy"
421 in your ipy_user_conf.py
423 in your ipy_user_conf.py
422
424
423 * Move sh and scipy profile to Extensions from UserConfig. this implies
425 * Move sh and scipy profile to Extensions from UserConfig. this implies
424 you should not edit them, but you don't need to run %upgrade when
426 you should not edit them, but you don't need to run %upgrade when
425 upgrading IPython anymore.
427 upgrading IPython anymore.
426
428
427 * %hist/%history now operates in "raw" mode by default. To get the old
429 * %hist/%history now operates in "raw" mode by default. To get the old
428 behaviour, run '%hist -n' (native mode).
430 behaviour, run '%hist -n' (native mode).
429
431
430 * split ipy_stock_completers.py to ipy_stock_completers.py and
432 * split ipy_stock_completers.py to ipy_stock_completers.py and
431 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
433 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
432 installed as default.
434 installed as default.
433
435
434 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
436 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
435 handling.
437 handling.
436
438
437 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
439 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
438 input if readline is available.
440 input if readline is available.
439
441
440 2007-05-23 Ville Vainio <vivainio@gmail.com>
442 2007-05-23 Ville Vainio <vivainio@gmail.com>
441
443
442 * macro.py: %store uses __getstate__ properly
444 * macro.py: %store uses __getstate__ properly
443
445
444 * exesetup.py: added new setup script for creating
446 * exesetup.py: added new setup script for creating
445 standalone IPython executables with py2exe (i.e.
447 standalone IPython executables with py2exe (i.e.
446 no python installation required).
448 no python installation required).
447
449
448 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
450 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
449 its place.
451 its place.
450
452
451 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
453 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
452
454
453 2007-05-21 Ville Vainio <vivainio@gmail.com>
455 2007-05-21 Ville Vainio <vivainio@gmail.com>
454
456
455 * platutil_win32.py (set_term_title): handle
457 * platutil_win32.py (set_term_title): handle
456 failure of 'title' system call properly.
458 failure of 'title' system call properly.
457
459
458 2007-05-17 Walter Doerwald <walter@livinglogic.de>
460 2007-05-17 Walter Doerwald <walter@livinglogic.de>
459
461
460 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
462 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
461 (Bug detected by Paul Mueller).
463 (Bug detected by Paul Mueller).
462
464
463 2007-05-16 Ville Vainio <vivainio@gmail.com>
465 2007-05-16 Ville Vainio <vivainio@gmail.com>
464
466
465 * ipy_profile_sci.py, ipython_win_post_install.py: Create
467 * ipy_profile_sci.py, ipython_win_post_install.py: Create
466 new "sci" profile, effectively a modern version of the old
468 new "sci" profile, effectively a modern version of the old
467 "scipy" profile (which is now slated for deprecation).
469 "scipy" profile (which is now slated for deprecation).
468
470
469 2007-05-15 Ville Vainio <vivainio@gmail.com>
471 2007-05-15 Ville Vainio <vivainio@gmail.com>
470
472
471 * pycolorize.py, pycolor.1: Paul Mueller's patches that
473 * pycolorize.py, pycolor.1: Paul Mueller's patches that
472 make pycolorize read input from stdin when run without arguments.
474 make pycolorize read input from stdin when run without arguments.
473
475
474 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
476 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
475
477
476 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
478 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
477 it in sh profile (instead of ipy_system_conf.py).
479 it in sh profile (instead of ipy_system_conf.py).
478
480
479 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
481 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
480 aliases are now lower case on windows (MyCommand.exe => mycommand).
482 aliases are now lower case on windows (MyCommand.exe => mycommand).
481
483
482 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
484 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
483 Macros are now callable objects that inherit from ipapi.IPyAutocall,
485 Macros are now callable objects that inherit from ipapi.IPyAutocall,
484 i.e. get autocalled regardless of system autocall setting.
486 i.e. get autocalled regardless of system autocall setting.
485
487
486 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
488 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
487
489
488 * IPython/rlineimpl.py: check for clear_history in readline and
490 * IPython/rlineimpl.py: check for clear_history in readline and
489 make it a dummy no-op if not available. This function isn't
491 make it a dummy no-op if not available. This function isn't
490 guaranteed to be in the API and appeared in Python 2.4, so we need
492 guaranteed to be in the API and appeared in Python 2.4, so we need
491 to check it ourselves. Also, clean up this file quite a bit.
493 to check it ourselves. Also, clean up this file quite a bit.
492
494
493 * ipython.1: update man page and full manual with information
495 * ipython.1: update man page and full manual with information
494 about threads (remove outdated warning). Closes #151.
496 about threads (remove outdated warning). Closes #151.
495
497
496 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
498 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
497
499
498 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
500 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
499 in trunk (note that this made it into the 0.8.1 release already,
501 in trunk (note that this made it into the 0.8.1 release already,
500 but the changelogs didn't get coordinated). Many thanks to Gael
502 but the changelogs didn't get coordinated). Many thanks to Gael
501 Varoquaux <gael.varoquaux-AT-normalesup.org>
503 Varoquaux <gael.varoquaux-AT-normalesup.org>
502
504
503 2007-05-09 *** Released version 0.8.1
505 2007-05-09 *** Released version 0.8.1
504
506
505 2007-05-10 Walter Doerwald <walter@livinglogic.de>
507 2007-05-10 Walter Doerwald <walter@livinglogic.de>
506
508
507 * IPython/Extensions/igrid.py: Incorporate html help into
509 * IPython/Extensions/igrid.py: Incorporate html help into
508 the module, so we don't have to search for the file.
510 the module, so we don't have to search for the file.
509
511
510 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
512 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
511
513
512 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
514 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
513
515
514 2007-04-30 Ville Vainio <vivainio@gmail.com>
516 2007-04-30 Ville Vainio <vivainio@gmail.com>
515
517
516 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
518 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
517 user has illegal (non-ascii) home directory name
519 user has illegal (non-ascii) home directory name
518
520
519 2007-04-27 Ville Vainio <vivainio@gmail.com>
521 2007-04-27 Ville Vainio <vivainio@gmail.com>
520
522
521 * platutils_win32.py: implement set_term_title for windows
523 * platutils_win32.py: implement set_term_title for windows
522
524
523 * Update version number
525 * Update version number
524
526
525 * ipy_profile_sh.py: more informative prompt (2 dir levels)
527 * ipy_profile_sh.py: more informative prompt (2 dir levels)
526
528
527 2007-04-26 Walter Doerwald <walter@livinglogic.de>
529 2007-04-26 Walter Doerwald <walter@livinglogic.de>
528
530
529 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
531 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
530 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
532 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
531 bug discovered by Ville).
533 bug discovered by Ville).
532
534
533 2007-04-26 Ville Vainio <vivainio@gmail.com>
535 2007-04-26 Ville Vainio <vivainio@gmail.com>
534
536
535 * Extensions/ipy_completers.py: Olivier's module completer now
537 * Extensions/ipy_completers.py: Olivier's module completer now
536 saves the list of root modules if it takes > 4 secs on the first run.
538 saves the list of root modules if it takes > 4 secs on the first run.
537
539
538 * Magic.py (%rehashx): %rehashx now clears the completer cache
540 * Magic.py (%rehashx): %rehashx now clears the completer cache
539
541
540
542
541 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
543 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
542
544
543 * ipython.el: fix incorrect color scheme, reported by Stefan.
545 * ipython.el: fix incorrect color scheme, reported by Stefan.
544 Closes #149.
546 Closes #149.
545
547
546 * IPython/PyColorize.py (Parser.format2): fix state-handling
548 * IPython/PyColorize.py (Parser.format2): fix state-handling
547 logic. I still don't like how that code handles state, but at
549 logic. I still don't like how that code handles state, but at
548 least now it should be correct, if inelegant. Closes #146.
550 least now it should be correct, if inelegant. Closes #146.
549
551
550 2007-04-25 Ville Vainio <vivainio@gmail.com>
552 2007-04-25 Ville Vainio <vivainio@gmail.com>
551
553
552 * Extensions/ipy_which.py: added extension for %which magic, works
554 * Extensions/ipy_which.py: added extension for %which magic, works
553 a lot like unix 'which' but also finds and expands aliases, and
555 a lot like unix 'which' but also finds and expands aliases, and
554 allows wildcards.
556 allows wildcards.
555
557
556 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
558 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
557 as opposed to returning nothing.
559 as opposed to returning nothing.
558
560
559 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
561 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
560 ipy_stock_completers on default profile, do import on sh profile.
562 ipy_stock_completers on default profile, do import on sh profile.
561
563
562 2007-04-22 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
564 2007-04-22 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
563
565
564 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
566 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
565 like ipython.py foo.py which raised a IndexError.
567 like ipython.py foo.py which raised a IndexError.
566
568
567 2007-04-21 Ville Vainio <vivainio@gmail.com>
569 2007-04-21 Ville Vainio <vivainio@gmail.com>
568
570
569 * Extensions/ipy_extutil.py: added extension to manage other ipython
571 * Extensions/ipy_extutil.py: added extension to manage other ipython
570 extensions. Now only supports 'ls' == list extensions.
572 extensions. Now only supports 'ls' == list extensions.
571
573
572 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
574 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
573
575
574 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
576 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
575 would prevent use of the exception system outside of a running
577 would prevent use of the exception system outside of a running
576 IPython instance.
578 IPython instance.
577
579
578 2007-04-20 Ville Vainio <vivainio@gmail.com>
580 2007-04-20 Ville Vainio <vivainio@gmail.com>
579
581
580 * Extensions/ipy_render.py: added extension for easy
582 * Extensions/ipy_render.py: added extension for easy
581 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
583 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
582 'Iptl' template notation,
584 'Iptl' template notation,
583
585
584 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
586 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
585 safer & faster 'import' completer.
587 safer & faster 'import' completer.
586
588
587 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
589 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
588 and _ip.defalias(name, command).
590 and _ip.defalias(name, command).
589
591
590 * Extensions/ipy_exportdb.py: New extension for exporting all the
592 * Extensions/ipy_exportdb.py: New extension for exporting all the
591 %store'd data in a portable format (normal ipapi calls like
593 %store'd data in a portable format (normal ipapi calls like
592 defmacro() etc.)
594 defmacro() etc.)
593
595
594 2007-04-19 Ville Vainio <vivainio@gmail.com>
596 2007-04-19 Ville Vainio <vivainio@gmail.com>
595
597
596 * upgrade_dir.py: skip junk files like *.pyc
598 * upgrade_dir.py: skip junk files like *.pyc
597
599
598 * Release.py: version number to 0.8.1
600 * Release.py: version number to 0.8.1
599
601
600 2007-04-18 Ville Vainio <vivainio@gmail.com>
602 2007-04-18 Ville Vainio <vivainio@gmail.com>
601
603
602 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
604 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
603 and later on win32.
605 and later on win32.
604
606
605 2007-04-16 Ville Vainio <vivainio@gmail.com>
607 2007-04-16 Ville Vainio <vivainio@gmail.com>
606
608
607 * iplib.py (showtraceback): Do not crash when running w/o readline.
609 * iplib.py (showtraceback): Do not crash when running w/o readline.
608
610
609 2007-04-12 Walter Doerwald <walter@livinglogic.de>
611 2007-04-12 Walter Doerwald <walter@livinglogic.de>
610
612
611 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
613 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
612 sorted (case sensitive with files and dirs mixed).
614 sorted (case sensitive with files and dirs mixed).
613
615
614 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
616 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
615
617
616 * IPython/Release.py (version): Open trunk for 0.8.1 development.
618 * IPython/Release.py (version): Open trunk for 0.8.1 development.
617
619
618 2007-04-10 *** Released version 0.8.0
620 2007-04-10 *** Released version 0.8.0
619
621
620 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
622 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
621
623
622 * Tag 0.8.0 for release.
624 * Tag 0.8.0 for release.
623
625
624 * IPython/iplib.py (reloadhist): add API function to cleanly
626 * IPython/iplib.py (reloadhist): add API function to cleanly
625 reload the readline history, which was growing inappropriately on
627 reload the readline history, which was growing inappropriately on
626 every %run call.
628 every %run call.
627
629
628 * win32_manual_post_install.py (run): apply last part of Nicolas
630 * win32_manual_post_install.py (run): apply last part of Nicolas
629 Pernetty's patch (I'd accidentally applied it in a different
631 Pernetty's patch (I'd accidentally applied it in a different
630 directory and this particular file didn't get patched).
632 directory and this particular file didn't get patched).
631
633
632 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
634 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
633
635
634 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
636 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
635 find the main thread id and use the proper API call. Thanks to
637 find the main thread id and use the proper API call. Thanks to
636 Stefan for the fix.
638 Stefan for the fix.
637
639
638 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
640 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
639 unit tests to reflect fixed ticket #52, and add more tests sent by
641 unit tests to reflect fixed ticket #52, and add more tests sent by
640 him.
642 him.
641
643
642 * IPython/iplib.py (raw_input): restore the readline completer
644 * IPython/iplib.py (raw_input): restore the readline completer
643 state on every input, in case third-party code messed it up.
645 state on every input, in case third-party code messed it up.
644 (_prefilter): revert recent addition of early-escape checks which
646 (_prefilter): revert recent addition of early-escape checks which
645 prevent many valid alias calls from working.
647 prevent many valid alias calls from working.
646
648
647 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
649 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
648 flag for sigint handler so we don't run a full signal() call on
650 flag for sigint handler so we don't run a full signal() call on
649 each runcode access.
651 each runcode access.
650
652
651 * IPython/Magic.py (magic_whos): small improvement to diagnostic
653 * IPython/Magic.py (magic_whos): small improvement to diagnostic
652 message.
654 message.
653
655
654 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
656 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
655
657
656 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
658 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
657 asynchronous exceptions working, i.e., Ctrl-C can actually
659 asynchronous exceptions working, i.e., Ctrl-C can actually
658 interrupt long-running code in the multithreaded shells.
660 interrupt long-running code in the multithreaded shells.
659
661
660 This is using Tomer Filiba's great ctypes-based trick:
662 This is using Tomer Filiba's great ctypes-based trick:
661 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
663 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
662 this in the past, but hadn't been able to make it work before. So
664 this in the past, but hadn't been able to make it work before. So
663 far it looks like it's actually running, but this needs more
665 far it looks like it's actually running, but this needs more
664 testing. If it really works, I'll be *very* happy, and we'll owe
666 testing. If it really works, I'll be *very* happy, and we'll owe
665 a huge thank you to Tomer. My current implementation is ugly,
667 a huge thank you to Tomer. My current implementation is ugly,
666 hackish and uses nasty globals, but I don't want to try and clean
668 hackish and uses nasty globals, but I don't want to try and clean
667 anything up until we know if it actually works.
669 anything up until we know if it actually works.
668
670
669 NOTE: this feature needs ctypes to work. ctypes is included in
671 NOTE: this feature needs ctypes to work. ctypes is included in
670 Python2.5, but 2.4 users will need to manually install it. This
672 Python2.5, but 2.4 users will need to manually install it. This
671 feature makes multi-threaded shells so much more usable that it's
673 feature makes multi-threaded shells so much more usable that it's
672 a minor price to pay (ctypes is very easy to install, already a
674 a minor price to pay (ctypes is very easy to install, already a
673 requirement for win32 and available in major linux distros).
675 requirement for win32 and available in major linux distros).
674
676
675 2007-04-04 Ville Vainio <vivainio@gmail.com>
677 2007-04-04 Ville Vainio <vivainio@gmail.com>
676
678
677 * Extensions/ipy_completers.py, ipy_stock_completers.py:
679 * Extensions/ipy_completers.py, ipy_stock_completers.py:
678 Moved implementations of 'bundled' completers to ipy_completers.py,
680 Moved implementations of 'bundled' completers to ipy_completers.py,
679 they are only enabled in ipy_stock_completers.py.
681 they are only enabled in ipy_stock_completers.py.
680
682
681 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
683 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
682
684
683 * IPython/PyColorize.py (Parser.format2): Fix identation of
685 * IPython/PyColorize.py (Parser.format2): Fix identation of
684 colorzied output and return early if color scheme is NoColor, to
686 colorzied output and return early if color scheme is NoColor, to
685 avoid unnecessary and expensive tokenization. Closes #131.
687 avoid unnecessary and expensive tokenization. Closes #131.
686
688
687 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
689 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
688
690
689 * IPython/Debugger.py: disable the use of pydb version 1.17. It
691 * IPython/Debugger.py: disable the use of pydb version 1.17. It
690 has a critical bug (a missing import that makes post-mortem not
692 has a critical bug (a missing import that makes post-mortem not
691 work at all). Unfortunately as of this time, this is the version
693 work at all). Unfortunately as of this time, this is the version
692 shipped with Ubuntu Edgy, so quite a few people have this one. I
694 shipped with Ubuntu Edgy, so quite a few people have this one. I
693 hope Edgy will update to a more recent package.
695 hope Edgy will update to a more recent package.
694
696
695 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
697 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
696
698
697 * IPython/iplib.py (_prefilter): close #52, second part of a patch
699 * IPython/iplib.py (_prefilter): close #52, second part of a patch
698 set by Stefan (only the first part had been applied before).
700 set by Stefan (only the first part had been applied before).
699
701
700 * IPython/Extensions/ipy_stock_completers.py (module_completer):
702 * IPython/Extensions/ipy_stock_completers.py (module_completer):
701 remove usage of the dangerous pkgutil.walk_packages(). See
703 remove usage of the dangerous pkgutil.walk_packages(). See
702 details in comments left in the code.
704 details in comments left in the code.
703
705
704 * IPython/Magic.py (magic_whos): add support for numpy arrays
706 * IPython/Magic.py (magic_whos): add support for numpy arrays
705 similar to what we had for Numeric.
707 similar to what we had for Numeric.
706
708
707 * IPython/completer.py (IPCompleter.complete): extend the
709 * IPython/completer.py (IPCompleter.complete): extend the
708 complete() call API to support completions by other mechanisms
710 complete() call API to support completions by other mechanisms
709 than readline. Closes #109.
711 than readline. Closes #109.
710
712
711 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
713 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
712 protect against a bug in Python's execfile(). Closes #123.
714 protect against a bug in Python's execfile(). Closes #123.
713
715
714 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
716 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
715
717
716 * IPython/iplib.py (split_user_input): ensure that when splitting
718 * IPython/iplib.py (split_user_input): ensure that when splitting
717 user input, the part that can be treated as a python name is pure
719 user input, the part that can be treated as a python name is pure
718 ascii (Python identifiers MUST be pure ascii). Part of the
720 ascii (Python identifiers MUST be pure ascii). Part of the
719 ongoing Unicode support work.
721 ongoing Unicode support work.
720
722
721 * IPython/Prompts.py (prompt_specials_color): Add \N for the
723 * IPython/Prompts.py (prompt_specials_color): Add \N for the
722 actual prompt number, without any coloring. This allows users to
724 actual prompt number, without any coloring. This allows users to
723 produce numbered prompts with their own colors. Added after a
725 produce numbered prompts with their own colors. Added after a
724 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
726 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
725
727
726 2007-03-31 Walter Doerwald <walter@livinglogic.de>
728 2007-03-31 Walter Doerwald <walter@livinglogic.de>
727
729
728 * IPython/Extensions/igrid.py: Map the return key
730 * IPython/Extensions/igrid.py: Map the return key
729 to enter() and shift-return to enterattr().
731 to enter() and shift-return to enterattr().
730
732
731 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
733 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
732
734
733 * IPython/Magic.py (magic_psearch): add unicode support by
735 * IPython/Magic.py (magic_psearch): add unicode support by
734 encoding to ascii the input, since this routine also only deals
736 encoding to ascii the input, since this routine also only deals
735 with valid Python names. Fixes a bug reported by Stefan.
737 with valid Python names. Fixes a bug reported by Stefan.
736
738
737 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
739 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
738
740
739 * IPython/Magic.py (_inspect): convert unicode input into ascii
741 * IPython/Magic.py (_inspect): convert unicode input into ascii
740 before trying to evaluate it as a Python identifier. This fixes a
742 before trying to evaluate it as a Python identifier. This fixes a
741 problem that the new unicode support had introduced when analyzing
743 problem that the new unicode support had introduced when analyzing
742 long definition lines for functions.
744 long definition lines for functions.
743
745
744 2007-03-24 Walter Doerwald <walter@livinglogic.de>
746 2007-03-24 Walter Doerwald <walter@livinglogic.de>
745
747
746 * IPython/Extensions/igrid.py: Fix picking. Using
748 * IPython/Extensions/igrid.py: Fix picking. Using
747 igrid with wxPython 2.6 and -wthread should work now.
749 igrid with wxPython 2.6 and -wthread should work now.
748 igrid.display() simply tries to create a frame without
750 igrid.display() simply tries to create a frame without
749 an application. Only if this fails an application is created.
751 an application. Only if this fails an application is created.
750
752
751 2007-03-23 Walter Doerwald <walter@livinglogic.de>
753 2007-03-23 Walter Doerwald <walter@livinglogic.de>
752
754
753 * IPython/Extensions/path.py: Updated to version 2.2.
755 * IPython/Extensions/path.py: Updated to version 2.2.
754
756
755 2007-03-23 Ville Vainio <vivainio@gmail.com>
757 2007-03-23 Ville Vainio <vivainio@gmail.com>
756
758
757 * iplib.py: recursive alias expansion now works better, so that
759 * iplib.py: recursive alias expansion now works better, so that
758 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
760 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
759 doesn't trip up the process, if 'd' has been aliased to 'ls'.
761 doesn't trip up the process, if 'd' has been aliased to 'ls'.
760
762
761 * Extensions/ipy_gnuglobal.py added, provides %global magic
763 * Extensions/ipy_gnuglobal.py added, provides %global magic
762 for users of http://www.gnu.org/software/global
764 for users of http://www.gnu.org/software/global
763
765
764 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
766 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
765 Closes #52. Patch by Stefan van der Walt.
767 Closes #52. Patch by Stefan van der Walt.
766
768
767 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
769 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
768
770
769 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
771 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
770 respect the __file__ attribute when using %run. Thanks to a bug
772 respect the __file__ attribute when using %run. Thanks to a bug
771 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
773 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
772
774
773 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
775 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
774
776
775 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
777 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
776 input. Patch sent by Stefan.
778 input. Patch sent by Stefan.
777
779
778 2007-03-20 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
780 2007-03-20 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
779 * IPython/Extensions/ipy_stock_completer.py
781 * IPython/Extensions/ipy_stock_completer.py
780 shlex_split, fix bug in shlex_split. len function
782 shlex_split, fix bug in shlex_split. len function
781 call was missing an if statement. Caused shlex_split to
783 call was missing an if statement. Caused shlex_split to
782 sometimes return "" as last element.
784 sometimes return "" as last element.
783
785
784 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
786 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
785
787
786 * IPython/completer.py
788 * IPython/completer.py
787 (IPCompleter.file_matches.single_dir_expand): fix a problem
789 (IPCompleter.file_matches.single_dir_expand): fix a problem
788 reported by Stefan, where directories containign a single subdir
790 reported by Stefan, where directories containign a single subdir
789 would be completed too early.
791 would be completed too early.
790
792
791 * IPython/Shell.py (_load_pylab): Make the execution of 'from
793 * IPython/Shell.py (_load_pylab): Make the execution of 'from
792 pylab import *' when -pylab is given be optional. A new flag,
794 pylab import *' when -pylab is given be optional. A new flag,
793 pylab_import_all controls this behavior, the default is True for
795 pylab_import_all controls this behavior, the default is True for
794 backwards compatibility.
796 backwards compatibility.
795
797
796 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
798 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
797 modified) R. Bernstein's patch for fully syntax highlighted
799 modified) R. Bernstein's patch for fully syntax highlighted
798 tracebacks. The functionality is also available under ultraTB for
800 tracebacks. The functionality is also available under ultraTB for
799 non-ipython users (someone using ultraTB but outside an ipython
801 non-ipython users (someone using ultraTB but outside an ipython
800 session). They can select the color scheme by setting the
802 session). They can select the color scheme by setting the
801 module-level global DEFAULT_SCHEME. The highlight functionality
803 module-level global DEFAULT_SCHEME. The highlight functionality
802 also works when debugging.
804 also works when debugging.
803
805
804 * IPython/genutils.py (IOStream.close): small patch by
806 * IPython/genutils.py (IOStream.close): small patch by
805 R. Bernstein for improved pydb support.
807 R. Bernstein for improved pydb support.
806
808
807 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
809 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
808 DaveS <davls@telus.net> to improve support of debugging under
810 DaveS <davls@telus.net> to improve support of debugging under
809 NTEmacs, including improved pydb behavior.
811 NTEmacs, including improved pydb behavior.
810
812
811 * IPython/Magic.py (magic_prun): Fix saving of profile info for
813 * IPython/Magic.py (magic_prun): Fix saving of profile info for
812 Python 2.5, where the stats object API changed a little. Thanks
814 Python 2.5, where the stats object API changed a little. Thanks
813 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
815 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
814
816
815 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
817 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
816 Pernetty's patch to improve support for (X)Emacs under Win32.
818 Pernetty's patch to improve support for (X)Emacs under Win32.
817
819
818 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
820 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
819
821
820 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
822 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
821 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
823 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
822 a report by Nik Tautenhahn.
824 a report by Nik Tautenhahn.
823
825
824 2007-03-16 Walter Doerwald <walter@livinglogic.de>
826 2007-03-16 Walter Doerwald <walter@livinglogic.de>
825
827
826 * setup.py: Add the igrid help files to the list of data files
828 * setup.py: Add the igrid help files to the list of data files
827 to be installed alongside igrid.
829 to be installed alongside igrid.
828 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
830 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
829 Show the input object of the igrid browser as the window tile.
831 Show the input object of the igrid browser as the window tile.
830 Show the object the cursor is on in the statusbar.
832 Show the object the cursor is on in the statusbar.
831
833
832 2007-03-15 Ville Vainio <vivainio@gmail.com>
834 2007-03-15 Ville Vainio <vivainio@gmail.com>
833
835
834 * Extensions/ipy_stock_completers.py: Fixed exception
836 * Extensions/ipy_stock_completers.py: Fixed exception
835 on mismatching quotes in %run completer. Patch by
837 on mismatching quotes in %run completer. Patch by
836 Jorgen Stenarson. Closes #127.
838 Jorgen Stenarson. Closes #127.
837
839
838 2007-03-14 Ville Vainio <vivainio@gmail.com>
840 2007-03-14 Ville Vainio <vivainio@gmail.com>
839
841
840 * Extensions/ext_rehashdir.py: Do not do auto_alias
842 * Extensions/ext_rehashdir.py: Do not do auto_alias
841 in %rehashdir, it clobbers %store'd aliases.
843 in %rehashdir, it clobbers %store'd aliases.
842
844
843 * UserConfig/ipy_profile_sh.py: envpersist.py extension
845 * UserConfig/ipy_profile_sh.py: envpersist.py extension
844 (beefed up %env) imported for sh profile.
846 (beefed up %env) imported for sh profile.
845
847
846 2007-03-10 Walter Doerwald <walter@livinglogic.de>
848 2007-03-10 Walter Doerwald <walter@livinglogic.de>
847
849
848 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
850 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
849 as the default browser.
851 as the default browser.
850 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
852 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
851 As igrid displays all attributes it ever encounters, fetch() (which has
853 As igrid displays all attributes it ever encounters, fetch() (which has
852 been renamed to _fetch()) doesn't have to recalculate the display attributes
854 been renamed to _fetch()) doesn't have to recalculate the display attributes
853 every time a new item is fetched. This should speed up scrolling.
855 every time a new item is fetched. This should speed up scrolling.
854
856
855 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
857 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
856
858
857 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
859 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
858 Schmolck's recently reported tab-completion bug (my previous one
860 Schmolck's recently reported tab-completion bug (my previous one
859 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
861 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
860
862
861 2007-03-09 Walter Doerwald <walter@livinglogic.de>
863 2007-03-09 Walter Doerwald <walter@livinglogic.de>
862
864
863 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
865 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
864 Close help window if exiting igrid.
866 Close help window if exiting igrid.
865
867
866 2007-03-02 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
868 2007-03-02 Jorgen Stenarson <jorgen.stenarson@bostream.nu>
867
869
868 * IPython/Extensions/ipy_defaults.py: Check if readline is available
870 * IPython/Extensions/ipy_defaults.py: Check if readline is available
869 before calling functions from readline.
871 before calling functions from readline.
870
872
871 2007-03-02 Walter Doerwald <walter@livinglogic.de>
873 2007-03-02 Walter Doerwald <walter@livinglogic.de>
872
874
873 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
875 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
874 igrid is a wxPython-based display object for ipipe. If your system has
876 igrid is a wxPython-based display object for ipipe. If your system has
875 wx installed igrid will be the default display. Without wx ipipe falls
877 wx installed igrid will be the default display. Without wx ipipe falls
876 back to ibrowse (which needs curses). If no curses is installed ipipe
878 back to ibrowse (which needs curses). If no curses is installed ipipe
877 falls back to idump.
879 falls back to idump.
878
880
879 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
881 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
880
882
881 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
883 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
882 my changes from yesterday, they introduced bugs. Will reactivate
884 my changes from yesterday, they introduced bugs. Will reactivate
883 once I get a correct solution, which will be much easier thanks to
885 once I get a correct solution, which will be much easier thanks to
884 Dan Milstein's new prefilter test suite.
886 Dan Milstein's new prefilter test suite.
885
887
886 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
888 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
887
889
888 * IPython/iplib.py (split_user_input): fix input splitting so we
890 * IPython/iplib.py (split_user_input): fix input splitting so we
889 don't attempt attribute accesses on things that can't possibly be
891 don't attempt attribute accesses on things that can't possibly be
890 valid Python attributes. After a bug report by Alex Schmolck.
892 valid Python attributes. After a bug report by Alex Schmolck.
891 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
893 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
892 %magic with explicit % prefix.
894 %magic with explicit % prefix.
893
895
894 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
896 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
895
897
896 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
898 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
897 avoid a DeprecationWarning from GTK.
899 avoid a DeprecationWarning from GTK.
898
900
899 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
901 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
900
902
901 * IPython/genutils.py (clock): I modified clock() to return total
903 * IPython/genutils.py (clock): I modified clock() to return total
902 time, user+system. This is a more commonly needed metric. I also
904 time, user+system. This is a more commonly needed metric. I also
903 introduced the new clocku/clocks to get only user/system time if
905 introduced the new clocku/clocks to get only user/system time if
904 one wants those instead.
906 one wants those instead.
905
907
906 ***WARNING: API CHANGE*** clock() used to return only user time,
908 ***WARNING: API CHANGE*** clock() used to return only user time,
907 so if you want exactly the same results as before, use clocku
909 so if you want exactly the same results as before, use clocku
908 instead.
910 instead.
909
911
910 2007-02-22 Ville Vainio <vivainio@gmail.com>
912 2007-02-22 Ville Vainio <vivainio@gmail.com>
911
913
912 * IPython/Extensions/ipy_p4.py: Extension for improved
914 * IPython/Extensions/ipy_p4.py: Extension for improved
913 p4 (perforce version control system) experience.
915 p4 (perforce version control system) experience.
914 Adds %p4 magic with p4 command completion and
916 Adds %p4 magic with p4 command completion and
915 automatic -G argument (marshall output as python dict)
917 automatic -G argument (marshall output as python dict)
916
918
917 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
919 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
918
920
919 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
921 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
920 stop marks.
922 stop marks.
921 (ClearingMixin): a simple mixin to easily make a Demo class clear
923 (ClearingMixin): a simple mixin to easily make a Demo class clear
922 the screen in between blocks and have empty marquees. The
924 the screen in between blocks and have empty marquees. The
923 ClearDemo and ClearIPDemo classes that use it are included.
925 ClearDemo and ClearIPDemo classes that use it are included.
924
926
925 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
927 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
926
928
927 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
929 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
928 protect against exceptions at Python shutdown time. Patch
930 protect against exceptions at Python shutdown time. Patch
929 sumbmitted to upstream.
931 sumbmitted to upstream.
930
932
931 2007-02-14 Walter Doerwald <walter@livinglogic.de>
933 2007-02-14 Walter Doerwald <walter@livinglogic.de>
932
934
933 * IPython/Extensions/ibrowse.py: If entering the first object level
935 * IPython/Extensions/ibrowse.py: If entering the first object level
934 (i.e. the object for which the browser has been started) fails,
936 (i.e. the object for which the browser has been started) fails,
935 now the error is raised directly (aborting the browser) instead of
937 now the error is raised directly (aborting the browser) instead of
936 running into an empty levels list later.
938 running into an empty levels list later.
937
939
938 2007-02-03 Walter Doerwald <walter@livinglogic.de>
940 2007-02-03 Walter Doerwald <walter@livinglogic.de>
939
941
940 * IPython/Extensions/ipipe.py: Add an xrepr implementation
942 * IPython/Extensions/ipipe.py: Add an xrepr implementation
941 for the noitem object.
943 for the noitem object.
942
944
943 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
945 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
944
946
945 * IPython/completer.py (Completer.attr_matches): Fix small
947 * IPython/completer.py (Completer.attr_matches): Fix small
946 tab-completion bug with Enthought Traits objects with units.
948 tab-completion bug with Enthought Traits objects with units.
947 Thanks to a bug report by Tom Denniston
949 Thanks to a bug report by Tom Denniston
948 <tom.denniston-AT-alum.dartmouth.org>.
950 <tom.denniston-AT-alum.dartmouth.org>.
949
951
950 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
952 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
951
953
952 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
954 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
953 bug where only .ipy or .py would be completed. Once the first
955 bug where only .ipy or .py would be completed. Once the first
954 argument to %run has been given, all completions are valid because
956 argument to %run has been given, all completions are valid because
955 they are the arguments to the script, which may well be non-python
957 they are the arguments to the script, which may well be non-python
956 filenames.
958 filenames.
957
959
958 * IPython/irunner.py (InteractiveRunner.run_source): major updates
960 * IPython/irunner.py (InteractiveRunner.run_source): major updates
959 to irunner to allow it to correctly support real doctesting of
961 to irunner to allow it to correctly support real doctesting of
960 out-of-process ipython code.
962 out-of-process ipython code.
961
963
962 * IPython/Magic.py (magic_cd): Make the setting of the terminal
964 * IPython/Magic.py (magic_cd): Make the setting of the terminal
963 title an option (-noterm_title) because it completely breaks
965 title an option (-noterm_title) because it completely breaks
964 doctesting.
966 doctesting.
965
967
966 * IPython/demo.py: fix IPythonDemo class that was not actually working.
968 * IPython/demo.py: fix IPythonDemo class that was not actually working.
967
969
968 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
970 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
969
971
970 * IPython/irunner.py (main): fix small bug where extensions were
972 * IPython/irunner.py (main): fix small bug where extensions were
971 not being correctly recognized.
973 not being correctly recognized.
972
974
973 2007-01-23 Walter Doerwald <walter@livinglogic.de>
975 2007-01-23 Walter Doerwald <walter@livinglogic.de>
974
976
975 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
977 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
976 a string containing a single line yields the string itself as the
978 a string containing a single line yields the string itself as the
977 only item.
979 only item.
978
980
979 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
981 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
980 object if it's the same as the one on the last level (This avoids
982 object if it's the same as the one on the last level (This avoids
981 infinite recursion for one line strings).
983 infinite recursion for one line strings).
982
984
983 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
985 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
984
986
985 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
987 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
986 all output streams before printing tracebacks. This ensures that
988 all output streams before printing tracebacks. This ensures that
987 user output doesn't end up interleaved with traceback output.
989 user output doesn't end up interleaved with traceback output.
988
990
989 2007-01-10 Ville Vainio <vivainio@gmail.com>
991 2007-01-10 Ville Vainio <vivainio@gmail.com>
990
992
991 * Extensions/envpersist.py: Turbocharged %env that remembers
993 * Extensions/envpersist.py: Turbocharged %env that remembers
992 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
994 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
993 "%env VISUAL=jed".
995 "%env VISUAL=jed".
994
996
995 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
997 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
996
998
997 * IPython/iplib.py (showtraceback): ensure that we correctly call
999 * IPython/iplib.py (showtraceback): ensure that we correctly call
998 custom handlers in all cases (some with pdb were slipping through,
1000 custom handlers in all cases (some with pdb were slipping through,
999 but I'm not exactly sure why).
1001 but I'm not exactly sure why).
1000
1002
1001 * IPython/Debugger.py (Tracer.__init__): added new class to
1003 * IPython/Debugger.py (Tracer.__init__): added new class to
1002 support set_trace-like usage of IPython's enhanced debugger.
1004 support set_trace-like usage of IPython's enhanced debugger.
1003
1005
1004 2006-12-24 Ville Vainio <vivainio@gmail.com>
1006 2006-12-24 Ville Vainio <vivainio@gmail.com>
1005
1007
1006 * ipmaker.py: more informative message when ipy_user_conf
1008 * ipmaker.py: more informative message when ipy_user_conf
1007 import fails (suggest running %upgrade).
1009 import fails (suggest running %upgrade).
1008
1010
1009 * tools/run_ipy_in_profiler.py: Utility to see where
1011 * tools/run_ipy_in_profiler.py: Utility to see where
1010 the time during IPython startup is spent.
1012 the time during IPython startup is spent.
1011
1013
1012 2006-12-20 Ville Vainio <vivainio@gmail.com>
1014 2006-12-20 Ville Vainio <vivainio@gmail.com>
1013
1015
1014 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
1016 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
1015
1017
1016 * ipapi.py: Add new ipapi method, expand_alias.
1018 * ipapi.py: Add new ipapi method, expand_alias.
1017
1019
1018 * Release.py: Bump up version to 0.7.4.svn
1020 * Release.py: Bump up version to 0.7.4.svn
1019
1021
1020 2006-12-17 Ville Vainio <vivainio@gmail.com>
1022 2006-12-17 Ville Vainio <vivainio@gmail.com>
1021
1023
1022 * Extensions/jobctrl.py: Fixed &cmd arg arg...
1024 * Extensions/jobctrl.py: Fixed &cmd arg arg...
1023 to work properly on posix too
1025 to work properly on posix too
1024
1026
1025 * Release.py: Update revnum (version is still just 0.7.3).
1027 * Release.py: Update revnum (version is still just 0.7.3).
1026
1028
1027 2006-12-15 Ville Vainio <vivainio@gmail.com>
1029 2006-12-15 Ville Vainio <vivainio@gmail.com>
1028
1030
1029 * scripts/ipython_win_post_install: create ipython.py in
1031 * scripts/ipython_win_post_install: create ipython.py in
1030 prefix + "/scripts".
1032 prefix + "/scripts".
1031
1033
1032 * Release.py: Update version to 0.7.3.
1034 * Release.py: Update version to 0.7.3.
1033
1035
1034 2006-12-14 Ville Vainio <vivainio@gmail.com>
1036 2006-12-14 Ville Vainio <vivainio@gmail.com>
1035
1037
1036 * scripts/ipython_win_post_install: Overwrite old shortcuts
1038 * scripts/ipython_win_post_install: Overwrite old shortcuts
1037 if they already exist
1039 if they already exist
1038
1040
1039 * Release.py: release 0.7.3rc2
1041 * Release.py: release 0.7.3rc2
1040
1042
1041 2006-12-13 Ville Vainio <vivainio@gmail.com>
1043 2006-12-13 Ville Vainio <vivainio@gmail.com>
1042
1044
1043 * Branch and update Release.py for 0.7.3rc1
1045 * Branch and update Release.py for 0.7.3rc1
1044
1046
1045 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
1047 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
1046
1048
1047 * IPython/Shell.py (IPShellWX): update for current WX naming
1049 * IPython/Shell.py (IPShellWX): update for current WX naming
1048 conventions, to avoid a deprecation warning with current WX
1050 conventions, to avoid a deprecation warning with current WX
1049 versions. Thanks to a report by Danny Shevitz.
1051 versions. Thanks to a report by Danny Shevitz.
1050
1052
1051 2006-12-12 Ville Vainio <vivainio@gmail.com>
1053 2006-12-12 Ville Vainio <vivainio@gmail.com>
1052
1054
1053 * ipmaker.py: apply david cournapeau's patch to make
1055 * ipmaker.py: apply david cournapeau's patch to make
1054 import_some work properly even when ipythonrc does
1056 import_some work properly even when ipythonrc does
1055 import_some on empty list (it was an old bug!).
1057 import_some on empty list (it was an old bug!).
1056
1058
1057 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
1059 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
1058 Add deprecation note to ipythonrc and a url to wiki
1060 Add deprecation note to ipythonrc and a url to wiki
1059 in ipy_user_conf.py
1061 in ipy_user_conf.py
1060
1062
1061
1063
1062 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
1064 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
1063 as if it was typed on IPython command prompt, i.e.
1065 as if it was typed on IPython command prompt, i.e.
1064 as IPython script.
1066 as IPython script.
1065
1067
1066 * example-magic.py, magic_grepl.py: remove outdated examples
1068 * example-magic.py, magic_grepl.py: remove outdated examples
1067
1069
1068 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
1070 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
1069
1071
1070 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
1072 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
1071 is called before any exception has occurred.
1073 is called before any exception has occurred.
1072
1074
1073 2006-12-08 Ville Vainio <vivainio@gmail.com>
1075 2006-12-08 Ville Vainio <vivainio@gmail.com>
1074
1076
1075 * Extensions/ipy_stock_completers.py: fix cd completer
1077 * Extensions/ipy_stock_completers.py: fix cd completer
1076 to translate /'s to \'s again.
1078 to translate /'s to \'s again.
1077
1079
1078 * completer.py: prevent traceback on file completions w/
1080 * completer.py: prevent traceback on file completions w/
1079 backslash.
1081 backslash.
1080
1082
1081 * Release.py: Update release number to 0.7.3b3 for release
1083 * Release.py: Update release number to 0.7.3b3 for release
1082
1084
1083 2006-12-07 Ville Vainio <vivainio@gmail.com>
1085 2006-12-07 Ville Vainio <vivainio@gmail.com>
1084
1086
1085 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
1087 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
1086 while executing external code. Provides more shell-like behaviour
1088 while executing external code. Provides more shell-like behaviour
1087 and overall better response to ctrl + C / ctrl + break.
1089 and overall better response to ctrl + C / ctrl + break.
1088
1090
1089 * tools/make_tarball.py: new script to create tarball straight from svn
1091 * tools/make_tarball.py: new script to create tarball straight from svn
1090 (setup.py sdist doesn't work on win32).
1092 (setup.py sdist doesn't work on win32).
1091
1093
1092 * Extensions/ipy_stock_completers.py: fix cd completer to give up
1094 * Extensions/ipy_stock_completers.py: fix cd completer to give up
1093 on dirnames with spaces and use the default completer instead.
1095 on dirnames with spaces and use the default completer instead.
1094
1096
1095 * Revision.py: Change version to 0.7.3b2 for release.
1097 * Revision.py: Change version to 0.7.3b2 for release.
1096
1098
1097 2006-12-05 Ville Vainio <vivainio@gmail.com>
1099 2006-12-05 Ville Vainio <vivainio@gmail.com>
1098
1100
1099 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
1101 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
1100 pydb patch 4 (rm debug printing, py 2.5 checking)
1102 pydb patch 4 (rm debug printing, py 2.5 checking)
1101
1103
1102 2006-11-30 Walter Doerwald <walter@livinglogic.de>
1104 2006-11-30 Walter Doerwald <walter@livinglogic.de>
1103 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
1105 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
1104 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
1106 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
1105 "refreshfind" (mapped to "R") does the same but tries to go back to the same
1107 "refreshfind" (mapped to "R") does the same but tries to go back to the same
1106 object the cursor was on before the refresh. The command "markrange" is
1108 object the cursor was on before the refresh. The command "markrange" is
1107 mapped to "%" now.
1109 mapped to "%" now.
1108 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
1110 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
1109
1111
1110 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
1112 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
1111
1113
1112 * IPython/Magic.py (magic_debug): new %debug magic to activate the
1114 * IPython/Magic.py (magic_debug): new %debug magic to activate the
1113 interactive debugger on the last traceback, without having to call
1115 interactive debugger on the last traceback, without having to call
1114 %pdb and rerun your code. Made minor changes in various modules,
1116 %pdb and rerun your code. Made minor changes in various modules,
1115 should automatically recognize pydb if available.
1117 should automatically recognize pydb if available.
1116
1118
1117 2006-11-28 Ville Vainio <vivainio@gmail.com>
1119 2006-11-28 Ville Vainio <vivainio@gmail.com>
1118
1120
1119 * completer.py: If the text start with !, show file completions
1121 * completer.py: If the text start with !, show file completions
1120 properly. This helps when trying to complete command name
1122 properly. This helps when trying to complete command name
1121 for shell escapes.
1123 for shell escapes.
1122
1124
1123 2006-11-27 Ville Vainio <vivainio@gmail.com>
1125 2006-11-27 Ville Vainio <vivainio@gmail.com>
1124
1126
1125 * ipy_stock_completers.py: bzr completer submitted by Stefan van
1127 * ipy_stock_completers.py: bzr completer submitted by Stefan van
1126 der Walt. Clean up svn and hg completers by using a common
1128 der Walt. Clean up svn and hg completers by using a common
1127 vcs_completer.
1129 vcs_completer.
1128
1130
1129 2006-11-26 Ville Vainio <vivainio@gmail.com>
1131 2006-11-26 Ville Vainio <vivainio@gmail.com>
1130
1132
1131 * Remove ipconfig and %config; you should use _ip.options structure
1133 * Remove ipconfig and %config; you should use _ip.options structure
1132 directly instead!
1134 directly instead!
1133
1135
1134 * genutils.py: add wrap_deprecated function for deprecating callables
1136 * genutils.py: add wrap_deprecated function for deprecating callables
1135
1137
1136 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
1138 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
1137 _ip.system instead. ipalias is redundant.
1139 _ip.system instead. ipalias is redundant.
1138
1140
1139 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
1141 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
1140 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
1142 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
1141 explicit.
1143 explicit.
1142
1144
1143 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
1145 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
1144 completer. Try it by entering 'hg ' and pressing tab.
1146 completer. Try it by entering 'hg ' and pressing tab.
1145
1147
1146 * macro.py: Give Macro a useful __repr__ method
1148 * macro.py: Give Macro a useful __repr__ method
1147
1149
1148 * Magic.py: %whos abbreviates the typename of Macro for brevity.
1150 * Magic.py: %whos abbreviates the typename of Macro for brevity.
1149
1151
1150 2006-11-24 Walter Doerwald <walter@livinglogic.de>
1152 2006-11-24 Walter Doerwald <walter@livinglogic.de>
1151 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
1153 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
1152 we don't get a duplicate ipipe module, where registration of the xrepr
1154 we don't get a duplicate ipipe module, where registration of the xrepr
1153 implementation for Text is useless.
1155 implementation for Text is useless.
1154
1156
1155 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
1157 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
1156
1158
1157 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
1159 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
1158
1160
1159 2006-11-24 Ville Vainio <vivainio@gmail.com>
1161 2006-11-24 Ville Vainio <vivainio@gmail.com>
1160
1162
1161 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
1163 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
1162 try to use "cProfile" instead of the slower pure python
1164 try to use "cProfile" instead of the slower pure python
1163 "profile"
1165 "profile"
1164
1166
1165 2006-11-23 Ville Vainio <vivainio@gmail.com>
1167 2006-11-23 Ville Vainio <vivainio@gmail.com>
1166
1168
1167 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
1169 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
1168 Qt+IPython+Designer link in documentation.
1170 Qt+IPython+Designer link in documentation.
1169
1171
1170 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
1172 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
1171 correct Pdb object to %pydb.
1173 correct Pdb object to %pydb.
1172
1174
1173
1175
1174 2006-11-22 Walter Doerwald <walter@livinglogic.de>
1176 2006-11-22 Walter Doerwald <walter@livinglogic.de>
1175 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
1177 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
1176 generic xrepr(), otherwise the list implementation would kick in.
1178 generic xrepr(), otherwise the list implementation would kick in.
1177
1179
1178 2006-11-21 Ville Vainio <vivainio@gmail.com>
1180 2006-11-21 Ville Vainio <vivainio@gmail.com>
1179
1181
1180 * upgrade_dir.py: Now actually overwrites a nonmodified user file
1182 * upgrade_dir.py: Now actually overwrites a nonmodified user file
1181 with one from UserConfig.
1183 with one from UserConfig.
1182
1184
1183 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
1185 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
1184 it was missing which broke the sh profile.
1186 it was missing which broke the sh profile.
1185
1187
1186 * completer.py: file completer now uses explicit '/' instead
1188 * completer.py: file completer now uses explicit '/' instead
1187 of os.path.join, expansion of 'foo' was broken on win32
1189 of os.path.join, expansion of 'foo' was broken on win32
1188 if there was one directory with name 'foobar'.
1190 if there was one directory with name 'foobar'.
1189
1191
1190 * A bunch of patches from Kirill Smelkov:
1192 * A bunch of patches from Kirill Smelkov:
1191
1193
1192 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
1194 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
1193
1195
1194 * [patch 7/9] Implement %page -r (page in raw mode) -
1196 * [patch 7/9] Implement %page -r (page in raw mode) -
1195
1197
1196 * [patch 5/9] ScientificPython webpage has moved
1198 * [patch 5/9] ScientificPython webpage has moved
1197
1199
1198 * [patch 4/9] The manual mentions %ds, should be %dhist
1200 * [patch 4/9] The manual mentions %ds, should be %dhist
1199
1201
1200 * [patch 3/9] Kill old bits from %prun doc.
1202 * [patch 3/9] Kill old bits from %prun doc.
1201
1203
1202 * [patch 1/9] Fix typos here and there.
1204 * [patch 1/9] Fix typos here and there.
1203
1205
1204 2006-11-08 Ville Vainio <vivainio@gmail.com>
1206 2006-11-08 Ville Vainio <vivainio@gmail.com>
1205
1207
1206 * completer.py (attr_matches): catch all exceptions raised
1208 * completer.py (attr_matches): catch all exceptions raised
1207 by eval of expr with dots.
1209 by eval of expr with dots.
1208
1210
1209 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
1211 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
1210
1212
1211 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
1213 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
1212 input if it starts with whitespace. This allows you to paste
1214 input if it starts with whitespace. This allows you to paste
1213 indented input from any editor without manually having to type in
1215 indented input from any editor without manually having to type in
1214 the 'if 1:', which is convenient when working interactively.
1216 the 'if 1:', which is convenient when working interactively.
1215 Slightly modifed version of a patch by Bo Peng
1217 Slightly modifed version of a patch by Bo Peng
1216 <bpeng-AT-rice.edu>.
1218 <bpeng-AT-rice.edu>.
1217
1219
1218 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1220 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1219
1221
1220 * IPython/irunner.py (main): modified irunner so it automatically
1222 * IPython/irunner.py (main): modified irunner so it automatically
1221 recognizes the right runner to use based on the extension (.py for
1223 recognizes the right runner to use based on the extension (.py for
1222 python, .ipy for ipython and .sage for sage).
1224 python, .ipy for ipython and .sage for sage).
1223
1225
1224 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
1226 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
1225 visible in ipapi as ip.config(), to programatically control the
1227 visible in ipapi as ip.config(), to programatically control the
1226 internal rc object. There's an accompanying %config magic for
1228 internal rc object. There's an accompanying %config magic for
1227 interactive use, which has been enhanced to match the
1229 interactive use, which has been enhanced to match the
1228 funtionality in ipconfig.
1230 funtionality in ipconfig.
1229
1231
1230 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
1232 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
1231 so it's not just a toggle, it now takes an argument. Add support
1233 so it's not just a toggle, it now takes an argument. Add support
1232 for a customizable header when making system calls, as the new
1234 for a customizable header when making system calls, as the new
1233 system_header variable in the ipythonrc file.
1235 system_header variable in the ipythonrc file.
1234
1236
1235 2006-11-03 Walter Doerwald <walter@livinglogic.de>
1237 2006-11-03 Walter Doerwald <walter@livinglogic.de>
1236
1238
1237 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
1239 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
1238 generic functions (using Philip J. Eby's simplegeneric package).
1240 generic functions (using Philip J. Eby's simplegeneric package).
1239 This makes it possible to customize the display of third-party classes
1241 This makes it possible to customize the display of third-party classes
1240 without having to monkeypatch them. xiter() no longer supports a mode
1242 without having to monkeypatch them. xiter() no longer supports a mode
1241 argument and the XMode class has been removed. The same functionality can
1243 argument and the XMode class has been removed. The same functionality can
1242 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
1244 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
1243 One consequence of the switch to generic functions is that xrepr() and
1245 One consequence of the switch to generic functions is that xrepr() and
1244 xattrs() implementation must define the default value for the mode
1246 xattrs() implementation must define the default value for the mode
1245 argument themselves and xattrs() implementations must return real
1247 argument themselves and xattrs() implementations must return real
1246 descriptors.
1248 descriptors.
1247
1249
1248 * IPython/external: This new subpackage will contain all third-party
1250 * IPython/external: This new subpackage will contain all third-party
1249 packages that are bundled with IPython. (The first one is simplegeneric).
1251 packages that are bundled with IPython. (The first one is simplegeneric).
1250
1252
1251 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
1253 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
1252 directory which as been dropped in r1703.
1254 directory which as been dropped in r1703.
1253
1255
1254 * IPython/Extensions/ipipe.py (iless): Fixed.
1256 * IPython/Extensions/ipipe.py (iless): Fixed.
1255
1257
1256 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
1258 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
1257
1259
1258 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1260 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
1259
1261
1260 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
1262 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
1261 handling in variable expansion so that shells and magics recognize
1263 handling in variable expansion so that shells and magics recognize
1262 function local scopes correctly. Bug reported by Brian.
1264 function local scopes correctly. Bug reported by Brian.
1263
1265
1264 * scripts/ipython: remove the very first entry in sys.path which
1266 * scripts/ipython: remove the very first entry in sys.path which
1265 Python auto-inserts for scripts, so that sys.path under IPython is
1267 Python auto-inserts for scripts, so that sys.path under IPython is
1266 as similar as possible to that under plain Python.
1268 as similar as possible to that under plain Python.
1267
1269
1268 * IPython/completer.py (IPCompleter.file_matches): Fix
1270 * IPython/completer.py (IPCompleter.file_matches): Fix
1269 tab-completion so that quotes are not closed unless the completion
1271 tab-completion so that quotes are not closed unless the completion
1270 is unambiguous. After a request by Stefan. Minor cleanups in
1272 is unambiguous. After a request by Stefan. Minor cleanups in
1271 ipy_stock_completers.
1273 ipy_stock_completers.
1272
1274
1273 2006-11-02 Ville Vainio <vivainio@gmail.com>
1275 2006-11-02 Ville Vainio <vivainio@gmail.com>
1274
1276
1275 * ipy_stock_completers.py: Add %run and %cd completers.
1277 * ipy_stock_completers.py: Add %run and %cd completers.
1276
1278
1277 * completer.py: Try running custom completer for both
1279 * completer.py: Try running custom completer for both
1278 "foo" and "%foo" if the command is just "foo". Ignore case
1280 "foo" and "%foo" if the command is just "foo". Ignore case
1279 when filtering possible completions.
1281 when filtering possible completions.
1280
1282
1281 * UserConfig/ipy_user_conf.py: install stock completers as default
1283 * UserConfig/ipy_user_conf.py: install stock completers as default
1282
1284
1283 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
1285 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
1284 simplified readline history save / restore through a wrapper
1286 simplified readline history save / restore through a wrapper
1285 function
1287 function
1286
1288
1287
1289
1288 2006-10-31 Ville Vainio <vivainio@gmail.com>
1290 2006-10-31 Ville Vainio <vivainio@gmail.com>
1289
1291
1290 * strdispatch.py, completer.py, ipy_stock_completers.py:
1292 * strdispatch.py, completer.py, ipy_stock_completers.py:
1291 Allow str_key ("command") in completer hooks. Implement
1293 Allow str_key ("command") in completer hooks. Implement
1292 trivial completer for 'import' (stdlib modules only). Rename
1294 trivial completer for 'import' (stdlib modules only). Rename
1293 ipy_linux_package_managers.py to ipy_stock_completers.py.
1295 ipy_linux_package_managers.py to ipy_stock_completers.py.
1294 SVN completer.
1296 SVN completer.
1295
1297
1296 * Extensions/ledit.py: %magic line editor for easily and
1298 * Extensions/ledit.py: %magic line editor for easily and
1297 incrementally manipulating lists of strings. The magic command
1299 incrementally manipulating lists of strings. The magic command
1298 name is %led.
1300 name is %led.
1299
1301
1300 2006-10-30 Ville Vainio <vivainio@gmail.com>
1302 2006-10-30 Ville Vainio <vivainio@gmail.com>
1301
1303
1302 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
1304 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
1303 Bernsteins's patches for pydb integration.
1305 Bernsteins's patches for pydb integration.
1304 http://bashdb.sourceforge.net/pydb/
1306 http://bashdb.sourceforge.net/pydb/
1305
1307
1306 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
1308 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
1307 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
1309 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
1308 custom completer hook to allow the users to implement their own
1310 custom completer hook to allow the users to implement their own
1309 completers. See ipy_linux_package_managers.py for example. The
1311 completers. See ipy_linux_package_managers.py for example. The
1310 hook name is 'complete_command'.
1312 hook name is 'complete_command'.
1311
1313
1312 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
1314 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
1313
1315
1314 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
1316 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
1315 Numeric leftovers.
1317 Numeric leftovers.
1316
1318
1317 * ipython.el (py-execute-region): apply Stefan's patch to fix
1319 * ipython.el (py-execute-region): apply Stefan's patch to fix
1318 garbled results if the python shell hasn't been previously started.
1320 garbled results if the python shell hasn't been previously started.
1319
1321
1320 * IPython/genutils.py (arg_split): moved to genutils, since it's a
1322 * IPython/genutils.py (arg_split): moved to genutils, since it's a
1321 pretty generic function and useful for other things.
1323 pretty generic function and useful for other things.
1322
1324
1323 * IPython/OInspect.py (getsource): Add customizable source
1325 * IPython/OInspect.py (getsource): Add customizable source
1324 extractor. After a request/patch form W. Stein (SAGE).
1326 extractor. After a request/patch form W. Stein (SAGE).
1325
1327
1326 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
1328 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
1327 window size to a more reasonable value from what pexpect does,
1329 window size to a more reasonable value from what pexpect does,
1328 since their choice causes wrapping bugs with long input lines.
1330 since their choice causes wrapping bugs with long input lines.
1329
1331
1330 2006-10-28 Ville Vainio <vivainio@gmail.com>
1332 2006-10-28 Ville Vainio <vivainio@gmail.com>
1331
1333
1332 * Magic.py (%run): Save and restore the readline history from
1334 * Magic.py (%run): Save and restore the readline history from
1333 file around %run commands to prevent side effects from
1335 file around %run commands to prevent side effects from
1334 %runned programs that might use readline (e.g. pydb).
1336 %runned programs that might use readline (e.g. pydb).
1335
1337
1336 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
1338 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
1337 invoking the pydb enhanced debugger.
1339 invoking the pydb enhanced debugger.
1338
1340
1339 2006-10-23 Walter Doerwald <walter@livinglogic.de>
1341 2006-10-23 Walter Doerwald <walter@livinglogic.de>
1340
1342
1341 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
1343 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
1342 call the base class method and propagate the return value to
1344 call the base class method and propagate the return value to
1343 ifile. This is now done by path itself.
1345 ifile. This is now done by path itself.
1344
1346
1345 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1347 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
1346
1348
1347 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
1349 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
1348 api: set_crash_handler(), to expose the ability to change the
1350 api: set_crash_handler(), to expose the ability to change the
1349 internal crash handler.
1351 internal crash handler.
1350
1352
1351 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
1353 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
1352 the various parameters of the crash handler so that apps using
1354 the various parameters of the crash handler so that apps using
1353 IPython as their engine can customize crash handling. Ipmlemented
1355 IPython as their engine can customize crash handling. Ipmlemented
1354 at the request of SAGE.
1356 at the request of SAGE.
1355
1357
1356 2006-10-14 Ville Vainio <vivainio@gmail.com>
1358 2006-10-14 Ville Vainio <vivainio@gmail.com>
1357
1359
1358 * Magic.py, ipython.el: applied first "safe" part of Rocky
1360 * Magic.py, ipython.el: applied first "safe" part of Rocky
1359 Bernstein's patch set for pydb integration.
1361 Bernstein's patch set for pydb integration.
1360
1362
1361 * Magic.py (%unalias, %alias): %store'd aliases can now be
1363 * Magic.py (%unalias, %alias): %store'd aliases can now be
1362 removed with '%unalias'. %alias w/o args now shows most
1364 removed with '%unalias'. %alias w/o args now shows most
1363 interesting (stored / manually defined) aliases last
1365 interesting (stored / manually defined) aliases last
1364 where they catch the eye w/o scrolling.
1366 where they catch the eye w/o scrolling.
1365
1367
1366 * Magic.py (%rehashx), ext_rehashdir.py: files with
1368 * Magic.py (%rehashx), ext_rehashdir.py: files with
1367 'py' extension are always considered executable, even
1369 'py' extension are always considered executable, even
1368 when not in PATHEXT environment variable.
1370 when not in PATHEXT environment variable.
1369
1371
1370 2006-10-12 Ville Vainio <vivainio@gmail.com>
1372 2006-10-12 Ville Vainio <vivainio@gmail.com>
1371
1373
1372 * jobctrl.py: Add new "jobctrl" extension for spawning background
1374 * jobctrl.py: Add new "jobctrl" extension for spawning background
1373 processes with "&find /". 'import jobctrl' to try it out. Requires
1375 processes with "&find /". 'import jobctrl' to try it out. Requires
1374 'subprocess' module, standard in python 2.4+.
1376 'subprocess' module, standard in python 2.4+.
1375
1377
1376 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1378 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1377 so if foo -> bar and bar -> baz, then foo -> baz.
1379 so if foo -> bar and bar -> baz, then foo -> baz.
1378
1380
1379 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1381 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1380
1382
1381 * IPython/Magic.py (Magic.parse_options): add a new posix option
1383 * IPython/Magic.py (Magic.parse_options): add a new posix option
1382 to allow parsing of input args in magics that doesn't strip quotes
1384 to allow parsing of input args in magics that doesn't strip quotes
1383 (if posix=False). This also closes %timeit bug reported by
1385 (if posix=False). This also closes %timeit bug reported by
1384 Stefan.
1386 Stefan.
1385
1387
1386 2006-10-03 Ville Vainio <vivainio@gmail.com>
1388 2006-10-03 Ville Vainio <vivainio@gmail.com>
1387
1389
1388 * iplib.py (raw_input, interact): Return ValueError catching for
1390 * iplib.py (raw_input, interact): Return ValueError catching for
1389 raw_input. Fixes infinite loop for sys.stdin.close() or
1391 raw_input. Fixes infinite loop for sys.stdin.close() or
1390 sys.stdout.close().
1392 sys.stdout.close().
1391
1393
1392 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1394 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1393
1395
1394 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1396 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1395 to help in handling doctests. irunner is now pretty useful for
1397 to help in handling doctests. irunner is now pretty useful for
1396 running standalone scripts and simulate a full interactive session
1398 running standalone scripts and simulate a full interactive session
1397 in a format that can be then pasted as a doctest.
1399 in a format that can be then pasted as a doctest.
1398
1400
1399 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1401 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1400 on top of the default (useless) ones. This also fixes the nasty
1402 on top of the default (useless) ones. This also fixes the nasty
1401 way in which 2.5's Quitter() exits (reverted [1785]).
1403 way in which 2.5's Quitter() exits (reverted [1785]).
1402
1404
1403 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1405 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1404 2.5.
1406 2.5.
1405
1407
1406 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1408 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1407 color scheme is updated as well when color scheme is changed
1409 color scheme is updated as well when color scheme is changed
1408 interactively.
1410 interactively.
1409
1411
1410 2006-09-27 Ville Vainio <vivainio@gmail.com>
1412 2006-09-27 Ville Vainio <vivainio@gmail.com>
1411
1413
1412 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1414 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1413 infinite loop and just exit. It's a hack, but will do for a while.
1415 infinite loop and just exit. It's a hack, but will do for a while.
1414
1416
1415 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1417 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1416
1418
1417 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1419 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1418 the constructor, this makes it possible to get a list of only directories
1420 the constructor, this makes it possible to get a list of only directories
1419 or only files.
1421 or only files.
1420
1422
1421 2006-08-12 Ville Vainio <vivainio@gmail.com>
1423 2006-08-12 Ville Vainio <vivainio@gmail.com>
1422
1424
1423 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1425 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1424 they broke unittest
1426 they broke unittest
1425
1427
1426 2006-08-11 Ville Vainio <vivainio@gmail.com>
1428 2006-08-11 Ville Vainio <vivainio@gmail.com>
1427
1429
1428 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1430 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1429 by resolving issue properly, i.e. by inheriting FakeModule
1431 by resolving issue properly, i.e. by inheriting FakeModule
1430 from types.ModuleType. Pickling ipython interactive data
1432 from types.ModuleType. Pickling ipython interactive data
1431 should still work as usual (testing appreciated).
1433 should still work as usual (testing appreciated).
1432
1434
1433 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1435 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1434
1436
1435 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1437 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1436 running under python 2.3 with code from 2.4 to fix a bug with
1438 running under python 2.3 with code from 2.4 to fix a bug with
1437 help(). Reported by the Debian maintainers, Norbert Tretkowski
1439 help(). Reported by the Debian maintainers, Norbert Tretkowski
1438 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1440 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1439 <afayolle-AT-debian.org>.
1441 <afayolle-AT-debian.org>.
1440
1442
1441 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1443 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1442
1444
1443 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1445 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1444 (which was displaying "quit" twice).
1446 (which was displaying "quit" twice).
1445
1447
1446 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1448 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1447
1449
1448 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1450 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1449 the mode argument).
1451 the mode argument).
1450
1452
1451 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1453 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1452
1454
1453 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1455 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1454 not running under IPython.
1456 not running under IPython.
1455
1457
1456 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1458 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1457 and make it iterable (iterating over the attribute itself). Add two new
1459 and make it iterable (iterating over the attribute itself). Add two new
1458 magic strings for __xattrs__(): If the string starts with "-", the attribute
1460 magic strings for __xattrs__(): If the string starts with "-", the attribute
1459 will not be displayed in ibrowse's detail view (but it can still be
1461 will not be displayed in ibrowse's detail view (but it can still be
1460 iterated over). This makes it possible to add attributes that are large
1462 iterated over). This makes it possible to add attributes that are large
1461 lists or generator methods to the detail view. Replace magic attribute names
1463 lists or generator methods to the detail view. Replace magic attribute names
1462 and _attrname() and _getattr() with "descriptors": For each type of magic
1464 and _attrname() and _getattr() with "descriptors": For each type of magic
1463 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1465 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1464 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1466 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1465 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1467 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1466 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1468 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1467 are still supported.
1469 are still supported.
1468
1470
1469 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1471 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1470 fails in ibrowse.fetch(), the exception object is added as the last item
1472 fails in ibrowse.fetch(), the exception object is added as the last item
1471 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1473 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1472 a generator throws an exception midway through execution.
1474 a generator throws an exception midway through execution.
1473
1475
1474 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1476 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1475 encoding into methods.
1477 encoding into methods.
1476
1478
1477 2006-07-26 Ville Vainio <vivainio@gmail.com>
1479 2006-07-26 Ville Vainio <vivainio@gmail.com>
1478
1480
1479 * iplib.py: history now stores multiline input as single
1481 * iplib.py: history now stores multiline input as single
1480 history entries. Patch by Jorgen Cederlof.
1482 history entries. Patch by Jorgen Cederlof.
1481
1483
1482 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1484 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1483
1485
1484 * IPython/Extensions/ibrowse.py: Make cursor visible over
1486 * IPython/Extensions/ibrowse.py: Make cursor visible over
1485 non existing attributes.
1487 non existing attributes.
1486
1488
1487 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1489 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1488
1490
1489 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1491 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1490 error output of the running command doesn't mess up the screen.
1492 error output of the running command doesn't mess up the screen.
1491
1493
1492 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1494 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1493
1495
1494 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1496 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1495 argument. This sorts the items themselves.
1497 argument. This sorts the items themselves.
1496
1498
1497 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1499 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1498
1500
1499 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1501 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1500 Compile expression strings into code objects. This should speed
1502 Compile expression strings into code objects. This should speed
1501 up ifilter and friends somewhat.
1503 up ifilter and friends somewhat.
1502
1504
1503 2006-07-08 Ville Vainio <vivainio@gmail.com>
1505 2006-07-08 Ville Vainio <vivainio@gmail.com>
1504
1506
1505 * Magic.py: %cpaste now strips > from the beginning of lines
1507 * Magic.py: %cpaste now strips > from the beginning of lines
1506 to ease pasting quoted code from emails. Contributed by
1508 to ease pasting quoted code from emails. Contributed by
1507 Stefan van der Walt.
1509 Stefan van der Walt.
1508
1510
1509 2006-06-29 Ville Vainio <vivainio@gmail.com>
1511 2006-06-29 Ville Vainio <vivainio@gmail.com>
1510
1512
1511 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1513 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1512 mode, patch contributed by Darren Dale. NEEDS TESTING!
1514 mode, patch contributed by Darren Dale. NEEDS TESTING!
1513
1515
1514 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1516 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1515
1517
1516 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1518 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1517 a blue background. Fix fetching new display rows when the browser
1519 a blue background. Fix fetching new display rows when the browser
1518 scrolls more than a screenful (e.g. by using the goto command).
1520 scrolls more than a screenful (e.g. by using the goto command).
1519
1521
1520 2006-06-27 Ville Vainio <vivainio@gmail.com>
1522 2006-06-27 Ville Vainio <vivainio@gmail.com>
1521
1523
1522 * Magic.py (_inspect, _ofind) Apply David Huard's
1524 * Magic.py (_inspect, _ofind) Apply David Huard's
1523 patch for displaying the correct docstring for 'property'
1525 patch for displaying the correct docstring for 'property'
1524 attributes.
1526 attributes.
1525
1527
1526 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1528 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1527
1529
1528 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1530 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1529 commands into the methods implementing them.
1531 commands into the methods implementing them.
1530
1532
1531 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1533 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1532
1534
1533 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1535 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1534 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1536 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1535 autoindent support was authored by Jin Liu.
1537 autoindent support was authored by Jin Liu.
1536
1538
1537 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1539 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1538
1540
1539 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1541 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1540 for keymaps with a custom class that simplifies handling.
1542 for keymaps with a custom class that simplifies handling.
1541
1543
1542 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1544 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1543
1545
1544 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1546 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1545 resizing. This requires Python 2.5 to work.
1547 resizing. This requires Python 2.5 to work.
1546
1548
1547 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1549 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1548
1550
1549 * IPython/Extensions/ibrowse.py: Add two new commands to
1551 * IPython/Extensions/ibrowse.py: Add two new commands to
1550 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1552 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1551 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1553 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1552 attributes again. Remapped the help command to "?". Display
1554 attributes again. Remapped the help command to "?". Display
1553 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1555 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1554 as keys for the "home" and "end" commands. Add three new commands
1556 as keys for the "home" and "end" commands. Add three new commands
1555 to the input mode for "find" and friends: "delend" (CTRL-K)
1557 to the input mode for "find" and friends: "delend" (CTRL-K)
1556 deletes to the end of line. "incsearchup" searches upwards in the
1558 deletes to the end of line. "incsearchup" searches upwards in the
1557 command history for an input that starts with the text before the cursor.
1559 command history for an input that starts with the text before the cursor.
1558 "incsearchdown" does the same downwards. Removed a bogus mapping of
1560 "incsearchdown" does the same downwards. Removed a bogus mapping of
1559 the x key to "delete".
1561 the x key to "delete".
1560
1562
1561 2006-06-15 Ville Vainio <vivainio@gmail.com>
1563 2006-06-15 Ville Vainio <vivainio@gmail.com>
1562
1564
1563 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1565 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1564 used to create prompts dynamically, instead of the "old" way of
1566 used to create prompts dynamically, instead of the "old" way of
1565 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1567 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1566 way still works (it's invoked by the default hook), of course.
1568 way still works (it's invoked by the default hook), of course.
1567
1569
1568 * Prompts.py: added generate_output_prompt hook for altering output
1570 * Prompts.py: added generate_output_prompt hook for altering output
1569 prompt
1571 prompt
1570
1572
1571 * Release.py: Changed version string to 0.7.3.svn.
1573 * Release.py: Changed version string to 0.7.3.svn.
1572
1574
1573 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1575 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1574
1576
1575 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1577 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1576 the call to fetch() always tries to fetch enough data for at least one
1578 the call to fetch() always tries to fetch enough data for at least one
1577 full screen. This makes it possible to simply call moveto(0,0,True) in
1579 full screen. This makes it possible to simply call moveto(0,0,True) in
1578 the constructor. Fix typos and removed the obsolete goto attribute.
1580 the constructor. Fix typos and removed the obsolete goto attribute.
1579
1581
1580 2006-06-12 Ville Vainio <vivainio@gmail.com>
1582 2006-06-12 Ville Vainio <vivainio@gmail.com>
1581
1583
1582 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1584 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1583 allowing $variable interpolation within multiline statements,
1585 allowing $variable interpolation within multiline statements,
1584 though so far only with "sh" profile for a testing period.
1586 though so far only with "sh" profile for a testing period.
1585 The patch also enables splitting long commands with \ but it
1587 The patch also enables splitting long commands with \ but it
1586 doesn't work properly yet.
1588 doesn't work properly yet.
1587
1589
1588 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1590 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1589
1591
1590 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1592 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1591 input history and the position of the cursor in the input history for
1593 input history and the position of the cursor in the input history for
1592 the find, findbackwards and goto command.
1594 the find, findbackwards and goto command.
1593
1595
1594 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1596 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1595
1597
1596 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1598 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1597 implements the basic functionality of browser commands that require
1599 implements the basic functionality of browser commands that require
1598 input. Reimplement the goto, find and findbackwards commands as
1600 input. Reimplement the goto, find and findbackwards commands as
1599 subclasses of _CommandInput. Add an input history and keymaps to those
1601 subclasses of _CommandInput. Add an input history and keymaps to those
1600 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1602 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1601 execute commands.
1603 execute commands.
1602
1604
1603 2006-06-07 Ville Vainio <vivainio@gmail.com>
1605 2006-06-07 Ville Vainio <vivainio@gmail.com>
1604
1606
1605 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1607 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1606 running the batch files instead of leaving the session open.
1608 running the batch files instead of leaving the session open.
1607
1609
1608 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1610 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1609
1611
1610 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1612 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1611 the original fix was incomplete. Patch submitted by W. Maier.
1613 the original fix was incomplete. Patch submitted by W. Maier.
1612
1614
1613 2006-06-07 Ville Vainio <vivainio@gmail.com>
1615 2006-06-07 Ville Vainio <vivainio@gmail.com>
1614
1616
1615 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1617 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1616 Confirmation prompts can be supressed by 'quiet' option.
1618 Confirmation prompts can be supressed by 'quiet' option.
1617 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1619 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1618
1620
1619 2006-06-06 *** Released version 0.7.2
1621 2006-06-06 *** Released version 0.7.2
1620
1622
1621 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1623 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1622
1624
1623 * IPython/Release.py (version): Made 0.7.2 final for release.
1625 * IPython/Release.py (version): Made 0.7.2 final for release.
1624 Repo tagged and release cut.
1626 Repo tagged and release cut.
1625
1627
1626 2006-06-05 Ville Vainio <vivainio@gmail.com>
1628 2006-06-05 Ville Vainio <vivainio@gmail.com>
1627
1629
1628 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1630 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1629 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1631 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1630
1632
1631 * upgrade_dir.py: try import 'path' module a bit harder
1633 * upgrade_dir.py: try import 'path' module a bit harder
1632 (for %upgrade)
1634 (for %upgrade)
1633
1635
1634 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1636 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1635
1637
1636 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1638 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1637 instead of looping 20 times.
1639 instead of looping 20 times.
1638
1640
1639 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1641 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1640 correctly at initialization time. Bug reported by Krishna Mohan
1642 correctly at initialization time. Bug reported by Krishna Mohan
1641 Gundu <gkmohan-AT-gmail.com> on the user list.
1643 Gundu <gkmohan-AT-gmail.com> on the user list.
1642
1644
1643 * IPython/Release.py (version): Mark 0.7.2 version to start
1645 * IPython/Release.py (version): Mark 0.7.2 version to start
1644 testing for release on 06/06.
1646 testing for release on 06/06.
1645
1647
1646 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1648 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1647
1649
1648 * scripts/irunner: thin script interface so users don't have to
1650 * scripts/irunner: thin script interface so users don't have to
1649 find the module and call it as an executable, since modules rarely
1651 find the module and call it as an executable, since modules rarely
1650 live in people's PATH.
1652 live in people's PATH.
1651
1653
1652 * IPython/irunner.py (InteractiveRunner.__init__): added
1654 * IPython/irunner.py (InteractiveRunner.__init__): added
1653 delaybeforesend attribute to control delays with newer versions of
1655 delaybeforesend attribute to control delays with newer versions of
1654 pexpect. Thanks to detailed help from pexpect's author, Noah
1656 pexpect. Thanks to detailed help from pexpect's author, Noah
1655 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1657 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1656 correctly (it works in NoColor mode).
1658 correctly (it works in NoColor mode).
1657
1659
1658 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1660 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1659 SAGE list, from improper log() calls.
1661 SAGE list, from improper log() calls.
1660
1662
1661 2006-05-31 Ville Vainio <vivainio@gmail.com>
1663 2006-05-31 Ville Vainio <vivainio@gmail.com>
1662
1664
1663 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1665 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1664 with args in parens to work correctly with dirs that have spaces.
1666 with args in parens to work correctly with dirs that have spaces.
1665
1667
1666 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1668 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1667
1669
1668 * IPython/Logger.py (Logger.logstart): add option to log raw input
1670 * IPython/Logger.py (Logger.logstart): add option to log raw input
1669 instead of the processed one. A -r flag was added to the
1671 instead of the processed one. A -r flag was added to the
1670 %logstart magic used for controlling logging.
1672 %logstart magic used for controlling logging.
1671
1673
1672 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1674 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1673
1675
1674 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1676 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1675 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1677 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1676 recognize the option. After a bug report by Will Maier. This
1678 recognize the option. After a bug report by Will Maier. This
1677 closes #64 (will do it after confirmation from W. Maier).
1679 closes #64 (will do it after confirmation from W. Maier).
1678
1680
1679 * IPython/irunner.py: New module to run scripts as if manually
1681 * IPython/irunner.py: New module to run scripts as if manually
1680 typed into an interactive environment, based on pexpect. After a
1682 typed into an interactive environment, based on pexpect. After a
1681 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1683 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1682 ipython-user list. Simple unittests in the tests/ directory.
1684 ipython-user list. Simple unittests in the tests/ directory.
1683
1685
1684 * tools/release: add Will Maier, OpenBSD port maintainer, to
1686 * tools/release: add Will Maier, OpenBSD port maintainer, to
1685 recepients list. We are now officially part of the OpenBSD ports:
1687 recepients list. We are now officially part of the OpenBSD ports:
1686 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1688 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1687 work.
1689 work.
1688
1690
1689 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1691 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1690
1692
1691 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1693 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1692 so that it doesn't break tkinter apps.
1694 so that it doesn't break tkinter apps.
1693
1695
1694 * IPython/iplib.py (_prefilter): fix bug where aliases would
1696 * IPython/iplib.py (_prefilter): fix bug where aliases would
1695 shadow variables when autocall was fully off. Reported by SAGE
1697 shadow variables when autocall was fully off. Reported by SAGE
1696 author William Stein.
1698 author William Stein.
1697
1699
1698 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1700 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1699 at what detail level strings are computed when foo? is requested.
1701 at what detail level strings are computed when foo? is requested.
1700 This allows users to ask for example that the string form of an
1702 This allows users to ask for example that the string form of an
1701 object is only computed when foo?? is called, or even never, by
1703 object is only computed when foo?? is called, or even never, by
1702 setting the object_info_string_level >= 2 in the configuration
1704 setting the object_info_string_level >= 2 in the configuration
1703 file. This new option has been added and documented. After a
1705 file. This new option has been added and documented. After a
1704 request by SAGE to be able to control the printing of very large
1706 request by SAGE to be able to control the printing of very large
1705 objects more easily.
1707 objects more easily.
1706
1708
1707 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1709 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1708
1710
1709 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1711 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1710 from sys.argv, to be 100% consistent with how Python itself works
1712 from sys.argv, to be 100% consistent with how Python itself works
1711 (as seen for example with python -i file.py). After a bug report
1713 (as seen for example with python -i file.py). After a bug report
1712 by Jeffrey Collins.
1714 by Jeffrey Collins.
1713
1715
1714 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1716 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1715 nasty bug which was preventing custom namespaces with -pylab,
1717 nasty bug which was preventing custom namespaces with -pylab,
1716 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1718 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1717 compatibility (long gone from mpl).
1719 compatibility (long gone from mpl).
1718
1720
1719 * IPython/ipapi.py (make_session): name change: create->make. We
1721 * IPython/ipapi.py (make_session): name change: create->make. We
1720 use make in other places (ipmaker,...), it's shorter and easier to
1722 use make in other places (ipmaker,...), it's shorter and easier to
1721 type and say, etc. I'm trying to clean things before 0.7.2 so
1723 type and say, etc. I'm trying to clean things before 0.7.2 so
1722 that I can keep things stable wrt to ipapi in the chainsaw branch.
1724 that I can keep things stable wrt to ipapi in the chainsaw branch.
1723
1725
1724 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1726 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1725 python-mode recognizes our debugger mode. Add support for
1727 python-mode recognizes our debugger mode. Add support for
1726 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1728 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1727 <m.liu.jin-AT-gmail.com> originally written by
1729 <m.liu.jin-AT-gmail.com> originally written by
1728 doxgen-AT-newsmth.net (with minor modifications for xemacs
1730 doxgen-AT-newsmth.net (with minor modifications for xemacs
1729 compatibility)
1731 compatibility)
1730
1732
1731 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1733 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1732 tracebacks when walking the stack so that the stack tracking system
1734 tracebacks when walking the stack so that the stack tracking system
1733 in emacs' python-mode can identify the frames correctly.
1735 in emacs' python-mode can identify the frames correctly.
1734
1736
1735 * IPython/ipmaker.py (make_IPython): make the internal (and
1737 * IPython/ipmaker.py (make_IPython): make the internal (and
1736 default config) autoedit_syntax value false by default. Too many
1738 default config) autoedit_syntax value false by default. Too many
1737 users have complained to me (both on and off-list) about problems
1739 users have complained to me (both on and off-list) about problems
1738 with this option being on by default, so I'm making it default to
1740 with this option being on by default, so I'm making it default to
1739 off. It can still be enabled by anyone via the usual mechanisms.
1741 off. It can still be enabled by anyone via the usual mechanisms.
1740
1742
1741 * IPython/completer.py (Completer.attr_matches): add support for
1743 * IPython/completer.py (Completer.attr_matches): add support for
1742 PyCrust-style _getAttributeNames magic method. Patch contributed
1744 PyCrust-style _getAttributeNames magic method. Patch contributed
1743 by <mscott-AT-goldenspud.com>. Closes #50.
1745 by <mscott-AT-goldenspud.com>. Closes #50.
1744
1746
1745 * IPython/iplib.py (InteractiveShell.__init__): remove the
1747 * IPython/iplib.py (InteractiveShell.__init__): remove the
1746 deletion of exit/quit from __builtin__, which can break
1748 deletion of exit/quit from __builtin__, which can break
1747 third-party tools like the Zope debugging console. The
1749 third-party tools like the Zope debugging console. The
1748 %exit/%quit magics remain. In general, it's probably a good idea
1750 %exit/%quit magics remain. In general, it's probably a good idea
1749 not to delete anything from __builtin__, since we never know what
1751 not to delete anything from __builtin__, since we never know what
1750 that will break. In any case, python now (for 2.5) will support
1752 that will break. In any case, python now (for 2.5) will support
1751 'real' exit/quit, so this issue is moot. Closes #55.
1753 'real' exit/quit, so this issue is moot. Closes #55.
1752
1754
1753 * IPython/genutils.py (with_obj): rename the 'with' function to
1755 * IPython/genutils.py (with_obj): rename the 'with' function to
1754 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1756 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1755 becomes a language keyword. Closes #53.
1757 becomes a language keyword. Closes #53.
1756
1758
1757 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1759 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1758 __file__ attribute to this so it fools more things into thinking
1760 __file__ attribute to this so it fools more things into thinking
1759 it is a real module. Closes #59.
1761 it is a real module. Closes #59.
1760
1762
1761 * IPython/Magic.py (magic_edit): add -n option to open the editor
1763 * IPython/Magic.py (magic_edit): add -n option to open the editor
1762 at a specific line number. After a patch by Stefan van der Walt.
1764 at a specific line number. After a patch by Stefan van der Walt.
1763
1765
1764 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1766 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1765
1767
1766 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1768 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1767 reason the file could not be opened. After automatic crash
1769 reason the file could not be opened. After automatic crash
1768 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1770 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1769 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1771 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1770 (_should_recompile): Don't fire editor if using %bg, since there
1772 (_should_recompile): Don't fire editor if using %bg, since there
1771 is no file in the first place. From the same report as above.
1773 is no file in the first place. From the same report as above.
1772 (raw_input): protect against faulty third-party prefilters. After
1774 (raw_input): protect against faulty third-party prefilters. After
1773 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1775 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1774 while running under SAGE.
1776 while running under SAGE.
1775
1777
1776 2006-05-23 Ville Vainio <vivainio@gmail.com>
1778 2006-05-23 Ville Vainio <vivainio@gmail.com>
1777
1779
1778 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1780 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1779 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1781 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1780 now returns None (again), unless dummy is specifically allowed by
1782 now returns None (again), unless dummy is specifically allowed by
1781 ipapi.get(allow_dummy=True).
1783 ipapi.get(allow_dummy=True).
1782
1784
1783 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1785 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1784
1786
1785 * IPython: remove all 2.2-compatibility objects and hacks from
1787 * IPython: remove all 2.2-compatibility objects and hacks from
1786 everywhere, since we only support 2.3 at this point. Docs
1788 everywhere, since we only support 2.3 at this point. Docs
1787 updated.
1789 updated.
1788
1790
1789 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1791 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1790 Anything requiring extra validation can be turned into a Python
1792 Anything requiring extra validation can be turned into a Python
1791 property in the future. I used a property for the db one b/c
1793 property in the future. I used a property for the db one b/c
1792 there was a nasty circularity problem with the initialization
1794 there was a nasty circularity problem with the initialization
1793 order, which right now I don't have time to clean up.
1795 order, which right now I don't have time to clean up.
1794
1796
1795 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1797 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1796 another locking bug reported by Jorgen. I'm not 100% sure though,
1798 another locking bug reported by Jorgen. I'm not 100% sure though,
1797 so more testing is needed...
1799 so more testing is needed...
1798
1800
1799 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1801 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1800
1802
1801 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1803 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1802 local variables from any routine in user code (typically executed
1804 local variables from any routine in user code (typically executed
1803 with %run) directly into the interactive namespace. Very useful
1805 with %run) directly into the interactive namespace. Very useful
1804 when doing complex debugging.
1806 when doing complex debugging.
1805 (IPythonNotRunning): Changed the default None object to a dummy
1807 (IPythonNotRunning): Changed the default None object to a dummy
1806 whose attributes can be queried as well as called without
1808 whose attributes can be queried as well as called without
1807 exploding, to ease writing code which works transparently both in
1809 exploding, to ease writing code which works transparently both in
1808 and out of ipython and uses some of this API.
1810 and out of ipython and uses some of this API.
1809
1811
1810 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1812 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1811
1813
1812 * IPython/hooks.py (result_display): Fix the fact that our display
1814 * IPython/hooks.py (result_display): Fix the fact that our display
1813 hook was using str() instead of repr(), as the default python
1815 hook was using str() instead of repr(), as the default python
1814 console does. This had gone unnoticed b/c it only happened if
1816 console does. This had gone unnoticed b/c it only happened if
1815 %Pprint was off, but the inconsistency was there.
1817 %Pprint was off, but the inconsistency was there.
1816
1818
1817 2006-05-15 Ville Vainio <vivainio@gmail.com>
1819 2006-05-15 Ville Vainio <vivainio@gmail.com>
1818
1820
1819 * Oinspect.py: Only show docstring for nonexisting/binary files
1821 * Oinspect.py: Only show docstring for nonexisting/binary files
1820 when doing object??, closing ticket #62
1822 when doing object??, closing ticket #62
1821
1823
1822 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1824 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1823
1825
1824 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1826 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1825 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1827 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1826 was being released in a routine which hadn't checked if it had
1828 was being released in a routine which hadn't checked if it had
1827 been the one to acquire it.
1829 been the one to acquire it.
1828
1830
1829 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1831 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1830
1832
1831 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1833 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1832
1834
1833 2006-04-11 Ville Vainio <vivainio@gmail.com>
1835 2006-04-11 Ville Vainio <vivainio@gmail.com>
1834
1836
1835 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1837 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1836 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1838 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1837 prefilters, allowing stuff like magics and aliases in the file.
1839 prefilters, allowing stuff like magics and aliases in the file.
1838
1840
1839 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1841 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1840 added. Supported now are "%clear in" and "%clear out" (clear input and
1842 added. Supported now are "%clear in" and "%clear out" (clear input and
1841 output history, respectively). Also fixed CachedOutput.flush to
1843 output history, respectively). Also fixed CachedOutput.flush to
1842 properly flush the output cache.
1844 properly flush the output cache.
1843
1845
1844 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1846 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1845 half-success (and fail explicitly).
1847 half-success (and fail explicitly).
1846
1848
1847 2006-03-28 Ville Vainio <vivainio@gmail.com>
1849 2006-03-28 Ville Vainio <vivainio@gmail.com>
1848
1850
1849 * iplib.py: Fix quoting of aliases so that only argless ones
1851 * iplib.py: Fix quoting of aliases so that only argless ones
1850 are quoted
1852 are quoted
1851
1853
1852 2006-03-28 Ville Vainio <vivainio@gmail.com>
1854 2006-03-28 Ville Vainio <vivainio@gmail.com>
1853
1855
1854 * iplib.py: Quote aliases with spaces in the name.
1856 * iplib.py: Quote aliases with spaces in the name.
1855 "c:\program files\blah\bin" is now legal alias target.
1857 "c:\program files\blah\bin" is now legal alias target.
1856
1858
1857 * ext_rehashdir.py: Space no longer allowed as arg
1859 * ext_rehashdir.py: Space no longer allowed as arg
1858 separator, since space is legal in path names.
1860 separator, since space is legal in path names.
1859
1861
1860 2006-03-16 Ville Vainio <vivainio@gmail.com>
1862 2006-03-16 Ville Vainio <vivainio@gmail.com>
1861
1863
1862 * upgrade_dir.py: Take path.py from Extensions, correcting
1864 * upgrade_dir.py: Take path.py from Extensions, correcting
1863 %upgrade magic
1865 %upgrade magic
1864
1866
1865 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1867 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1866
1868
1867 * hooks.py: Only enclose editor binary in quotes if legal and
1869 * hooks.py: Only enclose editor binary in quotes if legal and
1868 necessary (space in the name, and is an existing file). Fixes a bug
1870 necessary (space in the name, and is an existing file). Fixes a bug
1869 reported by Zachary Pincus.
1871 reported by Zachary Pincus.
1870
1872
1871 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1873 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1872
1874
1873 * Manual: thanks to a tip on proper color handling for Emacs, by
1875 * Manual: thanks to a tip on proper color handling for Emacs, by
1874 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1876 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1875
1877
1876 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1878 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1877 by applying the provided patch. Thanks to Liu Jin
1879 by applying the provided patch. Thanks to Liu Jin
1878 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1880 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1879 XEmacs/Linux, I'm trusting the submitter that it actually helps
1881 XEmacs/Linux, I'm trusting the submitter that it actually helps
1880 under win32/GNU Emacs. Will revisit if any problems are reported.
1882 under win32/GNU Emacs. Will revisit if any problems are reported.
1881
1883
1882 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1884 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1883
1885
1884 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1886 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1885 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1887 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1886
1888
1887 2006-03-12 Ville Vainio <vivainio@gmail.com>
1889 2006-03-12 Ville Vainio <vivainio@gmail.com>
1888
1890
1889 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1891 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1890 Torsten Marek.
1892 Torsten Marek.
1891
1893
1892 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1894 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1893
1895
1894 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1896 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1895 line ranges works again.
1897 line ranges works again.
1896
1898
1897 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1899 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1898
1900
1899 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1901 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1900 and friends, after a discussion with Zach Pincus on ipython-user.
1902 and friends, after a discussion with Zach Pincus on ipython-user.
1901 I'm not 100% sure, but after thinking about it quite a bit, it may
1903 I'm not 100% sure, but after thinking about it quite a bit, it may
1902 be OK. Testing with the multithreaded shells didn't reveal any
1904 be OK. Testing with the multithreaded shells didn't reveal any
1903 problems, but let's keep an eye out.
1905 problems, but let's keep an eye out.
1904
1906
1905 In the process, I fixed a few things which were calling
1907 In the process, I fixed a few things which were calling
1906 self.InteractiveTB() directly (like safe_execfile), which is a
1908 self.InteractiveTB() directly (like safe_execfile), which is a
1907 mistake: ALL exception reporting should be done by calling
1909 mistake: ALL exception reporting should be done by calling
1908 self.showtraceback(), which handles state and tab-completion and
1910 self.showtraceback(), which handles state and tab-completion and
1909 more.
1911 more.
1910
1912
1911 2006-03-01 Ville Vainio <vivainio@gmail.com>
1913 2006-03-01 Ville Vainio <vivainio@gmail.com>
1912
1914
1913 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1915 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1914 To use, do "from ipipe import *".
1916 To use, do "from ipipe import *".
1915
1917
1916 2006-02-24 Ville Vainio <vivainio@gmail.com>
1918 2006-02-24 Ville Vainio <vivainio@gmail.com>
1917
1919
1918 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1920 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1919 "cleanly" and safely than the older upgrade mechanism.
1921 "cleanly" and safely than the older upgrade mechanism.
1920
1922
1921 2006-02-21 Ville Vainio <vivainio@gmail.com>
1923 2006-02-21 Ville Vainio <vivainio@gmail.com>
1922
1924
1923 * Magic.py: %save works again.
1925 * Magic.py: %save works again.
1924
1926
1925 2006-02-15 Ville Vainio <vivainio@gmail.com>
1927 2006-02-15 Ville Vainio <vivainio@gmail.com>
1926
1928
1927 * Magic.py: %Pprint works again
1929 * Magic.py: %Pprint works again
1928
1930
1929 * Extensions/ipy_sane_defaults.py: Provide everything provided
1931 * Extensions/ipy_sane_defaults.py: Provide everything provided
1930 in default ipythonrc, to make it possible to have a completely empty
1932 in default ipythonrc, to make it possible to have a completely empty
1931 ipythonrc (and thus completely rc-file free configuration)
1933 ipythonrc (and thus completely rc-file free configuration)
1932
1934
1933 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1935 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1934
1936
1935 * IPython/hooks.py (editor): quote the call to the editor command,
1937 * IPython/hooks.py (editor): quote the call to the editor command,
1936 to allow commands with spaces in them. Problem noted by watching
1938 to allow commands with spaces in them. Problem noted by watching
1937 Ian Oswald's video about textpad under win32 at
1939 Ian Oswald's video about textpad under win32 at
1938 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1940 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1939
1941
1940 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1942 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1941 describing magics (we haven't used @ for a loong time).
1943 describing magics (we haven't used @ for a loong time).
1942
1944
1943 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1945 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1944 contributed by marienz to close
1946 contributed by marienz to close
1945 http://www.scipy.net/roundup/ipython/issue53.
1947 http://www.scipy.net/roundup/ipython/issue53.
1946
1948
1947 2006-02-10 Ville Vainio <vivainio@gmail.com>
1949 2006-02-10 Ville Vainio <vivainio@gmail.com>
1948
1950
1949 * genutils.py: getoutput now works in win32 too
1951 * genutils.py: getoutput now works in win32 too
1950
1952
1951 * completer.py: alias and magic completion only invoked
1953 * completer.py: alias and magic completion only invoked
1952 at the first "item" in the line, to avoid "cd %store"
1954 at the first "item" in the line, to avoid "cd %store"
1953 nonsense.
1955 nonsense.
1954
1956
1955 2006-02-09 Ville Vainio <vivainio@gmail.com>
1957 2006-02-09 Ville Vainio <vivainio@gmail.com>
1956
1958
1957 * test/*: Added a unit testing framework (finally).
1959 * test/*: Added a unit testing framework (finally).
1958 '%run runtests.py' to run test_*.
1960 '%run runtests.py' to run test_*.
1959
1961
1960 * ipapi.py: Exposed runlines and set_custom_exc
1962 * ipapi.py: Exposed runlines and set_custom_exc
1961
1963
1962 2006-02-07 Ville Vainio <vivainio@gmail.com>
1964 2006-02-07 Ville Vainio <vivainio@gmail.com>
1963
1965
1964 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1966 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1965 instead use "f(1 2)" as before.
1967 instead use "f(1 2)" as before.
1966
1968
1967 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1969 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1968
1970
1969 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1971 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1970 facilities, for demos processed by the IPython input filter
1972 facilities, for demos processed by the IPython input filter
1971 (IPythonDemo), and for running a script one-line-at-a-time as a
1973 (IPythonDemo), and for running a script one-line-at-a-time as a
1972 demo, both for pure Python (LineDemo) and for IPython-processed
1974 demo, both for pure Python (LineDemo) and for IPython-processed
1973 input (IPythonLineDemo). After a request by Dave Kohel, from the
1975 input (IPythonLineDemo). After a request by Dave Kohel, from the
1974 SAGE team.
1976 SAGE team.
1975 (Demo.edit): added an edit() method to the demo objects, to edit
1977 (Demo.edit): added an edit() method to the demo objects, to edit
1976 the in-memory copy of the last executed block.
1978 the in-memory copy of the last executed block.
1977
1979
1978 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1980 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1979 processing to %edit, %macro and %save. These commands can now be
1981 processing to %edit, %macro and %save. These commands can now be
1980 invoked on the unprocessed input as it was typed by the user
1982 invoked on the unprocessed input as it was typed by the user
1981 (without any prefilters applied). After requests by the SAGE team
1983 (without any prefilters applied). After requests by the SAGE team
1982 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1984 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1983
1985
1984 2006-02-01 Ville Vainio <vivainio@gmail.com>
1986 2006-02-01 Ville Vainio <vivainio@gmail.com>
1985
1987
1986 * setup.py, eggsetup.py: easy_install ipython==dev works
1988 * setup.py, eggsetup.py: easy_install ipython==dev works
1987 correctly now (on Linux)
1989 correctly now (on Linux)
1988
1990
1989 * ipy_user_conf,ipmaker: user config changes, removed spurious
1991 * ipy_user_conf,ipmaker: user config changes, removed spurious
1990 warnings
1992 warnings
1991
1993
1992 * iplib: if rc.banner is string, use it as is.
1994 * iplib: if rc.banner is string, use it as is.
1993
1995
1994 * Magic: %pycat accepts a string argument and pages it's contents.
1996 * Magic: %pycat accepts a string argument and pages it's contents.
1995
1997
1996
1998
1997 2006-01-30 Ville Vainio <vivainio@gmail.com>
1999 2006-01-30 Ville Vainio <vivainio@gmail.com>
1998
2000
1999 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
2001 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
2000 Now %store and bookmarks work through PickleShare, meaning that
2002 Now %store and bookmarks work through PickleShare, meaning that
2001 concurrent access is possible and all ipython sessions see the
2003 concurrent access is possible and all ipython sessions see the
2002 same database situation all the time, instead of snapshot of
2004 same database situation all the time, instead of snapshot of
2003 the situation when the session was started. Hence, %bookmark
2005 the situation when the session was started. Hence, %bookmark
2004 results are immediately accessible from othes sessions. The database
2006 results are immediately accessible from othes sessions. The database
2005 is also available for use by user extensions. See:
2007 is also available for use by user extensions. See:
2006 http://www.python.org/pypi/pickleshare
2008 http://www.python.org/pypi/pickleshare
2007
2009
2008 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
2010 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
2009
2011
2010 * aliases can now be %store'd
2012 * aliases can now be %store'd
2011
2013
2012 * path.py moved to Extensions so that pickleshare does not need
2014 * path.py moved to Extensions so that pickleshare does not need
2013 IPython-specific import. Extensions added to pythonpath right
2015 IPython-specific import. Extensions added to pythonpath right
2014 at __init__.
2016 at __init__.
2015
2017
2016 * iplib.py: ipalias deprecated/redundant; aliases are converted and
2018 * iplib.py: ipalias deprecated/redundant; aliases are converted and
2017 called with _ip.system and the pre-transformed command string.
2019 called with _ip.system and the pre-transformed command string.
2018
2020
2019 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
2021 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
2020
2022
2021 * IPython/iplib.py (interact): Fix that we were not catching
2023 * IPython/iplib.py (interact): Fix that we were not catching
2022 KeyboardInterrupt exceptions properly. I'm not quite sure why the
2024 KeyboardInterrupt exceptions properly. I'm not quite sure why the
2023 logic here had to change, but it's fixed now.
2025 logic here had to change, but it's fixed now.
2024
2026
2025 2006-01-29 Ville Vainio <vivainio@gmail.com>
2027 2006-01-29 Ville Vainio <vivainio@gmail.com>
2026
2028
2027 * iplib.py: Try to import pyreadline on Windows.
2029 * iplib.py: Try to import pyreadline on Windows.
2028
2030
2029 2006-01-27 Ville Vainio <vivainio@gmail.com>
2031 2006-01-27 Ville Vainio <vivainio@gmail.com>
2030
2032
2031 * iplib.py: Expose ipapi as _ip in builtin namespace.
2033 * iplib.py: Expose ipapi as _ip in builtin namespace.
2032 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
2034 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
2033 and ip_set_hook (-> _ip.set_hook) redundant. % and !
2035 and ip_set_hook (-> _ip.set_hook) redundant. % and !
2034 syntax now produce _ip.* variant of the commands.
2036 syntax now produce _ip.* variant of the commands.
2035
2037
2036 * "_ip.options().autoedit_syntax = 2" automatically throws
2038 * "_ip.options().autoedit_syntax = 2" automatically throws
2037 user to editor for syntax error correction without prompting.
2039 user to editor for syntax error correction without prompting.
2038
2040
2039 2006-01-27 Ville Vainio <vivainio@gmail.com>
2041 2006-01-27 Ville Vainio <vivainio@gmail.com>
2040
2042
2041 * ipmaker.py: Give "realistic" sys.argv for scripts (without
2043 * ipmaker.py: Give "realistic" sys.argv for scripts (without
2042 'ipython' at argv[0]) executed through command line.
2044 'ipython' at argv[0]) executed through command line.
2043 NOTE: this DEPRECATES calling ipython with multiple scripts
2045 NOTE: this DEPRECATES calling ipython with multiple scripts
2044 ("ipython a.py b.py c.py")
2046 ("ipython a.py b.py c.py")
2045
2047
2046 * iplib.py, hooks.py: Added configurable input prefilter,
2048 * iplib.py, hooks.py: Added configurable input prefilter,
2047 named 'input_prefilter'. See ext_rescapture.py for example
2049 named 'input_prefilter'. See ext_rescapture.py for example
2048 usage.
2050 usage.
2049
2051
2050 * ext_rescapture.py, Magic.py: Better system command output capture
2052 * ext_rescapture.py, Magic.py: Better system command output capture
2051 through 'var = !ls' (deprecates user-visible %sc). Same notation
2053 through 'var = !ls' (deprecates user-visible %sc). Same notation
2052 applies for magics, 'var = %alias' assigns alias list to var.
2054 applies for magics, 'var = %alias' assigns alias list to var.
2053
2055
2054 * ipapi.py: added meta() for accessing extension-usable data store.
2056 * ipapi.py: added meta() for accessing extension-usable data store.
2055
2057
2056 * iplib.py: added InteractiveShell.getapi(). New magics should be
2058 * iplib.py: added InteractiveShell.getapi(). New magics should be
2057 written doing self.getapi() instead of using the shell directly.
2059 written doing self.getapi() instead of using the shell directly.
2058
2060
2059 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
2061 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
2060 %store foo >> ~/myfoo.txt to store variables to files (in clean
2062 %store foo >> ~/myfoo.txt to store variables to files (in clean
2061 textual form, not a restorable pickle).
2063 textual form, not a restorable pickle).
2062
2064
2063 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
2065 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
2064
2066
2065 * usage.py, Magic.py: added %quickref
2067 * usage.py, Magic.py: added %quickref
2066
2068
2067 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
2069 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
2068
2070
2069 * GetoptErrors when invoking magics etc. with wrong args
2071 * GetoptErrors when invoking magics etc. with wrong args
2070 are now more helpful:
2072 are now more helpful:
2071 GetoptError: option -l not recognized (allowed: "qb" )
2073 GetoptError: option -l not recognized (allowed: "qb" )
2072
2074
2073 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
2075 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
2074
2076
2075 * IPython/demo.py (Demo.show): Flush stdout after each block, so
2077 * IPython/demo.py (Demo.show): Flush stdout after each block, so
2076 computationally intensive blocks don't appear to stall the demo.
2078 computationally intensive blocks don't appear to stall the demo.
2077
2079
2078 2006-01-24 Ville Vainio <vivainio@gmail.com>
2080 2006-01-24 Ville Vainio <vivainio@gmail.com>
2079
2081
2080 * iplib.py, hooks.py: 'result_display' hook can return a non-None
2082 * iplib.py, hooks.py: 'result_display' hook can return a non-None
2081 value to manipulate resulting history entry.
2083 value to manipulate resulting history entry.
2082
2084
2083 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
2085 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
2084 to instance methods of IPApi class, to make extending an embedded
2086 to instance methods of IPApi class, to make extending an embedded
2085 IPython feasible. See ext_rehashdir.py for example usage.
2087 IPython feasible. See ext_rehashdir.py for example usage.
2086
2088
2087 * Merged 1071-1076 from branches/0.7.1
2089 * Merged 1071-1076 from branches/0.7.1
2088
2090
2089
2091
2090 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
2092 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
2091
2093
2092 * tools/release (daystamp): Fix build tools to use the new
2094 * tools/release (daystamp): Fix build tools to use the new
2093 eggsetup.py script to build lightweight eggs.
2095 eggsetup.py script to build lightweight eggs.
2094
2096
2095 * Applied changesets 1062 and 1064 before 0.7.1 release.
2097 * Applied changesets 1062 and 1064 before 0.7.1 release.
2096
2098
2097 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
2099 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
2098 see the raw input history (without conversions like %ls ->
2100 see the raw input history (without conversions like %ls ->
2099 ipmagic("ls")). After a request from W. Stein, SAGE
2101 ipmagic("ls")). After a request from W. Stein, SAGE
2100 (http://modular.ucsd.edu/sage) developer. This information is
2102 (http://modular.ucsd.edu/sage) developer. This information is
2101 stored in the input_hist_raw attribute of the IPython instance, so
2103 stored in the input_hist_raw attribute of the IPython instance, so
2102 developers can access it if needed (it's an InputList instance).
2104 developers can access it if needed (it's an InputList instance).
2103
2105
2104 * Versionstring = 0.7.2.svn
2106 * Versionstring = 0.7.2.svn
2105
2107
2106 * eggsetup.py: A separate script for constructing eggs, creates
2108 * eggsetup.py: A separate script for constructing eggs, creates
2107 proper launch scripts even on Windows (an .exe file in
2109 proper launch scripts even on Windows (an .exe file in
2108 \python24\scripts).
2110 \python24\scripts).
2109
2111
2110 * ipapi.py: launch_new_instance, launch entry point needed for the
2112 * ipapi.py: launch_new_instance, launch entry point needed for the
2111 egg.
2113 egg.
2112
2114
2113 2006-01-23 Ville Vainio <vivainio@gmail.com>
2115 2006-01-23 Ville Vainio <vivainio@gmail.com>
2114
2116
2115 * Added %cpaste magic for pasting python code
2117 * Added %cpaste magic for pasting python code
2116
2118
2117 2006-01-22 Ville Vainio <vivainio@gmail.com>
2119 2006-01-22 Ville Vainio <vivainio@gmail.com>
2118
2120
2119 * Merge from branches/0.7.1 into trunk, revs 1052-1057
2121 * Merge from branches/0.7.1 into trunk, revs 1052-1057
2120
2122
2121 * Versionstring = 0.7.2.svn
2123 * Versionstring = 0.7.2.svn
2122
2124
2123 * eggsetup.py: A separate script for constructing eggs, creates
2125 * eggsetup.py: A separate script for constructing eggs, creates
2124 proper launch scripts even on Windows (an .exe file in
2126 proper launch scripts even on Windows (an .exe file in
2125 \python24\scripts).
2127 \python24\scripts).
2126
2128
2127 * ipapi.py: launch_new_instance, launch entry point needed for the
2129 * ipapi.py: launch_new_instance, launch entry point needed for the
2128 egg.
2130 egg.
2129
2131
2130 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
2132 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
2131
2133
2132 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
2134 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
2133 %pfile foo would print the file for foo even if it was a binary.
2135 %pfile foo would print the file for foo even if it was a binary.
2134 Now, extensions '.so' and '.dll' are skipped.
2136 Now, extensions '.so' and '.dll' are skipped.
2135
2137
2136 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
2138 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
2137 bug, where macros would fail in all threaded modes. I'm not 100%
2139 bug, where macros would fail in all threaded modes. I'm not 100%
2138 sure, so I'm going to put out an rc instead of making a release
2140 sure, so I'm going to put out an rc instead of making a release
2139 today, and wait for feedback for at least a few days.
2141 today, and wait for feedback for at least a few days.
2140
2142
2141 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
2143 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
2142 it...) the handling of pasting external code with autoindent on.
2144 it...) the handling of pasting external code with autoindent on.
2143 To get out of a multiline input, the rule will appear for most
2145 To get out of a multiline input, the rule will appear for most
2144 users unchanged: two blank lines or change the indent level
2146 users unchanged: two blank lines or change the indent level
2145 proposed by IPython. But there is a twist now: you can
2147 proposed by IPython. But there is a twist now: you can
2146 add/subtract only *one or two spaces*. If you add/subtract three
2148 add/subtract only *one or two spaces*. If you add/subtract three
2147 or more (unless you completely delete the line), IPython will
2149 or more (unless you completely delete the line), IPython will
2148 accept that line, and you'll need to enter a second one of pure
2150 accept that line, and you'll need to enter a second one of pure
2149 whitespace. I know it sounds complicated, but I can't find a
2151 whitespace. I know it sounds complicated, but I can't find a
2150 different solution that covers all the cases, with the right
2152 different solution that covers all the cases, with the right
2151 heuristics. Hopefully in actual use, nobody will really notice
2153 heuristics. Hopefully in actual use, nobody will really notice
2152 all these strange rules and things will 'just work'.
2154 all these strange rules and things will 'just work'.
2153
2155
2154 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
2156 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
2155
2157
2156 * IPython/iplib.py (interact): catch exceptions which can be
2158 * IPython/iplib.py (interact): catch exceptions which can be
2157 triggered asynchronously by signal handlers. Thanks to an
2159 triggered asynchronously by signal handlers. Thanks to an
2158 automatic crash report, submitted by Colin Kingsley
2160 automatic crash report, submitted by Colin Kingsley
2159 <tercel-AT-gentoo.org>.
2161 <tercel-AT-gentoo.org>.
2160
2162
2161 2006-01-20 Ville Vainio <vivainio@gmail.com>
2163 2006-01-20 Ville Vainio <vivainio@gmail.com>
2162
2164
2163 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
2165 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
2164 (%rehashdir, very useful, try it out) of how to extend ipython
2166 (%rehashdir, very useful, try it out) of how to extend ipython
2165 with new magics. Also added Extensions dir to pythonpath to make
2167 with new magics. Also added Extensions dir to pythonpath to make
2166 importing extensions easy.
2168 importing extensions easy.
2167
2169
2168 * %store now complains when trying to store interactively declared
2170 * %store now complains when trying to store interactively declared
2169 classes / instances of those classes.
2171 classes / instances of those classes.
2170
2172
2171 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
2173 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
2172 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
2174 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
2173 if they exist, and ipy_user_conf.py with some defaults is created for
2175 if they exist, and ipy_user_conf.py with some defaults is created for
2174 the user.
2176 the user.
2175
2177
2176 * Startup rehashing done by the config file, not InterpreterExec.
2178 * Startup rehashing done by the config file, not InterpreterExec.
2177 This means system commands are available even without selecting the
2179 This means system commands are available even without selecting the
2178 pysh profile. It's the sensible default after all.
2180 pysh profile. It's the sensible default after all.
2179
2181
2180 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
2182 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
2181
2183
2182 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
2184 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
2183 multiline code with autoindent on working. But I am really not
2185 multiline code with autoindent on working. But I am really not
2184 sure, so this needs more testing. Will commit a debug-enabled
2186 sure, so this needs more testing. Will commit a debug-enabled
2185 version for now, while I test it some more, so that Ville and
2187 version for now, while I test it some more, so that Ville and
2186 others may also catch any problems. Also made
2188 others may also catch any problems. Also made
2187 self.indent_current_str() a method, to ensure that there's no
2189 self.indent_current_str() a method, to ensure that there's no
2188 chance of the indent space count and the corresponding string
2190 chance of the indent space count and the corresponding string
2189 falling out of sync. All code needing the string should just call
2191 falling out of sync. All code needing the string should just call
2190 the method.
2192 the method.
2191
2193
2192 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
2194 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
2193
2195
2194 * IPython/Magic.py (magic_edit): fix check for when users don't
2196 * IPython/Magic.py (magic_edit): fix check for when users don't
2195 save their output files, the try/except was in the wrong section.
2197 save their output files, the try/except was in the wrong section.
2196
2198
2197 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
2199 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
2198
2200
2199 * IPython/Magic.py (magic_run): fix __file__ global missing from
2201 * IPython/Magic.py (magic_run): fix __file__ global missing from
2200 script's namespace when executed via %run. After a report by
2202 script's namespace when executed via %run. After a report by
2201 Vivian.
2203 Vivian.
2202
2204
2203 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
2205 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
2204 when using python 2.4. The parent constructor changed in 2.4, and
2206 when using python 2.4. The parent constructor changed in 2.4, and
2205 we need to track it directly (we can't call it, as it messes up
2207 we need to track it directly (we can't call it, as it messes up
2206 readline and tab-completion inside our pdb would stop working).
2208 readline and tab-completion inside our pdb would stop working).
2207 After a bug report by R. Bernstein <rocky-AT-panix.com>.
2209 After a bug report by R. Bernstein <rocky-AT-panix.com>.
2208
2210
2209 2006-01-16 Ville Vainio <vivainio@gmail.com>
2211 2006-01-16 Ville Vainio <vivainio@gmail.com>
2210
2212
2211 * Ipython/magic.py: Reverted back to old %edit functionality
2213 * Ipython/magic.py: Reverted back to old %edit functionality
2212 that returns file contents on exit.
2214 that returns file contents on exit.
2213
2215
2214 * IPython/path.py: Added Jason Orendorff's "path" module to
2216 * IPython/path.py: Added Jason Orendorff's "path" module to
2215 IPython tree, http://www.jorendorff.com/articles/python/path/.
2217 IPython tree, http://www.jorendorff.com/articles/python/path/.
2216 You can get path objects conveniently through %sc, and !!, e.g.:
2218 You can get path objects conveniently through %sc, and !!, e.g.:
2217 sc files=ls
2219 sc files=ls
2218 for p in files.paths: # or files.p
2220 for p in files.paths: # or files.p
2219 print p,p.mtime
2221 print p,p.mtime
2220
2222
2221 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
2223 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
2222 now work again without considering the exclusion regexp -
2224 now work again without considering the exclusion regexp -
2223 hence, things like ',foo my/path' turn to 'foo("my/path")'
2225 hence, things like ',foo my/path' turn to 'foo("my/path")'
2224 instead of syntax error.
2226 instead of syntax error.
2225
2227
2226
2228
2227 2006-01-14 Ville Vainio <vivainio@gmail.com>
2229 2006-01-14 Ville Vainio <vivainio@gmail.com>
2228
2230
2229 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
2231 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
2230 ipapi decorators for python 2.4 users, options() provides access to rc
2232 ipapi decorators for python 2.4 users, options() provides access to rc
2231 data.
2233 data.
2232
2234
2233 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
2235 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
2234 as path separators (even on Linux ;-). Space character after
2236 as path separators (even on Linux ;-). Space character after
2235 backslash (as yielded by tab completer) is still space;
2237 backslash (as yielded by tab completer) is still space;
2236 "%cd long\ name" works as expected.
2238 "%cd long\ name" works as expected.
2237
2239
2238 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
2240 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
2239 as "chain of command", with priority. API stays the same,
2241 as "chain of command", with priority. API stays the same,
2240 TryNext exception raised by a hook function signals that
2242 TryNext exception raised by a hook function signals that
2241 current hook failed and next hook should try handling it, as
2243 current hook failed and next hook should try handling it, as
2242 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
2244 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
2243 requested configurable display hook, which is now implemented.
2245 requested configurable display hook, which is now implemented.
2244
2246
2245 2006-01-13 Ville Vainio <vivainio@gmail.com>
2247 2006-01-13 Ville Vainio <vivainio@gmail.com>
2246
2248
2247 * IPython/platutils*.py: platform specific utility functions,
2249 * IPython/platutils*.py: platform specific utility functions,
2248 so far only set_term_title is implemented (change terminal
2250 so far only set_term_title is implemented (change terminal
2249 label in windowing systems). %cd now changes the title to
2251 label in windowing systems). %cd now changes the title to
2250 current dir.
2252 current dir.
2251
2253
2252 * IPython/Release.py: Added myself to "authors" list,
2254 * IPython/Release.py: Added myself to "authors" list,
2253 had to create new files.
2255 had to create new files.
2254
2256
2255 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
2257 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
2256 shell escape; not a known bug but had potential to be one in the
2258 shell escape; not a known bug but had potential to be one in the
2257 future.
2259 future.
2258
2260
2259 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
2261 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
2260 extension API for IPython! See the module for usage example. Fix
2262 extension API for IPython! See the module for usage example. Fix
2261 OInspect for docstring-less magic functions.
2263 OInspect for docstring-less magic functions.
2262
2264
2263
2265
2264 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
2266 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
2265
2267
2266 * IPython/iplib.py (raw_input): temporarily deactivate all
2268 * IPython/iplib.py (raw_input): temporarily deactivate all
2267 attempts at allowing pasting of code with autoindent on. It
2269 attempts at allowing pasting of code with autoindent on. It
2268 introduced bugs (reported by Prabhu) and I can't seem to find a
2270 introduced bugs (reported by Prabhu) and I can't seem to find a
2269 robust combination which works in all cases. Will have to revisit
2271 robust combination which works in all cases. Will have to revisit
2270 later.
2272 later.
2271
2273
2272 * IPython/genutils.py: remove isspace() function. We've dropped
2274 * IPython/genutils.py: remove isspace() function. We've dropped
2273 2.2 compatibility, so it's OK to use the string method.
2275 2.2 compatibility, so it's OK to use the string method.
2274
2276
2275 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2277 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2276
2278
2277 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
2279 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
2278 matching what NOT to autocall on, to include all python binary
2280 matching what NOT to autocall on, to include all python binary
2279 operators (including things like 'and', 'or', 'is' and 'in').
2281 operators (including things like 'and', 'or', 'is' and 'in').
2280 Prompted by a bug report on 'foo & bar', but I realized we had
2282 Prompted by a bug report on 'foo & bar', but I realized we had
2281 many more potential bug cases with other operators. The regexp is
2283 many more potential bug cases with other operators. The regexp is
2282 self.re_exclude_auto, it's fairly commented.
2284 self.re_exclude_auto, it's fairly commented.
2283
2285
2284 2006-01-12 Ville Vainio <vivainio@gmail.com>
2286 2006-01-12 Ville Vainio <vivainio@gmail.com>
2285
2287
2286 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
2288 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
2287 Prettified and hardened string/backslash quoting with ipsystem(),
2289 Prettified and hardened string/backslash quoting with ipsystem(),
2288 ipalias() and ipmagic(). Now even \ characters are passed to
2290 ipalias() and ipmagic(). Now even \ characters are passed to
2289 %magics, !shell escapes and aliases exactly as they are in the
2291 %magics, !shell escapes and aliases exactly as they are in the
2290 ipython command line. Should improve backslash experience,
2292 ipython command line. Should improve backslash experience,
2291 particularly in Windows (path delimiter for some commands that
2293 particularly in Windows (path delimiter for some commands that
2292 won't understand '/'), but Unix benefits as well (regexps). %cd
2294 won't understand '/'), but Unix benefits as well (regexps). %cd
2293 magic still doesn't support backslash path delimiters, though. Also
2295 magic still doesn't support backslash path delimiters, though. Also
2294 deleted all pretense of supporting multiline command strings in
2296 deleted all pretense of supporting multiline command strings in
2295 !system or %magic commands. Thanks to Jerry McRae for suggestions.
2297 !system or %magic commands. Thanks to Jerry McRae for suggestions.
2296
2298
2297 * doc/build_doc_instructions.txt added. Documentation on how to
2299 * doc/build_doc_instructions.txt added. Documentation on how to
2298 use doc/update_manual.py, added yesterday. Both files contributed
2300 use doc/update_manual.py, added yesterday. Both files contributed
2299 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
2301 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
2300 doc/*.sh for deprecation at a later date.
2302 doc/*.sh for deprecation at a later date.
2301
2303
2302 * /ipython.py Added ipython.py to root directory for
2304 * /ipython.py Added ipython.py to root directory for
2303 zero-installation (tar xzvf ipython.tgz; cd ipython; python
2305 zero-installation (tar xzvf ipython.tgz; cd ipython; python
2304 ipython.py) and development convenience (no need to keep doing
2306 ipython.py) and development convenience (no need to keep doing
2305 "setup.py install" between changes).
2307 "setup.py install" between changes).
2306
2308
2307 * Made ! and !! shell escapes work (again) in multiline expressions:
2309 * Made ! and !! shell escapes work (again) in multiline expressions:
2308 if 1:
2310 if 1:
2309 !ls
2311 !ls
2310 !!ls
2312 !!ls
2311
2313
2312 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2314 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
2313
2315
2314 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
2316 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
2315 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
2317 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
2316 module in case-insensitive installation. Was causing crashes
2318 module in case-insensitive installation. Was causing crashes
2317 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
2319 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
2318
2320
2319 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
2321 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
2320 <marienz-AT-gentoo.org>, closes
2322 <marienz-AT-gentoo.org>, closes
2321 http://www.scipy.net/roundup/ipython/issue51.
2323 http://www.scipy.net/roundup/ipython/issue51.
2322
2324
2323 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
2325 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
2324
2326
2325 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
2327 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
2326 problem of excessive CPU usage under *nix and keyboard lag under
2328 problem of excessive CPU usage under *nix and keyboard lag under
2327 win32.
2329 win32.
2328
2330
2329 2006-01-10 *** Released version 0.7.0
2331 2006-01-10 *** Released version 0.7.0
2330
2332
2331 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
2333 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
2332
2334
2333 * IPython/Release.py (revision): tag version number to 0.7.0,
2335 * IPython/Release.py (revision): tag version number to 0.7.0,
2334 ready for release.
2336 ready for release.
2335
2337
2336 * IPython/Magic.py (magic_edit): Add print statement to %edit so
2338 * IPython/Magic.py (magic_edit): Add print statement to %edit so
2337 it informs the user of the name of the temp. file used. This can
2339 it informs the user of the name of the temp. file used. This can
2338 help if you decide later to reuse that same file, so you know
2340 help if you decide later to reuse that same file, so you know
2339 where to copy the info from.
2341 where to copy the info from.
2340
2342
2341 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
2343 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
2342
2344
2343 * setup_bdist_egg.py: little script to build an egg. Added
2345 * setup_bdist_egg.py: little script to build an egg. Added
2344 support in the release tools as well.
2346 support in the release tools as well.
2345
2347
2346 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
2348 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
2347
2349
2348 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
2350 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
2349 version selection (new -wxversion command line and ipythonrc
2351 version selection (new -wxversion command line and ipythonrc
2350 parameter). Patch contributed by Arnd Baecker
2352 parameter). Patch contributed by Arnd Baecker
2351 <arnd.baecker-AT-web.de>.
2353 <arnd.baecker-AT-web.de>.
2352
2354
2353 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2355 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2354 embedded instances, for variables defined at the interactive
2356 embedded instances, for variables defined at the interactive
2355 prompt of the embedded ipython. Reported by Arnd.
2357 prompt of the embedded ipython. Reported by Arnd.
2356
2358
2357 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2359 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2358 it can be used as a (stateful) toggle, or with a direct parameter.
2360 it can be used as a (stateful) toggle, or with a direct parameter.
2359
2361
2360 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2362 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2361 could be triggered in certain cases and cause the traceback
2363 could be triggered in certain cases and cause the traceback
2362 printer not to work.
2364 printer not to work.
2363
2365
2364 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2366 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2365
2367
2366 * IPython/iplib.py (_should_recompile): Small fix, closes
2368 * IPython/iplib.py (_should_recompile): Small fix, closes
2367 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2369 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2368
2370
2369 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2371 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2370
2372
2371 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2373 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2372 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2374 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2373 Moad for help with tracking it down.
2375 Moad for help with tracking it down.
2374
2376
2375 * IPython/iplib.py (handle_auto): fix autocall handling for
2377 * IPython/iplib.py (handle_auto): fix autocall handling for
2376 objects which support BOTH __getitem__ and __call__ (so that f [x]
2378 objects which support BOTH __getitem__ and __call__ (so that f [x]
2377 is left alone, instead of becoming f([x]) automatically).
2379 is left alone, instead of becoming f([x]) automatically).
2378
2380
2379 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2381 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2380 Ville's patch.
2382 Ville's patch.
2381
2383
2382 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2384 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2383
2385
2384 * IPython/iplib.py (handle_auto): changed autocall semantics to
2386 * IPython/iplib.py (handle_auto): changed autocall semantics to
2385 include 'smart' mode, where the autocall transformation is NOT
2387 include 'smart' mode, where the autocall transformation is NOT
2386 applied if there are no arguments on the line. This allows you to
2388 applied if there are no arguments on the line. This allows you to
2387 just type 'foo' if foo is a callable to see its internal form,
2389 just type 'foo' if foo is a callable to see its internal form,
2388 instead of having it called with no arguments (typically a
2390 instead of having it called with no arguments (typically a
2389 mistake). The old 'full' autocall still exists: for that, you
2391 mistake). The old 'full' autocall still exists: for that, you
2390 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2392 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2391
2393
2392 * IPython/completer.py (Completer.attr_matches): add
2394 * IPython/completer.py (Completer.attr_matches): add
2393 tab-completion support for Enthoughts' traits. After a report by
2395 tab-completion support for Enthoughts' traits. After a report by
2394 Arnd and a patch by Prabhu.
2396 Arnd and a patch by Prabhu.
2395
2397
2396 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2398 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2397
2399
2398 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2400 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2399 Schmolck's patch to fix inspect.getinnerframes().
2401 Schmolck's patch to fix inspect.getinnerframes().
2400
2402
2401 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2403 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2402 for embedded instances, regarding handling of namespaces and items
2404 for embedded instances, regarding handling of namespaces and items
2403 added to the __builtin__ one. Multiple embedded instances and
2405 added to the __builtin__ one. Multiple embedded instances and
2404 recursive embeddings should work better now (though I'm not sure
2406 recursive embeddings should work better now (though I'm not sure
2405 I've got all the corner cases fixed, that code is a bit of a brain
2407 I've got all the corner cases fixed, that code is a bit of a brain
2406 twister).
2408 twister).
2407
2409
2408 * IPython/Magic.py (magic_edit): added support to edit in-memory
2410 * IPython/Magic.py (magic_edit): added support to edit in-memory
2409 macros (automatically creates the necessary temp files). %edit
2411 macros (automatically creates the necessary temp files). %edit
2410 also doesn't return the file contents anymore, it's just noise.
2412 also doesn't return the file contents anymore, it's just noise.
2411
2413
2412 * IPython/completer.py (Completer.attr_matches): revert change to
2414 * IPython/completer.py (Completer.attr_matches): revert change to
2413 complete only on attributes listed in __all__. I realized it
2415 complete only on attributes listed in __all__. I realized it
2414 cripples the tab-completion system as a tool for exploring the
2416 cripples the tab-completion system as a tool for exploring the
2415 internals of unknown libraries (it renders any non-__all__
2417 internals of unknown libraries (it renders any non-__all__
2416 attribute off-limits). I got bit by this when trying to see
2418 attribute off-limits). I got bit by this when trying to see
2417 something inside the dis module.
2419 something inside the dis module.
2418
2420
2419 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2421 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2420
2422
2421 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2423 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2422 namespace for users and extension writers to hold data in. This
2424 namespace for users and extension writers to hold data in. This
2423 follows the discussion in
2425 follows the discussion in
2424 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2426 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2425
2427
2426 * IPython/completer.py (IPCompleter.complete): small patch to help
2428 * IPython/completer.py (IPCompleter.complete): small patch to help
2427 tab-completion under Emacs, after a suggestion by John Barnard
2429 tab-completion under Emacs, after a suggestion by John Barnard
2428 <barnarj-AT-ccf.org>.
2430 <barnarj-AT-ccf.org>.
2429
2431
2430 * IPython/Magic.py (Magic.extract_input_slices): added support for
2432 * IPython/Magic.py (Magic.extract_input_slices): added support for
2431 the slice notation in magics to use N-M to represent numbers N...M
2433 the slice notation in magics to use N-M to represent numbers N...M
2432 (closed endpoints). This is used by %macro and %save.
2434 (closed endpoints). This is used by %macro and %save.
2433
2435
2434 * IPython/completer.py (Completer.attr_matches): for modules which
2436 * IPython/completer.py (Completer.attr_matches): for modules which
2435 define __all__, complete only on those. After a patch by Jeffrey
2437 define __all__, complete only on those. After a patch by Jeffrey
2436 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2438 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2437 speed up this routine.
2439 speed up this routine.
2438
2440
2439 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2441 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2440 don't know if this is the end of it, but the behavior now is
2442 don't know if this is the end of it, but the behavior now is
2441 certainly much more correct. Note that coupled with macros,
2443 certainly much more correct. Note that coupled with macros,
2442 slightly surprising (at first) behavior may occur: a macro will in
2444 slightly surprising (at first) behavior may occur: a macro will in
2443 general expand to multiple lines of input, so upon exiting, the
2445 general expand to multiple lines of input, so upon exiting, the
2444 in/out counters will both be bumped by the corresponding amount
2446 in/out counters will both be bumped by the corresponding amount
2445 (as if the macro's contents had been typed interactively). Typing
2447 (as if the macro's contents had been typed interactively). Typing
2446 %hist will reveal the intermediate (silently processed) lines.
2448 %hist will reveal the intermediate (silently processed) lines.
2447
2449
2448 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2450 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2449 pickle to fail (%run was overwriting __main__ and not restoring
2451 pickle to fail (%run was overwriting __main__ and not restoring
2450 it, but pickle relies on __main__ to operate).
2452 it, but pickle relies on __main__ to operate).
2451
2453
2452 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2454 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2453 using properties, but forgot to make the main InteractiveShell
2455 using properties, but forgot to make the main InteractiveShell
2454 class a new-style class. Properties fail silently, and
2456 class a new-style class. Properties fail silently, and
2455 mysteriously, with old-style class (getters work, but
2457 mysteriously, with old-style class (getters work, but
2456 setters don't do anything).
2458 setters don't do anything).
2457
2459
2458 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2460 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2459
2461
2460 * IPython/Magic.py (magic_history): fix history reporting bug (I
2462 * IPython/Magic.py (magic_history): fix history reporting bug (I
2461 know some nasties are still there, I just can't seem to find a
2463 know some nasties are still there, I just can't seem to find a
2462 reproducible test case to track them down; the input history is
2464 reproducible test case to track them down; the input history is
2463 falling out of sync...)
2465 falling out of sync...)
2464
2466
2465 * IPython/iplib.py (handle_shell_escape): fix bug where both
2467 * IPython/iplib.py (handle_shell_escape): fix bug where both
2466 aliases and system accesses where broken for indented code (such
2468 aliases and system accesses where broken for indented code (such
2467 as loops).
2469 as loops).
2468
2470
2469 * IPython/genutils.py (shell): fix small but critical bug for
2471 * IPython/genutils.py (shell): fix small but critical bug for
2470 win32 system access.
2472 win32 system access.
2471
2473
2472 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2474 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2473
2475
2474 * IPython/iplib.py (showtraceback): remove use of the
2476 * IPython/iplib.py (showtraceback): remove use of the
2475 sys.last_{type/value/traceback} structures, which are non
2477 sys.last_{type/value/traceback} structures, which are non
2476 thread-safe.
2478 thread-safe.
2477 (_prefilter): change control flow to ensure that we NEVER
2479 (_prefilter): change control flow to ensure that we NEVER
2478 introspect objects when autocall is off. This will guarantee that
2480 introspect objects when autocall is off. This will guarantee that
2479 having an input line of the form 'x.y', where access to attribute
2481 having an input line of the form 'x.y', where access to attribute
2480 'y' has side effects, doesn't trigger the side effect TWICE. It
2482 'y' has side effects, doesn't trigger the side effect TWICE. It
2481 is important to note that, with autocall on, these side effects
2483 is important to note that, with autocall on, these side effects
2482 can still happen.
2484 can still happen.
2483 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2485 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2484 trio. IPython offers these three kinds of special calls which are
2486 trio. IPython offers these three kinds of special calls which are
2485 not python code, and it's a good thing to have their call method
2487 not python code, and it's a good thing to have their call method
2486 be accessible as pure python functions (not just special syntax at
2488 be accessible as pure python functions (not just special syntax at
2487 the command line). It gives us a better internal implementation
2489 the command line). It gives us a better internal implementation
2488 structure, as well as exposing these for user scripting more
2490 structure, as well as exposing these for user scripting more
2489 cleanly.
2491 cleanly.
2490
2492
2491 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2493 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2492 file. Now that they'll be more likely to be used with the
2494 file. Now that they'll be more likely to be used with the
2493 persistance system (%store), I want to make sure their module path
2495 persistance system (%store), I want to make sure their module path
2494 doesn't change in the future, so that we don't break things for
2496 doesn't change in the future, so that we don't break things for
2495 users' persisted data.
2497 users' persisted data.
2496
2498
2497 * IPython/iplib.py (autoindent_update): move indentation
2499 * IPython/iplib.py (autoindent_update): move indentation
2498 management into the _text_ processing loop, not the keyboard
2500 management into the _text_ processing loop, not the keyboard
2499 interactive one. This is necessary to correctly process non-typed
2501 interactive one. This is necessary to correctly process non-typed
2500 multiline input (such as macros).
2502 multiline input (such as macros).
2501
2503
2502 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2504 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2503 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2505 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2504 which was producing problems in the resulting manual.
2506 which was producing problems in the resulting manual.
2505 (magic_whos): improve reporting of instances (show their class,
2507 (magic_whos): improve reporting of instances (show their class,
2506 instead of simply printing 'instance' which isn't terribly
2508 instead of simply printing 'instance' which isn't terribly
2507 informative).
2509 informative).
2508
2510
2509 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2511 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2510 (minor mods) to support network shares under win32.
2512 (minor mods) to support network shares under win32.
2511
2513
2512 * IPython/winconsole.py (get_console_size): add new winconsole
2514 * IPython/winconsole.py (get_console_size): add new winconsole
2513 module and fixes to page_dumb() to improve its behavior under
2515 module and fixes to page_dumb() to improve its behavior under
2514 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2516 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2515
2517
2516 * IPython/Magic.py (Macro): simplified Macro class to just
2518 * IPython/Magic.py (Macro): simplified Macro class to just
2517 subclass list. We've had only 2.2 compatibility for a very long
2519 subclass list. We've had only 2.2 compatibility for a very long
2518 time, yet I was still avoiding subclassing the builtin types. No
2520 time, yet I was still avoiding subclassing the builtin types. No
2519 more (I'm also starting to use properties, though I won't shift to
2521 more (I'm also starting to use properties, though I won't shift to
2520 2.3-specific features quite yet).
2522 2.3-specific features quite yet).
2521 (magic_store): added Ville's patch for lightweight variable
2523 (magic_store): added Ville's patch for lightweight variable
2522 persistence, after a request on the user list by Matt Wilkie
2524 persistence, after a request on the user list by Matt Wilkie
2523 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2525 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2524 details.
2526 details.
2525
2527
2526 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2528 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2527 changed the default logfile name from 'ipython.log' to
2529 changed the default logfile name from 'ipython.log' to
2528 'ipython_log.py'. These logs are real python files, and now that
2530 'ipython_log.py'. These logs are real python files, and now that
2529 we have much better multiline support, people are more likely to
2531 we have much better multiline support, people are more likely to
2530 want to use them as such. Might as well name them correctly.
2532 want to use them as such. Might as well name them correctly.
2531
2533
2532 * IPython/Magic.py: substantial cleanup. While we can't stop
2534 * IPython/Magic.py: substantial cleanup. While we can't stop
2533 using magics as mixins, due to the existing customizations 'out
2535 using magics as mixins, due to the existing customizations 'out
2534 there' which rely on the mixin naming conventions, at least I
2536 there' which rely on the mixin naming conventions, at least I
2535 cleaned out all cross-class name usage. So once we are OK with
2537 cleaned out all cross-class name usage. So once we are OK with
2536 breaking compatibility, the two systems can be separated.
2538 breaking compatibility, the two systems can be separated.
2537
2539
2538 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2540 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2539 anymore, and the class is a fair bit less hideous as well. New
2541 anymore, and the class is a fair bit less hideous as well. New
2540 features were also introduced: timestamping of input, and logging
2542 features were also introduced: timestamping of input, and logging
2541 of output results. These are user-visible with the -t and -o
2543 of output results. These are user-visible with the -t and -o
2542 options to %logstart. Closes
2544 options to %logstart. Closes
2543 http://www.scipy.net/roundup/ipython/issue11 and a request by
2545 http://www.scipy.net/roundup/ipython/issue11 and a request by
2544 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2546 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2545
2547
2546 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2548 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2547
2549
2548 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2550 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2549 better handle backslashes in paths. See the thread 'More Windows
2551 better handle backslashes in paths. See the thread 'More Windows
2550 questions part 2 - \/ characters revisited' on the iypthon user
2552 questions part 2 - \/ characters revisited' on the iypthon user
2551 list:
2553 list:
2552 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2554 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2553
2555
2554 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2556 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2555
2557
2556 (InteractiveShell.__init__): change threaded shells to not use the
2558 (InteractiveShell.__init__): change threaded shells to not use the
2557 ipython crash handler. This was causing more problems than not,
2559 ipython crash handler. This was causing more problems than not,
2558 as exceptions in the main thread (GUI code, typically) would
2560 as exceptions in the main thread (GUI code, typically) would
2559 always show up as a 'crash', when they really weren't.
2561 always show up as a 'crash', when they really weren't.
2560
2562
2561 The colors and exception mode commands (%colors/%xmode) have been
2563 The colors and exception mode commands (%colors/%xmode) have been
2562 synchronized to also take this into account, so users can get
2564 synchronized to also take this into account, so users can get
2563 verbose exceptions for their threaded code as well. I also added
2565 verbose exceptions for their threaded code as well. I also added
2564 support for activating pdb inside this exception handler as well,
2566 support for activating pdb inside this exception handler as well,
2565 so now GUI authors can use IPython's enhanced pdb at runtime.
2567 so now GUI authors can use IPython's enhanced pdb at runtime.
2566
2568
2567 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2569 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2568 true by default, and add it to the shipped ipythonrc file. Since
2570 true by default, and add it to the shipped ipythonrc file. Since
2569 this asks the user before proceeding, I think it's OK to make it
2571 this asks the user before proceeding, I think it's OK to make it
2570 true by default.
2572 true by default.
2571
2573
2572 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2574 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2573 of the previous special-casing of input in the eval loop. I think
2575 of the previous special-casing of input in the eval loop. I think
2574 this is cleaner, as they really are commands and shouldn't have
2576 this is cleaner, as they really are commands and shouldn't have
2575 a special role in the middle of the core code.
2577 a special role in the middle of the core code.
2576
2578
2577 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2579 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2578
2580
2579 * IPython/iplib.py (edit_syntax_error): added support for
2581 * IPython/iplib.py (edit_syntax_error): added support for
2580 automatically reopening the editor if the file had a syntax error
2582 automatically reopening the editor if the file had a syntax error
2581 in it. Thanks to scottt who provided the patch at:
2583 in it. Thanks to scottt who provided the patch at:
2582 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2584 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2583 version committed).
2585 version committed).
2584
2586
2585 * IPython/iplib.py (handle_normal): add suport for multi-line
2587 * IPython/iplib.py (handle_normal): add suport for multi-line
2586 input with emtpy lines. This fixes
2588 input with emtpy lines. This fixes
2587 http://www.scipy.net/roundup/ipython/issue43 and a similar
2589 http://www.scipy.net/roundup/ipython/issue43 and a similar
2588 discussion on the user list.
2590 discussion on the user list.
2589
2591
2590 WARNING: a behavior change is necessarily introduced to support
2592 WARNING: a behavior change is necessarily introduced to support
2591 blank lines: now a single blank line with whitespace does NOT
2593 blank lines: now a single blank line with whitespace does NOT
2592 break the input loop, which means that when autoindent is on, by
2594 break the input loop, which means that when autoindent is on, by
2593 default hitting return on the next (indented) line does NOT exit.
2595 default hitting return on the next (indented) line does NOT exit.
2594
2596
2595 Instead, to exit a multiline input you can either have:
2597 Instead, to exit a multiline input you can either have:
2596
2598
2597 - TWO whitespace lines (just hit return again), or
2599 - TWO whitespace lines (just hit return again), or
2598 - a single whitespace line of a different length than provided
2600 - a single whitespace line of a different length than provided
2599 by the autoindent (add or remove a space).
2601 by the autoindent (add or remove a space).
2600
2602
2601 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2603 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2602 module to better organize all readline-related functionality.
2604 module to better organize all readline-related functionality.
2603 I've deleted FlexCompleter and put all completion clases here.
2605 I've deleted FlexCompleter and put all completion clases here.
2604
2606
2605 * IPython/iplib.py (raw_input): improve indentation management.
2607 * IPython/iplib.py (raw_input): improve indentation management.
2606 It is now possible to paste indented code with autoindent on, and
2608 It is now possible to paste indented code with autoindent on, and
2607 the code is interpreted correctly (though it still looks bad on
2609 the code is interpreted correctly (though it still looks bad on
2608 screen, due to the line-oriented nature of ipython).
2610 screen, due to the line-oriented nature of ipython).
2609 (MagicCompleter.complete): change behavior so that a TAB key on an
2611 (MagicCompleter.complete): change behavior so that a TAB key on an
2610 otherwise empty line actually inserts a tab, instead of completing
2612 otherwise empty line actually inserts a tab, instead of completing
2611 on the entire global namespace. This makes it easier to use the
2613 on the entire global namespace. This makes it easier to use the
2612 TAB key for indentation. After a request by Hans Meine
2614 TAB key for indentation. After a request by Hans Meine
2613 <hans_meine-AT-gmx.net>
2615 <hans_meine-AT-gmx.net>
2614 (_prefilter): add support so that typing plain 'exit' or 'quit'
2616 (_prefilter): add support so that typing plain 'exit' or 'quit'
2615 does a sensible thing. Originally I tried to deviate as little as
2617 does a sensible thing. Originally I tried to deviate as little as
2616 possible from the default python behavior, but even that one may
2618 possible from the default python behavior, but even that one may
2617 change in this direction (thread on python-dev to that effect).
2619 change in this direction (thread on python-dev to that effect).
2618 Regardless, ipython should do the right thing even if CPython's
2620 Regardless, ipython should do the right thing even if CPython's
2619 '>>>' prompt doesn't.
2621 '>>>' prompt doesn't.
2620 (InteractiveShell): removed subclassing code.InteractiveConsole
2622 (InteractiveShell): removed subclassing code.InteractiveConsole
2621 class. By now we'd overridden just about all of its methods: I've
2623 class. By now we'd overridden just about all of its methods: I've
2622 copied the remaining two over, and now ipython is a standalone
2624 copied the remaining two over, and now ipython is a standalone
2623 class. This will provide a clearer picture for the chainsaw
2625 class. This will provide a clearer picture for the chainsaw
2624 branch refactoring.
2626 branch refactoring.
2625
2627
2626 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2628 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2627
2629
2628 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2630 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2629 failures for objects which break when dir() is called on them.
2631 failures for objects which break when dir() is called on them.
2630
2632
2631 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2633 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2632 distinct local and global namespaces in the completer API. This
2634 distinct local and global namespaces in the completer API. This
2633 change allows us to properly handle completion with distinct
2635 change allows us to properly handle completion with distinct
2634 scopes, including in embedded instances (this had never really
2636 scopes, including in embedded instances (this had never really
2635 worked correctly).
2637 worked correctly).
2636
2638
2637 Note: this introduces a change in the constructor for
2639 Note: this introduces a change in the constructor for
2638 MagicCompleter, as a new global_namespace parameter is now the
2640 MagicCompleter, as a new global_namespace parameter is now the
2639 second argument (the others were bumped one position).
2641 second argument (the others were bumped one position).
2640
2642
2641 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2643 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2642
2644
2643 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2645 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2644 embedded instances (which can be done now thanks to Vivian's
2646 embedded instances (which can be done now thanks to Vivian's
2645 frame-handling fixes for pdb).
2647 frame-handling fixes for pdb).
2646 (InteractiveShell.__init__): Fix namespace handling problem in
2648 (InteractiveShell.__init__): Fix namespace handling problem in
2647 embedded instances. We were overwriting __main__ unconditionally,
2649 embedded instances. We were overwriting __main__ unconditionally,
2648 and this should only be done for 'full' (non-embedded) IPython;
2650 and this should only be done for 'full' (non-embedded) IPython;
2649 embedded instances must respect the caller's __main__. Thanks to
2651 embedded instances must respect the caller's __main__. Thanks to
2650 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2652 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2651
2653
2652 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2654 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2653
2655
2654 * setup.py: added download_url to setup(). This registers the
2656 * setup.py: added download_url to setup(). This registers the
2655 download address at PyPI, which is not only useful to humans
2657 download address at PyPI, which is not only useful to humans
2656 browsing the site, but is also picked up by setuptools (the Eggs
2658 browsing the site, but is also picked up by setuptools (the Eggs
2657 machinery). Thanks to Ville and R. Kern for the info/discussion
2659 machinery). Thanks to Ville and R. Kern for the info/discussion
2658 on this.
2660 on this.
2659
2661
2660 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2662 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2661
2663
2662 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2664 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2663 This brings a lot of nice functionality to the pdb mode, which now
2665 This brings a lot of nice functionality to the pdb mode, which now
2664 has tab-completion, syntax highlighting, and better stack handling
2666 has tab-completion, syntax highlighting, and better stack handling
2665 than before. Many thanks to Vivian De Smedt
2667 than before. Many thanks to Vivian De Smedt
2666 <vivian-AT-vdesmedt.com> for the original patches.
2668 <vivian-AT-vdesmedt.com> for the original patches.
2667
2669
2668 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2670 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2669
2671
2670 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2672 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2671 sequence to consistently accept the banner argument. The
2673 sequence to consistently accept the banner argument. The
2672 inconsistency was tripping SAGE, thanks to Gary Zablackis
2674 inconsistency was tripping SAGE, thanks to Gary Zablackis
2673 <gzabl-AT-yahoo.com> for the report.
2675 <gzabl-AT-yahoo.com> for the report.
2674
2676
2675 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2677 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2676
2678
2677 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2679 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2678 Fix bug where a naked 'alias' call in the ipythonrc file would
2680 Fix bug where a naked 'alias' call in the ipythonrc file would
2679 cause a crash. Bug reported by Jorgen Stenarson.
2681 cause a crash. Bug reported by Jorgen Stenarson.
2680
2682
2681 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2683 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2682
2684
2683 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2685 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2684 startup time.
2686 startup time.
2685
2687
2686 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2688 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2687 instances had introduced a bug with globals in normal code. Now
2689 instances had introduced a bug with globals in normal code. Now
2688 it's working in all cases.
2690 it's working in all cases.
2689
2691
2690 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2692 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2691 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2693 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2692 has been introduced to set the default case sensitivity of the
2694 has been introduced to set the default case sensitivity of the
2693 searches. Users can still select either mode at runtime on a
2695 searches. Users can still select either mode at runtime on a
2694 per-search basis.
2696 per-search basis.
2695
2697
2696 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2698 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2697
2699
2698 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2700 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2699 attributes in wildcard searches for subclasses. Modified version
2701 attributes in wildcard searches for subclasses. Modified version
2700 of a patch by Jorgen.
2702 of a patch by Jorgen.
2701
2703
2702 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2704 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2703
2705
2704 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2706 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2705 embedded instances. I added a user_global_ns attribute to the
2707 embedded instances. I added a user_global_ns attribute to the
2706 InteractiveShell class to handle this.
2708 InteractiveShell class to handle this.
2707
2709
2708 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2710 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2709
2711
2710 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2712 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2711 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2713 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2712 (reported under win32, but may happen also in other platforms).
2714 (reported under win32, but may happen also in other platforms).
2713 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2715 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2714
2716
2715 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2717 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2716
2718
2717 * IPython/Magic.py (magic_psearch): new support for wildcard
2719 * IPython/Magic.py (magic_psearch): new support for wildcard
2718 patterns. Now, typing ?a*b will list all names which begin with a
2720 patterns. Now, typing ?a*b will list all names which begin with a
2719 and end in b, for example. The %psearch magic has full
2721 and end in b, for example. The %psearch magic has full
2720 docstrings. Many thanks to JΓΆrgen Stenarson
2722 docstrings. Many thanks to JΓΆrgen Stenarson
2721 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2723 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2722 implementing this functionality.
2724 implementing this functionality.
2723
2725
2724 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2726 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2725
2727
2726 * Manual: fixed long-standing annoyance of double-dashes (as in
2728 * Manual: fixed long-standing annoyance of double-dashes (as in
2727 --prefix=~, for example) being stripped in the HTML version. This
2729 --prefix=~, for example) being stripped in the HTML version. This
2728 is a latex2html bug, but a workaround was provided. Many thanks
2730 is a latex2html bug, but a workaround was provided. Many thanks
2729 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2731 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2730 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2732 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2731 rolling. This seemingly small issue had tripped a number of users
2733 rolling. This seemingly small issue had tripped a number of users
2732 when first installing, so I'm glad to see it gone.
2734 when first installing, so I'm glad to see it gone.
2733
2735
2734 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2736 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2735
2737
2736 * IPython/Extensions/numeric_formats.py: fix missing import,
2738 * IPython/Extensions/numeric_formats.py: fix missing import,
2737 reported by Stephen Walton.
2739 reported by Stephen Walton.
2738
2740
2739 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2741 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2740
2742
2741 * IPython/demo.py: finish demo module, fully documented now.
2743 * IPython/demo.py: finish demo module, fully documented now.
2742
2744
2743 * IPython/genutils.py (file_read): simple little utility to read a
2745 * IPython/genutils.py (file_read): simple little utility to read a
2744 file and ensure it's closed afterwards.
2746 file and ensure it's closed afterwards.
2745
2747
2746 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2748 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2747
2749
2748 * IPython/demo.py (Demo.__init__): added support for individually
2750 * IPython/demo.py (Demo.__init__): added support for individually
2749 tagging blocks for automatic execution.
2751 tagging blocks for automatic execution.
2750
2752
2751 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2753 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2752 syntax-highlighted python sources, requested by John.
2754 syntax-highlighted python sources, requested by John.
2753
2755
2754 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2756 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2755
2757
2756 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2758 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2757 finishing.
2759 finishing.
2758
2760
2759 * IPython/genutils.py (shlex_split): moved from Magic to here,
2761 * IPython/genutils.py (shlex_split): moved from Magic to here,
2760 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2762 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2761
2763
2762 * IPython/demo.py (Demo.__init__): added support for silent
2764 * IPython/demo.py (Demo.__init__): added support for silent
2763 blocks, improved marks as regexps, docstrings written.
2765 blocks, improved marks as regexps, docstrings written.
2764 (Demo.__init__): better docstring, added support for sys.argv.
2766 (Demo.__init__): better docstring, added support for sys.argv.
2765
2767
2766 * IPython/genutils.py (marquee): little utility used by the demo
2768 * IPython/genutils.py (marquee): little utility used by the demo
2767 code, handy in general.
2769 code, handy in general.
2768
2770
2769 * IPython/demo.py (Demo.__init__): new class for interactive
2771 * IPython/demo.py (Demo.__init__): new class for interactive
2770 demos. Not documented yet, I just wrote it in a hurry for
2772 demos. Not documented yet, I just wrote it in a hurry for
2771 scipy'05. Will docstring later.
2773 scipy'05. Will docstring later.
2772
2774
2773 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2775 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2774
2776
2775 * IPython/Shell.py (sigint_handler): Drastic simplification which
2777 * IPython/Shell.py (sigint_handler): Drastic simplification which
2776 also seems to make Ctrl-C work correctly across threads! This is
2778 also seems to make Ctrl-C work correctly across threads! This is
2777 so simple, that I can't beleive I'd missed it before. Needs more
2779 so simple, that I can't beleive I'd missed it before. Needs more
2778 testing, though.
2780 testing, though.
2779 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2781 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2780 like this before...
2782 like this before...
2781
2783
2782 * IPython/genutils.py (get_home_dir): add protection against
2784 * IPython/genutils.py (get_home_dir): add protection against
2783 non-dirs in win32 registry.
2785 non-dirs in win32 registry.
2784
2786
2785 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2787 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2786 bug where dict was mutated while iterating (pysh crash).
2788 bug where dict was mutated while iterating (pysh crash).
2787
2789
2788 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2790 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2789
2791
2790 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2792 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2791 spurious newlines added by this routine. After a report by
2793 spurious newlines added by this routine. After a report by
2792 F. Mantegazza.
2794 F. Mantegazza.
2793
2795
2794 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2796 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2795
2797
2796 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2798 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2797 calls. These were a leftover from the GTK 1.x days, and can cause
2799 calls. These were a leftover from the GTK 1.x days, and can cause
2798 problems in certain cases (after a report by John Hunter).
2800 problems in certain cases (after a report by John Hunter).
2799
2801
2800 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2802 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2801 os.getcwd() fails at init time. Thanks to patch from David Remahl
2803 os.getcwd() fails at init time. Thanks to patch from David Remahl
2802 <chmod007-AT-mac.com>.
2804 <chmod007-AT-mac.com>.
2803 (InteractiveShell.__init__): prevent certain special magics from
2805 (InteractiveShell.__init__): prevent certain special magics from
2804 being shadowed by aliases. Closes
2806 being shadowed by aliases. Closes
2805 http://www.scipy.net/roundup/ipython/issue41.
2807 http://www.scipy.net/roundup/ipython/issue41.
2806
2808
2807 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2809 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2808
2810
2809 * IPython/iplib.py (InteractiveShell.complete): Added new
2811 * IPython/iplib.py (InteractiveShell.complete): Added new
2810 top-level completion method to expose the completion mechanism
2812 top-level completion method to expose the completion mechanism
2811 beyond readline-based environments.
2813 beyond readline-based environments.
2812
2814
2813 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2815 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2814
2816
2815 * tools/ipsvnc (svnversion): fix svnversion capture.
2817 * tools/ipsvnc (svnversion): fix svnversion capture.
2816
2818
2817 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2819 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2818 attribute to self, which was missing. Before, it was set by a
2820 attribute to self, which was missing. Before, it was set by a
2819 routine which in certain cases wasn't being called, so the
2821 routine which in certain cases wasn't being called, so the
2820 instance could end up missing the attribute. This caused a crash.
2822 instance could end up missing the attribute. This caused a crash.
2821 Closes http://www.scipy.net/roundup/ipython/issue40.
2823 Closes http://www.scipy.net/roundup/ipython/issue40.
2822
2824
2823 2005-08-16 Fernando Perez <fperez@colorado.edu>
2825 2005-08-16 Fernando Perez <fperez@colorado.edu>
2824
2826
2825 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2827 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2826 contains non-string attribute. Closes
2828 contains non-string attribute. Closes
2827 http://www.scipy.net/roundup/ipython/issue38.
2829 http://www.scipy.net/roundup/ipython/issue38.
2828
2830
2829 2005-08-14 Fernando Perez <fperez@colorado.edu>
2831 2005-08-14 Fernando Perez <fperez@colorado.edu>
2830
2832
2831 * tools/ipsvnc: Minor improvements, to add changeset info.
2833 * tools/ipsvnc: Minor improvements, to add changeset info.
2832
2834
2833 2005-08-12 Fernando Perez <fperez@colorado.edu>
2835 2005-08-12 Fernando Perez <fperez@colorado.edu>
2834
2836
2835 * IPython/iplib.py (runsource): remove self.code_to_run_src
2837 * IPython/iplib.py (runsource): remove self.code_to_run_src
2836 attribute. I realized this is nothing more than
2838 attribute. I realized this is nothing more than
2837 '\n'.join(self.buffer), and having the same data in two different
2839 '\n'.join(self.buffer), and having the same data in two different
2838 places is just asking for synchronization bugs. This may impact
2840 places is just asking for synchronization bugs. This may impact
2839 people who have custom exception handlers, so I need to warn
2841 people who have custom exception handlers, so I need to warn
2840 ipython-dev about it (F. Mantegazza may use them).
2842 ipython-dev about it (F. Mantegazza may use them).
2841
2843
2842 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2844 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2843
2845
2844 * IPython/genutils.py: fix 2.2 compatibility (generators)
2846 * IPython/genutils.py: fix 2.2 compatibility (generators)
2845
2847
2846 2005-07-18 Fernando Perez <fperez@colorado.edu>
2848 2005-07-18 Fernando Perez <fperez@colorado.edu>
2847
2849
2848 * IPython/genutils.py (get_home_dir): fix to help users with
2850 * IPython/genutils.py (get_home_dir): fix to help users with
2849 invalid $HOME under win32.
2851 invalid $HOME under win32.
2850
2852
2851 2005-07-17 Fernando Perez <fperez@colorado.edu>
2853 2005-07-17 Fernando Perez <fperez@colorado.edu>
2852
2854
2853 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2855 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2854 some old hacks and clean up a bit other routines; code should be
2856 some old hacks and clean up a bit other routines; code should be
2855 simpler and a bit faster.
2857 simpler and a bit faster.
2856
2858
2857 * IPython/iplib.py (interact): removed some last-resort attempts
2859 * IPython/iplib.py (interact): removed some last-resort attempts
2858 to survive broken stdout/stderr. That code was only making it
2860 to survive broken stdout/stderr. That code was only making it
2859 harder to abstract out the i/o (necessary for gui integration),
2861 harder to abstract out the i/o (necessary for gui integration),
2860 and the crashes it could prevent were extremely rare in practice
2862 and the crashes it could prevent were extremely rare in practice
2861 (besides being fully user-induced in a pretty violent manner).
2863 (besides being fully user-induced in a pretty violent manner).
2862
2864
2863 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2865 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2864 Nothing major yet, but the code is simpler to read; this should
2866 Nothing major yet, but the code is simpler to read; this should
2865 make it easier to do more serious modifications in the future.
2867 make it easier to do more serious modifications in the future.
2866
2868
2867 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2869 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2868 which broke in .15 (thanks to a report by Ville).
2870 which broke in .15 (thanks to a report by Ville).
2869
2871
2870 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2872 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2871 be quite correct, I know next to nothing about unicode). This
2873 be quite correct, I know next to nothing about unicode). This
2872 will allow unicode strings to be used in prompts, amongst other
2874 will allow unicode strings to be used in prompts, amongst other
2873 cases. It also will prevent ipython from crashing when unicode
2875 cases. It also will prevent ipython from crashing when unicode
2874 shows up unexpectedly in many places. If ascii encoding fails, we
2876 shows up unexpectedly in many places. If ascii encoding fails, we
2875 assume utf_8. Currently the encoding is not a user-visible
2877 assume utf_8. Currently the encoding is not a user-visible
2876 setting, though it could be made so if there is demand for it.
2878 setting, though it could be made so if there is demand for it.
2877
2879
2878 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2880 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2879
2881
2880 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2882 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2881
2883
2882 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2884 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2883
2885
2884 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2886 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2885 code can work transparently for 2.2/2.3.
2887 code can work transparently for 2.2/2.3.
2886
2888
2887 2005-07-16 Fernando Perez <fperez@colorado.edu>
2889 2005-07-16 Fernando Perez <fperez@colorado.edu>
2888
2890
2889 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2891 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2890 out of the color scheme table used for coloring exception
2892 out of the color scheme table used for coloring exception
2891 tracebacks. This allows user code to add new schemes at runtime.
2893 tracebacks. This allows user code to add new schemes at runtime.
2892 This is a minimally modified version of the patch at
2894 This is a minimally modified version of the patch at
2893 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2895 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2894 for the contribution.
2896 for the contribution.
2895
2897
2896 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2898 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2897 slightly modified version of the patch in
2899 slightly modified version of the patch in
2898 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2900 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2899 to remove the previous try/except solution (which was costlier).
2901 to remove the previous try/except solution (which was costlier).
2900 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2902 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2901
2903
2902 2005-06-08 Fernando Perez <fperez@colorado.edu>
2904 2005-06-08 Fernando Perez <fperez@colorado.edu>
2903
2905
2904 * IPython/iplib.py (write/write_err): Add methods to abstract all
2906 * IPython/iplib.py (write/write_err): Add methods to abstract all
2905 I/O a bit more.
2907 I/O a bit more.
2906
2908
2907 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2909 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2908 warning, reported by Aric Hagberg, fix by JD Hunter.
2910 warning, reported by Aric Hagberg, fix by JD Hunter.
2909
2911
2910 2005-06-02 *** Released version 0.6.15
2912 2005-06-02 *** Released version 0.6.15
2911
2913
2912 2005-06-01 Fernando Perez <fperez@colorado.edu>
2914 2005-06-01 Fernando Perez <fperez@colorado.edu>
2913
2915
2914 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2916 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2915 tab-completion of filenames within open-quoted strings. Note that
2917 tab-completion of filenames within open-quoted strings. Note that
2916 this requires that in ~/.ipython/ipythonrc, users change the
2918 this requires that in ~/.ipython/ipythonrc, users change the
2917 readline delimiters configuration to read:
2919 readline delimiters configuration to read:
2918
2920
2919 readline_remove_delims -/~
2921 readline_remove_delims -/~
2920
2922
2921
2923
2922 2005-05-31 *** Released version 0.6.14
2924 2005-05-31 *** Released version 0.6.14
2923
2925
2924 2005-05-29 Fernando Perez <fperez@colorado.edu>
2926 2005-05-29 Fernando Perez <fperez@colorado.edu>
2925
2927
2926 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2928 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2927 with files not on the filesystem. Reported by Eliyahu Sandler
2929 with files not on the filesystem. Reported by Eliyahu Sandler
2928 <eli@gondolin.net>
2930 <eli@gondolin.net>
2929
2931
2930 2005-05-22 Fernando Perez <fperez@colorado.edu>
2932 2005-05-22 Fernando Perez <fperez@colorado.edu>
2931
2933
2932 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2934 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2933 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2935 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2934
2936
2935 2005-05-19 Fernando Perez <fperez@colorado.edu>
2937 2005-05-19 Fernando Perez <fperez@colorado.edu>
2936
2938
2937 * IPython/iplib.py (safe_execfile): close a file which could be
2939 * IPython/iplib.py (safe_execfile): close a file which could be
2938 left open (causing problems in win32, which locks open files).
2940 left open (causing problems in win32, which locks open files).
2939 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2941 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2940
2942
2941 2005-05-18 Fernando Perez <fperez@colorado.edu>
2943 2005-05-18 Fernando Perez <fperez@colorado.edu>
2942
2944
2943 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2945 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2944 keyword arguments correctly to safe_execfile().
2946 keyword arguments correctly to safe_execfile().
2945
2947
2946 2005-05-13 Fernando Perez <fperez@colorado.edu>
2948 2005-05-13 Fernando Perez <fperez@colorado.edu>
2947
2949
2948 * ipython.1: Added info about Qt to manpage, and threads warning
2950 * ipython.1: Added info about Qt to manpage, and threads warning
2949 to usage page (invoked with --help).
2951 to usage page (invoked with --help).
2950
2952
2951 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2953 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2952 new matcher (it goes at the end of the priority list) to do
2954 new matcher (it goes at the end of the priority list) to do
2953 tab-completion on named function arguments. Submitted by George
2955 tab-completion on named function arguments. Submitted by George
2954 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2956 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2955 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2957 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2956 for more details.
2958 for more details.
2957
2959
2958 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2960 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2959 SystemExit exceptions in the script being run. Thanks to a report
2961 SystemExit exceptions in the script being run. Thanks to a report
2960 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2962 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2961 producing very annoying behavior when running unit tests.
2963 producing very annoying behavior when running unit tests.
2962
2964
2963 2005-05-12 Fernando Perez <fperez@colorado.edu>
2965 2005-05-12 Fernando Perez <fperez@colorado.edu>
2964
2966
2965 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2967 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2966 which I'd broken (again) due to a changed regexp. In the process,
2968 which I'd broken (again) due to a changed regexp. In the process,
2967 added ';' as an escape to auto-quote the whole line without
2969 added ';' as an escape to auto-quote the whole line without
2968 splitting its arguments. Thanks to a report by Jerry McRae
2970 splitting its arguments. Thanks to a report by Jerry McRae
2969 <qrs0xyc02-AT-sneakemail.com>.
2971 <qrs0xyc02-AT-sneakemail.com>.
2970
2972
2971 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2973 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2972 possible crashes caused by a TokenError. Reported by Ed Schofield
2974 possible crashes caused by a TokenError. Reported by Ed Schofield
2973 <schofield-AT-ftw.at>.
2975 <schofield-AT-ftw.at>.
2974
2976
2975 2005-05-06 Fernando Perez <fperez@colorado.edu>
2977 2005-05-06 Fernando Perez <fperez@colorado.edu>
2976
2978
2977 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2979 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2978
2980
2979 2005-04-29 Fernando Perez <fperez@colorado.edu>
2981 2005-04-29 Fernando Perez <fperez@colorado.edu>
2980
2982
2981 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2983 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2982 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2984 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2983 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2985 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2984 which provides support for Qt interactive usage (similar to the
2986 which provides support for Qt interactive usage (similar to the
2985 existing one for WX and GTK). This had been often requested.
2987 existing one for WX and GTK). This had been often requested.
2986
2988
2987 2005-04-14 *** Released version 0.6.13
2989 2005-04-14 *** Released version 0.6.13
2988
2990
2989 2005-04-08 Fernando Perez <fperez@colorado.edu>
2991 2005-04-08 Fernando Perez <fperez@colorado.edu>
2990
2992
2991 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2993 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2992 from _ofind, which gets called on almost every input line. Now,
2994 from _ofind, which gets called on almost every input line. Now,
2993 we only try to get docstrings if they are actually going to be
2995 we only try to get docstrings if they are actually going to be
2994 used (the overhead of fetching unnecessary docstrings can be
2996 used (the overhead of fetching unnecessary docstrings can be
2995 noticeable for certain objects, such as Pyro proxies).
2997 noticeable for certain objects, such as Pyro proxies).
2996
2998
2997 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2999 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2998 for completers. For some reason I had been passing them the state
3000 for completers. For some reason I had been passing them the state
2999 variable, which completers never actually need, and was in
3001 variable, which completers never actually need, and was in
3000 conflict with the rlcompleter API. Custom completers ONLY need to
3002 conflict with the rlcompleter API. Custom completers ONLY need to
3001 take the text parameter.
3003 take the text parameter.
3002
3004
3003 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
3005 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
3004 work correctly in pysh. I've also moved all the logic which used
3006 work correctly in pysh. I've also moved all the logic which used
3005 to be in pysh.py here, which will prevent problems with future
3007 to be in pysh.py here, which will prevent problems with future
3006 upgrades. However, this time I must warn users to update their
3008 upgrades. However, this time I must warn users to update their
3007 pysh profile to include the line
3009 pysh profile to include the line
3008
3010
3009 import_all IPython.Extensions.InterpreterExec
3011 import_all IPython.Extensions.InterpreterExec
3010
3012
3011 because otherwise things won't work for them. They MUST also
3013 because otherwise things won't work for them. They MUST also
3012 delete pysh.py and the line
3014 delete pysh.py and the line
3013
3015
3014 execfile pysh.py
3016 execfile pysh.py
3015
3017
3016 from their ipythonrc-pysh.
3018 from their ipythonrc-pysh.
3017
3019
3018 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
3020 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
3019 robust in the face of objects whose dir() returns non-strings
3021 robust in the face of objects whose dir() returns non-strings
3020 (which it shouldn't, but some broken libs like ITK do). Thanks to
3022 (which it shouldn't, but some broken libs like ITK do). Thanks to
3021 a patch by John Hunter (implemented differently, though). Also
3023 a patch by John Hunter (implemented differently, though). Also
3022 minor improvements by using .extend instead of + on lists.
3024 minor improvements by using .extend instead of + on lists.
3023
3025
3024 * pysh.py:
3026 * pysh.py:
3025
3027
3026 2005-04-06 Fernando Perez <fperez@colorado.edu>
3028 2005-04-06 Fernando Perez <fperez@colorado.edu>
3027
3029
3028 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
3030 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
3029 by default, so that all users benefit from it. Those who don't
3031 by default, so that all users benefit from it. Those who don't
3030 want it can still turn it off.
3032 want it can still turn it off.
3031
3033
3032 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
3034 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
3033 config file, I'd forgotten about this, so users were getting it
3035 config file, I'd forgotten about this, so users were getting it
3034 off by default.
3036 off by default.
3035
3037
3036 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
3038 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
3037 consistency. Now magics can be called in multiline statements,
3039 consistency. Now magics can be called in multiline statements,
3038 and python variables can be expanded in magic calls via $var.
3040 and python variables can be expanded in magic calls via $var.
3039 This makes the magic system behave just like aliases or !system
3041 This makes the magic system behave just like aliases or !system
3040 calls.
3042 calls.
3041
3043
3042 2005-03-28 Fernando Perez <fperez@colorado.edu>
3044 2005-03-28 Fernando Perez <fperez@colorado.edu>
3043
3045
3044 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
3046 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
3045 expensive string additions for building command. Add support for
3047 expensive string additions for building command. Add support for
3046 trailing ';' when autocall is used.
3048 trailing ';' when autocall is used.
3047
3049
3048 2005-03-26 Fernando Perez <fperez@colorado.edu>
3050 2005-03-26 Fernando Perez <fperez@colorado.edu>
3049
3051
3050 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
3052 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
3051 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
3053 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
3052 ipython.el robust against prompts with any number of spaces
3054 ipython.el robust against prompts with any number of spaces
3053 (including 0) after the ':' character.
3055 (including 0) after the ':' character.
3054
3056
3055 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
3057 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
3056 continuation prompt, which misled users to think the line was
3058 continuation prompt, which misled users to think the line was
3057 already indented. Closes debian Bug#300847, reported to me by
3059 already indented. Closes debian Bug#300847, reported to me by
3058 Norbert Tretkowski <tretkowski-AT-inittab.de>.
3060 Norbert Tretkowski <tretkowski-AT-inittab.de>.
3059
3061
3060 2005-03-23 Fernando Perez <fperez@colorado.edu>
3062 2005-03-23 Fernando Perez <fperez@colorado.edu>
3061
3063
3062 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
3064 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
3063 properly aligned if they have embedded newlines.
3065 properly aligned if they have embedded newlines.
3064
3066
3065 * IPython/iplib.py (runlines): Add a public method to expose
3067 * IPython/iplib.py (runlines): Add a public method to expose
3066 IPython's code execution machinery, so that users can run strings
3068 IPython's code execution machinery, so that users can run strings
3067 as if they had been typed at the prompt interactively.
3069 as if they had been typed at the prompt interactively.
3068 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
3070 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
3069 methods which can call the system shell, but with python variable
3071 methods which can call the system shell, but with python variable
3070 expansion. The three such methods are: __IPYTHON__.system,
3072 expansion. The three such methods are: __IPYTHON__.system,
3071 .getoutput and .getoutputerror. These need to be documented in a
3073 .getoutput and .getoutputerror. These need to be documented in a
3072 'public API' section (to be written) of the manual.
3074 'public API' section (to be written) of the manual.
3073
3075
3074 2005-03-20 Fernando Perez <fperez@colorado.edu>
3076 2005-03-20 Fernando Perez <fperez@colorado.edu>
3075
3077
3076 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
3078 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
3077 for custom exception handling. This is quite powerful, and it
3079 for custom exception handling. This is quite powerful, and it
3078 allows for user-installable exception handlers which can trap
3080 allows for user-installable exception handlers which can trap
3079 custom exceptions at runtime and treat them separately from
3081 custom exceptions at runtime and treat them separately from
3080 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
3082 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
3081 Mantegazza <mantegazza-AT-ill.fr>.
3083 Mantegazza <mantegazza-AT-ill.fr>.
3082 (InteractiveShell.set_custom_completer): public API function to
3084 (InteractiveShell.set_custom_completer): public API function to
3083 add new completers at runtime.
3085 add new completers at runtime.
3084
3086
3085 2005-03-19 Fernando Perez <fperez@colorado.edu>
3087 2005-03-19 Fernando Perez <fperez@colorado.edu>
3086
3088
3087 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
3089 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
3088 allow objects which provide their docstrings via non-standard
3090 allow objects which provide their docstrings via non-standard
3089 mechanisms (like Pyro proxies) to still be inspected by ipython's
3091 mechanisms (like Pyro proxies) to still be inspected by ipython's
3090 ? system.
3092 ? system.
3091
3093
3092 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
3094 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
3093 automatic capture system. I tried quite hard to make it work
3095 automatic capture system. I tried quite hard to make it work
3094 reliably, and simply failed. I tried many combinations with the
3096 reliably, and simply failed. I tried many combinations with the
3095 subprocess module, but eventually nothing worked in all needed
3097 subprocess module, but eventually nothing worked in all needed
3096 cases (not blocking stdin for the child, duplicating stdout
3098 cases (not blocking stdin for the child, duplicating stdout
3097 without blocking, etc). The new %sc/%sx still do capture to these
3099 without blocking, etc). The new %sc/%sx still do capture to these
3098 magical list/string objects which make shell use much more
3100 magical list/string objects which make shell use much more
3099 conveninent, so not all is lost.
3101 conveninent, so not all is lost.
3100
3102
3101 XXX - FIX MANUAL for the change above!
3103 XXX - FIX MANUAL for the change above!
3102
3104
3103 (runsource): I copied code.py's runsource() into ipython to modify
3105 (runsource): I copied code.py's runsource() into ipython to modify
3104 it a bit. Now the code object and source to be executed are
3106 it a bit. Now the code object and source to be executed are
3105 stored in ipython. This makes this info accessible to third-party
3107 stored in ipython. This makes this info accessible to third-party
3106 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
3108 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
3107 Mantegazza <mantegazza-AT-ill.fr>.
3109 Mantegazza <mantegazza-AT-ill.fr>.
3108
3110
3109 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
3111 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
3110 history-search via readline (like C-p/C-n). I'd wanted this for a
3112 history-search via readline (like C-p/C-n). I'd wanted this for a
3111 long time, but only recently found out how to do it. For users
3113 long time, but only recently found out how to do it. For users
3112 who already have their ipythonrc files made and want this, just
3114 who already have their ipythonrc files made and want this, just
3113 add:
3115 add:
3114
3116
3115 readline_parse_and_bind "\e[A": history-search-backward
3117 readline_parse_and_bind "\e[A": history-search-backward
3116 readline_parse_and_bind "\e[B": history-search-forward
3118 readline_parse_and_bind "\e[B": history-search-forward
3117
3119
3118 2005-03-18 Fernando Perez <fperez@colorado.edu>
3120 2005-03-18 Fernando Perez <fperez@colorado.edu>
3119
3121
3120 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
3122 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
3121 LSString and SList classes which allow transparent conversions
3123 LSString and SList classes which allow transparent conversions
3122 between list mode and whitespace-separated string.
3124 between list mode and whitespace-separated string.
3123 (magic_r): Fix recursion problem in %r.
3125 (magic_r): Fix recursion problem in %r.
3124
3126
3125 * IPython/genutils.py (LSString): New class to be used for
3127 * IPython/genutils.py (LSString): New class to be used for
3126 automatic storage of the results of all alias/system calls in _o
3128 automatic storage of the results of all alias/system calls in _o
3127 and _e (stdout/err). These provide a .l/.list attribute which
3129 and _e (stdout/err). These provide a .l/.list attribute which
3128 does automatic splitting on newlines. This means that for most
3130 does automatic splitting on newlines. This means that for most
3129 uses, you'll never need to do capturing of output with %sc/%sx
3131 uses, you'll never need to do capturing of output with %sc/%sx
3130 anymore, since ipython keeps this always done for you. Note that
3132 anymore, since ipython keeps this always done for you. Note that
3131 only the LAST results are stored, the _o/e variables are
3133 only the LAST results are stored, the _o/e variables are
3132 overwritten on each call. If you need to save their contents
3134 overwritten on each call. If you need to save their contents
3133 further, simply bind them to any other name.
3135 further, simply bind them to any other name.
3134
3136
3135 2005-03-17 Fernando Perez <fperez@colorado.edu>
3137 2005-03-17 Fernando Perez <fperez@colorado.edu>
3136
3138
3137 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
3139 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
3138 prompt namespace handling.
3140 prompt namespace handling.
3139
3141
3140 2005-03-16 Fernando Perez <fperez@colorado.edu>
3142 2005-03-16 Fernando Perez <fperez@colorado.edu>
3141
3143
3142 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
3144 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
3143 classic prompts to be '>>> ' (final space was missing, and it
3145 classic prompts to be '>>> ' (final space was missing, and it
3144 trips the emacs python mode).
3146 trips the emacs python mode).
3145 (BasePrompt.__str__): Added safe support for dynamic prompt
3147 (BasePrompt.__str__): Added safe support for dynamic prompt
3146 strings. Now you can set your prompt string to be '$x', and the
3148 strings. Now you can set your prompt string to be '$x', and the
3147 value of x will be printed from your interactive namespace. The
3149 value of x will be printed from your interactive namespace. The
3148 interpolation syntax includes the full Itpl support, so
3150 interpolation syntax includes the full Itpl support, so
3149 ${foo()+x+bar()} is a valid prompt string now, and the function
3151 ${foo()+x+bar()} is a valid prompt string now, and the function
3150 calls will be made at runtime.
3152 calls will be made at runtime.
3151
3153
3152 2005-03-15 Fernando Perez <fperez@colorado.edu>
3154 2005-03-15 Fernando Perez <fperez@colorado.edu>
3153
3155
3154 * IPython/Magic.py (magic_history): renamed %hist to %history, to
3156 * IPython/Magic.py (magic_history): renamed %hist to %history, to
3155 avoid name clashes in pylab. %hist still works, it just forwards
3157 avoid name clashes in pylab. %hist still works, it just forwards
3156 the call to %history.
3158 the call to %history.
3157
3159
3158 2005-03-02 *** Released version 0.6.12
3160 2005-03-02 *** Released version 0.6.12
3159
3161
3160 2005-03-02 Fernando Perez <fperez@colorado.edu>
3162 2005-03-02 Fernando Perez <fperez@colorado.edu>
3161
3163
3162 * IPython/iplib.py (handle_magic): log magic calls properly as
3164 * IPython/iplib.py (handle_magic): log magic calls properly as
3163 ipmagic() function calls.
3165 ipmagic() function calls.
3164
3166
3165 * IPython/Magic.py (magic_time): Improved %time to support
3167 * IPython/Magic.py (magic_time): Improved %time to support
3166 statements and provide wall-clock as well as CPU time.
3168 statements and provide wall-clock as well as CPU time.
3167
3169
3168 2005-02-27 Fernando Perez <fperez@colorado.edu>
3170 2005-02-27 Fernando Perez <fperez@colorado.edu>
3169
3171
3170 * IPython/hooks.py: New hooks module, to expose user-modifiable
3172 * IPython/hooks.py: New hooks module, to expose user-modifiable
3171 IPython functionality in a clean manner. For now only the editor
3173 IPython functionality in a clean manner. For now only the editor
3172 hook is actually written, and other thigns which I intend to turn
3174 hook is actually written, and other thigns which I intend to turn
3173 into proper hooks aren't yet there. The display and prefilter
3175 into proper hooks aren't yet there. The display and prefilter
3174 stuff, for example, should be hooks. But at least now the
3176 stuff, for example, should be hooks. But at least now the
3175 framework is in place, and the rest can be moved here with more
3177 framework is in place, and the rest can be moved here with more
3176 time later. IPython had had a .hooks variable for a long time for
3178 time later. IPython had had a .hooks variable for a long time for
3177 this purpose, but I'd never actually used it for anything.
3179 this purpose, but I'd never actually used it for anything.
3178
3180
3179 2005-02-26 Fernando Perez <fperez@colorado.edu>
3181 2005-02-26 Fernando Perez <fperez@colorado.edu>
3180
3182
3181 * IPython/ipmaker.py (make_IPython): make the default ipython
3183 * IPython/ipmaker.py (make_IPython): make the default ipython
3182 directory be called _ipython under win32, to follow more the
3184 directory be called _ipython under win32, to follow more the
3183 naming peculiarities of that platform (where buggy software like
3185 naming peculiarities of that platform (where buggy software like
3184 Visual Sourcesafe breaks with .named directories). Reported by
3186 Visual Sourcesafe breaks with .named directories). Reported by
3185 Ville Vainio.
3187 Ville Vainio.
3186
3188
3187 2005-02-23 Fernando Perez <fperez@colorado.edu>
3189 2005-02-23 Fernando Perez <fperez@colorado.edu>
3188
3190
3189 * IPython/iplib.py (InteractiveShell.__init__): removed a few
3191 * IPython/iplib.py (InteractiveShell.__init__): removed a few
3190 auto_aliases for win32 which were causing problems. Users can
3192 auto_aliases for win32 which were causing problems. Users can
3191 define the ones they personally like.
3193 define the ones they personally like.
3192
3194
3193 2005-02-21 Fernando Perez <fperez@colorado.edu>
3195 2005-02-21 Fernando Perez <fperez@colorado.edu>
3194
3196
3195 * IPython/Magic.py (magic_time): new magic to time execution of
3197 * IPython/Magic.py (magic_time): new magic to time execution of
3196 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
3198 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
3197
3199
3198 2005-02-19 Fernando Perez <fperez@colorado.edu>
3200 2005-02-19 Fernando Perez <fperez@colorado.edu>
3199
3201
3200 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
3202 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
3201 into keys (for prompts, for example).
3203 into keys (for prompts, for example).
3202
3204
3203 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
3205 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
3204 prompts in case users want them. This introduces a small behavior
3206 prompts in case users want them. This introduces a small behavior
3205 change: ipython does not automatically add a space to all prompts
3207 change: ipython does not automatically add a space to all prompts
3206 anymore. To get the old prompts with a space, users should add it
3208 anymore. To get the old prompts with a space, users should add it
3207 manually to their ipythonrc file, so for example prompt_in1 should
3209 manually to their ipythonrc file, so for example prompt_in1 should
3208 now read 'In [\#]: ' instead of 'In [\#]:'.
3210 now read 'In [\#]: ' instead of 'In [\#]:'.
3209 (BasePrompt.__init__): New option prompts_pad_left (only in rc
3211 (BasePrompt.__init__): New option prompts_pad_left (only in rc
3210 file) to control left-padding of secondary prompts.
3212 file) to control left-padding of secondary prompts.
3211
3213
3212 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
3214 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
3213 the profiler can't be imported. Fix for Debian, which removed
3215 the profiler can't be imported. Fix for Debian, which removed
3214 profile.py because of License issues. I applied a slightly
3216 profile.py because of License issues. I applied a slightly
3215 modified version of the original Debian patch at
3217 modified version of the original Debian patch at
3216 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
3218 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
3217
3219
3218 2005-02-17 Fernando Perez <fperez@colorado.edu>
3220 2005-02-17 Fernando Perez <fperez@colorado.edu>
3219
3221
3220 * IPython/genutils.py (native_line_ends): Fix bug which would
3222 * IPython/genutils.py (native_line_ends): Fix bug which would
3221 cause improper line-ends under win32 b/c I was not opening files
3223 cause improper line-ends under win32 b/c I was not opening files
3222 in binary mode. Bug report and fix thanks to Ville.
3224 in binary mode. Bug report and fix thanks to Ville.
3223
3225
3224 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
3226 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
3225 trying to catch spurious foo[1] autocalls. My fix actually broke
3227 trying to catch spurious foo[1] autocalls. My fix actually broke
3226 ',/' autoquote/call with explicit escape (bad regexp).
3228 ',/' autoquote/call with explicit escape (bad regexp).
3227
3229
3228 2005-02-15 *** Released version 0.6.11
3230 2005-02-15 *** Released version 0.6.11
3229
3231
3230 2005-02-14 Fernando Perez <fperez@colorado.edu>
3232 2005-02-14 Fernando Perez <fperez@colorado.edu>
3231
3233
3232 * IPython/background_jobs.py: New background job management
3234 * IPython/background_jobs.py: New background job management
3233 subsystem. This is implemented via a new set of classes, and
3235 subsystem. This is implemented via a new set of classes, and
3234 IPython now provides a builtin 'jobs' object for background job
3236 IPython now provides a builtin 'jobs' object for background job
3235 execution. A convenience %bg magic serves as a lightweight
3237 execution. A convenience %bg magic serves as a lightweight
3236 frontend for starting the more common type of calls. This was
3238 frontend for starting the more common type of calls. This was
3237 inspired by discussions with B. Granger and the BackgroundCommand
3239 inspired by discussions with B. Granger and the BackgroundCommand
3238 class described in the book Python Scripting for Computational
3240 class described in the book Python Scripting for Computational
3239 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
3241 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
3240 (although ultimately no code from this text was used, as IPython's
3242 (although ultimately no code from this text was used, as IPython's
3241 system is a separate implementation).
3243 system is a separate implementation).
3242
3244
3243 * IPython/iplib.py (MagicCompleter.python_matches): add new option
3245 * IPython/iplib.py (MagicCompleter.python_matches): add new option
3244 to control the completion of single/double underscore names
3246 to control the completion of single/double underscore names
3245 separately. As documented in the example ipytonrc file, the
3247 separately. As documented in the example ipytonrc file, the
3246 readline_omit__names variable can now be set to 2, to omit even
3248 readline_omit__names variable can now be set to 2, to omit even
3247 single underscore names. Thanks to a patch by Brian Wong
3249 single underscore names. Thanks to a patch by Brian Wong
3248 <BrianWong-AT-AirgoNetworks.Com>.
3250 <BrianWong-AT-AirgoNetworks.Com>.
3249 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
3251 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
3250 be autocalled as foo([1]) if foo were callable. A problem for
3252 be autocalled as foo([1]) if foo were callable. A problem for
3251 things which are both callable and implement __getitem__.
3253 things which are both callable and implement __getitem__.
3252 (init_readline): Fix autoindentation for win32. Thanks to a patch
3254 (init_readline): Fix autoindentation for win32. Thanks to a patch
3253 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
3255 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
3254
3256
3255 2005-02-12 Fernando Perez <fperez@colorado.edu>
3257 2005-02-12 Fernando Perez <fperez@colorado.edu>
3256
3258
3257 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
3259 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
3258 which I had written long ago to sort out user error messages which
3260 which I had written long ago to sort out user error messages which
3259 may occur during startup. This seemed like a good idea initially,
3261 may occur during startup. This seemed like a good idea initially,
3260 but it has proven a disaster in retrospect. I don't want to
3262 but it has proven a disaster in retrospect. I don't want to
3261 change much code for now, so my fix is to set the internal 'debug'
3263 change much code for now, so my fix is to set the internal 'debug'
3262 flag to true everywhere, whose only job was precisely to control
3264 flag to true everywhere, whose only job was precisely to control
3263 this subsystem. This closes issue 28 (as well as avoiding all
3265 this subsystem. This closes issue 28 (as well as avoiding all
3264 sorts of strange hangups which occur from time to time).
3266 sorts of strange hangups which occur from time to time).
3265
3267
3266 2005-02-07 Fernando Perez <fperez@colorado.edu>
3268 2005-02-07 Fernando Perez <fperez@colorado.edu>
3267
3269
3268 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
3270 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
3269 previous call produced a syntax error.
3271 previous call produced a syntax error.
3270
3272
3271 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3273 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3272 classes without constructor.
3274 classes without constructor.
3273
3275
3274 2005-02-06 Fernando Perez <fperez@colorado.edu>
3276 2005-02-06 Fernando Perez <fperez@colorado.edu>
3275
3277
3276 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
3278 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
3277 completions with the results of each matcher, so we return results
3279 completions with the results of each matcher, so we return results
3278 to the user from all namespaces. This breaks with ipython
3280 to the user from all namespaces. This breaks with ipython
3279 tradition, but I think it's a nicer behavior. Now you get all
3281 tradition, but I think it's a nicer behavior. Now you get all
3280 possible completions listed, from all possible namespaces (python,
3282 possible completions listed, from all possible namespaces (python,
3281 filesystem, magics...) After a request by John Hunter
3283 filesystem, magics...) After a request by John Hunter
3282 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3284 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3283
3285
3284 2005-02-05 Fernando Perez <fperez@colorado.edu>
3286 2005-02-05 Fernando Perez <fperez@colorado.edu>
3285
3287
3286 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
3288 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
3287 the call had quote characters in it (the quotes were stripped).
3289 the call had quote characters in it (the quotes were stripped).
3288
3290
3289 2005-01-31 Fernando Perez <fperez@colorado.edu>
3291 2005-01-31 Fernando Perez <fperez@colorado.edu>
3290
3292
3291 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
3293 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
3292 Itpl.itpl() to make the code more robust against psyco
3294 Itpl.itpl() to make the code more robust against psyco
3293 optimizations.
3295 optimizations.
3294
3296
3295 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
3297 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
3296 of causing an exception. Quicker, cleaner.
3298 of causing an exception. Quicker, cleaner.
3297
3299
3298 2005-01-28 Fernando Perez <fperez@colorado.edu>
3300 2005-01-28 Fernando Perez <fperez@colorado.edu>
3299
3301
3300 * scripts/ipython_win_post_install.py (install): hardcode
3302 * scripts/ipython_win_post_install.py (install): hardcode
3301 sys.prefix+'python.exe' as the executable path. It turns out that
3303 sys.prefix+'python.exe' as the executable path. It turns out that
3302 during the post-installation run, sys.executable resolves to the
3304 during the post-installation run, sys.executable resolves to the
3303 name of the binary installer! I should report this as a distutils
3305 name of the binary installer! I should report this as a distutils
3304 bug, I think. I updated the .10 release with this tiny fix, to
3306 bug, I think. I updated the .10 release with this tiny fix, to
3305 avoid annoying the lists further.
3307 avoid annoying the lists further.
3306
3308
3307 2005-01-27 *** Released version 0.6.10
3309 2005-01-27 *** Released version 0.6.10
3308
3310
3309 2005-01-27 Fernando Perez <fperez@colorado.edu>
3311 2005-01-27 Fernando Perez <fperez@colorado.edu>
3310
3312
3311 * IPython/numutils.py (norm): Added 'inf' as optional name for
3313 * IPython/numutils.py (norm): Added 'inf' as optional name for
3312 L-infinity norm, included references to mathworld.com for vector
3314 L-infinity norm, included references to mathworld.com for vector
3313 norm definitions.
3315 norm definitions.
3314 (amin/amax): added amin/amax for array min/max. Similar to what
3316 (amin/amax): added amin/amax for array min/max. Similar to what
3315 pylab ships with after the recent reorganization of names.
3317 pylab ships with after the recent reorganization of names.
3316 (spike/spike_odd): removed deprecated spike/spike_odd functions.
3318 (spike/spike_odd): removed deprecated spike/spike_odd functions.
3317
3319
3318 * ipython.el: committed Alex's recent fixes and improvements.
3320 * ipython.el: committed Alex's recent fixes and improvements.
3319 Tested with python-mode from CVS, and it looks excellent. Since
3321 Tested with python-mode from CVS, and it looks excellent. Since
3320 python-mode hasn't released anything in a while, I'm temporarily
3322 python-mode hasn't released anything in a while, I'm temporarily
3321 putting a copy of today's CVS (v 4.70) of python-mode in:
3323 putting a copy of today's CVS (v 4.70) of python-mode in:
3322 http://ipython.scipy.org/tmp/python-mode.el
3324 http://ipython.scipy.org/tmp/python-mode.el
3323
3325
3324 * scripts/ipython_win_post_install.py (install): Win32 fix to use
3326 * scripts/ipython_win_post_install.py (install): Win32 fix to use
3325 sys.executable for the executable name, instead of assuming it's
3327 sys.executable for the executable name, instead of assuming it's
3326 called 'python.exe' (the post-installer would have produced broken
3328 called 'python.exe' (the post-installer would have produced broken
3327 setups on systems with a differently named python binary).
3329 setups on systems with a differently named python binary).
3328
3330
3329 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
3331 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
3330 references to os.linesep, to make the code more
3332 references to os.linesep, to make the code more
3331 platform-independent. This is also part of the win32 coloring
3333 platform-independent. This is also part of the win32 coloring
3332 fixes.
3334 fixes.
3333
3335
3334 * IPython/genutils.py (page_dumb): Remove attempts to chop long
3336 * IPython/genutils.py (page_dumb): Remove attempts to chop long
3335 lines, which actually cause coloring bugs because the length of
3337 lines, which actually cause coloring bugs because the length of
3336 the line is very difficult to correctly compute with embedded
3338 the line is very difficult to correctly compute with embedded
3337 escapes. This was the source of all the coloring problems under
3339 escapes. This was the source of all the coloring problems under
3338 Win32. I think that _finally_, Win32 users have a properly
3340 Win32. I think that _finally_, Win32 users have a properly
3339 working ipython in all respects. This would never have happened
3341 working ipython in all respects. This would never have happened
3340 if not for Gary Bishop and Viktor Ransmayr's great help and work.
3342 if not for Gary Bishop and Viktor Ransmayr's great help and work.
3341
3343
3342 2005-01-26 *** Released version 0.6.9
3344 2005-01-26 *** Released version 0.6.9
3343
3345
3344 2005-01-25 Fernando Perez <fperez@colorado.edu>
3346 2005-01-25 Fernando Perez <fperez@colorado.edu>
3345
3347
3346 * setup.py: finally, we have a true Windows installer, thanks to
3348 * setup.py: finally, we have a true Windows installer, thanks to
3347 the excellent work of Viktor Ransmayr
3349 the excellent work of Viktor Ransmayr
3348 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
3350 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
3349 Windows users. The setup routine is quite a bit cleaner thanks to
3351 Windows users. The setup routine is quite a bit cleaner thanks to
3350 this, and the post-install script uses the proper functions to
3352 this, and the post-install script uses the proper functions to
3351 allow a clean de-installation using the standard Windows Control
3353 allow a clean de-installation using the standard Windows Control
3352 Panel.
3354 Panel.
3353
3355
3354 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3356 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3355 environment variable under all OSes (including win32) if
3357 environment variable under all OSes (including win32) if
3356 available. This will give consistency to win32 users who have set
3358 available. This will give consistency to win32 users who have set
3357 this variable for any reason. If os.environ['HOME'] fails, the
3359 this variable for any reason. If os.environ['HOME'] fails, the
3358 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3360 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3359
3361
3360 2005-01-24 Fernando Perez <fperez@colorado.edu>
3362 2005-01-24 Fernando Perez <fperez@colorado.edu>
3361
3363
3362 * IPython/numutils.py (empty_like): add empty_like(), similar to
3364 * IPython/numutils.py (empty_like): add empty_like(), similar to
3363 zeros_like() but taking advantage of the new empty() Numeric routine.
3365 zeros_like() but taking advantage of the new empty() Numeric routine.
3364
3366
3365 2005-01-23 *** Released version 0.6.8
3367 2005-01-23 *** Released version 0.6.8
3366
3368
3367 2005-01-22 Fernando Perez <fperez@colorado.edu>
3369 2005-01-22 Fernando Perez <fperez@colorado.edu>
3368
3370
3369 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3371 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3370 automatic show() calls. After discussing things with JDH, it
3372 automatic show() calls. After discussing things with JDH, it
3371 turns out there are too many corner cases where this can go wrong.
3373 turns out there are too many corner cases where this can go wrong.
3372 It's best not to try to be 'too smart', and simply have ipython
3374 It's best not to try to be 'too smart', and simply have ipython
3373 reproduce as much as possible the default behavior of a normal
3375 reproduce as much as possible the default behavior of a normal
3374 python shell.
3376 python shell.
3375
3377
3376 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3378 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3377 line-splitting regexp and _prefilter() to avoid calling getattr()
3379 line-splitting regexp and _prefilter() to avoid calling getattr()
3378 on assignments. This closes
3380 on assignments. This closes
3379 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3381 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3380 readline uses getattr(), so a simple <TAB> keypress is still
3382 readline uses getattr(), so a simple <TAB> keypress is still
3381 enough to trigger getattr() calls on an object.
3383 enough to trigger getattr() calls on an object.
3382
3384
3383 2005-01-21 Fernando Perez <fperez@colorado.edu>
3385 2005-01-21 Fernando Perez <fperez@colorado.edu>
3384
3386
3385 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3387 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3386 docstring under pylab so it doesn't mask the original.
3388 docstring under pylab so it doesn't mask the original.
3387
3389
3388 2005-01-21 *** Released version 0.6.7
3390 2005-01-21 *** Released version 0.6.7
3389
3391
3390 2005-01-21 Fernando Perez <fperez@colorado.edu>
3392 2005-01-21 Fernando Perez <fperez@colorado.edu>
3391
3393
3392 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3394 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3393 signal handling for win32 users in multithreaded mode.
3395 signal handling for win32 users in multithreaded mode.
3394
3396
3395 2005-01-17 Fernando Perez <fperez@colorado.edu>
3397 2005-01-17 Fernando Perez <fperez@colorado.edu>
3396
3398
3397 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3399 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3398 instances with no __init__. After a crash report by Norbert Nemec
3400 instances with no __init__. After a crash report by Norbert Nemec
3399 <Norbert-AT-nemec-online.de>.
3401 <Norbert-AT-nemec-online.de>.
3400
3402
3401 2005-01-14 Fernando Perez <fperez@colorado.edu>
3403 2005-01-14 Fernando Perez <fperez@colorado.edu>
3402
3404
3403 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3405 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3404 names for verbose exceptions, when multiple dotted names and the
3406 names for verbose exceptions, when multiple dotted names and the
3405 'parent' object were present on the same line.
3407 'parent' object were present on the same line.
3406
3408
3407 2005-01-11 Fernando Perez <fperez@colorado.edu>
3409 2005-01-11 Fernando Perez <fperez@colorado.edu>
3408
3410
3409 * IPython/genutils.py (flag_calls): new utility to trap and flag
3411 * IPython/genutils.py (flag_calls): new utility to trap and flag
3410 calls in functions. I need it to clean up matplotlib support.
3412 calls in functions. I need it to clean up matplotlib support.
3411 Also removed some deprecated code in genutils.
3413 Also removed some deprecated code in genutils.
3412
3414
3413 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3415 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3414 that matplotlib scripts called with %run, which don't call show()
3416 that matplotlib scripts called with %run, which don't call show()
3415 themselves, still have their plotting windows open.
3417 themselves, still have their plotting windows open.
3416
3418
3417 2005-01-05 Fernando Perez <fperez@colorado.edu>
3419 2005-01-05 Fernando Perez <fperez@colorado.edu>
3418
3420
3419 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3421 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3420 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3422 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3421
3423
3422 2004-12-19 Fernando Perez <fperez@colorado.edu>
3424 2004-12-19 Fernando Perez <fperez@colorado.edu>
3423
3425
3424 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3426 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3425 parent_runcode, which was an eyesore. The same result can be
3427 parent_runcode, which was an eyesore. The same result can be
3426 obtained with Python's regular superclass mechanisms.
3428 obtained with Python's regular superclass mechanisms.
3427
3429
3428 2004-12-17 Fernando Perez <fperez@colorado.edu>
3430 2004-12-17 Fernando Perez <fperez@colorado.edu>
3429
3431
3430 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3432 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3431 reported by Prabhu.
3433 reported by Prabhu.
3432 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3434 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3433 sys.stderr) instead of explicitly calling sys.stderr. This helps
3435 sys.stderr) instead of explicitly calling sys.stderr. This helps
3434 maintain our I/O abstractions clean, for future GUI embeddings.
3436 maintain our I/O abstractions clean, for future GUI embeddings.
3435
3437
3436 * IPython/genutils.py (info): added new utility for sys.stderr
3438 * IPython/genutils.py (info): added new utility for sys.stderr
3437 unified info message handling (thin wrapper around warn()).
3439 unified info message handling (thin wrapper around warn()).
3438
3440
3439 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3441 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3440 composite (dotted) names on verbose exceptions.
3442 composite (dotted) names on verbose exceptions.
3441 (VerboseTB.nullrepr): harden against another kind of errors which
3443 (VerboseTB.nullrepr): harden against another kind of errors which
3442 Python's inspect module can trigger, and which were crashing
3444 Python's inspect module can trigger, and which were crashing
3443 IPython. Thanks to a report by Marco Lombardi
3445 IPython. Thanks to a report by Marco Lombardi
3444 <mlombard-AT-ma010192.hq.eso.org>.
3446 <mlombard-AT-ma010192.hq.eso.org>.
3445
3447
3446 2004-12-13 *** Released version 0.6.6
3448 2004-12-13 *** Released version 0.6.6
3447
3449
3448 2004-12-12 Fernando Perez <fperez@colorado.edu>
3450 2004-12-12 Fernando Perez <fperez@colorado.edu>
3449
3451
3450 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3452 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3451 generated by pygtk upon initialization if it was built without
3453 generated by pygtk upon initialization if it was built without
3452 threads (for matplotlib users). After a crash reported by
3454 threads (for matplotlib users). After a crash reported by
3453 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3455 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3454
3456
3455 * IPython/ipmaker.py (make_IPython): fix small bug in the
3457 * IPython/ipmaker.py (make_IPython): fix small bug in the
3456 import_some parameter for multiple imports.
3458 import_some parameter for multiple imports.
3457
3459
3458 * IPython/iplib.py (ipmagic): simplified the interface of
3460 * IPython/iplib.py (ipmagic): simplified the interface of
3459 ipmagic() to take a single string argument, just as it would be
3461 ipmagic() to take a single string argument, just as it would be
3460 typed at the IPython cmd line.
3462 typed at the IPython cmd line.
3461 (ipalias): Added new ipalias() with an interface identical to
3463 (ipalias): Added new ipalias() with an interface identical to
3462 ipmagic(). This completes exposing a pure python interface to the
3464 ipmagic(). This completes exposing a pure python interface to the
3463 alias and magic system, which can be used in loops or more complex
3465 alias and magic system, which can be used in loops or more complex
3464 code where IPython's automatic line mangling is not active.
3466 code where IPython's automatic line mangling is not active.
3465
3467
3466 * IPython/genutils.py (timing): changed interface of timing to
3468 * IPython/genutils.py (timing): changed interface of timing to
3467 simply run code once, which is the most common case. timings()
3469 simply run code once, which is the most common case. timings()
3468 remains unchanged, for the cases where you want multiple runs.
3470 remains unchanged, for the cases where you want multiple runs.
3469
3471
3470 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3472 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3471 bug where Python2.2 crashes with exec'ing code which does not end
3473 bug where Python2.2 crashes with exec'ing code which does not end
3472 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3474 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3473 before.
3475 before.
3474
3476
3475 2004-12-10 Fernando Perez <fperez@colorado.edu>
3477 2004-12-10 Fernando Perez <fperez@colorado.edu>
3476
3478
3477 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3479 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3478 -t to -T, to accomodate the new -t flag in %run (the %run and
3480 -t to -T, to accomodate the new -t flag in %run (the %run and
3479 %prun options are kind of intermixed, and it's not easy to change
3481 %prun options are kind of intermixed, and it's not easy to change
3480 this with the limitations of python's getopt).
3482 this with the limitations of python's getopt).
3481
3483
3482 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3484 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3483 the execution of scripts. It's not as fine-tuned as timeit.py,
3485 the execution of scripts. It's not as fine-tuned as timeit.py,
3484 but it works from inside ipython (and under 2.2, which lacks
3486 but it works from inside ipython (and under 2.2, which lacks
3485 timeit.py). Optionally a number of runs > 1 can be given for
3487 timeit.py). Optionally a number of runs > 1 can be given for
3486 timing very short-running code.
3488 timing very short-running code.
3487
3489
3488 * IPython/genutils.py (uniq_stable): new routine which returns a
3490 * IPython/genutils.py (uniq_stable): new routine which returns a
3489 list of unique elements in any iterable, but in stable order of
3491 list of unique elements in any iterable, but in stable order of
3490 appearance. I needed this for the ultraTB fixes, and it's a handy
3492 appearance. I needed this for the ultraTB fixes, and it's a handy
3491 utility.
3493 utility.
3492
3494
3493 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3495 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3494 dotted names in Verbose exceptions. This had been broken since
3496 dotted names in Verbose exceptions. This had been broken since
3495 the very start, now x.y will properly be printed in a Verbose
3497 the very start, now x.y will properly be printed in a Verbose
3496 traceback, instead of x being shown and y appearing always as an
3498 traceback, instead of x being shown and y appearing always as an
3497 'undefined global'. Getting this to work was a bit tricky,
3499 'undefined global'. Getting this to work was a bit tricky,
3498 because by default python tokenizers are stateless. Saved by
3500 because by default python tokenizers are stateless. Saved by
3499 python's ability to easily add a bit of state to an arbitrary
3501 python's ability to easily add a bit of state to an arbitrary
3500 function (without needing to build a full-blown callable object).
3502 function (without needing to build a full-blown callable object).
3501
3503
3502 Also big cleanup of this code, which had horrendous runtime
3504 Also big cleanup of this code, which had horrendous runtime
3503 lookups of zillions of attributes for colorization. Moved all
3505 lookups of zillions of attributes for colorization. Moved all
3504 this code into a few templates, which make it cleaner and quicker.
3506 this code into a few templates, which make it cleaner and quicker.
3505
3507
3506 Printout quality was also improved for Verbose exceptions: one
3508 Printout quality was also improved for Verbose exceptions: one
3507 variable per line, and memory addresses are printed (this can be
3509 variable per line, and memory addresses are printed (this can be
3508 quite handy in nasty debugging situations, which is what Verbose
3510 quite handy in nasty debugging situations, which is what Verbose
3509 is for).
3511 is for).
3510
3512
3511 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3513 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3512 the command line as scripts to be loaded by embedded instances.
3514 the command line as scripts to be loaded by embedded instances.
3513 Doing so has the potential for an infinite recursion if there are
3515 Doing so has the potential for an infinite recursion if there are
3514 exceptions thrown in the process. This fixes a strange crash
3516 exceptions thrown in the process. This fixes a strange crash
3515 reported by Philippe MULLER <muller-AT-irit.fr>.
3517 reported by Philippe MULLER <muller-AT-irit.fr>.
3516
3518
3517 2004-12-09 Fernando Perez <fperez@colorado.edu>
3519 2004-12-09 Fernando Perez <fperez@colorado.edu>
3518
3520
3519 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3521 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3520 to reflect new names in matplotlib, which now expose the
3522 to reflect new names in matplotlib, which now expose the
3521 matlab-compatible interface via a pylab module instead of the
3523 matlab-compatible interface via a pylab module instead of the
3522 'matlab' name. The new code is backwards compatible, so users of
3524 'matlab' name. The new code is backwards compatible, so users of
3523 all matplotlib versions are OK. Patch by J. Hunter.
3525 all matplotlib versions are OK. Patch by J. Hunter.
3524
3526
3525 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3527 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3526 of __init__ docstrings for instances (class docstrings are already
3528 of __init__ docstrings for instances (class docstrings are already
3527 automatically printed). Instances with customized docstrings
3529 automatically printed). Instances with customized docstrings
3528 (indep. of the class) are also recognized and all 3 separate
3530 (indep. of the class) are also recognized and all 3 separate
3529 docstrings are printed (instance, class, constructor). After some
3531 docstrings are printed (instance, class, constructor). After some
3530 comments/suggestions by J. Hunter.
3532 comments/suggestions by J. Hunter.
3531
3533
3532 2004-12-05 Fernando Perez <fperez@colorado.edu>
3534 2004-12-05 Fernando Perez <fperez@colorado.edu>
3533
3535
3534 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3536 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3535 warnings when tab-completion fails and triggers an exception.
3537 warnings when tab-completion fails and triggers an exception.
3536
3538
3537 2004-12-03 Fernando Perez <fperez@colorado.edu>
3539 2004-12-03 Fernando Perez <fperez@colorado.edu>
3538
3540
3539 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3541 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3540 be triggered when using 'run -p'. An incorrect option flag was
3542 be triggered when using 'run -p'. An incorrect option flag was
3541 being set ('d' instead of 'D').
3543 being set ('d' instead of 'D').
3542 (manpage): fix missing escaped \- sign.
3544 (manpage): fix missing escaped \- sign.
3543
3545
3544 2004-11-30 *** Released version 0.6.5
3546 2004-11-30 *** Released version 0.6.5
3545
3547
3546 2004-11-30 Fernando Perez <fperez@colorado.edu>
3548 2004-11-30 Fernando Perez <fperez@colorado.edu>
3547
3549
3548 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3550 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3549 setting with -d option.
3551 setting with -d option.
3550
3552
3551 * setup.py (docfiles): Fix problem where the doc glob I was using
3553 * setup.py (docfiles): Fix problem where the doc glob I was using
3552 was COMPLETELY BROKEN. It was giving the right files by pure
3554 was COMPLETELY BROKEN. It was giving the right files by pure
3553 accident, but failed once I tried to include ipython.el. Note:
3555 accident, but failed once I tried to include ipython.el. Note:
3554 glob() does NOT allow you to do exclusion on multiple endings!
3556 glob() does NOT allow you to do exclusion on multiple endings!
3555
3557
3556 2004-11-29 Fernando Perez <fperez@colorado.edu>
3558 2004-11-29 Fernando Perez <fperez@colorado.edu>
3557
3559
3558 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3560 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3559 the manpage as the source. Better formatting & consistency.
3561 the manpage as the source. Better formatting & consistency.
3560
3562
3561 * IPython/Magic.py (magic_run): Added new -d option, to run
3563 * IPython/Magic.py (magic_run): Added new -d option, to run
3562 scripts under the control of the python pdb debugger. Note that
3564 scripts under the control of the python pdb debugger. Note that
3563 this required changing the %prun option -d to -D, to avoid a clash
3565 this required changing the %prun option -d to -D, to avoid a clash
3564 (since %run must pass options to %prun, and getopt is too dumb to
3566 (since %run must pass options to %prun, and getopt is too dumb to
3565 handle options with string values with embedded spaces). Thanks
3567 handle options with string values with embedded spaces). Thanks
3566 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3568 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3567 (magic_who_ls): added type matching to %who and %whos, so that one
3569 (magic_who_ls): added type matching to %who and %whos, so that one
3568 can filter their output to only include variables of certain
3570 can filter their output to only include variables of certain
3569 types. Another suggestion by Matthew.
3571 types. Another suggestion by Matthew.
3570 (magic_whos): Added memory summaries in kb and Mb for arrays.
3572 (magic_whos): Added memory summaries in kb and Mb for arrays.
3571 (magic_who): Improve formatting (break lines every 9 vars).
3573 (magic_who): Improve formatting (break lines every 9 vars).
3572
3574
3573 2004-11-28 Fernando Perez <fperez@colorado.edu>
3575 2004-11-28 Fernando Perez <fperez@colorado.edu>
3574
3576
3575 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3577 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3576 cache when empty lines were present.
3578 cache when empty lines were present.
3577
3579
3578 2004-11-24 Fernando Perez <fperez@colorado.edu>
3580 2004-11-24 Fernando Perez <fperez@colorado.edu>
3579
3581
3580 * IPython/usage.py (__doc__): document the re-activated threading
3582 * IPython/usage.py (__doc__): document the re-activated threading
3581 options for WX and GTK.
3583 options for WX and GTK.
3582
3584
3583 2004-11-23 Fernando Perez <fperez@colorado.edu>
3585 2004-11-23 Fernando Perez <fperez@colorado.edu>
3584
3586
3585 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3587 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3586 the -wthread and -gthread options, along with a new -tk one to try
3588 the -wthread and -gthread options, along with a new -tk one to try
3587 and coordinate Tk threading with wx/gtk. The tk support is very
3589 and coordinate Tk threading with wx/gtk. The tk support is very
3588 platform dependent, since it seems to require Tcl and Tk to be
3590 platform dependent, since it seems to require Tcl and Tk to be
3589 built with threads (Fedora1/2 appears NOT to have it, but in
3591 built with threads (Fedora1/2 appears NOT to have it, but in
3590 Prabhu's Debian boxes it works OK). But even with some Tk
3592 Prabhu's Debian boxes it works OK). But even with some Tk
3591 limitations, this is a great improvement.
3593 limitations, this is a great improvement.
3592
3594
3593 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3595 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3594 info in user prompts. Patch by Prabhu.
3596 info in user prompts. Patch by Prabhu.
3595
3597
3596 2004-11-18 Fernando Perez <fperez@colorado.edu>
3598 2004-11-18 Fernando Perez <fperez@colorado.edu>
3597
3599
3598 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3600 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3599 EOFErrors and bail, to avoid infinite loops if a non-terminating
3601 EOFErrors and bail, to avoid infinite loops if a non-terminating
3600 file is fed into ipython. Patch submitted in issue 19 by user,
3602 file is fed into ipython. Patch submitted in issue 19 by user,
3601 many thanks.
3603 many thanks.
3602
3604
3603 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3605 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3604 autoquote/parens in continuation prompts, which can cause lots of
3606 autoquote/parens in continuation prompts, which can cause lots of
3605 problems. Closes roundup issue 20.
3607 problems. Closes roundup issue 20.
3606
3608
3607 2004-11-17 Fernando Perez <fperez@colorado.edu>
3609 2004-11-17 Fernando Perez <fperez@colorado.edu>
3608
3610
3609 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3611 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3610 reported as debian bug #280505. I'm not sure my local changelog
3612 reported as debian bug #280505. I'm not sure my local changelog
3611 entry has the proper debian format (Jack?).
3613 entry has the proper debian format (Jack?).
3612
3614
3613 2004-11-08 *** Released version 0.6.4
3615 2004-11-08 *** Released version 0.6.4
3614
3616
3615 2004-11-08 Fernando Perez <fperez@colorado.edu>
3617 2004-11-08 Fernando Perez <fperez@colorado.edu>
3616
3618
3617 * IPython/iplib.py (init_readline): Fix exit message for Windows
3619 * IPython/iplib.py (init_readline): Fix exit message for Windows
3618 when readline is active. Thanks to a report by Eric Jones
3620 when readline is active. Thanks to a report by Eric Jones
3619 <eric-AT-enthought.com>.
3621 <eric-AT-enthought.com>.
3620
3622
3621 2004-11-07 Fernando Perez <fperez@colorado.edu>
3623 2004-11-07 Fernando Perez <fperez@colorado.edu>
3622
3624
3623 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3625 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3624 sometimes seen by win2k/cygwin users.
3626 sometimes seen by win2k/cygwin users.
3625
3627
3626 2004-11-06 Fernando Perez <fperez@colorado.edu>
3628 2004-11-06 Fernando Perez <fperez@colorado.edu>
3627
3629
3628 * IPython/iplib.py (interact): Change the handling of %Exit from
3630 * IPython/iplib.py (interact): Change the handling of %Exit from
3629 trying to propagate a SystemExit to an internal ipython flag.
3631 trying to propagate a SystemExit to an internal ipython flag.
3630 This is less elegant than using Python's exception mechanism, but
3632 This is less elegant than using Python's exception mechanism, but
3631 I can't get that to work reliably with threads, so under -pylab
3633 I can't get that to work reliably with threads, so under -pylab
3632 %Exit was hanging IPython. Cross-thread exception handling is
3634 %Exit was hanging IPython. Cross-thread exception handling is
3633 really a bitch. Thaks to a bug report by Stephen Walton
3635 really a bitch. Thaks to a bug report by Stephen Walton
3634 <stephen.walton-AT-csun.edu>.
3636 <stephen.walton-AT-csun.edu>.
3635
3637
3636 2004-11-04 Fernando Perez <fperez@colorado.edu>
3638 2004-11-04 Fernando Perez <fperez@colorado.edu>
3637
3639
3638 * IPython/iplib.py (raw_input_original): store a pointer to the
3640 * IPython/iplib.py (raw_input_original): store a pointer to the
3639 true raw_input to harden against code which can modify it
3641 true raw_input to harden against code which can modify it
3640 (wx.py.PyShell does this and would otherwise crash ipython).
3642 (wx.py.PyShell does this and would otherwise crash ipython).
3641 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3643 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3642
3644
3643 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3645 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3644 Ctrl-C problem, which does not mess up the input line.
3646 Ctrl-C problem, which does not mess up the input line.
3645
3647
3646 2004-11-03 Fernando Perez <fperez@colorado.edu>
3648 2004-11-03 Fernando Perez <fperez@colorado.edu>
3647
3649
3648 * IPython/Release.py: Changed licensing to BSD, in all files.
3650 * IPython/Release.py: Changed licensing to BSD, in all files.
3649 (name): lowercase name for tarball/RPM release.
3651 (name): lowercase name for tarball/RPM release.
3650
3652
3651 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3653 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3652 use throughout ipython.
3654 use throughout ipython.
3653
3655
3654 * IPython/Magic.py (Magic._ofind): Switch to using the new
3656 * IPython/Magic.py (Magic._ofind): Switch to using the new
3655 OInspect.getdoc() function.
3657 OInspect.getdoc() function.
3656
3658
3657 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3659 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3658 of the line currently being canceled via Ctrl-C. It's extremely
3660 of the line currently being canceled via Ctrl-C. It's extremely
3659 ugly, but I don't know how to do it better (the problem is one of
3661 ugly, but I don't know how to do it better (the problem is one of
3660 handling cross-thread exceptions).
3662 handling cross-thread exceptions).
3661
3663
3662 2004-10-28 Fernando Perez <fperez@colorado.edu>
3664 2004-10-28 Fernando Perez <fperez@colorado.edu>
3663
3665
3664 * IPython/Shell.py (signal_handler): add signal handlers to trap
3666 * IPython/Shell.py (signal_handler): add signal handlers to trap
3665 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3667 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3666 report by Francesc Alted.
3668 report by Francesc Alted.
3667
3669
3668 2004-10-21 Fernando Perez <fperez@colorado.edu>
3670 2004-10-21 Fernando Perez <fperez@colorado.edu>
3669
3671
3670 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3672 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3671 to % for pysh syntax extensions.
3673 to % for pysh syntax extensions.
3672
3674
3673 2004-10-09 Fernando Perez <fperez@colorado.edu>
3675 2004-10-09 Fernando Perez <fperez@colorado.edu>
3674
3676
3675 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3677 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3676 arrays to print a more useful summary, without calling str(arr).
3678 arrays to print a more useful summary, without calling str(arr).
3677 This avoids the problem of extremely lengthy computations which
3679 This avoids the problem of extremely lengthy computations which
3678 occur if arr is large, and appear to the user as a system lockup
3680 occur if arr is large, and appear to the user as a system lockup
3679 with 100% cpu activity. After a suggestion by Kristian Sandberg
3681 with 100% cpu activity. After a suggestion by Kristian Sandberg
3680 <Kristian.Sandberg@colorado.edu>.
3682 <Kristian.Sandberg@colorado.edu>.
3681 (Magic.__init__): fix bug in global magic escapes not being
3683 (Magic.__init__): fix bug in global magic escapes not being
3682 correctly set.
3684 correctly set.
3683
3685
3684 2004-10-08 Fernando Perez <fperez@colorado.edu>
3686 2004-10-08 Fernando Perez <fperez@colorado.edu>
3685
3687
3686 * IPython/Magic.py (__license__): change to absolute imports of
3688 * IPython/Magic.py (__license__): change to absolute imports of
3687 ipython's own internal packages, to start adapting to the absolute
3689 ipython's own internal packages, to start adapting to the absolute
3688 import requirement of PEP-328.
3690 import requirement of PEP-328.
3689
3691
3690 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3692 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3691 files, and standardize author/license marks through the Release
3693 files, and standardize author/license marks through the Release
3692 module instead of having per/file stuff (except for files with
3694 module instead of having per/file stuff (except for files with
3693 particular licenses, like the MIT/PSF-licensed codes).
3695 particular licenses, like the MIT/PSF-licensed codes).
3694
3696
3695 * IPython/Debugger.py: remove dead code for python 2.1
3697 * IPython/Debugger.py: remove dead code for python 2.1
3696
3698
3697 2004-10-04 Fernando Perez <fperez@colorado.edu>
3699 2004-10-04 Fernando Perez <fperez@colorado.edu>
3698
3700
3699 * IPython/iplib.py (ipmagic): New function for accessing magics
3701 * IPython/iplib.py (ipmagic): New function for accessing magics
3700 via a normal python function call.
3702 via a normal python function call.
3701
3703
3702 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3704 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3703 from '@' to '%', to accomodate the new @decorator syntax of python
3705 from '@' to '%', to accomodate the new @decorator syntax of python
3704 2.4.
3706 2.4.
3705
3707
3706 2004-09-29 Fernando Perez <fperez@colorado.edu>
3708 2004-09-29 Fernando Perez <fperez@colorado.edu>
3707
3709
3708 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3710 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3709 matplotlib.use to prevent running scripts which try to switch
3711 matplotlib.use to prevent running scripts which try to switch
3710 interactive backends from within ipython. This will just crash
3712 interactive backends from within ipython. This will just crash
3711 the python interpreter, so we can't allow it (but a detailed error
3713 the python interpreter, so we can't allow it (but a detailed error
3712 is given to the user).
3714 is given to the user).
3713
3715
3714 2004-09-28 Fernando Perez <fperez@colorado.edu>
3716 2004-09-28 Fernando Perez <fperez@colorado.edu>
3715
3717
3716 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3718 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3717 matplotlib-related fixes so that using @run with non-matplotlib
3719 matplotlib-related fixes so that using @run with non-matplotlib
3718 scripts doesn't pop up spurious plot windows. This requires
3720 scripts doesn't pop up spurious plot windows. This requires
3719 matplotlib >= 0.63, where I had to make some changes as well.
3721 matplotlib >= 0.63, where I had to make some changes as well.
3720
3722
3721 * IPython/ipmaker.py (make_IPython): update version requirement to
3723 * IPython/ipmaker.py (make_IPython): update version requirement to
3722 python 2.2.
3724 python 2.2.
3723
3725
3724 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3726 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3725 banner arg for embedded customization.
3727 banner arg for embedded customization.
3726
3728
3727 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3729 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3728 explicit uses of __IP as the IPython's instance name. Now things
3730 explicit uses of __IP as the IPython's instance name. Now things
3729 are properly handled via the shell.name value. The actual code
3731 are properly handled via the shell.name value. The actual code
3730 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3732 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3731 is much better than before. I'll clean things completely when the
3733 is much better than before. I'll clean things completely when the
3732 magic stuff gets a real overhaul.
3734 magic stuff gets a real overhaul.
3733
3735
3734 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3736 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3735 minor changes to debian dir.
3737 minor changes to debian dir.
3736
3738
3737 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3739 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3738 pointer to the shell itself in the interactive namespace even when
3740 pointer to the shell itself in the interactive namespace even when
3739 a user-supplied dict is provided. This is needed for embedding
3741 a user-supplied dict is provided. This is needed for embedding
3740 purposes (found by tests with Michel Sanner).
3742 purposes (found by tests with Michel Sanner).
3741
3743
3742 2004-09-27 Fernando Perez <fperez@colorado.edu>
3744 2004-09-27 Fernando Perez <fperez@colorado.edu>
3743
3745
3744 * IPython/UserConfig/ipythonrc: remove []{} from
3746 * IPython/UserConfig/ipythonrc: remove []{} from
3745 readline_remove_delims, so that things like [modname.<TAB> do
3747 readline_remove_delims, so that things like [modname.<TAB> do
3746 proper completion. This disables [].TAB, but that's a less common
3748 proper completion. This disables [].TAB, but that's a less common
3747 case than module names in list comprehensions, for example.
3749 case than module names in list comprehensions, for example.
3748 Thanks to a report by Andrea Riciputi.
3750 Thanks to a report by Andrea Riciputi.
3749
3751
3750 2004-09-09 Fernando Perez <fperez@colorado.edu>
3752 2004-09-09 Fernando Perez <fperez@colorado.edu>
3751
3753
3752 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3754 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3753 blocking problems in win32 and osx. Fix by John.
3755 blocking problems in win32 and osx. Fix by John.
3754
3756
3755 2004-09-08 Fernando Perez <fperez@colorado.edu>
3757 2004-09-08 Fernando Perez <fperez@colorado.edu>
3756
3758
3757 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3759 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3758 for Win32 and OSX. Fix by John Hunter.
3760 for Win32 and OSX. Fix by John Hunter.
3759
3761
3760 2004-08-30 *** Released version 0.6.3
3762 2004-08-30 *** Released version 0.6.3
3761
3763
3762 2004-08-30 Fernando Perez <fperez@colorado.edu>
3764 2004-08-30 Fernando Perez <fperez@colorado.edu>
3763
3765
3764 * setup.py (isfile): Add manpages to list of dependent files to be
3766 * setup.py (isfile): Add manpages to list of dependent files to be
3765 updated.
3767 updated.
3766
3768
3767 2004-08-27 Fernando Perez <fperez@colorado.edu>
3769 2004-08-27 Fernando Perez <fperez@colorado.edu>
3768
3770
3769 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3771 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3770 for now. They don't really work with standalone WX/GTK code
3772 for now. They don't really work with standalone WX/GTK code
3771 (though matplotlib IS working fine with both of those backends).
3773 (though matplotlib IS working fine with both of those backends).
3772 This will neeed much more testing. I disabled most things with
3774 This will neeed much more testing. I disabled most things with
3773 comments, so turning it back on later should be pretty easy.
3775 comments, so turning it back on later should be pretty easy.
3774
3776
3775 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3777 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3776 autocalling of expressions like r'foo', by modifying the line
3778 autocalling of expressions like r'foo', by modifying the line
3777 split regexp. Closes
3779 split regexp. Closes
3778 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3780 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3779 Riley <ipythonbugs-AT-sabi.net>.
3781 Riley <ipythonbugs-AT-sabi.net>.
3780 (InteractiveShell.mainloop): honor --nobanner with banner
3782 (InteractiveShell.mainloop): honor --nobanner with banner
3781 extensions.
3783 extensions.
3782
3784
3783 * IPython/Shell.py: Significant refactoring of all classes, so
3785 * IPython/Shell.py: Significant refactoring of all classes, so
3784 that we can really support ALL matplotlib backends and threading
3786 that we can really support ALL matplotlib backends and threading
3785 models (John spotted a bug with Tk which required this). Now we
3787 models (John spotted a bug with Tk which required this). Now we
3786 should support single-threaded, WX-threads and GTK-threads, both
3788 should support single-threaded, WX-threads and GTK-threads, both
3787 for generic code and for matplotlib.
3789 for generic code and for matplotlib.
3788
3790
3789 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3791 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3790 -pylab, to simplify things for users. Will also remove the pylab
3792 -pylab, to simplify things for users. Will also remove the pylab
3791 profile, since now all of matplotlib configuration is directly
3793 profile, since now all of matplotlib configuration is directly
3792 handled here. This also reduces startup time.
3794 handled here. This also reduces startup time.
3793
3795
3794 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3796 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3795 shell wasn't being correctly called. Also in IPShellWX.
3797 shell wasn't being correctly called. Also in IPShellWX.
3796
3798
3797 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3799 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3798 fine-tune banner.
3800 fine-tune banner.
3799
3801
3800 * IPython/numutils.py (spike): Deprecate these spike functions,
3802 * IPython/numutils.py (spike): Deprecate these spike functions,
3801 delete (long deprecated) gnuplot_exec handler.
3803 delete (long deprecated) gnuplot_exec handler.
3802
3804
3803 2004-08-26 Fernando Perez <fperez@colorado.edu>
3805 2004-08-26 Fernando Perez <fperez@colorado.edu>
3804
3806
3805 * ipython.1: Update for threading options, plus some others which
3807 * ipython.1: Update for threading options, plus some others which
3806 were missing.
3808 were missing.
3807
3809
3808 * IPython/ipmaker.py (__call__): Added -wthread option for
3810 * IPython/ipmaker.py (__call__): Added -wthread option for
3809 wxpython thread handling. Make sure threading options are only
3811 wxpython thread handling. Make sure threading options are only
3810 valid at the command line.
3812 valid at the command line.
3811
3813
3812 * scripts/ipython: moved shell selection into a factory function
3814 * scripts/ipython: moved shell selection into a factory function
3813 in Shell.py, to keep the starter script to a minimum.
3815 in Shell.py, to keep the starter script to a minimum.
3814
3816
3815 2004-08-25 Fernando Perez <fperez@colorado.edu>
3817 2004-08-25 Fernando Perez <fperez@colorado.edu>
3816
3818
3817 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3819 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3818 John. Along with some recent changes he made to matplotlib, the
3820 John. Along with some recent changes he made to matplotlib, the
3819 next versions of both systems should work very well together.
3821 next versions of both systems should work very well together.
3820
3822
3821 2004-08-24 Fernando Perez <fperez@colorado.edu>
3823 2004-08-24 Fernando Perez <fperez@colorado.edu>
3822
3824
3823 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3825 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3824 tried to switch the profiling to using hotshot, but I'm getting
3826 tried to switch the profiling to using hotshot, but I'm getting
3825 strange errors from prof.runctx() there. I may be misreading the
3827 strange errors from prof.runctx() there. I may be misreading the
3826 docs, but it looks weird. For now the profiling code will
3828 docs, but it looks weird. For now the profiling code will
3827 continue to use the standard profiler.
3829 continue to use the standard profiler.
3828
3830
3829 2004-08-23 Fernando Perez <fperez@colorado.edu>
3831 2004-08-23 Fernando Perez <fperez@colorado.edu>
3830
3832
3831 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3833 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3832 threaded shell, by John Hunter. It's not quite ready yet, but
3834 threaded shell, by John Hunter. It's not quite ready yet, but
3833 close.
3835 close.
3834
3836
3835 2004-08-22 Fernando Perez <fperez@colorado.edu>
3837 2004-08-22 Fernando Perez <fperez@colorado.edu>
3836
3838
3837 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3839 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3838 in Magic and ultraTB.
3840 in Magic and ultraTB.
3839
3841
3840 * ipython.1: document threading options in manpage.
3842 * ipython.1: document threading options in manpage.
3841
3843
3842 * scripts/ipython: Changed name of -thread option to -gthread,
3844 * scripts/ipython: Changed name of -thread option to -gthread,
3843 since this is GTK specific. I want to leave the door open for a
3845 since this is GTK specific. I want to leave the door open for a
3844 -wthread option for WX, which will most likely be necessary. This
3846 -wthread option for WX, which will most likely be necessary. This
3845 change affects usage and ipmaker as well.
3847 change affects usage and ipmaker as well.
3846
3848
3847 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3849 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3848 handle the matplotlib shell issues. Code by John Hunter
3850 handle the matplotlib shell issues. Code by John Hunter
3849 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3851 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3850 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3852 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3851 broken (and disabled for end users) for now, but it puts the
3853 broken (and disabled for end users) for now, but it puts the
3852 infrastructure in place.
3854 infrastructure in place.
3853
3855
3854 2004-08-21 Fernando Perez <fperez@colorado.edu>
3856 2004-08-21 Fernando Perez <fperez@colorado.edu>
3855
3857
3856 * ipythonrc-pylab: Add matplotlib support.
3858 * ipythonrc-pylab: Add matplotlib support.
3857
3859
3858 * matplotlib_config.py: new files for matplotlib support, part of
3860 * matplotlib_config.py: new files for matplotlib support, part of
3859 the pylab profile.
3861 the pylab profile.
3860
3862
3861 * IPython/usage.py (__doc__): documented the threading options.
3863 * IPython/usage.py (__doc__): documented the threading options.
3862
3864
3863 2004-08-20 Fernando Perez <fperez@colorado.edu>
3865 2004-08-20 Fernando Perez <fperez@colorado.edu>
3864
3866
3865 * ipython: Modified the main calling routine to handle the -thread
3867 * ipython: Modified the main calling routine to handle the -thread
3866 and -mpthread options. This needs to be done as a top-level hack,
3868 and -mpthread options. This needs to be done as a top-level hack,
3867 because it determines which class to instantiate for IPython
3869 because it determines which class to instantiate for IPython
3868 itself.
3870 itself.
3869
3871
3870 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3872 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3871 classes to support multithreaded GTK operation without blocking,
3873 classes to support multithreaded GTK operation without blocking,
3872 and matplotlib with all backends. This is a lot of still very
3874 and matplotlib with all backends. This is a lot of still very
3873 experimental code, and threads are tricky. So it may still have a
3875 experimental code, and threads are tricky. So it may still have a
3874 few rough edges... This code owes a lot to
3876 few rough edges... This code owes a lot to
3875 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3877 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3876 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3878 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3877 to John Hunter for all the matplotlib work.
3879 to John Hunter for all the matplotlib work.
3878
3880
3879 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3881 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3880 options for gtk thread and matplotlib support.
3882 options for gtk thread and matplotlib support.
3881
3883
3882 2004-08-16 Fernando Perez <fperez@colorado.edu>
3884 2004-08-16 Fernando Perez <fperez@colorado.edu>
3883
3885
3884 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3886 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3885 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3887 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3886 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3888 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3887
3889
3888 2004-08-11 Fernando Perez <fperez@colorado.edu>
3890 2004-08-11 Fernando Perez <fperez@colorado.edu>
3889
3891
3890 * setup.py (isfile): Fix build so documentation gets updated for
3892 * setup.py (isfile): Fix build so documentation gets updated for
3891 rpms (it was only done for .tgz builds).
3893 rpms (it was only done for .tgz builds).
3892
3894
3893 2004-08-10 Fernando Perez <fperez@colorado.edu>
3895 2004-08-10 Fernando Perez <fperez@colorado.edu>
3894
3896
3895 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3897 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3896
3898
3897 * iplib.py : Silence syntax error exceptions in tab-completion.
3899 * iplib.py : Silence syntax error exceptions in tab-completion.
3898
3900
3899 2004-08-05 Fernando Perez <fperez@colorado.edu>
3901 2004-08-05 Fernando Perez <fperez@colorado.edu>
3900
3902
3901 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3903 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3902 'color off' mark for continuation prompts. This was causing long
3904 'color off' mark for continuation prompts. This was causing long
3903 continuation lines to mis-wrap.
3905 continuation lines to mis-wrap.
3904
3906
3905 2004-08-01 Fernando Perez <fperez@colorado.edu>
3907 2004-08-01 Fernando Perez <fperez@colorado.edu>
3906
3908
3907 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3909 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3908 for building ipython to be a parameter. All this is necessary
3910 for building ipython to be a parameter. All this is necessary
3909 right now to have a multithreaded version, but this insane
3911 right now to have a multithreaded version, but this insane
3910 non-design will be cleaned up soon. For now, it's a hack that
3912 non-design will be cleaned up soon. For now, it's a hack that
3911 works.
3913 works.
3912
3914
3913 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3915 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3914 args in various places. No bugs so far, but it's a dangerous
3916 args in various places. No bugs so far, but it's a dangerous
3915 practice.
3917 practice.
3916
3918
3917 2004-07-31 Fernando Perez <fperez@colorado.edu>
3919 2004-07-31 Fernando Perez <fperez@colorado.edu>
3918
3920
3919 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3921 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3920 fix completion of files with dots in their names under most
3922 fix completion of files with dots in their names under most
3921 profiles (pysh was OK because the completion order is different).
3923 profiles (pysh was OK because the completion order is different).
3922
3924
3923 2004-07-27 Fernando Perez <fperez@colorado.edu>
3925 2004-07-27 Fernando Perez <fperez@colorado.edu>
3924
3926
3925 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3927 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3926 keywords manually, b/c the one in keyword.py was removed in python
3928 keywords manually, b/c the one in keyword.py was removed in python
3927 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3929 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3928 This is NOT a bug under python 2.3 and earlier.
3930 This is NOT a bug under python 2.3 and earlier.
3929
3931
3930 2004-07-26 Fernando Perez <fperez@colorado.edu>
3932 2004-07-26 Fernando Perez <fperez@colorado.edu>
3931
3933
3932 * IPython/ultraTB.py (VerboseTB.text): Add another
3934 * IPython/ultraTB.py (VerboseTB.text): Add another
3933 linecache.checkcache() call to try to prevent inspect.py from
3935 linecache.checkcache() call to try to prevent inspect.py from
3934 crashing under python 2.3. I think this fixes
3936 crashing under python 2.3. I think this fixes
3935 http://www.scipy.net/roundup/ipython/issue17.
3937 http://www.scipy.net/roundup/ipython/issue17.
3936
3938
3937 2004-07-26 *** Released version 0.6.2
3939 2004-07-26 *** Released version 0.6.2
3938
3940
3939 2004-07-26 Fernando Perez <fperez@colorado.edu>
3941 2004-07-26 Fernando Perez <fperez@colorado.edu>
3940
3942
3941 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3943 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3942 fail for any number.
3944 fail for any number.
3943 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3945 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3944 empty bookmarks.
3946 empty bookmarks.
3945
3947
3946 2004-07-26 *** Released version 0.6.1
3948 2004-07-26 *** Released version 0.6.1
3947
3949
3948 2004-07-26 Fernando Perez <fperez@colorado.edu>
3950 2004-07-26 Fernando Perez <fperez@colorado.edu>
3949
3951
3950 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3952 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3951
3953
3952 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3954 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3953 escaping '()[]{}' in filenames.
3955 escaping '()[]{}' in filenames.
3954
3956
3955 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3957 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3956 Python 2.2 users who lack a proper shlex.split.
3958 Python 2.2 users who lack a proper shlex.split.
3957
3959
3958 2004-07-19 Fernando Perez <fperez@colorado.edu>
3960 2004-07-19 Fernando Perez <fperez@colorado.edu>
3959
3961
3960 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3962 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3961 for reading readline's init file. I follow the normal chain:
3963 for reading readline's init file. I follow the normal chain:
3962 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3964 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3963 report by Mike Heeter. This closes
3965 report by Mike Heeter. This closes
3964 http://www.scipy.net/roundup/ipython/issue16.
3966 http://www.scipy.net/roundup/ipython/issue16.
3965
3967
3966 2004-07-18 Fernando Perez <fperez@colorado.edu>
3968 2004-07-18 Fernando Perez <fperez@colorado.edu>
3967
3969
3968 * IPython/iplib.py (__init__): Add better handling of '\' under
3970 * IPython/iplib.py (__init__): Add better handling of '\' under
3969 Win32 for filenames. After a patch by Ville.
3971 Win32 for filenames. After a patch by Ville.
3970
3972
3971 2004-07-17 Fernando Perez <fperez@colorado.edu>
3973 2004-07-17 Fernando Perez <fperez@colorado.edu>
3972
3974
3973 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3975 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3974 autocalling would be triggered for 'foo is bar' if foo is
3976 autocalling would be triggered for 'foo is bar' if foo is
3975 callable. I also cleaned up the autocall detection code to use a
3977 callable. I also cleaned up the autocall detection code to use a
3976 regexp, which is faster. Bug reported by Alexander Schmolck.
3978 regexp, which is faster. Bug reported by Alexander Schmolck.
3977
3979
3978 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3980 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3979 '?' in them would confuse the help system. Reported by Alex
3981 '?' in them would confuse the help system. Reported by Alex
3980 Schmolck.
3982 Schmolck.
3981
3983
3982 2004-07-16 Fernando Perez <fperez@colorado.edu>
3984 2004-07-16 Fernando Perez <fperez@colorado.edu>
3983
3985
3984 * IPython/GnuplotInteractive.py (__all__): added plot2.
3986 * IPython/GnuplotInteractive.py (__all__): added plot2.
3985
3987
3986 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3988 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3987 plotting dictionaries, lists or tuples of 1d arrays.
3989 plotting dictionaries, lists or tuples of 1d arrays.
3988
3990
3989 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3991 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3990 optimizations.
3992 optimizations.
3991
3993
3992 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3994 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3993 the information which was there from Janko's original IPP code:
3995 the information which was there from Janko's original IPP code:
3994
3996
3995 03.05.99 20:53 porto.ifm.uni-kiel.de
3997 03.05.99 20:53 porto.ifm.uni-kiel.de
3996 --Started changelog.
3998 --Started changelog.
3997 --make clear do what it say it does
3999 --make clear do what it say it does
3998 --added pretty output of lines from inputcache
4000 --added pretty output of lines from inputcache
3999 --Made Logger a mixin class, simplifies handling of switches
4001 --Made Logger a mixin class, simplifies handling of switches
4000 --Added own completer class. .string<TAB> expands to last history
4002 --Added own completer class. .string<TAB> expands to last history
4001 line which starts with string. The new expansion is also present
4003 line which starts with string. The new expansion is also present
4002 with Ctrl-r from the readline library. But this shows, who this
4004 with Ctrl-r from the readline library. But this shows, who this
4003 can be done for other cases.
4005 can be done for other cases.
4004 --Added convention that all shell functions should accept a
4006 --Added convention that all shell functions should accept a
4005 parameter_string This opens the door for different behaviour for
4007 parameter_string This opens the door for different behaviour for
4006 each function. @cd is a good example of this.
4008 each function. @cd is a good example of this.
4007
4009
4008 04.05.99 12:12 porto.ifm.uni-kiel.de
4010 04.05.99 12:12 porto.ifm.uni-kiel.de
4009 --added logfile rotation
4011 --added logfile rotation
4010 --added new mainloop method which freezes first the namespace
4012 --added new mainloop method which freezes first the namespace
4011
4013
4012 07.05.99 21:24 porto.ifm.uni-kiel.de
4014 07.05.99 21:24 porto.ifm.uni-kiel.de
4013 --added the docreader classes. Now there is a help system.
4015 --added the docreader classes. Now there is a help system.
4014 -This is only a first try. Currently it's not easy to put new
4016 -This is only a first try. Currently it's not easy to put new
4015 stuff in the indices. But this is the way to go. Info would be
4017 stuff in the indices. But this is the way to go. Info would be
4016 better, but HTML is every where and not everybody has an info
4018 better, but HTML is every where and not everybody has an info
4017 system installed and it's not so easy to change html-docs to info.
4019 system installed and it's not so easy to change html-docs to info.
4018 --added global logfile option
4020 --added global logfile option
4019 --there is now a hook for object inspection method pinfo needs to
4021 --there is now a hook for object inspection method pinfo needs to
4020 be provided for this. Can be reached by two '??'.
4022 be provided for this. Can be reached by two '??'.
4021
4023
4022 08.05.99 20:51 porto.ifm.uni-kiel.de
4024 08.05.99 20:51 porto.ifm.uni-kiel.de
4023 --added a README
4025 --added a README
4024 --bug in rc file. Something has changed so functions in the rc
4026 --bug in rc file. Something has changed so functions in the rc
4025 file need to reference the shell and not self. Not clear if it's a
4027 file need to reference the shell and not self. Not clear if it's a
4026 bug or feature.
4028 bug or feature.
4027 --changed rc file for new behavior
4029 --changed rc file for new behavior
4028
4030
4029 2004-07-15 Fernando Perez <fperez@colorado.edu>
4031 2004-07-15 Fernando Perez <fperez@colorado.edu>
4030
4032
4031 * IPython/Logger.py (Logger.log): fixed recent bug where the input
4033 * IPython/Logger.py (Logger.log): fixed recent bug where the input
4032 cache was falling out of sync in bizarre manners when multi-line
4034 cache was falling out of sync in bizarre manners when multi-line
4033 input was present. Minor optimizations and cleanup.
4035 input was present. Minor optimizations and cleanup.
4034
4036
4035 (Logger): Remove old Changelog info for cleanup. This is the
4037 (Logger): Remove old Changelog info for cleanup. This is the
4036 information which was there from Janko's original code:
4038 information which was there from Janko's original code:
4037
4039
4038 Changes to Logger: - made the default log filename a parameter
4040 Changes to Logger: - made the default log filename a parameter
4039
4041
4040 - put a check for lines beginning with !@? in log(). Needed
4042 - put a check for lines beginning with !@? in log(). Needed
4041 (even if the handlers properly log their lines) for mid-session
4043 (even if the handlers properly log their lines) for mid-session
4042 logging activation to work properly. Without this, lines logged
4044 logging activation to work properly. Without this, lines logged
4043 in mid session, which get read from the cache, would end up
4045 in mid session, which get read from the cache, would end up
4044 'bare' (with !@? in the open) in the log. Now they are caught
4046 'bare' (with !@? in the open) in the log. Now they are caught
4045 and prepended with a #.
4047 and prepended with a #.
4046
4048
4047 * IPython/iplib.py (InteractiveShell.init_readline): added check
4049 * IPython/iplib.py (InteractiveShell.init_readline): added check
4048 in case MagicCompleter fails to be defined, so we don't crash.
4050 in case MagicCompleter fails to be defined, so we don't crash.
4049
4051
4050 2004-07-13 Fernando Perez <fperez@colorado.edu>
4052 2004-07-13 Fernando Perez <fperez@colorado.edu>
4051
4053
4052 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
4054 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
4053 of EPS if the requested filename ends in '.eps'.
4055 of EPS if the requested filename ends in '.eps'.
4054
4056
4055 2004-07-04 Fernando Perez <fperez@colorado.edu>
4057 2004-07-04 Fernando Perez <fperez@colorado.edu>
4056
4058
4057 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
4059 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
4058 escaping of quotes when calling the shell.
4060 escaping of quotes when calling the shell.
4059
4061
4060 2004-07-02 Fernando Perez <fperez@colorado.edu>
4062 2004-07-02 Fernando Perez <fperez@colorado.edu>
4061
4063
4062 * IPython/Prompts.py (CachedOutput.update): Fix problem with
4064 * IPython/Prompts.py (CachedOutput.update): Fix problem with
4063 gettext not working because we were clobbering '_'. Fixes
4065 gettext not working because we were clobbering '_'. Fixes
4064 http://www.scipy.net/roundup/ipython/issue6.
4066 http://www.scipy.net/roundup/ipython/issue6.
4065
4067
4066 2004-07-01 Fernando Perez <fperez@colorado.edu>
4068 2004-07-01 Fernando Perez <fperez@colorado.edu>
4067
4069
4068 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
4070 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
4069 into @cd. Patch by Ville.
4071 into @cd. Patch by Ville.
4070
4072
4071 * IPython/iplib.py (InteractiveShell.post_config_initialization):
4073 * IPython/iplib.py (InteractiveShell.post_config_initialization):
4072 new function to store things after ipmaker runs. Patch by Ville.
4074 new function to store things after ipmaker runs. Patch by Ville.
4073 Eventually this will go away once ipmaker is removed and the class
4075 Eventually this will go away once ipmaker is removed and the class
4074 gets cleaned up, but for now it's ok. Key functionality here is
4076 gets cleaned up, but for now it's ok. Key functionality here is
4075 the addition of the persistent storage mechanism, a dict for
4077 the addition of the persistent storage mechanism, a dict for
4076 keeping data across sessions (for now just bookmarks, but more can
4078 keeping data across sessions (for now just bookmarks, but more can
4077 be implemented later).
4079 be implemented later).
4078
4080
4079 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
4081 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
4080 persistent across sections. Patch by Ville, I modified it
4082 persistent across sections. Patch by Ville, I modified it
4081 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
4083 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
4082 added a '-l' option to list all bookmarks.
4084 added a '-l' option to list all bookmarks.
4083
4085
4084 * IPython/iplib.py (InteractiveShell.atexit_operations): new
4086 * IPython/iplib.py (InteractiveShell.atexit_operations): new
4085 center for cleanup. Registered with atexit.register(). I moved
4087 center for cleanup. Registered with atexit.register(). I moved
4086 here the old exit_cleanup(). After a patch by Ville.
4088 here the old exit_cleanup(). After a patch by Ville.
4087
4089
4088 * IPython/Magic.py (get_py_filename): added '~' to the accepted
4090 * IPython/Magic.py (get_py_filename): added '~' to the accepted
4089 characters in the hacked shlex_split for python 2.2.
4091 characters in the hacked shlex_split for python 2.2.
4090
4092
4091 * IPython/iplib.py (file_matches): more fixes to filenames with
4093 * IPython/iplib.py (file_matches): more fixes to filenames with
4092 whitespace in them. It's not perfect, but limitations in python's
4094 whitespace in them. It's not perfect, but limitations in python's
4093 readline make it impossible to go further.
4095 readline make it impossible to go further.
4094
4096
4095 2004-06-29 Fernando Perez <fperez@colorado.edu>
4097 2004-06-29 Fernando Perez <fperez@colorado.edu>
4096
4098
4097 * IPython/iplib.py (file_matches): escape whitespace correctly in
4099 * IPython/iplib.py (file_matches): escape whitespace correctly in
4098 filename completions. Bug reported by Ville.
4100 filename completions. Bug reported by Ville.
4099
4101
4100 2004-06-28 Fernando Perez <fperez@colorado.edu>
4102 2004-06-28 Fernando Perez <fperez@colorado.edu>
4101
4103
4102 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
4104 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
4103 the history file will be called 'history-PROFNAME' (or just
4105 the history file will be called 'history-PROFNAME' (or just
4104 'history' if no profile is loaded). I was getting annoyed at
4106 'history' if no profile is loaded). I was getting annoyed at
4105 getting my Numerical work history clobbered by pysh sessions.
4107 getting my Numerical work history clobbered by pysh sessions.
4106
4108
4107 * IPython/iplib.py (InteractiveShell.__init__): Internal
4109 * IPython/iplib.py (InteractiveShell.__init__): Internal
4108 getoutputerror() function so that we can honor the system_verbose
4110 getoutputerror() function so that we can honor the system_verbose
4109 flag for _all_ system calls. I also added escaping of #
4111 flag for _all_ system calls. I also added escaping of #
4110 characters here to avoid confusing Itpl.
4112 characters here to avoid confusing Itpl.
4111
4113
4112 * IPython/Magic.py (shlex_split): removed call to shell in
4114 * IPython/Magic.py (shlex_split): removed call to shell in
4113 parse_options and replaced it with shlex.split(). The annoying
4115 parse_options and replaced it with shlex.split(). The annoying
4114 part was that in Python 2.2, shlex.split() doesn't exist, so I had
4116 part was that in Python 2.2, shlex.split() doesn't exist, so I had
4115 to backport it from 2.3, with several frail hacks (the shlex
4117 to backport it from 2.3, with several frail hacks (the shlex
4116 module is rather limited in 2.2). Thanks to a suggestion by Ville
4118 module is rather limited in 2.2). Thanks to a suggestion by Ville
4117 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
4119 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
4118 problem.
4120 problem.
4119
4121
4120 (Magic.magic_system_verbose): new toggle to print the actual
4122 (Magic.magic_system_verbose): new toggle to print the actual
4121 system calls made by ipython. Mainly for debugging purposes.
4123 system calls made by ipython. Mainly for debugging purposes.
4122
4124
4123 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
4125 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
4124 doesn't support persistence. Reported (and fix suggested) by
4126 doesn't support persistence. Reported (and fix suggested) by
4125 Travis Caldwell <travis_caldwell2000@yahoo.com>.
4127 Travis Caldwell <travis_caldwell2000@yahoo.com>.
4126
4128
4127 2004-06-26 Fernando Perez <fperez@colorado.edu>
4129 2004-06-26 Fernando Perez <fperez@colorado.edu>
4128
4130
4129 * IPython/Logger.py (Logger.log): fix to handle correctly empty
4131 * IPython/Logger.py (Logger.log): fix to handle correctly empty
4130 continue prompts.
4132 continue prompts.
4131
4133
4132 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
4134 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
4133 function (basically a big docstring) and a few more things here to
4135 function (basically a big docstring) and a few more things here to
4134 speedup startup. pysh.py is now very lightweight. We want because
4136 speedup startup. pysh.py is now very lightweight. We want because
4135 it gets execfile'd, while InterpreterExec gets imported, so
4137 it gets execfile'd, while InterpreterExec gets imported, so
4136 byte-compilation saves time.
4138 byte-compilation saves time.
4137
4139
4138 2004-06-25 Fernando Perez <fperez@colorado.edu>
4140 2004-06-25 Fernando Perez <fperez@colorado.edu>
4139
4141
4140 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
4142 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
4141 -NUM', which was recently broken.
4143 -NUM', which was recently broken.
4142
4144
4143 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
4145 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
4144 in multi-line input (but not !!, which doesn't make sense there).
4146 in multi-line input (but not !!, which doesn't make sense there).
4145
4147
4146 * IPython/UserConfig/ipythonrc: made autoindent on by default.
4148 * IPython/UserConfig/ipythonrc: made autoindent on by default.
4147 It's just too useful, and people can turn it off in the less
4149 It's just too useful, and people can turn it off in the less
4148 common cases where it's a problem.
4150 common cases where it's a problem.
4149
4151
4150 2004-06-24 Fernando Perez <fperez@colorado.edu>
4152 2004-06-24 Fernando Perez <fperez@colorado.edu>
4151
4153
4152 * IPython/iplib.py (InteractiveShell._prefilter): big change -
4154 * IPython/iplib.py (InteractiveShell._prefilter): big change -
4153 special syntaxes (like alias calling) is now allied in multi-line
4155 special syntaxes (like alias calling) is now allied in multi-line
4154 input. This is still _very_ experimental, but it's necessary for
4156 input. This is still _very_ experimental, but it's necessary for
4155 efficient shell usage combining python looping syntax with system
4157 efficient shell usage combining python looping syntax with system
4156 calls. For now it's restricted to aliases, I don't think it
4158 calls. For now it's restricted to aliases, I don't think it
4157 really even makes sense to have this for magics.
4159 really even makes sense to have this for magics.
4158
4160
4159 2004-06-23 Fernando Perez <fperez@colorado.edu>
4161 2004-06-23 Fernando Perez <fperez@colorado.edu>
4160
4162
4161 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
4163 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
4162 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
4164 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
4163
4165
4164 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
4166 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
4165 extensions under Windows (after code sent by Gary Bishop). The
4167 extensions under Windows (after code sent by Gary Bishop). The
4166 extensions considered 'executable' are stored in IPython's rc
4168 extensions considered 'executable' are stored in IPython's rc
4167 structure as win_exec_ext.
4169 structure as win_exec_ext.
4168
4170
4169 * IPython/genutils.py (shell): new function, like system() but
4171 * IPython/genutils.py (shell): new function, like system() but
4170 without return value. Very useful for interactive shell work.
4172 without return value. Very useful for interactive shell work.
4171
4173
4172 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
4174 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
4173 delete aliases.
4175 delete aliases.
4174
4176
4175 * IPython/iplib.py (InteractiveShell.alias_table_update): make
4177 * IPython/iplib.py (InteractiveShell.alias_table_update): make
4176 sure that the alias table doesn't contain python keywords.
4178 sure that the alias table doesn't contain python keywords.
4177
4179
4178 2004-06-21 Fernando Perez <fperez@colorado.edu>
4180 2004-06-21 Fernando Perez <fperez@colorado.edu>
4179
4181
4180 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
4182 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
4181 non-existent items are found in $PATH. Reported by Thorsten.
4183 non-existent items are found in $PATH. Reported by Thorsten.
4182
4184
4183 2004-06-20 Fernando Perez <fperez@colorado.edu>
4185 2004-06-20 Fernando Perez <fperez@colorado.edu>
4184
4186
4185 * IPython/iplib.py (complete): modified the completer so that the
4187 * IPython/iplib.py (complete): modified the completer so that the
4186 order of priorities can be easily changed at runtime.
4188 order of priorities can be easily changed at runtime.
4187
4189
4188 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
4190 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
4189 Modified to auto-execute all lines beginning with '~', '/' or '.'.
4191 Modified to auto-execute all lines beginning with '~', '/' or '.'.
4190
4192
4191 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
4193 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
4192 expand Python variables prepended with $ in all system calls. The
4194 expand Python variables prepended with $ in all system calls. The
4193 same was done to InteractiveShell.handle_shell_escape. Now all
4195 same was done to InteractiveShell.handle_shell_escape. Now all
4194 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
4196 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
4195 expansion of python variables and expressions according to the
4197 expansion of python variables and expressions according to the
4196 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
4198 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
4197
4199
4198 Though PEP-215 has been rejected, a similar (but simpler) one
4200 Though PEP-215 has been rejected, a similar (but simpler) one
4199 seems like it will go into Python 2.4, PEP-292 -
4201 seems like it will go into Python 2.4, PEP-292 -
4200 http://www.python.org/peps/pep-0292.html.
4202 http://www.python.org/peps/pep-0292.html.
4201
4203
4202 I'll keep the full syntax of PEP-215, since IPython has since the
4204 I'll keep the full syntax of PEP-215, since IPython has since the
4203 start used Ka-Ping Yee's reference implementation discussed there
4205 start used Ka-Ping Yee's reference implementation discussed there
4204 (Itpl), and I actually like the powerful semantics it offers.
4206 (Itpl), and I actually like the powerful semantics it offers.
4205
4207
4206 In order to access normal shell variables, the $ has to be escaped
4208 In order to access normal shell variables, the $ has to be escaped
4207 via an extra $. For example:
4209 via an extra $. For example:
4208
4210
4209 In [7]: PATH='a python variable'
4211 In [7]: PATH='a python variable'
4210
4212
4211 In [8]: !echo $PATH
4213 In [8]: !echo $PATH
4212 a python variable
4214 a python variable
4213
4215
4214 In [9]: !echo $$PATH
4216 In [9]: !echo $$PATH
4215 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
4217 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
4216
4218
4217 (Magic.parse_options): escape $ so the shell doesn't evaluate
4219 (Magic.parse_options): escape $ so the shell doesn't evaluate
4218 things prematurely.
4220 things prematurely.
4219
4221
4220 * IPython/iplib.py (InteractiveShell.call_alias): added the
4222 * IPython/iplib.py (InteractiveShell.call_alias): added the
4221 ability for aliases to expand python variables via $.
4223 ability for aliases to expand python variables via $.
4222
4224
4223 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
4225 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
4224 system, now there's a @rehash/@rehashx pair of magics. These work
4226 system, now there's a @rehash/@rehashx pair of magics. These work
4225 like the csh rehash command, and can be invoked at any time. They
4227 like the csh rehash command, and can be invoked at any time. They
4226 build a table of aliases to everything in the user's $PATH
4228 build a table of aliases to everything in the user's $PATH
4227 (@rehash uses everything, @rehashx is slower but only adds
4229 (@rehash uses everything, @rehashx is slower but only adds
4228 executable files). With this, the pysh.py-based shell profile can
4230 executable files). With this, the pysh.py-based shell profile can
4229 now simply call rehash upon startup, and full access to all
4231 now simply call rehash upon startup, and full access to all
4230 programs in the user's path is obtained.
4232 programs in the user's path is obtained.
4231
4233
4232 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
4234 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
4233 functionality is now fully in place. I removed the old dynamic
4235 functionality is now fully in place. I removed the old dynamic
4234 code generation based approach, in favor of a much lighter one
4236 code generation based approach, in favor of a much lighter one
4235 based on a simple dict. The advantage is that this allows me to
4237 based on a simple dict. The advantage is that this allows me to
4236 now have thousands of aliases with negligible cost (unthinkable
4238 now have thousands of aliases with negligible cost (unthinkable
4237 with the old system).
4239 with the old system).
4238
4240
4239 2004-06-19 Fernando Perez <fperez@colorado.edu>
4241 2004-06-19 Fernando Perez <fperez@colorado.edu>
4240
4242
4241 * IPython/iplib.py (__init__): extended MagicCompleter class to
4243 * IPython/iplib.py (__init__): extended MagicCompleter class to
4242 also complete (last in priority) on user aliases.
4244 also complete (last in priority) on user aliases.
4243
4245
4244 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
4246 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
4245 call to eval.
4247 call to eval.
4246 (ItplNS.__init__): Added a new class which functions like Itpl,
4248 (ItplNS.__init__): Added a new class which functions like Itpl,
4247 but allows configuring the namespace for the evaluation to occur
4249 but allows configuring the namespace for the evaluation to occur
4248 in.
4250 in.
4249
4251
4250 2004-06-18 Fernando Perez <fperez@colorado.edu>
4252 2004-06-18 Fernando Perez <fperez@colorado.edu>
4251
4253
4252 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
4254 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
4253 better message when 'exit' or 'quit' are typed (a common newbie
4255 better message when 'exit' or 'quit' are typed (a common newbie
4254 confusion).
4256 confusion).
4255
4257
4256 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
4258 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
4257 check for Windows users.
4259 check for Windows users.
4258
4260
4259 * IPython/iplib.py (InteractiveShell.user_setup): removed
4261 * IPython/iplib.py (InteractiveShell.user_setup): removed
4260 disabling of colors for Windows. I'll test at runtime and issue a
4262 disabling of colors for Windows. I'll test at runtime and issue a
4261 warning if Gary's readline isn't found, as to nudge users to
4263 warning if Gary's readline isn't found, as to nudge users to
4262 download it.
4264 download it.
4263
4265
4264 2004-06-16 Fernando Perez <fperez@colorado.edu>
4266 2004-06-16 Fernando Perez <fperez@colorado.edu>
4265
4267
4266 * IPython/genutils.py (Stream.__init__): changed to print errors
4268 * IPython/genutils.py (Stream.__init__): changed to print errors
4267 to sys.stderr. I had a circular dependency here. Now it's
4269 to sys.stderr. I had a circular dependency here. Now it's
4268 possible to run ipython as IDLE's shell (consider this pre-alpha,
4270 possible to run ipython as IDLE's shell (consider this pre-alpha,
4269 since true stdout things end up in the starting terminal instead
4271 since true stdout things end up in the starting terminal instead
4270 of IDLE's out).
4272 of IDLE's out).
4271
4273
4272 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
4274 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
4273 users who haven't # updated their prompt_in2 definitions. Remove
4275 users who haven't # updated their prompt_in2 definitions. Remove
4274 eventually.
4276 eventually.
4275 (multiple_replace): added credit to original ASPN recipe.
4277 (multiple_replace): added credit to original ASPN recipe.
4276
4278
4277 2004-06-15 Fernando Perez <fperez@colorado.edu>
4279 2004-06-15 Fernando Perez <fperez@colorado.edu>
4278
4280
4279 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
4281 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
4280 list of auto-defined aliases.
4282 list of auto-defined aliases.
4281
4283
4282 2004-06-13 Fernando Perez <fperez@colorado.edu>
4284 2004-06-13 Fernando Perez <fperez@colorado.edu>
4283
4285
4284 * setup.py (scriptfiles): Don't trigger win_post_install unless an
4286 * setup.py (scriptfiles): Don't trigger win_post_install unless an
4285 install was really requested (so setup.py can be used for other
4287 install was really requested (so setup.py can be used for other
4286 things under Windows).
4288 things under Windows).
4287
4289
4288 2004-06-10 Fernando Perez <fperez@colorado.edu>
4290 2004-06-10 Fernando Perez <fperez@colorado.edu>
4289
4291
4290 * IPython/Logger.py (Logger.create_log): Manually remove any old
4292 * IPython/Logger.py (Logger.create_log): Manually remove any old
4291 backup, since os.remove may fail under Windows. Fixes bug
4293 backup, since os.remove may fail under Windows. Fixes bug
4292 reported by Thorsten.
4294 reported by Thorsten.
4293
4295
4294 2004-06-09 Fernando Perez <fperez@colorado.edu>
4296 2004-06-09 Fernando Perez <fperez@colorado.edu>
4295
4297
4296 * examples/example-embed.py: fixed all references to %n (replaced
4298 * examples/example-embed.py: fixed all references to %n (replaced
4297 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
4299 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
4298 for all examples and the manual as well.
4300 for all examples and the manual as well.
4299
4301
4300 2004-06-08 Fernando Perez <fperez@colorado.edu>
4302 2004-06-08 Fernando Perez <fperez@colorado.edu>
4301
4303
4302 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
4304 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
4303 alignment and color management. All 3 prompt subsystems now
4305 alignment and color management. All 3 prompt subsystems now
4304 inherit from BasePrompt.
4306 inherit from BasePrompt.
4305
4307
4306 * tools/release: updates for windows installer build and tag rpms
4308 * tools/release: updates for windows installer build and tag rpms
4307 with python version (since paths are fixed).
4309 with python version (since paths are fixed).
4308
4310
4309 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
4311 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
4310 which will become eventually obsolete. Also fixed the default
4312 which will become eventually obsolete. Also fixed the default
4311 prompt_in2 to use \D, so at least new users start with the correct
4313 prompt_in2 to use \D, so at least new users start with the correct
4312 defaults.
4314 defaults.
4313 WARNING: Users with existing ipythonrc files will need to apply
4315 WARNING: Users with existing ipythonrc files will need to apply
4314 this fix manually!
4316 this fix manually!
4315
4317
4316 * setup.py: make windows installer (.exe). This is finally the
4318 * setup.py: make windows installer (.exe). This is finally the
4317 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
4319 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
4318 which I hadn't included because it required Python 2.3 (or recent
4320 which I hadn't included because it required Python 2.3 (or recent
4319 distutils).
4321 distutils).
4320
4322
4321 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
4323 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
4322 usage of new '\D' escape.
4324 usage of new '\D' escape.
4323
4325
4324 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
4326 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
4325 lacks os.getuid())
4327 lacks os.getuid())
4326 (CachedOutput.set_colors): Added the ability to turn coloring
4328 (CachedOutput.set_colors): Added the ability to turn coloring
4327 on/off with @colors even for manually defined prompt colors. It
4329 on/off with @colors even for manually defined prompt colors. It
4328 uses a nasty global, but it works safely and via the generic color
4330 uses a nasty global, but it works safely and via the generic color
4329 handling mechanism.
4331 handling mechanism.
4330 (Prompt2.__init__): Introduced new escape '\D' for continuation
4332 (Prompt2.__init__): Introduced new escape '\D' for continuation
4331 prompts. It represents the counter ('\#') as dots.
4333 prompts. It represents the counter ('\#') as dots.
4332 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
4334 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
4333 need to update their ipythonrc files and replace '%n' with '\D' in
4335 need to update their ipythonrc files and replace '%n' with '\D' in
4334 their prompt_in2 settings everywhere. Sorry, but there's
4336 their prompt_in2 settings everywhere. Sorry, but there's
4335 otherwise no clean way to get all prompts to properly align. The
4337 otherwise no clean way to get all prompts to properly align. The
4336 ipythonrc shipped with IPython has been updated.
4338 ipythonrc shipped with IPython has been updated.
4337
4339
4338 2004-06-07 Fernando Perez <fperez@colorado.edu>
4340 2004-06-07 Fernando Perez <fperez@colorado.edu>
4339
4341
4340 * setup.py (isfile): Pass local_icons option to latex2html, so the
4342 * setup.py (isfile): Pass local_icons option to latex2html, so the
4341 resulting HTML file is self-contained. Thanks to
4343 resulting HTML file is self-contained. Thanks to
4342 dryice-AT-liu.com.cn for the tip.
4344 dryice-AT-liu.com.cn for the tip.
4343
4345
4344 * pysh.py: I created a new profile 'shell', which implements a
4346 * pysh.py: I created a new profile 'shell', which implements a
4345 _rudimentary_ IPython-based shell. This is in NO WAY a realy
4347 _rudimentary_ IPython-based shell. This is in NO WAY a realy
4346 system shell, nor will it become one anytime soon. It's mainly
4348 system shell, nor will it become one anytime soon. It's mainly
4347 meant to illustrate the use of the new flexible bash-like prompts.
4349 meant to illustrate the use of the new flexible bash-like prompts.
4348 I guess it could be used by hardy souls for true shell management,
4350 I guess it could be used by hardy souls for true shell management,
4349 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
4351 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
4350 profile. This uses the InterpreterExec extension provided by
4352 profile. This uses the InterpreterExec extension provided by
4351 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
4353 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
4352
4354
4353 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4355 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4354 auto-align itself with the length of the previous input prompt
4356 auto-align itself with the length of the previous input prompt
4355 (taking into account the invisible color escapes).
4357 (taking into account the invisible color escapes).
4356 (CachedOutput.__init__): Large restructuring of this class. Now
4358 (CachedOutput.__init__): Large restructuring of this class. Now
4357 all three prompts (primary1, primary2, output) are proper objects,
4359 all three prompts (primary1, primary2, output) are proper objects,
4358 managed by the 'parent' CachedOutput class. The code is still a
4360 managed by the 'parent' CachedOutput class. The code is still a
4359 bit hackish (all prompts share state via a pointer to the cache),
4361 bit hackish (all prompts share state via a pointer to the cache),
4360 but it's overall far cleaner than before.
4362 but it's overall far cleaner than before.
4361
4363
4362 * IPython/genutils.py (getoutputerror): modified to add verbose,
4364 * IPython/genutils.py (getoutputerror): modified to add verbose,
4363 debug and header options. This makes the interface of all getout*
4365 debug and header options. This makes the interface of all getout*
4364 functions uniform.
4366 functions uniform.
4365 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4367 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4366
4368
4367 * IPython/Magic.py (Magic.default_option): added a function to
4369 * IPython/Magic.py (Magic.default_option): added a function to
4368 allow registering default options for any magic command. This
4370 allow registering default options for any magic command. This
4369 makes it easy to have profiles which customize the magics globally
4371 makes it easy to have profiles which customize the magics globally
4370 for a certain use. The values set through this function are
4372 for a certain use. The values set through this function are
4371 picked up by the parse_options() method, which all magics should
4373 picked up by the parse_options() method, which all magics should
4372 use to parse their options.
4374 use to parse their options.
4373
4375
4374 * IPython/genutils.py (warn): modified the warnings framework to
4376 * IPython/genutils.py (warn): modified the warnings framework to
4375 use the Term I/O class. I'm trying to slowly unify all of
4377 use the Term I/O class. I'm trying to slowly unify all of
4376 IPython's I/O operations to pass through Term.
4378 IPython's I/O operations to pass through Term.
4377
4379
4378 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4380 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4379 the secondary prompt to correctly match the length of the primary
4381 the secondary prompt to correctly match the length of the primary
4380 one for any prompt. Now multi-line code will properly line up
4382 one for any prompt. Now multi-line code will properly line up
4381 even for path dependent prompts, such as the new ones available
4383 even for path dependent prompts, such as the new ones available
4382 via the prompt_specials.
4384 via the prompt_specials.
4383
4385
4384 2004-06-06 Fernando Perez <fperez@colorado.edu>
4386 2004-06-06 Fernando Perez <fperez@colorado.edu>
4385
4387
4386 * IPython/Prompts.py (prompt_specials): Added the ability to have
4388 * IPython/Prompts.py (prompt_specials): Added the ability to have
4387 bash-like special sequences in the prompts, which get
4389 bash-like special sequences in the prompts, which get
4388 automatically expanded. Things like hostname, current working
4390 automatically expanded. Things like hostname, current working
4389 directory and username are implemented already, but it's easy to
4391 directory and username are implemented already, but it's easy to
4390 add more in the future. Thanks to a patch by W.J. van der Laan
4392 add more in the future. Thanks to a patch by W.J. van der Laan
4391 <gnufnork-AT-hetdigitalegat.nl>
4393 <gnufnork-AT-hetdigitalegat.nl>
4392 (prompt_specials): Added color support for prompt strings, so
4394 (prompt_specials): Added color support for prompt strings, so
4393 users can define arbitrary color setups for their prompts.
4395 users can define arbitrary color setups for their prompts.
4394
4396
4395 2004-06-05 Fernando Perez <fperez@colorado.edu>
4397 2004-06-05 Fernando Perez <fperez@colorado.edu>
4396
4398
4397 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4399 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4398 code to load Gary Bishop's readline and configure it
4400 code to load Gary Bishop's readline and configure it
4399 automatically. Thanks to Gary for help on this.
4401 automatically. Thanks to Gary for help on this.
4400
4402
4401 2004-06-01 Fernando Perez <fperez@colorado.edu>
4403 2004-06-01 Fernando Perez <fperez@colorado.edu>
4402
4404
4403 * IPython/Logger.py (Logger.create_log): fix bug for logging
4405 * IPython/Logger.py (Logger.create_log): fix bug for logging
4404 with no filename (previous fix was incomplete).
4406 with no filename (previous fix was incomplete).
4405
4407
4406 2004-05-25 Fernando Perez <fperez@colorado.edu>
4408 2004-05-25 Fernando Perez <fperez@colorado.edu>
4407
4409
4408 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4410 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4409 parens would get passed to the shell.
4411 parens would get passed to the shell.
4410
4412
4411 2004-05-20 Fernando Perez <fperez@colorado.edu>
4413 2004-05-20 Fernando Perez <fperez@colorado.edu>
4412
4414
4413 * IPython/Magic.py (Magic.magic_prun): changed default profile
4415 * IPython/Magic.py (Magic.magic_prun): changed default profile
4414 sort order to 'time' (the more common profiling need).
4416 sort order to 'time' (the more common profiling need).
4415
4417
4416 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4418 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4417 so that source code shown is guaranteed in sync with the file on
4419 so that source code shown is guaranteed in sync with the file on
4418 disk (also changed in psource). Similar fix to the one for
4420 disk (also changed in psource). Similar fix to the one for
4419 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4421 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4420 <yann.ledu-AT-noos.fr>.
4422 <yann.ledu-AT-noos.fr>.
4421
4423
4422 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4424 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4423 with a single option would not be correctly parsed. Closes
4425 with a single option would not be correctly parsed. Closes
4424 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4426 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4425 introduced in 0.6.0 (on 2004-05-06).
4427 introduced in 0.6.0 (on 2004-05-06).
4426
4428
4427 2004-05-13 *** Released version 0.6.0
4429 2004-05-13 *** Released version 0.6.0
4428
4430
4429 2004-05-13 Fernando Perez <fperez@colorado.edu>
4431 2004-05-13 Fernando Perez <fperez@colorado.edu>
4430
4432
4431 * debian/: Added debian/ directory to CVS, so that debian support
4433 * debian/: Added debian/ directory to CVS, so that debian support
4432 is publicly accessible. The debian package is maintained by Jack
4434 is publicly accessible. The debian package is maintained by Jack
4433 Moffit <jack-AT-xiph.org>.
4435 Moffit <jack-AT-xiph.org>.
4434
4436
4435 * Documentation: included the notes about an ipython-based system
4437 * Documentation: included the notes about an ipython-based system
4436 shell (the hypothetical 'pysh') into the new_design.pdf document,
4438 shell (the hypothetical 'pysh') into the new_design.pdf document,
4437 so that these ideas get distributed to users along with the
4439 so that these ideas get distributed to users along with the
4438 official documentation.
4440 official documentation.
4439
4441
4440 2004-05-10 Fernando Perez <fperez@colorado.edu>
4442 2004-05-10 Fernando Perez <fperez@colorado.edu>
4441
4443
4442 * IPython/Logger.py (Logger.create_log): fix recently introduced
4444 * IPython/Logger.py (Logger.create_log): fix recently introduced
4443 bug (misindented line) where logstart would fail when not given an
4445 bug (misindented line) where logstart would fail when not given an
4444 explicit filename.
4446 explicit filename.
4445
4447
4446 2004-05-09 Fernando Perez <fperez@colorado.edu>
4448 2004-05-09 Fernando Perez <fperez@colorado.edu>
4447
4449
4448 * IPython/Magic.py (Magic.parse_options): skip system call when
4450 * IPython/Magic.py (Magic.parse_options): skip system call when
4449 there are no options to look for. Faster, cleaner for the common
4451 there are no options to look for. Faster, cleaner for the common
4450 case.
4452 case.
4451
4453
4452 * Documentation: many updates to the manual: describing Windows
4454 * Documentation: many updates to the manual: describing Windows
4453 support better, Gnuplot updates, credits, misc small stuff. Also
4455 support better, Gnuplot updates, credits, misc small stuff. Also
4454 updated the new_design doc a bit.
4456 updated the new_design doc a bit.
4455
4457
4456 2004-05-06 *** Released version 0.6.0.rc1
4458 2004-05-06 *** Released version 0.6.0.rc1
4457
4459
4458 2004-05-06 Fernando Perez <fperez@colorado.edu>
4460 2004-05-06 Fernando Perez <fperez@colorado.edu>
4459
4461
4460 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4462 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4461 operations to use the vastly more efficient list/''.join() method.
4463 operations to use the vastly more efficient list/''.join() method.
4462 (FormattedTB.text): Fix
4464 (FormattedTB.text): Fix
4463 http://www.scipy.net/roundup/ipython/issue12 - exception source
4465 http://www.scipy.net/roundup/ipython/issue12 - exception source
4464 extract not updated after reload. Thanks to Mike Salib
4466 extract not updated after reload. Thanks to Mike Salib
4465 <msalib-AT-mit.edu> for pinning the source of the problem.
4467 <msalib-AT-mit.edu> for pinning the source of the problem.
4466 Fortunately, the solution works inside ipython and doesn't require
4468 Fortunately, the solution works inside ipython and doesn't require
4467 any changes to python proper.
4469 any changes to python proper.
4468
4470
4469 * IPython/Magic.py (Magic.parse_options): Improved to process the
4471 * IPython/Magic.py (Magic.parse_options): Improved to process the
4470 argument list as a true shell would (by actually using the
4472 argument list as a true shell would (by actually using the
4471 underlying system shell). This way, all @magics automatically get
4473 underlying system shell). This way, all @magics automatically get
4472 shell expansion for variables. Thanks to a comment by Alex
4474 shell expansion for variables. Thanks to a comment by Alex
4473 Schmolck.
4475 Schmolck.
4474
4476
4475 2004-04-04 Fernando Perez <fperez@colorado.edu>
4477 2004-04-04 Fernando Perez <fperez@colorado.edu>
4476
4478
4477 * IPython/iplib.py (InteractiveShell.interact): Added a special
4479 * IPython/iplib.py (InteractiveShell.interact): Added a special
4478 trap for a debugger quit exception, which is basically impossible
4480 trap for a debugger quit exception, which is basically impossible
4479 to handle by normal mechanisms, given what pdb does to the stack.
4481 to handle by normal mechanisms, given what pdb does to the stack.
4480 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4482 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4481
4483
4482 2004-04-03 Fernando Perez <fperez@colorado.edu>
4484 2004-04-03 Fernando Perez <fperez@colorado.edu>
4483
4485
4484 * IPython/genutils.py (Term): Standardized the names of the Term
4486 * IPython/genutils.py (Term): Standardized the names of the Term
4485 class streams to cin/cout/cerr, following C++ naming conventions
4487 class streams to cin/cout/cerr, following C++ naming conventions
4486 (I can't use in/out/err because 'in' is not a valid attribute
4488 (I can't use in/out/err because 'in' is not a valid attribute
4487 name).
4489 name).
4488
4490
4489 * IPython/iplib.py (InteractiveShell.interact): don't increment
4491 * IPython/iplib.py (InteractiveShell.interact): don't increment
4490 the prompt if there's no user input. By Daniel 'Dang' Griffith
4492 the prompt if there's no user input. By Daniel 'Dang' Griffith
4491 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4493 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4492 Francois Pinard.
4494 Francois Pinard.
4493
4495
4494 2004-04-02 Fernando Perez <fperez@colorado.edu>
4496 2004-04-02 Fernando Perez <fperez@colorado.edu>
4495
4497
4496 * IPython/genutils.py (Stream.__init__): Modified to survive at
4498 * IPython/genutils.py (Stream.__init__): Modified to survive at
4497 least importing in contexts where stdin/out/err aren't true file
4499 least importing in contexts where stdin/out/err aren't true file
4498 objects, such as PyCrust (they lack fileno() and mode). However,
4500 objects, such as PyCrust (they lack fileno() and mode). However,
4499 the recovery facilities which rely on these things existing will
4501 the recovery facilities which rely on these things existing will
4500 not work.
4502 not work.
4501
4503
4502 2004-04-01 Fernando Perez <fperez@colorado.edu>
4504 2004-04-01 Fernando Perez <fperez@colorado.edu>
4503
4505
4504 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4506 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4505 use the new getoutputerror() function, so it properly
4507 use the new getoutputerror() function, so it properly
4506 distinguishes stdout/err.
4508 distinguishes stdout/err.
4507
4509
4508 * IPython/genutils.py (getoutputerror): added a function to
4510 * IPython/genutils.py (getoutputerror): added a function to
4509 capture separately the standard output and error of a command.
4511 capture separately the standard output and error of a command.
4510 After a comment from dang on the mailing lists. This code is
4512 After a comment from dang on the mailing lists. This code is
4511 basically a modified version of commands.getstatusoutput(), from
4513 basically a modified version of commands.getstatusoutput(), from
4512 the standard library.
4514 the standard library.
4513
4515
4514 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4516 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4515 '!!' as a special syntax (shorthand) to access @sx.
4517 '!!' as a special syntax (shorthand) to access @sx.
4516
4518
4517 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4519 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4518 command and return its output as a list split on '\n'.
4520 command and return its output as a list split on '\n'.
4519
4521
4520 2004-03-31 Fernando Perez <fperez@colorado.edu>
4522 2004-03-31 Fernando Perez <fperez@colorado.edu>
4521
4523
4522 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4524 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4523 method to dictionaries used as FakeModule instances if they lack
4525 method to dictionaries used as FakeModule instances if they lack
4524 it. At least pydoc in python2.3 breaks for runtime-defined
4526 it. At least pydoc in python2.3 breaks for runtime-defined
4525 functions without this hack. At some point I need to _really_
4527 functions without this hack. At some point I need to _really_
4526 understand what FakeModule is doing, because it's a gross hack.
4528 understand what FakeModule is doing, because it's a gross hack.
4527 But it solves Arnd's problem for now...
4529 But it solves Arnd's problem for now...
4528
4530
4529 2004-02-27 Fernando Perez <fperez@colorado.edu>
4531 2004-02-27 Fernando Perez <fperez@colorado.edu>
4530
4532
4531 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4533 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4532 mode would behave erratically. Also increased the number of
4534 mode would behave erratically. Also increased the number of
4533 possible logs in rotate mod to 999. Thanks to Rod Holland
4535 possible logs in rotate mod to 999. Thanks to Rod Holland
4534 <rhh@StructureLABS.com> for the report and fixes.
4536 <rhh@StructureLABS.com> for the report and fixes.
4535
4537
4536 2004-02-26 Fernando Perez <fperez@colorado.edu>
4538 2004-02-26 Fernando Perez <fperez@colorado.edu>
4537
4539
4538 * IPython/genutils.py (page): Check that the curses module really
4540 * IPython/genutils.py (page): Check that the curses module really
4539 has the initscr attribute before trying to use it. For some
4541 has the initscr attribute before trying to use it. For some
4540 reason, the Solaris curses module is missing this. I think this
4542 reason, the Solaris curses module is missing this. I think this
4541 should be considered a Solaris python bug, but I'm not sure.
4543 should be considered a Solaris python bug, but I'm not sure.
4542
4544
4543 2004-01-17 Fernando Perez <fperez@colorado.edu>
4545 2004-01-17 Fernando Perez <fperez@colorado.edu>
4544
4546
4545 * IPython/genutils.py (Stream.__init__): Changes to try to make
4547 * IPython/genutils.py (Stream.__init__): Changes to try to make
4546 ipython robust against stdin/out/err being closed by the user.
4548 ipython robust against stdin/out/err being closed by the user.
4547 This is 'user error' (and blocks a normal python session, at least
4549 This is 'user error' (and blocks a normal python session, at least
4548 the stdout case). However, Ipython should be able to survive such
4550 the stdout case). However, Ipython should be able to survive such
4549 instances of abuse as gracefully as possible. To simplify the
4551 instances of abuse as gracefully as possible. To simplify the
4550 coding and maintain compatibility with Gary Bishop's Term
4552 coding and maintain compatibility with Gary Bishop's Term
4551 contributions, I've made use of classmethods for this. I think
4553 contributions, I've made use of classmethods for this. I think
4552 this introduces a dependency on python 2.2.
4554 this introduces a dependency on python 2.2.
4553
4555
4554 2004-01-13 Fernando Perez <fperez@colorado.edu>
4556 2004-01-13 Fernando Perez <fperez@colorado.edu>
4555
4557
4556 * IPython/numutils.py (exp_safe): simplified the code a bit and
4558 * IPython/numutils.py (exp_safe): simplified the code a bit and
4557 removed the need for importing the kinds module altogether.
4559 removed the need for importing the kinds module altogether.
4558
4560
4559 2004-01-06 Fernando Perez <fperez@colorado.edu>
4561 2004-01-06 Fernando Perez <fperez@colorado.edu>
4560
4562
4561 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4563 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4562 a magic function instead, after some community feedback. No
4564 a magic function instead, after some community feedback. No
4563 special syntax will exist for it, but its name is deliberately
4565 special syntax will exist for it, but its name is deliberately
4564 very short.
4566 very short.
4565
4567
4566 2003-12-20 Fernando Perez <fperez@colorado.edu>
4568 2003-12-20 Fernando Perez <fperez@colorado.edu>
4567
4569
4568 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4570 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4569 new functionality, to automagically assign the result of a shell
4571 new functionality, to automagically assign the result of a shell
4570 command to a variable. I'll solicit some community feedback on
4572 command to a variable. I'll solicit some community feedback on
4571 this before making it permanent.
4573 this before making it permanent.
4572
4574
4573 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4575 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4574 requested about callables for which inspect couldn't obtain a
4576 requested about callables for which inspect couldn't obtain a
4575 proper argspec. Thanks to a crash report sent by Etienne
4577 proper argspec. Thanks to a crash report sent by Etienne
4576 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4578 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4577
4579
4578 2003-12-09 Fernando Perez <fperez@colorado.edu>
4580 2003-12-09 Fernando Perez <fperez@colorado.edu>
4579
4581
4580 * IPython/genutils.py (page): patch for the pager to work across
4582 * IPython/genutils.py (page): patch for the pager to work across
4581 various versions of Windows. By Gary Bishop.
4583 various versions of Windows. By Gary Bishop.
4582
4584
4583 2003-12-04 Fernando Perez <fperez@colorado.edu>
4585 2003-12-04 Fernando Perez <fperez@colorado.edu>
4584
4586
4585 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4587 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4586 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4588 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4587 While I tested this and it looks ok, there may still be corner
4589 While I tested this and it looks ok, there may still be corner
4588 cases I've missed.
4590 cases I've missed.
4589
4591
4590 2003-12-01 Fernando Perez <fperez@colorado.edu>
4592 2003-12-01 Fernando Perez <fperez@colorado.edu>
4591
4593
4592 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4594 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4593 where a line like 'p,q=1,2' would fail because the automagic
4595 where a line like 'p,q=1,2' would fail because the automagic
4594 system would be triggered for @p.
4596 system would be triggered for @p.
4595
4597
4596 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4598 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4597 cleanups, code unmodified.
4599 cleanups, code unmodified.
4598
4600
4599 * IPython/genutils.py (Term): added a class for IPython to handle
4601 * IPython/genutils.py (Term): added a class for IPython to handle
4600 output. In most cases it will just be a proxy for stdout/err, but
4602 output. In most cases it will just be a proxy for stdout/err, but
4601 having this allows modifications to be made for some platforms,
4603 having this allows modifications to be made for some platforms,
4602 such as handling color escapes under Windows. All of this code
4604 such as handling color escapes under Windows. All of this code
4603 was contributed by Gary Bishop, with minor modifications by me.
4605 was contributed by Gary Bishop, with minor modifications by me.
4604 The actual changes affect many files.
4606 The actual changes affect many files.
4605
4607
4606 2003-11-30 Fernando Perez <fperez@colorado.edu>
4608 2003-11-30 Fernando Perez <fperez@colorado.edu>
4607
4609
4608 * IPython/iplib.py (file_matches): new completion code, courtesy
4610 * IPython/iplib.py (file_matches): new completion code, courtesy
4609 of Jeff Collins. This enables filename completion again under
4611 of Jeff Collins. This enables filename completion again under
4610 python 2.3, which disabled it at the C level.
4612 python 2.3, which disabled it at the C level.
4611
4613
4612 2003-11-11 Fernando Perez <fperez@colorado.edu>
4614 2003-11-11 Fernando Perez <fperez@colorado.edu>
4613
4615
4614 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4616 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4615 for Numeric.array(map(...)), but often convenient.
4617 for Numeric.array(map(...)), but often convenient.
4616
4618
4617 2003-11-05 Fernando Perez <fperez@colorado.edu>
4619 2003-11-05 Fernando Perez <fperez@colorado.edu>
4618
4620
4619 * IPython/numutils.py (frange): Changed a call from int() to
4621 * IPython/numutils.py (frange): Changed a call from int() to
4620 int(round()) to prevent a problem reported with arange() in the
4622 int(round()) to prevent a problem reported with arange() in the
4621 numpy list.
4623 numpy list.
4622
4624
4623 2003-10-06 Fernando Perez <fperez@colorado.edu>
4625 2003-10-06 Fernando Perez <fperez@colorado.edu>
4624
4626
4625 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4627 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4626 prevent crashes if sys lacks an argv attribute (it happens with
4628 prevent crashes if sys lacks an argv attribute (it happens with
4627 embedded interpreters which build a bare-bones sys module).
4629 embedded interpreters which build a bare-bones sys module).
4628 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4630 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4629
4631
4630 2003-09-24 Fernando Perez <fperez@colorado.edu>
4632 2003-09-24 Fernando Perez <fperez@colorado.edu>
4631
4633
4632 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4634 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4633 to protect against poorly written user objects where __getattr__
4635 to protect against poorly written user objects where __getattr__
4634 raises exceptions other than AttributeError. Thanks to a bug
4636 raises exceptions other than AttributeError. Thanks to a bug
4635 report by Oliver Sander <osander-AT-gmx.de>.
4637 report by Oliver Sander <osander-AT-gmx.de>.
4636
4638
4637 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4639 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4638 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4640 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4639
4641
4640 2003-09-09 Fernando Perez <fperez@colorado.edu>
4642 2003-09-09 Fernando Perez <fperez@colorado.edu>
4641
4643
4642 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4644 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4643 unpacking a list whith a callable as first element would
4645 unpacking a list whith a callable as first element would
4644 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4646 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4645 Collins.
4647 Collins.
4646
4648
4647 2003-08-25 *** Released version 0.5.0
4649 2003-08-25 *** Released version 0.5.0
4648
4650
4649 2003-08-22 Fernando Perez <fperez@colorado.edu>
4651 2003-08-22 Fernando Perez <fperez@colorado.edu>
4650
4652
4651 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4653 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4652 improperly defined user exceptions. Thanks to feedback from Mark
4654 improperly defined user exceptions. Thanks to feedback from Mark
4653 Russell <mrussell-AT-verio.net>.
4655 Russell <mrussell-AT-verio.net>.
4654
4656
4655 2003-08-20 Fernando Perez <fperez@colorado.edu>
4657 2003-08-20 Fernando Perez <fperez@colorado.edu>
4656
4658
4657 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4659 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4658 printing so that it would print multi-line string forms starting
4660 printing so that it would print multi-line string forms starting
4659 with a new line. This way the formatting is better respected for
4661 with a new line. This way the formatting is better respected for
4660 objects which work hard to make nice string forms.
4662 objects which work hard to make nice string forms.
4661
4663
4662 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4664 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4663 autocall would overtake data access for objects with both
4665 autocall would overtake data access for objects with both
4664 __getitem__ and __call__.
4666 __getitem__ and __call__.
4665
4667
4666 2003-08-19 *** Released version 0.5.0-rc1
4668 2003-08-19 *** Released version 0.5.0-rc1
4667
4669
4668 2003-08-19 Fernando Perez <fperez@colorado.edu>
4670 2003-08-19 Fernando Perez <fperez@colorado.edu>
4669
4671
4670 * IPython/deep_reload.py (load_tail): single tiny change here
4672 * IPython/deep_reload.py (load_tail): single tiny change here
4671 seems to fix the long-standing bug of dreload() failing to work
4673 seems to fix the long-standing bug of dreload() failing to work
4672 for dotted names. But this module is pretty tricky, so I may have
4674 for dotted names. But this module is pretty tricky, so I may have
4673 missed some subtlety. Needs more testing!.
4675 missed some subtlety. Needs more testing!.
4674
4676
4675 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4677 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4676 exceptions which have badly implemented __str__ methods.
4678 exceptions which have badly implemented __str__ methods.
4677 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4679 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4678 which I've been getting reports about from Python 2.3 users. I
4680 which I've been getting reports about from Python 2.3 users. I
4679 wish I had a simple test case to reproduce the problem, so I could
4681 wish I had a simple test case to reproduce the problem, so I could
4680 either write a cleaner workaround or file a bug report if
4682 either write a cleaner workaround or file a bug report if
4681 necessary.
4683 necessary.
4682
4684
4683 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4685 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4684 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4686 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4685 a bug report by Tjabo Kloppenburg.
4687 a bug report by Tjabo Kloppenburg.
4686
4688
4687 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4689 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4688 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4690 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4689 seems rather unstable. Thanks to a bug report by Tjabo
4691 seems rather unstable. Thanks to a bug report by Tjabo
4690 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4692 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4691
4693
4692 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4694 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4693 this out soon because of the critical fixes in the inner loop for
4695 this out soon because of the critical fixes in the inner loop for
4694 generators.
4696 generators.
4695
4697
4696 * IPython/Magic.py (Magic.getargspec): removed. This (and
4698 * IPython/Magic.py (Magic.getargspec): removed. This (and
4697 _get_def) have been obsoleted by OInspect for a long time, I
4699 _get_def) have been obsoleted by OInspect for a long time, I
4698 hadn't noticed that they were dead code.
4700 hadn't noticed that they were dead code.
4699 (Magic._ofind): restored _ofind functionality for a few literals
4701 (Magic._ofind): restored _ofind functionality for a few literals
4700 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4702 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4701 for things like "hello".capitalize?, since that would require a
4703 for things like "hello".capitalize?, since that would require a
4702 potentially dangerous eval() again.
4704 potentially dangerous eval() again.
4703
4705
4704 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4706 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4705 logic a bit more to clean up the escapes handling and minimize the
4707 logic a bit more to clean up the escapes handling and minimize the
4706 use of _ofind to only necessary cases. The interactive 'feel' of
4708 use of _ofind to only necessary cases. The interactive 'feel' of
4707 IPython should have improved quite a bit with the changes in
4709 IPython should have improved quite a bit with the changes in
4708 _prefilter and _ofind (besides being far safer than before).
4710 _prefilter and _ofind (besides being far safer than before).
4709
4711
4710 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4712 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4711 obscure, never reported). Edit would fail to find the object to
4713 obscure, never reported). Edit would fail to find the object to
4712 edit under some circumstances.
4714 edit under some circumstances.
4713 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4715 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4714 which were causing double-calling of generators. Those eval calls
4716 which were causing double-calling of generators. Those eval calls
4715 were _very_ dangerous, since code with side effects could be
4717 were _very_ dangerous, since code with side effects could be
4716 triggered. As they say, 'eval is evil'... These were the
4718 triggered. As they say, 'eval is evil'... These were the
4717 nastiest evals in IPython. Besides, _ofind is now far simpler,
4719 nastiest evals in IPython. Besides, _ofind is now far simpler,
4718 and it should also be quite a bit faster. Its use of inspect is
4720 and it should also be quite a bit faster. Its use of inspect is
4719 also safer, so perhaps some of the inspect-related crashes I've
4721 also safer, so perhaps some of the inspect-related crashes I've
4720 seen lately with Python 2.3 might be taken care of. That will
4722 seen lately with Python 2.3 might be taken care of. That will
4721 need more testing.
4723 need more testing.
4722
4724
4723 2003-08-17 Fernando Perez <fperez@colorado.edu>
4725 2003-08-17 Fernando Perez <fperez@colorado.edu>
4724
4726
4725 * IPython/iplib.py (InteractiveShell._prefilter): significant
4727 * IPython/iplib.py (InteractiveShell._prefilter): significant
4726 simplifications to the logic for handling user escapes. Faster
4728 simplifications to the logic for handling user escapes. Faster
4727 and simpler code.
4729 and simpler code.
4728
4730
4729 2003-08-14 Fernando Perez <fperez@colorado.edu>
4731 2003-08-14 Fernando Perez <fperez@colorado.edu>
4730
4732
4731 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4733 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4732 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4734 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4733 but it should be quite a bit faster. And the recursive version
4735 but it should be quite a bit faster. And the recursive version
4734 generated O(log N) intermediate storage for all rank>1 arrays,
4736 generated O(log N) intermediate storage for all rank>1 arrays,
4735 even if they were contiguous.
4737 even if they were contiguous.
4736 (l1norm): Added this function.
4738 (l1norm): Added this function.
4737 (norm): Added this function for arbitrary norms (including
4739 (norm): Added this function for arbitrary norms (including
4738 l-infinity). l1 and l2 are still special cases for convenience
4740 l-infinity). l1 and l2 are still special cases for convenience
4739 and speed.
4741 and speed.
4740
4742
4741 2003-08-03 Fernando Perez <fperez@colorado.edu>
4743 2003-08-03 Fernando Perez <fperez@colorado.edu>
4742
4744
4743 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4745 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4744 exceptions, which now raise PendingDeprecationWarnings in Python
4746 exceptions, which now raise PendingDeprecationWarnings in Python
4745 2.3. There were some in Magic and some in Gnuplot2.
4747 2.3. There were some in Magic and some in Gnuplot2.
4746
4748
4747 2003-06-30 Fernando Perez <fperez@colorado.edu>
4749 2003-06-30 Fernando Perez <fperez@colorado.edu>
4748
4750
4749 * IPython/genutils.py (page): modified to call curses only for
4751 * IPython/genutils.py (page): modified to call curses only for
4750 terminals where TERM=='xterm'. After problems under many other
4752 terminals where TERM=='xterm'. After problems under many other
4751 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4753 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4752
4754
4753 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4755 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4754 would be triggered when readline was absent. This was just an old
4756 would be triggered when readline was absent. This was just an old
4755 debugging statement I'd forgotten to take out.
4757 debugging statement I'd forgotten to take out.
4756
4758
4757 2003-06-20 Fernando Perez <fperez@colorado.edu>
4759 2003-06-20 Fernando Perez <fperez@colorado.edu>
4758
4760
4759 * IPython/genutils.py (clock): modified to return only user time
4761 * IPython/genutils.py (clock): modified to return only user time
4760 (not counting system time), after a discussion on scipy. While
4762 (not counting system time), after a discussion on scipy. While
4761 system time may be a useful quantity occasionally, it may much
4763 system time may be a useful quantity occasionally, it may much
4762 more easily be skewed by occasional swapping or other similar
4764 more easily be skewed by occasional swapping or other similar
4763 activity.
4765 activity.
4764
4766
4765 2003-06-05 Fernando Perez <fperez@colorado.edu>
4767 2003-06-05 Fernando Perez <fperez@colorado.edu>
4766
4768
4767 * IPython/numutils.py (identity): new function, for building
4769 * IPython/numutils.py (identity): new function, for building
4768 arbitrary rank Kronecker deltas (mostly backwards compatible with
4770 arbitrary rank Kronecker deltas (mostly backwards compatible with
4769 Numeric.identity)
4771 Numeric.identity)
4770
4772
4771 2003-06-03 Fernando Perez <fperez@colorado.edu>
4773 2003-06-03 Fernando Perez <fperez@colorado.edu>
4772
4774
4773 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4775 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4774 arguments passed to magics with spaces, to allow trailing '\' to
4776 arguments passed to magics with spaces, to allow trailing '\' to
4775 work normally (mainly for Windows users).
4777 work normally (mainly for Windows users).
4776
4778
4777 2003-05-29 Fernando Perez <fperez@colorado.edu>
4779 2003-05-29 Fernando Perez <fperez@colorado.edu>
4778
4780
4779 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4781 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4780 instead of pydoc.help. This fixes a bizarre behavior where
4782 instead of pydoc.help. This fixes a bizarre behavior where
4781 printing '%s' % locals() would trigger the help system. Now
4783 printing '%s' % locals() would trigger the help system. Now
4782 ipython behaves like normal python does.
4784 ipython behaves like normal python does.
4783
4785
4784 Note that if one does 'from pydoc import help', the bizarre
4786 Note that if one does 'from pydoc import help', the bizarre
4785 behavior returns, but this will also happen in normal python, so
4787 behavior returns, but this will also happen in normal python, so
4786 it's not an ipython bug anymore (it has to do with how pydoc.help
4788 it's not an ipython bug anymore (it has to do with how pydoc.help
4787 is implemented).
4789 is implemented).
4788
4790
4789 2003-05-22 Fernando Perez <fperez@colorado.edu>
4791 2003-05-22 Fernando Perez <fperez@colorado.edu>
4790
4792
4791 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4793 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4792 return [] instead of None when nothing matches, also match to end
4794 return [] instead of None when nothing matches, also match to end
4793 of line. Patch by Gary Bishop.
4795 of line. Patch by Gary Bishop.
4794
4796
4795 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4797 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4796 protection as before, for files passed on the command line. This
4798 protection as before, for files passed on the command line. This
4797 prevents the CrashHandler from kicking in if user files call into
4799 prevents the CrashHandler from kicking in if user files call into
4798 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4800 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4799 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4801 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4800
4802
4801 2003-05-20 *** Released version 0.4.0
4803 2003-05-20 *** Released version 0.4.0
4802
4804
4803 2003-05-20 Fernando Perez <fperez@colorado.edu>
4805 2003-05-20 Fernando Perez <fperez@colorado.edu>
4804
4806
4805 * setup.py: added support for manpages. It's a bit hackish b/c of
4807 * setup.py: added support for manpages. It's a bit hackish b/c of
4806 a bug in the way the bdist_rpm distutils target handles gzipped
4808 a bug in the way the bdist_rpm distutils target handles gzipped
4807 manpages, but it works. After a patch by Jack.
4809 manpages, but it works. After a patch by Jack.
4808
4810
4809 2003-05-19 Fernando Perez <fperez@colorado.edu>
4811 2003-05-19 Fernando Perez <fperez@colorado.edu>
4810
4812
4811 * IPython/numutils.py: added a mockup of the kinds module, since
4813 * IPython/numutils.py: added a mockup of the kinds module, since
4812 it was recently removed from Numeric. This way, numutils will
4814 it was recently removed from Numeric. This way, numutils will
4813 work for all users even if they are missing kinds.
4815 work for all users even if they are missing kinds.
4814
4816
4815 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4817 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4816 failure, which can occur with SWIG-wrapped extensions. After a
4818 failure, which can occur with SWIG-wrapped extensions. After a
4817 crash report from Prabhu.
4819 crash report from Prabhu.
4818
4820
4819 2003-05-16 Fernando Perez <fperez@colorado.edu>
4821 2003-05-16 Fernando Perez <fperez@colorado.edu>
4820
4822
4821 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4823 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4822 protect ipython from user code which may call directly
4824 protect ipython from user code which may call directly
4823 sys.excepthook (this looks like an ipython crash to the user, even
4825 sys.excepthook (this looks like an ipython crash to the user, even
4824 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4826 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4825 This is especially important to help users of WxWindows, but may
4827 This is especially important to help users of WxWindows, but may
4826 also be useful in other cases.
4828 also be useful in other cases.
4827
4829
4828 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4830 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4829 an optional tb_offset to be specified, and to preserve exception
4831 an optional tb_offset to be specified, and to preserve exception
4830 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4832 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4831
4833
4832 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4834 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4833
4835
4834 2003-05-15 Fernando Perez <fperez@colorado.edu>
4836 2003-05-15 Fernando Perez <fperez@colorado.edu>
4835
4837
4836 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4838 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4837 installing for a new user under Windows.
4839 installing for a new user under Windows.
4838
4840
4839 2003-05-12 Fernando Perez <fperez@colorado.edu>
4841 2003-05-12 Fernando Perez <fperez@colorado.edu>
4840
4842
4841 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4843 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4842 handler for Emacs comint-based lines. Currently it doesn't do
4844 handler for Emacs comint-based lines. Currently it doesn't do
4843 much (but importantly, it doesn't update the history cache). In
4845 much (but importantly, it doesn't update the history cache). In
4844 the future it may be expanded if Alex needs more functionality
4846 the future it may be expanded if Alex needs more functionality
4845 there.
4847 there.
4846
4848
4847 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4849 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4848 info to crash reports.
4850 info to crash reports.
4849
4851
4850 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4852 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4851 just like Python's -c. Also fixed crash with invalid -color
4853 just like Python's -c. Also fixed crash with invalid -color
4852 option value at startup. Thanks to Will French
4854 option value at startup. Thanks to Will French
4853 <wfrench-AT-bestweb.net> for the bug report.
4855 <wfrench-AT-bestweb.net> for the bug report.
4854
4856
4855 2003-05-09 Fernando Perez <fperez@colorado.edu>
4857 2003-05-09 Fernando Perez <fperez@colorado.edu>
4856
4858
4857 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4859 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4858 to EvalDict (it's a mapping, after all) and simplified its code
4860 to EvalDict (it's a mapping, after all) and simplified its code
4859 quite a bit, after a nice discussion on c.l.py where Gustavo
4861 quite a bit, after a nice discussion on c.l.py where Gustavo
4860 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
4862 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
4861
4863
4862 2003-04-30 Fernando Perez <fperez@colorado.edu>
4864 2003-04-30 Fernando Perez <fperez@colorado.edu>
4863
4865
4864 * IPython/genutils.py (timings_out): modified it to reduce its
4866 * IPython/genutils.py (timings_out): modified it to reduce its
4865 overhead in the common reps==1 case.
4867 overhead in the common reps==1 case.
4866
4868
4867 2003-04-29 Fernando Perez <fperez@colorado.edu>
4869 2003-04-29 Fernando Perez <fperez@colorado.edu>
4868
4870
4869 * IPython/genutils.py (timings_out): Modified to use the resource
4871 * IPython/genutils.py (timings_out): Modified to use the resource
4870 module, which avoids the wraparound problems of time.clock().
4872 module, which avoids the wraparound problems of time.clock().
4871
4873
4872 2003-04-17 *** Released version 0.2.15pre4
4874 2003-04-17 *** Released version 0.2.15pre4
4873
4875
4874 2003-04-17 Fernando Perez <fperez@colorado.edu>
4876 2003-04-17 Fernando Perez <fperez@colorado.edu>
4875
4877
4876 * setup.py (scriptfiles): Split windows-specific stuff over to a
4878 * setup.py (scriptfiles): Split windows-specific stuff over to a
4877 separate file, in an attempt to have a Windows GUI installer.
4879 separate file, in an attempt to have a Windows GUI installer.
4878 That didn't work, but part of the groundwork is done.
4880 That didn't work, but part of the groundwork is done.
4879
4881
4880 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4882 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4881 indent/unindent with 4 spaces. Particularly useful in combination
4883 indent/unindent with 4 spaces. Particularly useful in combination
4882 with the new auto-indent option.
4884 with the new auto-indent option.
4883
4885
4884 2003-04-16 Fernando Perez <fperez@colorado.edu>
4886 2003-04-16 Fernando Perez <fperez@colorado.edu>
4885
4887
4886 * IPython/Magic.py: various replacements of self.rc for
4888 * IPython/Magic.py: various replacements of self.rc for
4887 self.shell.rc. A lot more remains to be done to fully disentangle
4889 self.shell.rc. A lot more remains to be done to fully disentangle
4888 this class from the main Shell class.
4890 this class from the main Shell class.
4889
4891
4890 * IPython/GnuplotRuntime.py: added checks for mouse support so
4892 * IPython/GnuplotRuntime.py: added checks for mouse support so
4891 that we don't try to enable it if the current gnuplot doesn't
4893 that we don't try to enable it if the current gnuplot doesn't
4892 really support it. Also added checks so that we don't try to
4894 really support it. Also added checks so that we don't try to
4893 enable persist under Windows (where Gnuplot doesn't recognize the
4895 enable persist under Windows (where Gnuplot doesn't recognize the
4894 option).
4896 option).
4895
4897
4896 * IPython/iplib.py (InteractiveShell.interact): Added optional
4898 * IPython/iplib.py (InteractiveShell.interact): Added optional
4897 auto-indenting code, after a patch by King C. Shu
4899 auto-indenting code, after a patch by King C. Shu
4898 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4900 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4899 get along well with pasting indented code. If I ever figure out
4901 get along well with pasting indented code. If I ever figure out
4900 how to make that part go well, it will become on by default.
4902 how to make that part go well, it will become on by default.
4901
4903
4902 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4904 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4903 crash ipython if there was an unmatched '%' in the user's prompt
4905 crash ipython if there was an unmatched '%' in the user's prompt
4904 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4906 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4905
4907
4906 * IPython/iplib.py (InteractiveShell.interact): removed the
4908 * IPython/iplib.py (InteractiveShell.interact): removed the
4907 ability to ask the user whether he wants to crash or not at the
4909 ability to ask the user whether he wants to crash or not at the
4908 'last line' exception handler. Calling functions at that point
4910 'last line' exception handler. Calling functions at that point
4909 changes the stack, and the error reports would have incorrect
4911 changes the stack, and the error reports would have incorrect
4910 tracebacks.
4912 tracebacks.
4911
4913
4912 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4914 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4913 pass through a peger a pretty-printed form of any object. After a
4915 pass through a peger a pretty-printed form of any object. After a
4914 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4916 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4915
4917
4916 2003-04-14 Fernando Perez <fperez@colorado.edu>
4918 2003-04-14 Fernando Perez <fperez@colorado.edu>
4917
4919
4918 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4920 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4919 all files in ~ would be modified at first install (instead of
4921 all files in ~ would be modified at first install (instead of
4920 ~/.ipython). This could be potentially disastrous, as the
4922 ~/.ipython). This could be potentially disastrous, as the
4921 modification (make line-endings native) could damage binary files.
4923 modification (make line-endings native) could damage binary files.
4922
4924
4923 2003-04-10 Fernando Perez <fperez@colorado.edu>
4925 2003-04-10 Fernando Perez <fperez@colorado.edu>
4924
4926
4925 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4927 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4926 handle only lines which are invalid python. This now means that
4928 handle only lines which are invalid python. This now means that
4927 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4929 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4928 for the bug report.
4930 for the bug report.
4929
4931
4930 2003-04-01 Fernando Perez <fperez@colorado.edu>
4932 2003-04-01 Fernando Perez <fperez@colorado.edu>
4931
4933
4932 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4934 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4933 where failing to set sys.last_traceback would crash pdb.pm().
4935 where failing to set sys.last_traceback would crash pdb.pm().
4934 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4936 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4935 report.
4937 report.
4936
4938
4937 2003-03-25 Fernando Perez <fperez@colorado.edu>
4939 2003-03-25 Fernando Perez <fperez@colorado.edu>
4938
4940
4939 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4941 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4940 before printing it (it had a lot of spurious blank lines at the
4942 before printing it (it had a lot of spurious blank lines at the
4941 end).
4943 end).
4942
4944
4943 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4945 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4944 output would be sent 21 times! Obviously people don't use this
4946 output would be sent 21 times! Obviously people don't use this
4945 too often, or I would have heard about it.
4947 too often, or I would have heard about it.
4946
4948
4947 2003-03-24 Fernando Perez <fperez@colorado.edu>
4949 2003-03-24 Fernando Perez <fperez@colorado.edu>
4948
4950
4949 * setup.py (scriptfiles): renamed the data_files parameter from
4951 * setup.py (scriptfiles): renamed the data_files parameter from
4950 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4952 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4951 for the patch.
4953 for the patch.
4952
4954
4953 2003-03-20 Fernando Perez <fperez@colorado.edu>
4955 2003-03-20 Fernando Perez <fperez@colorado.edu>
4954
4956
4955 * IPython/genutils.py (error): added error() and fatal()
4957 * IPython/genutils.py (error): added error() and fatal()
4956 functions.
4958 functions.
4957
4959
4958 2003-03-18 *** Released version 0.2.15pre3
4960 2003-03-18 *** Released version 0.2.15pre3
4959
4961
4960 2003-03-18 Fernando Perez <fperez@colorado.edu>
4962 2003-03-18 Fernando Perez <fperez@colorado.edu>
4961
4963
4962 * setupext/install_data_ext.py
4964 * setupext/install_data_ext.py
4963 (install_data_ext.initialize_options): Class contributed by Jack
4965 (install_data_ext.initialize_options): Class contributed by Jack
4964 Moffit for fixing the old distutils hack. He is sending this to
4966 Moffit for fixing the old distutils hack. He is sending this to
4965 the distutils folks so in the future we may not need it as a
4967 the distutils folks so in the future we may not need it as a
4966 private fix.
4968 private fix.
4967
4969
4968 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4970 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4969 changes for Debian packaging. See his patch for full details.
4971 changes for Debian packaging. See his patch for full details.
4970 The old distutils hack of making the ipythonrc* files carry a
4972 The old distutils hack of making the ipythonrc* files carry a
4971 bogus .py extension is gone, at last. Examples were moved to a
4973 bogus .py extension is gone, at last. Examples were moved to a
4972 separate subdir under doc/, and the separate executable scripts
4974 separate subdir under doc/, and the separate executable scripts
4973 now live in their own directory. Overall a great cleanup. The
4975 now live in their own directory. Overall a great cleanup. The
4974 manual was updated to use the new files, and setup.py has been
4976 manual was updated to use the new files, and setup.py has been
4975 fixed for this setup.
4977 fixed for this setup.
4976
4978
4977 * IPython/PyColorize.py (Parser.usage): made non-executable and
4979 * IPython/PyColorize.py (Parser.usage): made non-executable and
4978 created a pycolor wrapper around it to be included as a script.
4980 created a pycolor wrapper around it to be included as a script.
4979
4981
4980 2003-03-12 *** Released version 0.2.15pre2
4982 2003-03-12 *** Released version 0.2.15pre2
4981
4983
4982 2003-03-12 Fernando Perez <fperez@colorado.edu>
4984 2003-03-12 Fernando Perez <fperez@colorado.edu>
4983
4985
4984 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4986 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4985 long-standing problem with garbage characters in some terminals.
4987 long-standing problem with garbage characters in some terminals.
4986 The issue was really that the \001 and \002 escapes must _only_ be
4988 The issue was really that the \001 and \002 escapes must _only_ be
4987 passed to input prompts (which call readline), but _never_ to
4989 passed to input prompts (which call readline), but _never_ to
4988 normal text to be printed on screen. I changed ColorANSI to have
4990 normal text to be printed on screen. I changed ColorANSI to have
4989 two classes: TermColors and InputTermColors, each with the
4991 two classes: TermColors and InputTermColors, each with the
4990 appropriate escapes for input prompts or normal text. The code in
4992 appropriate escapes for input prompts or normal text. The code in
4991 Prompts.py got slightly more complicated, but this very old and
4993 Prompts.py got slightly more complicated, but this very old and
4992 annoying bug is finally fixed.
4994 annoying bug is finally fixed.
4993
4995
4994 All the credit for nailing down the real origin of this problem
4996 All the credit for nailing down the real origin of this problem
4995 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4997 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4996 *Many* thanks to him for spending quite a bit of effort on this.
4998 *Many* thanks to him for spending quite a bit of effort on this.
4997
4999
4998 2003-03-05 *** Released version 0.2.15pre1
5000 2003-03-05 *** Released version 0.2.15pre1
4999
5001
5000 2003-03-03 Fernando Perez <fperez@colorado.edu>
5002 2003-03-03 Fernando Perez <fperez@colorado.edu>
5001
5003
5002 * IPython/FakeModule.py: Moved the former _FakeModule to a
5004 * IPython/FakeModule.py: Moved the former _FakeModule to a
5003 separate file, because it's also needed by Magic (to fix a similar
5005 separate file, because it's also needed by Magic (to fix a similar
5004 pickle-related issue in @run).
5006 pickle-related issue in @run).
5005
5007
5006 2003-03-02 Fernando Perez <fperez@colorado.edu>
5008 2003-03-02 Fernando Perez <fperez@colorado.edu>
5007
5009
5008 * IPython/Magic.py (Magic.magic_autocall): new magic to control
5010 * IPython/Magic.py (Magic.magic_autocall): new magic to control
5009 the autocall option at runtime.
5011 the autocall option at runtime.
5010 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
5012 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
5011 across Magic.py to start separating Magic from InteractiveShell.
5013 across Magic.py to start separating Magic from InteractiveShell.
5012 (Magic._ofind): Fixed to return proper namespace for dotted
5014 (Magic._ofind): Fixed to return proper namespace for dotted
5013 names. Before, a dotted name would always return 'not currently
5015 names. Before, a dotted name would always return 'not currently
5014 defined', because it would find the 'parent'. s.x would be found,
5016 defined', because it would find the 'parent'. s.x would be found,
5015 but since 'x' isn't defined by itself, it would get confused.
5017 but since 'x' isn't defined by itself, it would get confused.
5016 (Magic.magic_run): Fixed pickling problems reported by Ralf
5018 (Magic.magic_run): Fixed pickling problems reported by Ralf
5017 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
5019 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
5018 that I'd used when Mike Heeter reported similar issues at the
5020 that I'd used when Mike Heeter reported similar issues at the
5019 top-level, but now for @run. It boils down to injecting the
5021 top-level, but now for @run. It boils down to injecting the
5020 namespace where code is being executed with something that looks
5022 namespace where code is being executed with something that looks
5021 enough like a module to fool pickle.dump(). Since a pickle stores
5023 enough like a module to fool pickle.dump(). Since a pickle stores
5022 a named reference to the importing module, we need this for
5024 a named reference to the importing module, we need this for
5023 pickles to save something sensible.
5025 pickles to save something sensible.
5024
5026
5025 * IPython/ipmaker.py (make_IPython): added an autocall option.
5027 * IPython/ipmaker.py (make_IPython): added an autocall option.
5026
5028
5027 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
5029 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
5028 the auto-eval code. Now autocalling is an option, and the code is
5030 the auto-eval code. Now autocalling is an option, and the code is
5029 also vastly safer. There is no more eval() involved at all.
5031 also vastly safer. There is no more eval() involved at all.
5030
5032
5031 2003-03-01 Fernando Perez <fperez@colorado.edu>
5033 2003-03-01 Fernando Perez <fperez@colorado.edu>
5032
5034
5033 * IPython/Magic.py (Magic._ofind): Changed interface to return a
5035 * IPython/Magic.py (Magic._ofind): Changed interface to return a
5034 dict with named keys instead of a tuple.
5036 dict with named keys instead of a tuple.
5035
5037
5036 * IPython: Started using CVS for IPython as of 0.2.15pre1.
5038 * IPython: Started using CVS for IPython as of 0.2.15pre1.
5037
5039
5038 * setup.py (make_shortcut): Fixed message about directories
5040 * setup.py (make_shortcut): Fixed message about directories
5039 created during Windows installation (the directories were ok, just
5041 created during Windows installation (the directories were ok, just
5040 the printed message was misleading). Thanks to Chris Liechti
5042 the printed message was misleading). Thanks to Chris Liechti
5041 <cliechti-AT-gmx.net> for the heads up.
5043 <cliechti-AT-gmx.net> for the heads up.
5042
5044
5043 2003-02-21 Fernando Perez <fperez@colorado.edu>
5045 2003-02-21 Fernando Perez <fperez@colorado.edu>
5044
5046
5045 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
5047 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
5046 of ValueError exception when checking for auto-execution. This
5048 of ValueError exception when checking for auto-execution. This
5047 one is raised by things like Numeric arrays arr.flat when the
5049 one is raised by things like Numeric arrays arr.flat when the
5048 array is non-contiguous.
5050 array is non-contiguous.
5049
5051
5050 2003-01-31 Fernando Perez <fperez@colorado.edu>
5052 2003-01-31 Fernando Perez <fperez@colorado.edu>
5051
5053
5052 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
5054 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
5053 not return any value at all (even though the command would get
5055 not return any value at all (even though the command would get
5054 executed).
5056 executed).
5055 (xsys): Flush stdout right after printing the command to ensure
5057 (xsys): Flush stdout right after printing the command to ensure
5056 proper ordering of commands and command output in the total
5058 proper ordering of commands and command output in the total
5057 output.
5059 output.
5058 (SystemExec/xsys/bq): Switched the names of xsys/bq and
5060 (SystemExec/xsys/bq): Switched the names of xsys/bq and
5059 system/getoutput as defaults. The old ones are kept for
5061 system/getoutput as defaults. The old ones are kept for
5060 compatibility reasons, so no code which uses this library needs
5062 compatibility reasons, so no code which uses this library needs
5061 changing.
5063 changing.
5062
5064
5063 2003-01-27 *** Released version 0.2.14
5065 2003-01-27 *** Released version 0.2.14
5064
5066
5065 2003-01-25 Fernando Perez <fperez@colorado.edu>
5067 2003-01-25 Fernando Perez <fperez@colorado.edu>
5066
5068
5067 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
5069 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
5068 functions defined in previous edit sessions could not be re-edited
5070 functions defined in previous edit sessions could not be re-edited
5069 (because the temp files were immediately removed). Now temp files
5071 (because the temp files were immediately removed). Now temp files
5070 are removed only at IPython's exit.
5072 are removed only at IPython's exit.
5071 (Magic.magic_run): Improved @run to perform shell-like expansions
5073 (Magic.magic_run): Improved @run to perform shell-like expansions
5072 on its arguments (~users and $VARS). With this, @run becomes more
5074 on its arguments (~users and $VARS). With this, @run becomes more
5073 like a normal command-line.
5075 like a normal command-line.
5074
5076
5075 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
5077 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
5076 bugs related to embedding and cleaned up that code. A fairly
5078 bugs related to embedding and cleaned up that code. A fairly
5077 important one was the impossibility to access the global namespace
5079 important one was the impossibility to access the global namespace
5078 through the embedded IPython (only local variables were visible).
5080 through the embedded IPython (only local variables were visible).
5079
5081
5080 2003-01-14 Fernando Perez <fperez@colorado.edu>
5082 2003-01-14 Fernando Perez <fperez@colorado.edu>
5081
5083
5082 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
5084 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
5083 auto-calling to be a bit more conservative. Now it doesn't get
5085 auto-calling to be a bit more conservative. Now it doesn't get
5084 triggered if any of '!=()<>' are in the rest of the input line, to
5086 triggered if any of '!=()<>' are in the rest of the input line, to
5085 allow comparing callables. Thanks to Alex for the heads up.
5087 allow comparing callables. Thanks to Alex for the heads up.
5086
5088
5087 2003-01-07 Fernando Perez <fperez@colorado.edu>
5089 2003-01-07 Fernando Perez <fperez@colorado.edu>
5088
5090
5089 * IPython/genutils.py (page): fixed estimation of the number of
5091 * IPython/genutils.py (page): fixed estimation of the number of
5090 lines in a string to be paged to simply count newlines. This
5092 lines in a string to be paged to simply count newlines. This
5091 prevents over-guessing due to embedded escape sequences. A better
5093 prevents over-guessing due to embedded escape sequences. A better
5092 long-term solution would involve stripping out the control chars
5094 long-term solution would involve stripping out the control chars
5093 for the count, but it's potentially so expensive I just don't
5095 for the count, but it's potentially so expensive I just don't
5094 think it's worth doing.
5096 think it's worth doing.
5095
5097
5096 2002-12-19 *** Released version 0.2.14pre50
5098 2002-12-19 *** Released version 0.2.14pre50
5097
5099
5098 2002-12-19 Fernando Perez <fperez@colorado.edu>
5100 2002-12-19 Fernando Perez <fperez@colorado.edu>
5099
5101
5100 * tools/release (version): Changed release scripts to inform
5102 * tools/release (version): Changed release scripts to inform
5101 Andrea and build a NEWS file with a list of recent changes.
5103 Andrea and build a NEWS file with a list of recent changes.
5102
5104
5103 * IPython/ColorANSI.py (__all__): changed terminal detection
5105 * IPython/ColorANSI.py (__all__): changed terminal detection
5104 code. Seems to work better for xterms without breaking
5106 code. Seems to work better for xterms without breaking
5105 konsole. Will need more testing to determine if WinXP and Mac OSX
5107 konsole. Will need more testing to determine if WinXP and Mac OSX
5106 also work ok.
5108 also work ok.
5107
5109
5108 2002-12-18 *** Released version 0.2.14pre49
5110 2002-12-18 *** Released version 0.2.14pre49
5109
5111
5110 2002-12-18 Fernando Perez <fperez@colorado.edu>
5112 2002-12-18 Fernando Perez <fperez@colorado.edu>
5111
5113
5112 * Docs: added new info about Mac OSX, from Andrea.
5114 * Docs: added new info about Mac OSX, from Andrea.
5113
5115
5114 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
5116 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
5115 allow direct plotting of python strings whose format is the same
5117 allow direct plotting of python strings whose format is the same
5116 of gnuplot data files.
5118 of gnuplot data files.
5117
5119
5118 2002-12-16 Fernando Perez <fperez@colorado.edu>
5120 2002-12-16 Fernando Perez <fperez@colorado.edu>
5119
5121
5120 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
5122 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
5121 value of exit question to be acknowledged.
5123 value of exit question to be acknowledged.
5122
5124
5123 2002-12-03 Fernando Perez <fperez@colorado.edu>
5125 2002-12-03 Fernando Perez <fperez@colorado.edu>
5124
5126
5125 * IPython/ipmaker.py: removed generators, which had been added
5127 * IPython/ipmaker.py: removed generators, which had been added
5126 by mistake in an earlier debugging run. This was causing trouble
5128 by mistake in an earlier debugging run. This was causing trouble
5127 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
5129 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
5128 for pointing this out.
5130 for pointing this out.
5129
5131
5130 2002-11-17 Fernando Perez <fperez@colorado.edu>
5132 2002-11-17 Fernando Perez <fperez@colorado.edu>
5131
5133
5132 * Manual: updated the Gnuplot section.
5134 * Manual: updated the Gnuplot section.
5133
5135
5134 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
5136 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
5135 a much better split of what goes in Runtime and what goes in
5137 a much better split of what goes in Runtime and what goes in
5136 Interactive.
5138 Interactive.
5137
5139
5138 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
5140 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
5139 being imported from iplib.
5141 being imported from iplib.
5140
5142
5141 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
5143 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
5142 for command-passing. Now the global Gnuplot instance is called
5144 for command-passing. Now the global Gnuplot instance is called
5143 'gp' instead of 'g', which was really a far too fragile and
5145 'gp' instead of 'g', which was really a far too fragile and
5144 common name.
5146 common name.
5145
5147
5146 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
5148 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
5147 bounding boxes generated by Gnuplot for square plots.
5149 bounding boxes generated by Gnuplot for square plots.
5148
5150
5149 * IPython/genutils.py (popkey): new function added. I should
5151 * IPython/genutils.py (popkey): new function added. I should
5150 suggest this on c.l.py as a dict method, it seems useful.
5152 suggest this on c.l.py as a dict method, it seems useful.
5151
5153
5152 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
5154 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
5153 to transparently handle PostScript generation. MUCH better than
5155 to transparently handle PostScript generation. MUCH better than
5154 the previous plot_eps/replot_eps (which I removed now). The code
5156 the previous plot_eps/replot_eps (which I removed now). The code
5155 is also fairly clean and well documented now (including
5157 is also fairly clean and well documented now (including
5156 docstrings).
5158 docstrings).
5157
5159
5158 2002-11-13 Fernando Perez <fperez@colorado.edu>
5160 2002-11-13 Fernando Perez <fperez@colorado.edu>
5159
5161
5160 * IPython/Magic.py (Magic.magic_edit): fixed docstring
5162 * IPython/Magic.py (Magic.magic_edit): fixed docstring
5161 (inconsistent with options).
5163 (inconsistent with options).
5162
5164
5163 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
5165 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
5164 manually disabled, I don't know why. Fixed it.
5166 manually disabled, I don't know why. Fixed it.
5165 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
5167 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
5166 eps output.
5168 eps output.
5167
5169
5168 2002-11-12 Fernando Perez <fperez@colorado.edu>
5170 2002-11-12 Fernando Perez <fperez@colorado.edu>
5169
5171
5170 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
5172 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
5171 don't propagate up to caller. Fixes crash reported by François
5173 don't propagate up to caller. Fixes crash reported by François
5172 Pinard.
5174 Pinard.
5173
5175
5174 2002-11-09 Fernando Perez <fperez@colorado.edu>
5176 2002-11-09 Fernando Perez <fperez@colorado.edu>
5175
5177
5176 * IPython/ipmaker.py (make_IPython): fixed problem with writing
5178 * IPython/ipmaker.py (make_IPython): fixed problem with writing
5177 history file for new users.
5179 history file for new users.
5178 (make_IPython): fixed bug where initial install would leave the
5180 (make_IPython): fixed bug where initial install would leave the
5179 user running in the .ipython dir.
5181 user running in the .ipython dir.
5180 (make_IPython): fixed bug where config dir .ipython would be
5182 (make_IPython): fixed bug where config dir .ipython would be
5181 created regardless of the given -ipythondir option. Thanks to Cory
5183 created regardless of the given -ipythondir option. Thanks to Cory
5182 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
5184 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
5183
5185
5184 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
5186 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
5185 type confirmations. Will need to use it in all of IPython's code
5187 type confirmations. Will need to use it in all of IPython's code
5186 consistently.
5188 consistently.
5187
5189
5188 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
5190 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
5189 context to print 31 lines instead of the default 5. This will make
5191 context to print 31 lines instead of the default 5. This will make
5190 the crash reports extremely detailed in case the problem is in
5192 the crash reports extremely detailed in case the problem is in
5191 libraries I don't have access to.
5193 libraries I don't have access to.
5192
5194
5193 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
5195 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
5194 line of defense' code to still crash, but giving users fair
5196 line of defense' code to still crash, but giving users fair
5195 warning. I don't want internal errors to go unreported: if there's
5197 warning. I don't want internal errors to go unreported: if there's
5196 an internal problem, IPython should crash and generate a full
5198 an internal problem, IPython should crash and generate a full
5197 report.
5199 report.
5198
5200
5199 2002-11-08 Fernando Perez <fperez@colorado.edu>
5201 2002-11-08 Fernando Perez <fperez@colorado.edu>
5200
5202
5201 * IPython/iplib.py (InteractiveShell.interact): added code to trap
5203 * IPython/iplib.py (InteractiveShell.interact): added code to trap
5202 otherwise uncaught exceptions which can appear if people set
5204 otherwise uncaught exceptions which can appear if people set
5203 sys.stdout to something badly broken. Thanks to a crash report
5205 sys.stdout to something badly broken. Thanks to a crash report
5204 from henni-AT-mail.brainbot.com.
5206 from henni-AT-mail.brainbot.com.
5205
5207
5206 2002-11-04 Fernando Perez <fperez@colorado.edu>
5208 2002-11-04 Fernando Perez <fperez@colorado.edu>
5207
5209
5208 * IPython/iplib.py (InteractiveShell.interact): added
5210 * IPython/iplib.py (InteractiveShell.interact): added
5209 __IPYTHON__active to the builtins. It's a flag which goes on when
5211 __IPYTHON__active to the builtins. It's a flag which goes on when
5210 the interaction starts and goes off again when it stops. This
5212 the interaction starts and goes off again when it stops. This
5211 allows embedding code to detect being inside IPython. Before this
5213 allows embedding code to detect being inside IPython. Before this
5212 was done via __IPYTHON__, but that only shows that an IPython
5214 was done via __IPYTHON__, but that only shows that an IPython
5213 instance has been created.
5215 instance has been created.
5214
5216
5215 * IPython/Magic.py (Magic.magic_env): I realized that in a
5217 * IPython/Magic.py (Magic.magic_env): I realized that in a
5216 UserDict, instance.data holds the data as a normal dict. So I
5218 UserDict, instance.data holds the data as a normal dict. So I
5217 modified @env to return os.environ.data instead of rebuilding a
5219 modified @env to return os.environ.data instead of rebuilding a
5218 dict by hand.
5220 dict by hand.
5219
5221
5220 2002-11-02 Fernando Perez <fperez@colorado.edu>
5222 2002-11-02 Fernando Perez <fperez@colorado.edu>
5221
5223
5222 * IPython/genutils.py (warn): changed so that level 1 prints no
5224 * IPython/genutils.py (warn): changed so that level 1 prints no
5223 header. Level 2 is now the default (with 'WARNING' header, as
5225 header. Level 2 is now the default (with 'WARNING' header, as
5224 before). I think I tracked all places where changes were needed in
5226 before). I think I tracked all places where changes were needed in
5225 IPython, but outside code using the old level numbering may have
5227 IPython, but outside code using the old level numbering may have
5226 broken.
5228 broken.
5227
5229
5228 * IPython/iplib.py (InteractiveShell.runcode): added this to
5230 * IPython/iplib.py (InteractiveShell.runcode): added this to
5229 handle the tracebacks in SystemExit traps correctly. The previous
5231 handle the tracebacks in SystemExit traps correctly. The previous
5230 code (through interact) was printing more of the stack than
5232 code (through interact) was printing more of the stack than
5231 necessary, showing IPython internal code to the user.
5233 necessary, showing IPython internal code to the user.
5232
5234
5233 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
5235 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
5234 default. Now that the default at the confirmation prompt is yes,
5236 default. Now that the default at the confirmation prompt is yes,
5235 it's not so intrusive. François' argument that ipython sessions
5237 it's not so intrusive. François' argument that ipython sessions
5236 tend to be complex enough not to lose them from an accidental C-d,
5238 tend to be complex enough not to lose them from an accidental C-d,
5237 is a valid one.
5239 is a valid one.
5238
5240
5239 * IPython/iplib.py (InteractiveShell.interact): added a
5241 * IPython/iplib.py (InteractiveShell.interact): added a
5240 showtraceback() call to the SystemExit trap, and modified the exit
5242 showtraceback() call to the SystemExit trap, and modified the exit
5241 confirmation to have yes as the default.
5243 confirmation to have yes as the default.
5242
5244
5243 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
5245 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
5244 this file. It's been gone from the code for a long time, this was
5246 this file. It's been gone from the code for a long time, this was
5245 simply leftover junk.
5247 simply leftover junk.
5246
5248
5247 2002-11-01 Fernando Perez <fperez@colorado.edu>
5249 2002-11-01 Fernando Perez <fperez@colorado.edu>
5248
5250
5249 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
5251 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
5250 added. If set, IPython now traps EOF and asks for
5252 added. If set, IPython now traps EOF and asks for
5251 confirmation. After a request by François Pinard.
5253 confirmation. After a request by François Pinard.
5252
5254
5253 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
5255 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
5254 of @abort, and with a new (better) mechanism for handling the
5256 of @abort, and with a new (better) mechanism for handling the
5255 exceptions.
5257 exceptions.
5256
5258
5257 2002-10-27 Fernando Perez <fperez@colorado.edu>
5259 2002-10-27 Fernando Perez <fperez@colorado.edu>
5258
5260
5259 * IPython/usage.py (__doc__): updated the --help information and
5261 * IPython/usage.py (__doc__): updated the --help information and
5260 the ipythonrc file to indicate that -log generates
5262 the ipythonrc file to indicate that -log generates
5261 ./ipython.log. Also fixed the corresponding info in @logstart.
5263 ./ipython.log. Also fixed the corresponding info in @logstart.
5262 This and several other fixes in the manuals thanks to reports by
5264 This and several other fixes in the manuals thanks to reports by
5263 François Pinard <pinard-AT-iro.umontreal.ca>.
5265 François Pinard <pinard-AT-iro.umontreal.ca>.
5264
5266
5265 * IPython/Logger.py (Logger.switch_log): Fixed error message to
5267 * IPython/Logger.py (Logger.switch_log): Fixed error message to
5266 refer to @logstart (instead of @log, which doesn't exist).
5268 refer to @logstart (instead of @log, which doesn't exist).
5267
5269
5268 * IPython/iplib.py (InteractiveShell._prefilter): fixed
5270 * IPython/iplib.py (InteractiveShell._prefilter): fixed
5269 AttributeError crash. Thanks to Christopher Armstrong
5271 AttributeError crash. Thanks to Christopher Armstrong
5270 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
5272 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
5271 introduced recently (in 0.2.14pre37) with the fix to the eval
5273 introduced recently (in 0.2.14pre37) with the fix to the eval
5272 problem mentioned below.
5274 problem mentioned below.
5273
5275
5274 2002-10-17 Fernando Perez <fperez@colorado.edu>
5276 2002-10-17 Fernando Perez <fperez@colorado.edu>
5275
5277
5276 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
5278 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
5277 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
5279 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
5278
5280
5279 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
5281 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
5280 this function to fix a problem reported by Alex Schmolck. He saw
5282 this function to fix a problem reported by Alex Schmolck. He saw
5281 it with list comprehensions and generators, which were getting
5283 it with list comprehensions and generators, which were getting
5282 called twice. The real problem was an 'eval' call in testing for
5284 called twice. The real problem was an 'eval' call in testing for
5283 automagic which was evaluating the input line silently.
5285 automagic which was evaluating the input line silently.
5284
5286
5285 This is a potentially very nasty bug, if the input has side
5287 This is a potentially very nasty bug, if the input has side
5286 effects which must not be repeated. The code is much cleaner now,
5288 effects which must not be repeated. The code is much cleaner now,
5287 without any blanket 'except' left and with a regexp test for
5289 without any blanket 'except' left and with a regexp test for
5288 actual function names.
5290 actual function names.
5289
5291
5290 But an eval remains, which I'm not fully comfortable with. I just
5292 But an eval remains, which I'm not fully comfortable with. I just
5291 don't know how to find out if an expression could be a callable in
5293 don't know how to find out if an expression could be a callable in
5292 the user's namespace without doing an eval on the string. However
5294 the user's namespace without doing an eval on the string. However
5293 that string is now much more strictly checked so that no code
5295 that string is now much more strictly checked so that no code
5294 slips by, so the eval should only happen for things that can
5296 slips by, so the eval should only happen for things that can
5295 really be only function/method names.
5297 really be only function/method names.
5296
5298
5297 2002-10-15 Fernando Perez <fperez@colorado.edu>
5299 2002-10-15 Fernando Perez <fperez@colorado.edu>
5298
5300
5299 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
5301 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
5300 OSX information to main manual, removed README_Mac_OSX file from
5302 OSX information to main manual, removed README_Mac_OSX file from
5301 distribution. Also updated credits for recent additions.
5303 distribution. Also updated credits for recent additions.
5302
5304
5303 2002-10-10 Fernando Perez <fperez@colorado.edu>
5305 2002-10-10 Fernando Perez <fperez@colorado.edu>
5304
5306
5305 * README_Mac_OSX: Added a README for Mac OSX users for fixing
5307 * README_Mac_OSX: Added a README for Mac OSX users for fixing
5306 terminal-related issues. Many thanks to Andrea Riciputi
5308 terminal-related issues. Many thanks to Andrea Riciputi
5307 <andrea.riciputi-AT-libero.it> for writing it.
5309 <andrea.riciputi-AT-libero.it> for writing it.
5308
5310
5309 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
5311 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
5310 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5312 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
5311
5313
5312 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
5314 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
5313 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
5315 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
5314 <syver-en-AT-online.no> who both submitted patches for this problem.
5316 <syver-en-AT-online.no> who both submitted patches for this problem.
5315
5317
5316 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
5318 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
5317 global embedding to make sure that things don't overwrite user
5319 global embedding to make sure that things don't overwrite user
5318 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
5320 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
5319
5321
5320 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
5322 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
5321 compatibility. Thanks to Hayden Callow
5323 compatibility. Thanks to Hayden Callow
5322 <h.callow-AT-elec.canterbury.ac.nz>
5324 <h.callow-AT-elec.canterbury.ac.nz>
5323
5325
5324 2002-10-04 Fernando Perez <fperez@colorado.edu>
5326 2002-10-04 Fernando Perez <fperez@colorado.edu>
5325
5327
5326 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
5328 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
5327 Gnuplot.File objects.
5329 Gnuplot.File objects.
5328
5330
5329 2002-07-23 Fernando Perez <fperez@colorado.edu>
5331 2002-07-23 Fernando Perez <fperez@colorado.edu>
5330
5332
5331 * IPython/genutils.py (timing): Added timings() and timing() for
5333 * IPython/genutils.py (timing): Added timings() and timing() for
5332 quick access to the most commonly needed data, the execution
5334 quick access to the most commonly needed data, the execution
5333 times. Old timing() renamed to timings_out().
5335 times. Old timing() renamed to timings_out().
5334
5336
5335 2002-07-18 Fernando Perez <fperez@colorado.edu>
5337 2002-07-18 Fernando Perez <fperez@colorado.edu>
5336
5338
5337 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
5339 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
5338 bug with nested instances disrupting the parent's tab completion.
5340 bug with nested instances disrupting the parent's tab completion.
5339
5341
5340 * IPython/iplib.py (all_completions): Added Alex Schmolck's
5342 * IPython/iplib.py (all_completions): Added Alex Schmolck's
5341 all_completions code to begin the emacs integration.
5343 all_completions code to begin the emacs integration.
5342
5344
5343 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
5345 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
5344 argument to allow titling individual arrays when plotting.
5346 argument to allow titling individual arrays when plotting.
5345
5347
5346 2002-07-15 Fernando Perez <fperez@colorado.edu>
5348 2002-07-15 Fernando Perez <fperez@colorado.edu>
5347
5349
5348 * setup.py (make_shortcut): changed to retrieve the value of
5350 * setup.py (make_shortcut): changed to retrieve the value of
5349 'Program Files' directory from the registry (this value changes in
5351 'Program Files' directory from the registry (this value changes in
5350 non-english versions of Windows). Thanks to Thomas Fanslau
5352 non-english versions of Windows). Thanks to Thomas Fanslau
5351 <tfanslau-AT-gmx.de> for the report.
5353 <tfanslau-AT-gmx.de> for the report.
5352
5354
5353 2002-07-10 Fernando Perez <fperez@colorado.edu>
5355 2002-07-10 Fernando Perez <fperez@colorado.edu>
5354
5356
5355 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5357 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5356 a bug in pdb, which crashes if a line with only whitespace is
5358 a bug in pdb, which crashes if a line with only whitespace is
5357 entered. Bug report submitted to sourceforge.
5359 entered. Bug report submitted to sourceforge.
5358
5360
5359 2002-07-09 Fernando Perez <fperez@colorado.edu>
5361 2002-07-09 Fernando Perez <fperez@colorado.edu>
5360
5362
5361 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5363 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5362 reporting exceptions (it's a bug in inspect.py, I just set a
5364 reporting exceptions (it's a bug in inspect.py, I just set a
5363 workaround).
5365 workaround).
5364
5366
5365 2002-07-08 Fernando Perez <fperez@colorado.edu>
5367 2002-07-08 Fernando Perez <fperez@colorado.edu>
5366
5368
5367 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5369 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5368 __IPYTHON__ in __builtins__ to show up in user_ns.
5370 __IPYTHON__ in __builtins__ to show up in user_ns.
5369
5371
5370 2002-07-03 Fernando Perez <fperez@colorado.edu>
5372 2002-07-03 Fernando Perez <fperez@colorado.edu>
5371
5373
5372 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5374 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5373 name from @gp_set_instance to @gp_set_default.
5375 name from @gp_set_instance to @gp_set_default.
5374
5376
5375 * IPython/ipmaker.py (make_IPython): default editor value set to
5377 * IPython/ipmaker.py (make_IPython): default editor value set to
5376 '0' (a string), to match the rc file. Otherwise will crash when
5378 '0' (a string), to match the rc file. Otherwise will crash when
5377 .strip() is called on it.
5379 .strip() is called on it.
5378
5380
5379
5381
5380 2002-06-28 Fernando Perez <fperez@colorado.edu>
5382 2002-06-28 Fernando Perez <fperez@colorado.edu>
5381
5383
5382 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5384 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5383 of files in current directory when a file is executed via
5385 of files in current directory when a file is executed via
5384 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5386 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5385
5387
5386 * setup.py (manfiles): fix for rpm builds, submitted by RA
5388 * setup.py (manfiles): fix for rpm builds, submitted by RA
5387 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5389 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5388
5390
5389 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5391 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5390 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5392 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5391 string!). A. Schmolck caught this one.
5393 string!). A. Schmolck caught this one.
5392
5394
5393 2002-06-27 Fernando Perez <fperez@colorado.edu>
5395 2002-06-27 Fernando Perez <fperez@colorado.edu>
5394
5396
5395 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5397 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5396 defined files at the cmd line. __name__ wasn't being set to
5398 defined files at the cmd line. __name__ wasn't being set to
5397 __main__.
5399 __main__.
5398
5400
5399 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5401 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5400 regular lists and tuples besides Numeric arrays.
5402 regular lists and tuples besides Numeric arrays.
5401
5403
5402 * IPython/Prompts.py (CachedOutput.__call__): Added output
5404 * IPython/Prompts.py (CachedOutput.__call__): Added output
5403 supression for input ending with ';'. Similar to Mathematica and
5405 supression for input ending with ';'. Similar to Mathematica and
5404 Matlab. The _* vars and Out[] list are still updated, just like
5406 Matlab. The _* vars and Out[] list are still updated, just like
5405 Mathematica behaves.
5407 Mathematica behaves.
5406
5408
5407 2002-06-25 Fernando Perez <fperez@colorado.edu>
5409 2002-06-25 Fernando Perez <fperez@colorado.edu>
5408
5410
5409 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5411 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5410 .ini extensions for profiels under Windows.
5412 .ini extensions for profiels under Windows.
5411
5413
5412 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5414 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5413 string form. Fix contributed by Alexander Schmolck
5415 string form. Fix contributed by Alexander Schmolck
5414 <a.schmolck-AT-gmx.net>
5416 <a.schmolck-AT-gmx.net>
5415
5417
5416 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5418 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5417 pre-configured Gnuplot instance.
5419 pre-configured Gnuplot instance.
5418
5420
5419 2002-06-21 Fernando Perez <fperez@colorado.edu>
5421 2002-06-21 Fernando Perez <fperez@colorado.edu>
5420
5422
5421 * IPython/numutils.py (exp_safe): new function, works around the
5423 * IPython/numutils.py (exp_safe): new function, works around the
5422 underflow problems in Numeric.
5424 underflow problems in Numeric.
5423 (log2): New fn. Safe log in base 2: returns exact integer answer
5425 (log2): New fn. Safe log in base 2: returns exact integer answer
5424 for exact integer powers of 2.
5426 for exact integer powers of 2.
5425
5427
5426 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5428 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5427 properly.
5429 properly.
5428
5430
5429 2002-06-20 Fernando Perez <fperez@colorado.edu>
5431 2002-06-20 Fernando Perez <fperez@colorado.edu>
5430
5432
5431 * IPython/genutils.py (timing): new function like
5433 * IPython/genutils.py (timing): new function like
5432 Mathematica's. Similar to time_test, but returns more info.
5434 Mathematica's. Similar to time_test, but returns more info.
5433
5435
5434 2002-06-18 Fernando Perez <fperez@colorado.edu>
5436 2002-06-18 Fernando Perez <fperez@colorado.edu>
5435
5437
5436 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5438 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5437 according to Mike Heeter's suggestions.
5439 according to Mike Heeter's suggestions.
5438
5440
5439 2002-06-16 Fernando Perez <fperez@colorado.edu>
5441 2002-06-16 Fernando Perez <fperez@colorado.edu>
5440
5442
5441 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5443 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5442 system. GnuplotMagic is gone as a user-directory option. New files
5444 system. GnuplotMagic is gone as a user-directory option. New files
5443 make it easier to use all the gnuplot stuff both from external
5445 make it easier to use all the gnuplot stuff both from external
5444 programs as well as from IPython. Had to rewrite part of
5446 programs as well as from IPython. Had to rewrite part of
5445 hardcopy() b/c of a strange bug: often the ps files simply don't
5447 hardcopy() b/c of a strange bug: often the ps files simply don't
5446 get created, and require a repeat of the command (often several
5448 get created, and require a repeat of the command (often several
5447 times).
5449 times).
5448
5450
5449 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5451 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5450 resolve output channel at call time, so that if sys.stderr has
5452 resolve output channel at call time, so that if sys.stderr has
5451 been redirected by user this gets honored.
5453 been redirected by user this gets honored.
5452
5454
5453 2002-06-13 Fernando Perez <fperez@colorado.edu>
5455 2002-06-13 Fernando Perez <fperez@colorado.edu>
5454
5456
5455 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5457 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5456 IPShell. Kept a copy with the old names to avoid breaking people's
5458 IPShell. Kept a copy with the old names to avoid breaking people's
5457 embedded code.
5459 embedded code.
5458
5460
5459 * IPython/ipython: simplified it to the bare minimum after
5461 * IPython/ipython: simplified it to the bare minimum after
5460 Holger's suggestions. Added info about how to use it in
5462 Holger's suggestions. Added info about how to use it in
5461 PYTHONSTARTUP.
5463 PYTHONSTARTUP.
5462
5464
5463 * IPython/Shell.py (IPythonShell): changed the options passing
5465 * IPython/Shell.py (IPythonShell): changed the options passing
5464 from a string with funky %s replacements to a straight list. Maybe
5466 from a string with funky %s replacements to a straight list. Maybe
5465 a bit more typing, but it follows sys.argv conventions, so there's
5467 a bit more typing, but it follows sys.argv conventions, so there's
5466 less special-casing to remember.
5468 less special-casing to remember.
5467
5469
5468 2002-06-12 Fernando Perez <fperez@colorado.edu>
5470 2002-06-12 Fernando Perez <fperez@colorado.edu>
5469
5471
5470 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5472 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5471 command. Thanks to a suggestion by Mike Heeter.
5473 command. Thanks to a suggestion by Mike Heeter.
5472 (Magic.magic_pfile): added behavior to look at filenames if given
5474 (Magic.magic_pfile): added behavior to look at filenames if given
5473 arg is not a defined object.
5475 arg is not a defined object.
5474 (Magic.magic_save): New @save function to save code snippets. Also
5476 (Magic.magic_save): New @save function to save code snippets. Also
5475 a Mike Heeter idea.
5477 a Mike Heeter idea.
5476
5478
5477 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5479 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5478 plot() and replot(). Much more convenient now, especially for
5480 plot() and replot(). Much more convenient now, especially for
5479 interactive use.
5481 interactive use.
5480
5482
5481 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5483 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5482 filenames.
5484 filenames.
5483
5485
5484 2002-06-02 Fernando Perez <fperez@colorado.edu>
5486 2002-06-02 Fernando Perez <fperez@colorado.edu>
5485
5487
5486 * IPython/Struct.py (Struct.__init__): modified to admit
5488 * IPython/Struct.py (Struct.__init__): modified to admit
5487 initialization via another struct.
5489 initialization via another struct.
5488
5490
5489 * IPython/genutils.py (SystemExec.__init__): New stateful
5491 * IPython/genutils.py (SystemExec.__init__): New stateful
5490 interface to xsys and bq. Useful for writing system scripts.
5492 interface to xsys and bq. Useful for writing system scripts.
5491
5493
5492 2002-05-30 Fernando Perez <fperez@colorado.edu>
5494 2002-05-30 Fernando Perez <fperez@colorado.edu>
5493
5495
5494 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5496 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5495 documents. This will make the user download smaller (it's getting
5497 documents. This will make the user download smaller (it's getting
5496 too big).
5498 too big).
5497
5499
5498 2002-05-29 Fernando Perez <fperez@colorado.edu>
5500 2002-05-29 Fernando Perez <fperez@colorado.edu>
5499
5501
5500 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5502 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5501 fix problems with shelve and pickle. Seems to work, but I don't
5503 fix problems with shelve and pickle. Seems to work, but I don't
5502 know if corner cases break it. Thanks to Mike Heeter
5504 know if corner cases break it. Thanks to Mike Heeter
5503 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5505 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5504
5506
5505 2002-05-24 Fernando Perez <fperez@colorado.edu>
5507 2002-05-24 Fernando Perez <fperez@colorado.edu>
5506
5508
5507 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5509 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5508 macros having broken.
5510 macros having broken.
5509
5511
5510 2002-05-21 Fernando Perez <fperez@colorado.edu>
5512 2002-05-21 Fernando Perez <fperez@colorado.edu>
5511
5513
5512 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5514 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5513 introduced logging bug: all history before logging started was
5515 introduced logging bug: all history before logging started was
5514 being written one character per line! This came from the redesign
5516 being written one character per line! This came from the redesign
5515 of the input history as a special list which slices to strings,
5517 of the input history as a special list which slices to strings,
5516 not to lists.
5518 not to lists.
5517
5519
5518 2002-05-20 Fernando Perez <fperez@colorado.edu>
5520 2002-05-20 Fernando Perez <fperez@colorado.edu>
5519
5521
5520 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5522 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5521 be an attribute of all classes in this module. The design of these
5523 be an attribute of all classes in this module. The design of these
5522 classes needs some serious overhauling.
5524 classes needs some serious overhauling.
5523
5525
5524 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5526 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5525 which was ignoring '_' in option names.
5527 which was ignoring '_' in option names.
5526
5528
5527 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5529 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5528 'Verbose_novars' to 'Context' and made it the new default. It's a
5530 'Verbose_novars' to 'Context' and made it the new default. It's a
5529 bit more readable and also safer than verbose.
5531 bit more readable and also safer than verbose.
5530
5532
5531 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5533 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5532 triple-quoted strings.
5534 triple-quoted strings.
5533
5535
5534 * IPython/OInspect.py (__all__): new module exposing the object
5536 * IPython/OInspect.py (__all__): new module exposing the object
5535 introspection facilities. Now the corresponding magics are dummy
5537 introspection facilities. Now the corresponding magics are dummy
5536 wrappers around this. Having this module will make it much easier
5538 wrappers around this. Having this module will make it much easier
5537 to put these functions into our modified pdb.
5539 to put these functions into our modified pdb.
5538 This new object inspector system uses the new colorizing module,
5540 This new object inspector system uses the new colorizing module,
5539 so source code and other things are nicely syntax highlighted.
5541 so source code and other things are nicely syntax highlighted.
5540
5542
5541 2002-05-18 Fernando Perez <fperez@colorado.edu>
5543 2002-05-18 Fernando Perez <fperez@colorado.edu>
5542
5544
5543 * IPython/ColorANSI.py: Split the coloring tools into a separate
5545 * IPython/ColorANSI.py: Split the coloring tools into a separate
5544 module so I can use them in other code easier (they were part of
5546 module so I can use them in other code easier (they were part of
5545 ultraTB).
5547 ultraTB).
5546
5548
5547 2002-05-17 Fernando Perez <fperez@colorado.edu>
5549 2002-05-17 Fernando Perez <fperez@colorado.edu>
5548
5550
5549 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5551 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5550 fixed it to set the global 'g' also to the called instance, as
5552 fixed it to set the global 'g' also to the called instance, as
5551 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5553 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5552 user's 'g' variables).
5554 user's 'g' variables).
5553
5555
5554 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5556 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5555 global variables (aliases to _ih,_oh) so that users which expect
5557 global variables (aliases to _ih,_oh) so that users which expect
5556 In[5] or Out[7] to work aren't unpleasantly surprised.
5558 In[5] or Out[7] to work aren't unpleasantly surprised.
5557 (InputList.__getslice__): new class to allow executing slices of
5559 (InputList.__getslice__): new class to allow executing slices of
5558 input history directly. Very simple class, complements the use of
5560 input history directly. Very simple class, complements the use of
5559 macros.
5561 macros.
5560
5562
5561 2002-05-16 Fernando Perez <fperez@colorado.edu>
5563 2002-05-16 Fernando Perez <fperez@colorado.edu>
5562
5564
5563 * setup.py (docdirbase): make doc directory be just doc/IPython
5565 * setup.py (docdirbase): make doc directory be just doc/IPython
5564 without version numbers, it will reduce clutter for users.
5566 without version numbers, it will reduce clutter for users.
5565
5567
5566 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5568 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5567 execfile call to prevent possible memory leak. See for details:
5569 execfile call to prevent possible memory leak. See for details:
5568 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5570 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5569
5571
5570 2002-05-15 Fernando Perez <fperez@colorado.edu>
5572 2002-05-15 Fernando Perez <fperez@colorado.edu>
5571
5573
5572 * IPython/Magic.py (Magic.magic_psource): made the object
5574 * IPython/Magic.py (Magic.magic_psource): made the object
5573 introspection names be more standard: pdoc, pdef, pfile and
5575 introspection names be more standard: pdoc, pdef, pfile and
5574 psource. They all print/page their output, and it makes
5576 psource. They all print/page their output, and it makes
5575 remembering them easier. Kept old names for compatibility as
5577 remembering them easier. Kept old names for compatibility as
5576 aliases.
5578 aliases.
5577
5579
5578 2002-05-14 Fernando Perez <fperez@colorado.edu>
5580 2002-05-14 Fernando Perez <fperez@colorado.edu>
5579
5581
5580 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5582 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5581 what the mouse problem was. The trick is to use gnuplot with temp
5583 what the mouse problem was. The trick is to use gnuplot with temp
5582 files and NOT with pipes (for data communication), because having
5584 files and NOT with pipes (for data communication), because having
5583 both pipes and the mouse on is bad news.
5585 both pipes and the mouse on is bad news.
5584
5586
5585 2002-05-13 Fernando Perez <fperez@colorado.edu>
5587 2002-05-13 Fernando Perez <fperez@colorado.edu>
5586
5588
5587 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5589 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5588 bug. Information would be reported about builtins even when
5590 bug. Information would be reported about builtins even when
5589 user-defined functions overrode them.
5591 user-defined functions overrode them.
5590
5592
5591 2002-05-11 Fernando Perez <fperez@colorado.edu>
5593 2002-05-11 Fernando Perez <fperez@colorado.edu>
5592
5594
5593 * IPython/__init__.py (__all__): removed FlexCompleter from
5595 * IPython/__init__.py (__all__): removed FlexCompleter from
5594 __all__ so that things don't fail in platforms without readline.
5596 __all__ so that things don't fail in platforms without readline.
5595
5597
5596 2002-05-10 Fernando Perez <fperez@colorado.edu>
5598 2002-05-10 Fernando Perez <fperez@colorado.edu>
5597
5599
5598 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5600 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5599 it requires Numeric, effectively making Numeric a dependency for
5601 it requires Numeric, effectively making Numeric a dependency for
5600 IPython.
5602 IPython.
5601
5603
5602 * Released 0.2.13
5604 * Released 0.2.13
5603
5605
5604 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5606 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5605 profiler interface. Now all the major options from the profiler
5607 profiler interface. Now all the major options from the profiler
5606 module are directly supported in IPython, both for single
5608 module are directly supported in IPython, both for single
5607 expressions (@prun) and for full programs (@run -p).
5609 expressions (@prun) and for full programs (@run -p).
5608
5610
5609 2002-05-09 Fernando Perez <fperez@colorado.edu>
5611 2002-05-09 Fernando Perez <fperez@colorado.edu>
5610
5612
5611 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5613 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5612 magic properly formatted for screen.
5614 magic properly formatted for screen.
5613
5615
5614 * setup.py (make_shortcut): Changed things to put pdf version in
5616 * setup.py (make_shortcut): Changed things to put pdf version in
5615 doc/ instead of doc/manual (had to change lyxport a bit).
5617 doc/ instead of doc/manual (had to change lyxport a bit).
5616
5618
5617 * IPython/Magic.py (Profile.string_stats): made profile runs go
5619 * IPython/Magic.py (Profile.string_stats): made profile runs go
5618 through pager (they are long and a pager allows searching, saving,
5620 through pager (they are long and a pager allows searching, saving,
5619 etc.)
5621 etc.)
5620
5622
5621 2002-05-08 Fernando Perez <fperez@colorado.edu>
5623 2002-05-08 Fernando Perez <fperez@colorado.edu>
5622
5624
5623 * Released 0.2.12
5625 * Released 0.2.12
5624
5626
5625 2002-05-06 Fernando Perez <fperez@colorado.edu>
5627 2002-05-06 Fernando Perez <fperez@colorado.edu>
5626
5628
5627 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5629 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5628 introduced); 'hist n1 n2' was broken.
5630 introduced); 'hist n1 n2' was broken.
5629 (Magic.magic_pdb): added optional on/off arguments to @pdb
5631 (Magic.magic_pdb): added optional on/off arguments to @pdb
5630 (Magic.magic_run): added option -i to @run, which executes code in
5632 (Magic.magic_run): added option -i to @run, which executes code in
5631 the IPython namespace instead of a clean one. Also added @irun as
5633 the IPython namespace instead of a clean one. Also added @irun as
5632 an alias to @run -i.
5634 an alias to @run -i.
5633
5635
5634 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5636 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5635 fixed (it didn't really do anything, the namespaces were wrong).
5637 fixed (it didn't really do anything, the namespaces were wrong).
5636
5638
5637 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5639 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5638
5640
5639 * IPython/__init__.py (__all__): Fixed package namespace, now
5641 * IPython/__init__.py (__all__): Fixed package namespace, now
5640 'import IPython' does give access to IPython.<all> as
5642 'import IPython' does give access to IPython.<all> as
5641 expected. Also renamed __release__ to Release.
5643 expected. Also renamed __release__ to Release.
5642
5644
5643 * IPython/Debugger.py (__license__): created new Pdb class which
5645 * IPython/Debugger.py (__license__): created new Pdb class which
5644 functions like a drop-in for the normal pdb.Pdb but does NOT
5646 functions like a drop-in for the normal pdb.Pdb but does NOT
5645 import readline by default. This way it doesn't muck up IPython's
5647 import readline by default. This way it doesn't muck up IPython's
5646 readline handling, and now tab-completion finally works in the
5648 readline handling, and now tab-completion finally works in the
5647 debugger -- sort of. It completes things globally visible, but the
5649 debugger -- sort of. It completes things globally visible, but the
5648 completer doesn't track the stack as pdb walks it. That's a bit
5650 completer doesn't track the stack as pdb walks it. That's a bit
5649 tricky, and I'll have to implement it later.
5651 tricky, and I'll have to implement it later.
5650
5652
5651 2002-05-05 Fernando Perez <fperez@colorado.edu>
5653 2002-05-05 Fernando Perez <fperez@colorado.edu>
5652
5654
5653 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5655 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5654 magic docstrings when printed via ? (explicit \'s were being
5656 magic docstrings when printed via ? (explicit \'s were being
5655 printed).
5657 printed).
5656
5658
5657 * IPython/ipmaker.py (make_IPython): fixed namespace
5659 * IPython/ipmaker.py (make_IPython): fixed namespace
5658 identification bug. Now variables loaded via logs or command-line
5660 identification bug. Now variables loaded via logs or command-line
5659 files are recognized in the interactive namespace by @who.
5661 files are recognized in the interactive namespace by @who.
5660
5662
5661 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5663 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5662 log replay system stemming from the string form of Structs.
5664 log replay system stemming from the string form of Structs.
5663
5665
5664 * IPython/Magic.py (Macro.__init__): improved macros to properly
5666 * IPython/Magic.py (Macro.__init__): improved macros to properly
5665 handle magic commands in them.
5667 handle magic commands in them.
5666 (Magic.magic_logstart): usernames are now expanded so 'logstart
5668 (Magic.magic_logstart): usernames are now expanded so 'logstart
5667 ~/mylog' now works.
5669 ~/mylog' now works.
5668
5670
5669 * IPython/iplib.py (complete): fixed bug where paths starting with
5671 * IPython/iplib.py (complete): fixed bug where paths starting with
5670 '/' would be completed as magic names.
5672 '/' would be completed as magic names.
5671
5673
5672 2002-05-04 Fernando Perez <fperez@colorado.edu>
5674 2002-05-04 Fernando Perez <fperez@colorado.edu>
5673
5675
5674 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5676 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5675 allow running full programs under the profiler's control.
5677 allow running full programs under the profiler's control.
5676
5678
5677 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5679 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5678 mode to report exceptions verbosely but without formatting
5680 mode to report exceptions verbosely but without formatting
5679 variables. This addresses the issue of ipython 'freezing' (it's
5681 variables. This addresses the issue of ipython 'freezing' (it's
5680 not frozen, but caught in an expensive formatting loop) when huge
5682 not frozen, but caught in an expensive formatting loop) when huge
5681 variables are in the context of an exception.
5683 variables are in the context of an exception.
5682 (VerboseTB.text): Added '--->' markers at line where exception was
5684 (VerboseTB.text): Added '--->' markers at line where exception was
5683 triggered. Much clearer to read, especially in NoColor modes.
5685 triggered. Much clearer to read, especially in NoColor modes.
5684
5686
5685 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5687 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5686 implemented in reverse when changing to the new parse_options().
5688 implemented in reverse when changing to the new parse_options().
5687
5689
5688 2002-05-03 Fernando Perez <fperez@colorado.edu>
5690 2002-05-03 Fernando Perez <fperez@colorado.edu>
5689
5691
5690 * IPython/Magic.py (Magic.parse_options): new function so that
5692 * IPython/Magic.py (Magic.parse_options): new function so that
5691 magics can parse options easier.
5693 magics can parse options easier.
5692 (Magic.magic_prun): new function similar to profile.run(),
5694 (Magic.magic_prun): new function similar to profile.run(),
5693 suggested by Chris Hart.
5695 suggested by Chris Hart.
5694 (Magic.magic_cd): fixed behavior so that it only changes if
5696 (Magic.magic_cd): fixed behavior so that it only changes if
5695 directory actually is in history.
5697 directory actually is in history.
5696
5698
5697 * IPython/usage.py (__doc__): added information about potential
5699 * IPython/usage.py (__doc__): added information about potential
5698 slowness of Verbose exception mode when there are huge data
5700 slowness of Verbose exception mode when there are huge data
5699 structures to be formatted (thanks to Archie Paulson).
5701 structures to be formatted (thanks to Archie Paulson).
5700
5702
5701 * IPython/ipmaker.py (make_IPython): Changed default logging
5703 * IPython/ipmaker.py (make_IPython): Changed default logging
5702 (when simply called with -log) to use curr_dir/ipython.log in
5704 (when simply called with -log) to use curr_dir/ipython.log in
5703 rotate mode. Fixed crash which was occuring with -log before
5705 rotate mode. Fixed crash which was occuring with -log before
5704 (thanks to Jim Boyle).
5706 (thanks to Jim Boyle).
5705
5707
5706 2002-05-01 Fernando Perez <fperez@colorado.edu>
5708 2002-05-01 Fernando Perez <fperez@colorado.edu>
5707
5709
5708 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5710 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5709 was nasty -- though somewhat of a corner case).
5711 was nasty -- though somewhat of a corner case).
5710
5712
5711 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5713 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5712 text (was a bug).
5714 text (was a bug).
5713
5715
5714 2002-04-30 Fernando Perez <fperez@colorado.edu>
5716 2002-04-30 Fernando Perez <fperez@colorado.edu>
5715
5717
5716 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5718 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5717 a print after ^D or ^C from the user so that the In[] prompt
5719 a print after ^D or ^C from the user so that the In[] prompt
5718 doesn't over-run the gnuplot one.
5720 doesn't over-run the gnuplot one.
5719
5721
5720 2002-04-29 Fernando Perez <fperez@colorado.edu>
5722 2002-04-29 Fernando Perez <fperez@colorado.edu>
5721
5723
5722 * Released 0.2.10
5724 * Released 0.2.10
5723
5725
5724 * IPython/__release__.py (version): get date dynamically.
5726 * IPython/__release__.py (version): get date dynamically.
5725
5727
5726 * Misc. documentation updates thanks to Arnd's comments. Also ran
5728 * Misc. documentation updates thanks to Arnd's comments. Also ran
5727 a full spellcheck on the manual (hadn't been done in a while).
5729 a full spellcheck on the manual (hadn't been done in a while).
5728
5730
5729 2002-04-27 Fernando Perez <fperez@colorado.edu>
5731 2002-04-27 Fernando Perez <fperez@colorado.edu>
5730
5732
5731 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5733 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5732 starting a log in mid-session would reset the input history list.
5734 starting a log in mid-session would reset the input history list.
5733
5735
5734 2002-04-26 Fernando Perez <fperez@colorado.edu>
5736 2002-04-26 Fernando Perez <fperez@colorado.edu>
5735
5737
5736 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5738 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5737 all files were being included in an update. Now anything in
5739 all files were being included in an update. Now anything in
5738 UserConfig that matches [A-Za-z]*.py will go (this excludes
5740 UserConfig that matches [A-Za-z]*.py will go (this excludes
5739 __init__.py)
5741 __init__.py)
5740
5742
5741 2002-04-25 Fernando Perez <fperez@colorado.edu>
5743 2002-04-25 Fernando Perez <fperez@colorado.edu>
5742
5744
5743 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5745 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5744 to __builtins__ so that any form of embedded or imported code can
5746 to __builtins__ so that any form of embedded or imported code can
5745 test for being inside IPython.
5747 test for being inside IPython.
5746
5748
5747 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5749 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5748 changed to GnuplotMagic because it's now an importable module,
5750 changed to GnuplotMagic because it's now an importable module,
5749 this makes the name follow that of the standard Gnuplot module.
5751 this makes the name follow that of the standard Gnuplot module.
5750 GnuplotMagic can now be loaded at any time in mid-session.
5752 GnuplotMagic can now be loaded at any time in mid-session.
5751
5753
5752 2002-04-24 Fernando Perez <fperez@colorado.edu>
5754 2002-04-24 Fernando Perez <fperez@colorado.edu>
5753
5755
5754 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5756 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5755 the globals (IPython has its own namespace) and the
5757 the globals (IPython has its own namespace) and the
5756 PhysicalQuantity stuff is much better anyway.
5758 PhysicalQuantity stuff is much better anyway.
5757
5759
5758 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5760 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5759 embedding example to standard user directory for
5761 embedding example to standard user directory for
5760 distribution. Also put it in the manual.
5762 distribution. Also put it in the manual.
5761
5763
5762 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5764 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5763 instance as first argument (so it doesn't rely on some obscure
5765 instance as first argument (so it doesn't rely on some obscure
5764 hidden global).
5766 hidden global).
5765
5767
5766 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5768 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5767 delimiters. While it prevents ().TAB from working, it allows
5769 delimiters. While it prevents ().TAB from working, it allows
5768 completions in open (... expressions. This is by far a more common
5770 completions in open (... expressions. This is by far a more common
5769 case.
5771 case.
5770
5772
5771 2002-04-23 Fernando Perez <fperez@colorado.edu>
5773 2002-04-23 Fernando Perez <fperez@colorado.edu>
5772
5774
5773 * IPython/Extensions/InterpreterPasteInput.py: new
5775 * IPython/Extensions/InterpreterPasteInput.py: new
5774 syntax-processing module for pasting lines with >>> or ... at the
5776 syntax-processing module for pasting lines with >>> or ... at the
5775 start.
5777 start.
5776
5778
5777 * IPython/Extensions/PhysicalQ_Interactive.py
5779 * IPython/Extensions/PhysicalQ_Interactive.py
5778 (PhysicalQuantityInteractive.__int__): fixed to work with either
5780 (PhysicalQuantityInteractive.__int__): fixed to work with either
5779 Numeric or math.
5781 Numeric or math.
5780
5782
5781 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5783 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5782 provided profiles. Now we have:
5784 provided profiles. Now we have:
5783 -math -> math module as * and cmath with its own namespace.
5785 -math -> math module as * and cmath with its own namespace.
5784 -numeric -> Numeric as *, plus gnuplot & grace
5786 -numeric -> Numeric as *, plus gnuplot & grace
5785 -physics -> same as before
5787 -physics -> same as before
5786
5788
5787 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5789 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5788 user-defined magics wouldn't be found by @magic if they were
5790 user-defined magics wouldn't be found by @magic if they were
5789 defined as class methods. Also cleaned up the namespace search
5791 defined as class methods. Also cleaned up the namespace search
5790 logic and the string building (to use %s instead of many repeated
5792 logic and the string building (to use %s instead of many repeated
5791 string adds).
5793 string adds).
5792
5794
5793 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5795 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5794 of user-defined magics to operate with class methods (cleaner, in
5796 of user-defined magics to operate with class methods (cleaner, in
5795 line with the gnuplot code).
5797 line with the gnuplot code).
5796
5798
5797 2002-04-22 Fernando Perez <fperez@colorado.edu>
5799 2002-04-22 Fernando Perez <fperez@colorado.edu>
5798
5800
5799 * setup.py: updated dependency list so that manual is updated when
5801 * setup.py: updated dependency list so that manual is updated when
5800 all included files change.
5802 all included files change.
5801
5803
5802 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5804 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5803 the delimiter removal option (the fix is ugly right now).
5805 the delimiter removal option (the fix is ugly right now).
5804
5806
5805 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5807 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5806 all of the math profile (quicker loading, no conflict between
5808 all of the math profile (quicker loading, no conflict between
5807 g-9.8 and g-gnuplot).
5809 g-9.8 and g-gnuplot).
5808
5810
5809 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5811 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5810 name of post-mortem files to IPython_crash_report.txt.
5812 name of post-mortem files to IPython_crash_report.txt.
5811
5813
5812 * Cleanup/update of the docs. Added all the new readline info and
5814 * Cleanup/update of the docs. Added all the new readline info and
5813 formatted all lists as 'real lists'.
5815 formatted all lists as 'real lists'.
5814
5816
5815 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5817 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5816 tab-completion options, since the full readline parse_and_bind is
5818 tab-completion options, since the full readline parse_and_bind is
5817 now accessible.
5819 now accessible.
5818
5820
5819 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5821 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5820 handling of readline options. Now users can specify any string to
5822 handling of readline options. Now users can specify any string to
5821 be passed to parse_and_bind(), as well as the delimiters to be
5823 be passed to parse_and_bind(), as well as the delimiters to be
5822 removed.
5824 removed.
5823 (InteractiveShell.__init__): Added __name__ to the global
5825 (InteractiveShell.__init__): Added __name__ to the global
5824 namespace so that things like Itpl which rely on its existence
5826 namespace so that things like Itpl which rely on its existence
5825 don't crash.
5827 don't crash.
5826 (InteractiveShell._prefilter): Defined the default with a _ so
5828 (InteractiveShell._prefilter): Defined the default with a _ so
5827 that prefilter() is easier to override, while the default one
5829 that prefilter() is easier to override, while the default one
5828 remains available.
5830 remains available.
5829
5831
5830 2002-04-18 Fernando Perez <fperez@colorado.edu>
5832 2002-04-18 Fernando Perez <fperez@colorado.edu>
5831
5833
5832 * Added information about pdb in the docs.
5834 * Added information about pdb in the docs.
5833
5835
5834 2002-04-17 Fernando Perez <fperez@colorado.edu>
5836 2002-04-17 Fernando Perez <fperez@colorado.edu>
5835
5837
5836 * IPython/ipmaker.py (make_IPython): added rc_override option to
5838 * IPython/ipmaker.py (make_IPython): added rc_override option to
5837 allow passing config options at creation time which may override
5839 allow passing config options at creation time which may override
5838 anything set in the config files or command line. This is
5840 anything set in the config files or command line. This is
5839 particularly useful for configuring embedded instances.
5841 particularly useful for configuring embedded instances.
5840
5842
5841 2002-04-15 Fernando Perez <fperez@colorado.edu>
5843 2002-04-15 Fernando Perez <fperez@colorado.edu>
5842
5844
5843 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5845 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5844 crash embedded instances because of the input cache falling out of
5846 crash embedded instances because of the input cache falling out of
5845 sync with the output counter.
5847 sync with the output counter.
5846
5848
5847 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5849 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5848 mode which calls pdb after an uncaught exception in IPython itself.
5850 mode which calls pdb after an uncaught exception in IPython itself.
5849
5851
5850 2002-04-14 Fernando Perez <fperez@colorado.edu>
5852 2002-04-14 Fernando Perez <fperez@colorado.edu>
5851
5853
5852 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5854 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5853 readline, fix it back after each call.
5855 readline, fix it back after each call.
5854
5856
5855 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5857 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5856 method to force all access via __call__(), which guarantees that
5858 method to force all access via __call__(), which guarantees that
5857 traceback references are properly deleted.
5859 traceback references are properly deleted.
5858
5860
5859 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5861 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5860 improve printing when pprint is in use.
5862 improve printing when pprint is in use.
5861
5863
5862 2002-04-13 Fernando Perez <fperez@colorado.edu>
5864 2002-04-13 Fernando Perez <fperez@colorado.edu>
5863
5865
5864 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5866 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5865 exceptions aren't caught anymore. If the user triggers one, he
5867 exceptions aren't caught anymore. If the user triggers one, he
5866 should know why he's doing it and it should go all the way up,
5868 should know why he's doing it and it should go all the way up,
5867 just like any other exception. So now @abort will fully kill the
5869 just like any other exception. So now @abort will fully kill the
5868 embedded interpreter and the embedding code (unless that happens
5870 embedded interpreter and the embedding code (unless that happens
5869 to catch SystemExit).
5871 to catch SystemExit).
5870
5872
5871 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5873 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5872 and a debugger() method to invoke the interactive pdb debugger
5874 and a debugger() method to invoke the interactive pdb debugger
5873 after printing exception information. Also added the corresponding
5875 after printing exception information. Also added the corresponding
5874 -pdb option and @pdb magic to control this feature, and updated
5876 -pdb option and @pdb magic to control this feature, and updated
5875 the docs. After a suggestion from Christopher Hart
5877 the docs. After a suggestion from Christopher Hart
5876 (hart-AT-caltech.edu).
5878 (hart-AT-caltech.edu).
5877
5879
5878 2002-04-12 Fernando Perez <fperez@colorado.edu>
5880 2002-04-12 Fernando Perez <fperez@colorado.edu>
5879
5881
5880 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5882 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5881 the exception handlers defined by the user (not the CrashHandler)
5883 the exception handlers defined by the user (not the CrashHandler)
5882 so that user exceptions don't trigger an ipython bug report.
5884 so that user exceptions don't trigger an ipython bug report.
5883
5885
5884 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5886 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5885 configurable (it should have always been so).
5887 configurable (it should have always been so).
5886
5888
5887 2002-03-26 Fernando Perez <fperez@colorado.edu>
5889 2002-03-26 Fernando Perez <fperez@colorado.edu>
5888
5890
5889 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5891 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5890 and there to fix embedding namespace issues. This should all be
5892 and there to fix embedding namespace issues. This should all be
5891 done in a more elegant way.
5893 done in a more elegant way.
5892
5894
5893 2002-03-25 Fernando Perez <fperez@colorado.edu>
5895 2002-03-25 Fernando Perez <fperez@colorado.edu>
5894
5896
5895 * IPython/genutils.py (get_home_dir): Try to make it work under
5897 * IPython/genutils.py (get_home_dir): Try to make it work under
5896 win9x also.
5898 win9x also.
5897
5899
5898 2002-03-20 Fernando Perez <fperez@colorado.edu>
5900 2002-03-20 Fernando Perez <fperez@colorado.edu>
5899
5901
5900 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5902 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5901 sys.displayhook untouched upon __init__.
5903 sys.displayhook untouched upon __init__.
5902
5904
5903 2002-03-19 Fernando Perez <fperez@colorado.edu>
5905 2002-03-19 Fernando Perez <fperez@colorado.edu>
5904
5906
5905 * Released 0.2.9 (for embedding bug, basically).
5907 * Released 0.2.9 (for embedding bug, basically).
5906
5908
5907 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5909 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5908 exceptions so that enclosing shell's state can be restored.
5910 exceptions so that enclosing shell's state can be restored.
5909
5911
5910 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5912 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5911 naming conventions in the .ipython/ dir.
5913 naming conventions in the .ipython/ dir.
5912
5914
5913 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5915 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5914 from delimiters list so filenames with - in them get expanded.
5916 from delimiters list so filenames with - in them get expanded.
5915
5917
5916 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5918 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5917 sys.displayhook not being properly restored after an embedded call.
5919 sys.displayhook not being properly restored after an embedded call.
5918
5920
5919 2002-03-18 Fernando Perez <fperez@colorado.edu>
5921 2002-03-18 Fernando Perez <fperez@colorado.edu>
5920
5922
5921 * Released 0.2.8
5923 * Released 0.2.8
5922
5924
5923 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5925 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5924 some files weren't being included in a -upgrade.
5926 some files weren't being included in a -upgrade.
5925 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5927 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5926 on' so that the first tab completes.
5928 on' so that the first tab completes.
5927 (InteractiveShell.handle_magic): fixed bug with spaces around
5929 (InteractiveShell.handle_magic): fixed bug with spaces around
5928 quotes breaking many magic commands.
5930 quotes breaking many magic commands.
5929
5931
5930 * setup.py: added note about ignoring the syntax error messages at
5932 * setup.py: added note about ignoring the syntax error messages at
5931 installation.
5933 installation.
5932
5934
5933 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5935 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5934 streamlining the gnuplot interface, now there's only one magic @gp.
5936 streamlining the gnuplot interface, now there's only one magic @gp.
5935
5937
5936 2002-03-17 Fernando Perez <fperez@colorado.edu>
5938 2002-03-17 Fernando Perez <fperez@colorado.edu>
5937
5939
5938 * IPython/UserConfig/magic_gnuplot.py: new name for the
5940 * IPython/UserConfig/magic_gnuplot.py: new name for the
5939 example-magic_pm.py file. Much enhanced system, now with a shell
5941 example-magic_pm.py file. Much enhanced system, now with a shell
5940 for communicating directly with gnuplot, one command at a time.
5942 for communicating directly with gnuplot, one command at a time.
5941
5943
5942 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5944 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5943 setting __name__=='__main__'.
5945 setting __name__=='__main__'.
5944
5946
5945 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5947 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5946 mini-shell for accessing gnuplot from inside ipython. Should
5948 mini-shell for accessing gnuplot from inside ipython. Should
5947 extend it later for grace access too. Inspired by Arnd's
5949 extend it later for grace access too. Inspired by Arnd's
5948 suggestion.
5950 suggestion.
5949
5951
5950 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5952 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5951 calling magic functions with () in their arguments. Thanks to Arnd
5953 calling magic functions with () in their arguments. Thanks to Arnd
5952 Baecker for pointing this to me.
5954 Baecker for pointing this to me.
5953
5955
5954 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5956 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5955 infinitely for integer or complex arrays (only worked with floats).
5957 infinitely for integer or complex arrays (only worked with floats).
5956
5958
5957 2002-03-16 Fernando Perez <fperez@colorado.edu>
5959 2002-03-16 Fernando Perez <fperez@colorado.edu>
5958
5960
5959 * setup.py: Merged setup and setup_windows into a single script
5961 * setup.py: Merged setup and setup_windows into a single script
5960 which properly handles things for windows users.
5962 which properly handles things for windows users.
5961
5963
5962 2002-03-15 Fernando Perez <fperez@colorado.edu>
5964 2002-03-15 Fernando Perez <fperez@colorado.edu>
5963
5965
5964 * Big change to the manual: now the magics are all automatically
5966 * Big change to the manual: now the magics are all automatically
5965 documented. This information is generated from their docstrings
5967 documented. This information is generated from their docstrings
5966 and put in a latex file included by the manual lyx file. This way
5968 and put in a latex file included by the manual lyx file. This way
5967 we get always up to date information for the magics. The manual
5969 we get always up to date information for the magics. The manual
5968 now also has proper version information, also auto-synced.
5970 now also has proper version information, also auto-synced.
5969
5971
5970 For this to work, an undocumented --magic_docstrings option was added.
5972 For this to work, an undocumented --magic_docstrings option was added.
5971
5973
5972 2002-03-13 Fernando Perez <fperez@colorado.edu>
5974 2002-03-13 Fernando Perez <fperez@colorado.edu>
5973
5975
5974 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5976 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5975 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5977 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5976
5978
5977 2002-03-12 Fernando Perez <fperez@colorado.edu>
5979 2002-03-12 Fernando Perez <fperez@colorado.edu>
5978
5980
5979 * IPython/ultraTB.py (TermColors): changed color escapes again to
5981 * IPython/ultraTB.py (TermColors): changed color escapes again to
5980 fix the (old, reintroduced) line-wrapping bug. Basically, if
5982 fix the (old, reintroduced) line-wrapping bug. Basically, if
5981 \001..\002 aren't given in the color escapes, lines get wrapped
5983 \001..\002 aren't given in the color escapes, lines get wrapped
5982 weirdly. But giving those screws up old xterms and emacs terms. So
5984 weirdly. But giving those screws up old xterms and emacs terms. So
5983 I added some logic for emacs terms to be ok, but I can't identify old
5985 I added some logic for emacs terms to be ok, but I can't identify old
5984 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5986 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5985
5987
5986 2002-03-10 Fernando Perez <fperez@colorado.edu>
5988 2002-03-10 Fernando Perez <fperez@colorado.edu>
5987
5989
5988 * IPython/usage.py (__doc__): Various documentation cleanups and
5990 * IPython/usage.py (__doc__): Various documentation cleanups and
5989 updates, both in usage docstrings and in the manual.
5991 updates, both in usage docstrings and in the manual.
5990
5992
5991 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5993 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5992 handling of caching. Set minimum acceptabe value for having a
5994 handling of caching. Set minimum acceptabe value for having a
5993 cache at 20 values.
5995 cache at 20 values.
5994
5996
5995 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5997 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5996 install_first_time function to a method, renamed it and added an
5998 install_first_time function to a method, renamed it and added an
5997 'upgrade' mode. Now people can update their config directory with
5999 'upgrade' mode. Now people can update their config directory with
5998 a simple command line switch (-upgrade, also new).
6000 a simple command line switch (-upgrade, also new).
5999
6001
6000 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
6002 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
6001 @file (convenient for automagic users under Python >= 2.2).
6003 @file (convenient for automagic users under Python >= 2.2).
6002 Removed @files (it seemed more like a plural than an abbrev. of
6004 Removed @files (it seemed more like a plural than an abbrev. of
6003 'file show').
6005 'file show').
6004
6006
6005 * IPython/iplib.py (install_first_time): Fixed crash if there were
6007 * IPython/iplib.py (install_first_time): Fixed crash if there were
6006 backup files ('~') in .ipython/ install directory.
6008 backup files ('~') in .ipython/ install directory.
6007
6009
6008 * IPython/ipmaker.py (make_IPython): fixes for new prompt
6010 * IPython/ipmaker.py (make_IPython): fixes for new prompt
6009 system. Things look fine, but these changes are fairly
6011 system. Things look fine, but these changes are fairly
6010 intrusive. Test them for a few days.
6012 intrusive. Test them for a few days.
6011
6013
6012 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
6014 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
6013 the prompts system. Now all in/out prompt strings are user
6015 the prompts system. Now all in/out prompt strings are user
6014 controllable. This is particularly useful for embedding, as one
6016 controllable. This is particularly useful for embedding, as one
6015 can tag embedded instances with particular prompts.
6017 can tag embedded instances with particular prompts.
6016
6018
6017 Also removed global use of sys.ps1/2, which now allows nested
6019 Also removed global use of sys.ps1/2, which now allows nested
6018 embeddings without any problems. Added command-line options for
6020 embeddings without any problems. Added command-line options for
6019 the prompt strings.
6021 the prompt strings.
6020
6022
6021 2002-03-08 Fernando Perez <fperez@colorado.edu>
6023 2002-03-08 Fernando Perez <fperez@colorado.edu>
6022
6024
6023 * IPython/UserConfig/example-embed-short.py (ipshell): added
6025 * IPython/UserConfig/example-embed-short.py (ipshell): added
6024 example file with the bare minimum code for embedding.
6026 example file with the bare minimum code for embedding.
6025
6027
6026 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
6028 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
6027 functionality for the embeddable shell to be activated/deactivated
6029 functionality for the embeddable shell to be activated/deactivated
6028 either globally or at each call.
6030 either globally or at each call.
6029
6031
6030 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
6032 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
6031 rewriting the prompt with '--->' for auto-inputs with proper
6033 rewriting the prompt with '--->' for auto-inputs with proper
6032 coloring. Now the previous UGLY hack in handle_auto() is gone, and
6034 coloring. Now the previous UGLY hack in handle_auto() is gone, and
6033 this is handled by the prompts class itself, as it should.
6035 this is handled by the prompts class itself, as it should.
6034
6036
6035 2002-03-05 Fernando Perez <fperez@colorado.edu>
6037 2002-03-05 Fernando Perez <fperez@colorado.edu>
6036
6038
6037 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
6039 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
6038 @logstart to avoid name clashes with the math log function.
6040 @logstart to avoid name clashes with the math log function.
6039
6041
6040 * Big updates to X/Emacs section of the manual.
6042 * Big updates to X/Emacs section of the manual.
6041
6043
6042 * Removed ipython_emacs. Milan explained to me how to pass
6044 * Removed ipython_emacs. Milan explained to me how to pass
6043 arguments to ipython through Emacs. Some day I'm going to end up
6045 arguments to ipython through Emacs. Some day I'm going to end up
6044 learning some lisp...
6046 learning some lisp...
6045
6047
6046 2002-03-04 Fernando Perez <fperez@colorado.edu>
6048 2002-03-04 Fernando Perez <fperez@colorado.edu>
6047
6049
6048 * IPython/ipython_emacs: Created script to be used as the
6050 * IPython/ipython_emacs: Created script to be used as the
6049 py-python-command Emacs variable so we can pass IPython
6051 py-python-command Emacs variable so we can pass IPython
6050 parameters. I can't figure out how to tell Emacs directly to pass
6052 parameters. I can't figure out how to tell Emacs directly to pass
6051 parameters to IPython, so a dummy shell script will do it.
6053 parameters to IPython, so a dummy shell script will do it.
6052
6054
6053 Other enhancements made for things to work better under Emacs'
6055 Other enhancements made for things to work better under Emacs'
6054 various types of terminals. Many thanks to Milan Zamazal
6056 various types of terminals. Many thanks to Milan Zamazal
6055 <pdm-AT-zamazal.org> for all the suggestions and pointers.
6057 <pdm-AT-zamazal.org> for all the suggestions and pointers.
6056
6058
6057 2002-03-01 Fernando Perez <fperez@colorado.edu>
6059 2002-03-01 Fernando Perez <fperez@colorado.edu>
6058
6060
6059 * IPython/ipmaker.py (make_IPython): added a --readline! option so
6061 * IPython/ipmaker.py (make_IPython): added a --readline! option so
6060 that loading of readline is now optional. This gives better
6062 that loading of readline is now optional. This gives better
6061 control to emacs users.
6063 control to emacs users.
6062
6064
6063 * IPython/ultraTB.py (__date__): Modified color escape sequences
6065 * IPython/ultraTB.py (__date__): Modified color escape sequences
6064 and now things work fine under xterm and in Emacs' term buffers
6066 and now things work fine under xterm and in Emacs' term buffers
6065 (though not shell ones). Well, in emacs you get colors, but all
6067 (though not shell ones). Well, in emacs you get colors, but all
6066 seem to be 'light' colors (no difference between dark and light
6068 seem to be 'light' colors (no difference between dark and light
6067 ones). But the garbage chars are gone, and also in xterms. It
6069 ones). But the garbage chars are gone, and also in xterms. It
6068 seems that now I'm using 'cleaner' ansi sequences.
6070 seems that now I'm using 'cleaner' ansi sequences.
6069
6071
6070 2002-02-21 Fernando Perez <fperez@colorado.edu>
6072 2002-02-21 Fernando Perez <fperez@colorado.edu>
6071
6073
6072 * Released 0.2.7 (mainly to publish the scoping fix).
6074 * Released 0.2.7 (mainly to publish the scoping fix).
6073
6075
6074 * IPython/Logger.py (Logger.logstate): added. A corresponding
6076 * IPython/Logger.py (Logger.logstate): added. A corresponding
6075 @logstate magic was created.
6077 @logstate magic was created.
6076
6078
6077 * IPython/Magic.py: fixed nested scoping problem under Python
6079 * IPython/Magic.py: fixed nested scoping problem under Python
6078 2.1.x (automagic wasn't working).
6080 2.1.x (automagic wasn't working).
6079
6081
6080 2002-02-20 Fernando Perez <fperez@colorado.edu>
6082 2002-02-20 Fernando Perez <fperez@colorado.edu>
6081
6083
6082 * Released 0.2.6.
6084 * Released 0.2.6.
6083
6085
6084 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
6086 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
6085 option so that logs can come out without any headers at all.
6087 option so that logs can come out without any headers at all.
6086
6088
6087 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
6089 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
6088 SciPy.
6090 SciPy.
6089
6091
6090 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
6092 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
6091 that embedded IPython calls don't require vars() to be explicitly
6093 that embedded IPython calls don't require vars() to be explicitly
6092 passed. Now they are extracted from the caller's frame (code
6094 passed. Now they are extracted from the caller's frame (code
6093 snatched from Eric Jones' weave). Added better documentation to
6095 snatched from Eric Jones' weave). Added better documentation to
6094 the section on embedding and the example file.
6096 the section on embedding and the example file.
6095
6097
6096 * IPython/genutils.py (page): Changed so that under emacs, it just
6098 * IPython/genutils.py (page): Changed so that under emacs, it just
6097 prints the string. You can then page up and down in the emacs
6099 prints the string. You can then page up and down in the emacs
6098 buffer itself. This is how the builtin help() works.
6100 buffer itself. This is how the builtin help() works.
6099
6101
6100 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
6102 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
6101 macro scoping: macros need to be executed in the user's namespace
6103 macro scoping: macros need to be executed in the user's namespace
6102 to work as if they had been typed by the user.
6104 to work as if they had been typed by the user.
6103
6105
6104 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
6106 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
6105 execute automatically (no need to type 'exec...'). They then
6107 execute automatically (no need to type 'exec...'). They then
6106 behave like 'true macros'. The printing system was also modified
6108 behave like 'true macros'. The printing system was also modified
6107 for this to work.
6109 for this to work.
6108
6110
6109 2002-02-19 Fernando Perez <fperez@colorado.edu>
6111 2002-02-19 Fernando Perez <fperez@colorado.edu>
6110
6112
6111 * IPython/genutils.py (page_file): new function for paging files
6113 * IPython/genutils.py (page_file): new function for paging files
6112 in an OS-independent way. Also necessary for file viewing to work
6114 in an OS-independent way. Also necessary for file viewing to work
6113 well inside Emacs buffers.
6115 well inside Emacs buffers.
6114 (page): Added checks for being in an emacs buffer.
6116 (page): Added checks for being in an emacs buffer.
6115 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
6117 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
6116 same bug in iplib.
6118 same bug in iplib.
6117
6119
6118 2002-02-18 Fernando Perez <fperez@colorado.edu>
6120 2002-02-18 Fernando Perez <fperez@colorado.edu>
6119
6121
6120 * IPython/iplib.py (InteractiveShell.init_readline): modified use
6122 * IPython/iplib.py (InteractiveShell.init_readline): modified use
6121 of readline so that IPython can work inside an Emacs buffer.
6123 of readline so that IPython can work inside an Emacs buffer.
6122
6124
6123 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
6125 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
6124 method signatures (they weren't really bugs, but it looks cleaner
6126 method signatures (they weren't really bugs, but it looks cleaner
6125 and keeps PyChecker happy).
6127 and keeps PyChecker happy).
6126
6128
6127 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
6129 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
6128 for implementing various user-defined hooks. Currently only
6130 for implementing various user-defined hooks. Currently only
6129 display is done.
6131 display is done.
6130
6132
6131 * IPython/Prompts.py (CachedOutput._display): changed display
6133 * IPython/Prompts.py (CachedOutput._display): changed display
6132 functions so that they can be dynamically changed by users easily.
6134 functions so that they can be dynamically changed by users easily.
6133
6135
6134 * IPython/Extensions/numeric_formats.py (num_display): added an
6136 * IPython/Extensions/numeric_formats.py (num_display): added an
6135 extension for printing NumPy arrays in flexible manners. It
6137 extension for printing NumPy arrays in flexible manners. It
6136 doesn't do anything yet, but all the structure is in
6138 doesn't do anything yet, but all the structure is in
6137 place. Ultimately the plan is to implement output format control
6139 place. Ultimately the plan is to implement output format control
6138 like in Octave.
6140 like in Octave.
6139
6141
6140 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
6142 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
6141 methods are found at run-time by all the automatic machinery.
6143 methods are found at run-time by all the automatic machinery.
6142
6144
6143 2002-02-17 Fernando Perez <fperez@colorado.edu>
6145 2002-02-17 Fernando Perez <fperez@colorado.edu>
6144
6146
6145 * setup_Windows.py (make_shortcut): documented. Cleaned up the
6147 * setup_Windows.py (make_shortcut): documented. Cleaned up the
6146 whole file a little.
6148 whole file a little.
6147
6149
6148 * ToDo: closed this document. Now there's a new_design.lyx
6150 * ToDo: closed this document. Now there's a new_design.lyx
6149 document for all new ideas. Added making a pdf of it for the
6151 document for all new ideas. Added making a pdf of it for the
6150 end-user distro.
6152 end-user distro.
6151
6153
6152 * IPython/Logger.py (Logger.switch_log): Created this to replace
6154 * IPython/Logger.py (Logger.switch_log): Created this to replace
6153 logon() and logoff(). It also fixes a nasty crash reported by
6155 logon() and logoff(). It also fixes a nasty crash reported by
6154 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
6156 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
6155
6157
6156 * IPython/iplib.py (complete): got auto-completion to work with
6158 * IPython/iplib.py (complete): got auto-completion to work with
6157 automagic (I had wanted this for a long time).
6159 automagic (I had wanted this for a long time).
6158
6160
6159 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
6161 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
6160 to @file, since file() is now a builtin and clashes with automagic
6162 to @file, since file() is now a builtin and clashes with automagic
6161 for @file.
6163 for @file.
6162
6164
6163 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
6165 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
6164 of this was previously in iplib, which had grown to more than 2000
6166 of this was previously in iplib, which had grown to more than 2000
6165 lines, way too long. No new functionality, but it makes managing
6167 lines, way too long. No new functionality, but it makes managing
6166 the code a bit easier.
6168 the code a bit easier.
6167
6169
6168 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
6170 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
6169 information to crash reports.
6171 information to crash reports.
6170
6172
6171 2002-02-12 Fernando Perez <fperez@colorado.edu>
6173 2002-02-12 Fernando Perez <fperez@colorado.edu>
6172
6174
6173 * Released 0.2.5.
6175 * Released 0.2.5.
6174
6176
6175 2002-02-11 Fernando Perez <fperez@colorado.edu>
6177 2002-02-11 Fernando Perez <fperez@colorado.edu>
6176
6178
6177 * Wrote a relatively complete Windows installer. It puts
6179 * Wrote a relatively complete Windows installer. It puts
6178 everything in place, creates Start Menu entries and fixes the
6180 everything in place, creates Start Menu entries and fixes the
6179 color issues. Nothing fancy, but it works.
6181 color issues. Nothing fancy, but it works.
6180
6182
6181 2002-02-10 Fernando Perez <fperez@colorado.edu>
6183 2002-02-10 Fernando Perez <fperez@colorado.edu>
6182
6184
6183 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
6185 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
6184 os.path.expanduser() call so that we can type @run ~/myfile.py and
6186 os.path.expanduser() call so that we can type @run ~/myfile.py and
6185 have thigs work as expected.
6187 have thigs work as expected.
6186
6188
6187 * IPython/genutils.py (page): fixed exception handling so things
6189 * IPython/genutils.py (page): fixed exception handling so things
6188 work both in Unix and Windows correctly. Quitting a pager triggers
6190 work both in Unix and Windows correctly. Quitting a pager triggers
6189 an IOError/broken pipe in Unix, and in windows not finding a pager
6191 an IOError/broken pipe in Unix, and in windows not finding a pager
6190 is also an IOError, so I had to actually look at the return value
6192 is also an IOError, so I had to actually look at the return value
6191 of the exception, not just the exception itself. Should be ok now.
6193 of the exception, not just the exception itself. Should be ok now.
6192
6194
6193 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
6195 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
6194 modified to allow case-insensitive color scheme changes.
6196 modified to allow case-insensitive color scheme changes.
6195
6197
6196 2002-02-09 Fernando Perez <fperez@colorado.edu>
6198 2002-02-09 Fernando Perez <fperez@colorado.edu>
6197
6199
6198 * IPython/genutils.py (native_line_ends): new function to leave
6200 * IPython/genutils.py (native_line_ends): new function to leave
6199 user config files with os-native line-endings.
6201 user config files with os-native line-endings.
6200
6202
6201 * README and manual updates.
6203 * README and manual updates.
6202
6204
6203 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
6205 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
6204 instead of StringType to catch Unicode strings.
6206 instead of StringType to catch Unicode strings.
6205
6207
6206 * IPython/genutils.py (filefind): fixed bug for paths with
6208 * IPython/genutils.py (filefind): fixed bug for paths with
6207 embedded spaces (very common in Windows).
6209 embedded spaces (very common in Windows).
6208
6210
6209 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
6211 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
6210 files under Windows, so that they get automatically associated
6212 files under Windows, so that they get automatically associated
6211 with a text editor. Windows makes it a pain to handle
6213 with a text editor. Windows makes it a pain to handle
6212 extension-less files.
6214 extension-less files.
6213
6215
6214 * IPython/iplib.py (InteractiveShell.init_readline): Made the
6216 * IPython/iplib.py (InteractiveShell.init_readline): Made the
6215 warning about readline only occur for Posix. In Windows there's no
6217 warning about readline only occur for Posix. In Windows there's no
6216 way to get readline, so why bother with the warning.
6218 way to get readline, so why bother with the warning.
6217
6219
6218 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
6220 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
6219 for __str__ instead of dir(self), since dir() changed in 2.2.
6221 for __str__ instead of dir(self), since dir() changed in 2.2.
6220
6222
6221 * Ported to Windows! Tested on XP, I suspect it should work fine
6223 * Ported to Windows! Tested on XP, I suspect it should work fine
6222 on NT/2000, but I don't think it will work on 98 et al. That
6224 on NT/2000, but I don't think it will work on 98 et al. That
6223 series of Windows is such a piece of junk anyway that I won't try
6225 series of Windows is such a piece of junk anyway that I won't try
6224 porting it there. The XP port was straightforward, showed a few
6226 porting it there. The XP port was straightforward, showed a few
6225 bugs here and there (fixed all), in particular some string
6227 bugs here and there (fixed all), in particular some string
6226 handling stuff which required considering Unicode strings (which
6228 handling stuff which required considering Unicode strings (which
6227 Windows uses). This is good, but hasn't been too tested :) No
6229 Windows uses). This is good, but hasn't been too tested :) No
6228 fancy installer yet, I'll put a note in the manual so people at
6230 fancy installer yet, I'll put a note in the manual so people at
6229 least make manually a shortcut.
6231 least make manually a shortcut.
6230
6232
6231 * IPython/iplib.py (Magic.magic_colors): Unified the color options
6233 * IPython/iplib.py (Magic.magic_colors): Unified the color options
6232 into a single one, "colors". This now controls both prompt and
6234 into a single one, "colors". This now controls both prompt and
6233 exception color schemes, and can be changed both at startup
6235 exception color schemes, and can be changed both at startup
6234 (either via command-line switches or via ipythonrc files) and at
6236 (either via command-line switches or via ipythonrc files) and at
6235 runtime, with @colors.
6237 runtime, with @colors.
6236 (Magic.magic_run): renamed @prun to @run and removed the old
6238 (Magic.magic_run): renamed @prun to @run and removed the old
6237 @run. The two were too similar to warrant keeping both.
6239 @run. The two were too similar to warrant keeping both.
6238
6240
6239 2002-02-03 Fernando Perez <fperez@colorado.edu>
6241 2002-02-03 Fernando Perez <fperez@colorado.edu>
6240
6242
6241 * IPython/iplib.py (install_first_time): Added comment on how to
6243 * IPython/iplib.py (install_first_time): Added comment on how to
6242 configure the color options for first-time users. Put a <return>
6244 configure the color options for first-time users. Put a <return>
6243 request at the end so that small-terminal users get a chance to
6245 request at the end so that small-terminal users get a chance to
6244 read the startup info.
6246 read the startup info.
6245
6247
6246 2002-01-23 Fernando Perez <fperez@colorado.edu>
6248 2002-01-23 Fernando Perez <fperez@colorado.edu>
6247
6249
6248 * IPython/iplib.py (CachedOutput.update): Changed output memory
6250 * IPython/iplib.py (CachedOutput.update): Changed output memory
6249 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
6251 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
6250 input history we still use _i. Did this b/c these variable are
6252 input history we still use _i. Did this b/c these variable are
6251 very commonly used in interactive work, so the less we need to
6253 very commonly used in interactive work, so the less we need to
6252 type the better off we are.
6254 type the better off we are.
6253 (Magic.magic_prun): updated @prun to better handle the namespaces
6255 (Magic.magic_prun): updated @prun to better handle the namespaces
6254 the file will run in, including a fix for __name__ not being set
6256 the file will run in, including a fix for __name__ not being set
6255 before.
6257 before.
6256
6258
6257 2002-01-20 Fernando Perez <fperez@colorado.edu>
6259 2002-01-20 Fernando Perez <fperez@colorado.edu>
6258
6260
6259 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
6261 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
6260 extra garbage for Python 2.2. Need to look more carefully into
6262 extra garbage for Python 2.2. Need to look more carefully into
6261 this later.
6263 this later.
6262
6264
6263 2002-01-19 Fernando Perez <fperez@colorado.edu>
6265 2002-01-19 Fernando Perez <fperez@colorado.edu>
6264
6266
6265 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
6267 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
6266 display SyntaxError exceptions properly formatted when they occur
6268 display SyntaxError exceptions properly formatted when they occur
6267 (they can be triggered by imported code).
6269 (they can be triggered by imported code).
6268
6270
6269 2002-01-18 Fernando Perez <fperez@colorado.edu>
6271 2002-01-18 Fernando Perez <fperez@colorado.edu>
6270
6272
6271 * IPython/iplib.py (InteractiveShell.safe_execfile): now
6273 * IPython/iplib.py (InteractiveShell.safe_execfile): now
6272 SyntaxError exceptions are reported nicely formatted, instead of
6274 SyntaxError exceptions are reported nicely formatted, instead of
6273 spitting out only offset information as before.
6275 spitting out only offset information as before.
6274 (Magic.magic_prun): Added the @prun function for executing
6276 (Magic.magic_prun): Added the @prun function for executing
6275 programs with command line args inside IPython.
6277 programs with command line args inside IPython.
6276
6278
6277 2002-01-16 Fernando Perez <fperez@colorado.edu>
6279 2002-01-16 Fernando Perez <fperez@colorado.edu>
6278
6280
6279 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
6281 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
6280 to *not* include the last item given in a range. This brings their
6282 to *not* include the last item given in a range. This brings their
6281 behavior in line with Python's slicing:
6283 behavior in line with Python's slicing:
6282 a[n1:n2] -> a[n1]...a[n2-1]
6284 a[n1:n2] -> a[n1]...a[n2-1]
6283 It may be a bit less convenient, but I prefer to stick to Python's
6285 It may be a bit less convenient, but I prefer to stick to Python's
6284 conventions *everywhere*, so users never have to wonder.
6286 conventions *everywhere*, so users never have to wonder.
6285 (Magic.magic_macro): Added @macro function to ease the creation of
6287 (Magic.magic_macro): Added @macro function to ease the creation of
6286 macros.
6288 macros.
6287
6289
6288 2002-01-05 Fernando Perez <fperez@colorado.edu>
6290 2002-01-05 Fernando Perez <fperez@colorado.edu>
6289
6291
6290 * Released 0.2.4.
6292 * Released 0.2.4.
6291
6293
6292 * IPython/iplib.py (Magic.magic_pdef):
6294 * IPython/iplib.py (Magic.magic_pdef):
6293 (InteractiveShell.safe_execfile): report magic lines and error
6295 (InteractiveShell.safe_execfile): report magic lines and error
6294 lines without line numbers so one can easily copy/paste them for
6296 lines without line numbers so one can easily copy/paste them for
6295 re-execution.
6297 re-execution.
6296
6298
6297 * Updated manual with recent changes.
6299 * Updated manual with recent changes.
6298
6300
6299 * IPython/iplib.py (Magic.magic_oinfo): added constructor
6301 * IPython/iplib.py (Magic.magic_oinfo): added constructor
6300 docstring printing when class? is called. Very handy for knowing
6302 docstring printing when class? is called. Very handy for knowing
6301 how to create class instances (as long as __init__ is well
6303 how to create class instances (as long as __init__ is well
6302 documented, of course :)
6304 documented, of course :)
6303 (Magic.magic_doc): print both class and constructor docstrings.
6305 (Magic.magic_doc): print both class and constructor docstrings.
6304 (Magic.magic_pdef): give constructor info if passed a class and
6306 (Magic.magic_pdef): give constructor info if passed a class and
6305 __call__ info for callable object instances.
6307 __call__ info for callable object instances.
6306
6308
6307 2002-01-04 Fernando Perez <fperez@colorado.edu>
6309 2002-01-04 Fernando Perez <fperez@colorado.edu>
6308
6310
6309 * Made deep_reload() off by default. It doesn't always work
6311 * Made deep_reload() off by default. It doesn't always work
6310 exactly as intended, so it's probably safer to have it off. It's
6312 exactly as intended, so it's probably safer to have it off. It's
6311 still available as dreload() anyway, so nothing is lost.
6313 still available as dreload() anyway, so nothing is lost.
6312
6314
6313 2002-01-02 Fernando Perez <fperez@colorado.edu>
6315 2002-01-02 Fernando Perez <fperez@colorado.edu>
6314
6316
6315 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
6317 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
6316 so I wanted an updated release).
6318 so I wanted an updated release).
6317
6319
6318 2001-12-27 Fernando Perez <fperez@colorado.edu>
6320 2001-12-27 Fernando Perez <fperez@colorado.edu>
6319
6321
6320 * IPython/iplib.py (InteractiveShell.interact): Added the original
6322 * IPython/iplib.py (InteractiveShell.interact): Added the original
6321 code from 'code.py' for this module in order to change the
6323 code from 'code.py' for this module in order to change the
6322 handling of a KeyboardInterrupt. This was necessary b/c otherwise
6324 handling of a KeyboardInterrupt. This was necessary b/c otherwise
6323 the history cache would break when the user hit Ctrl-C, and
6325 the history cache would break when the user hit Ctrl-C, and
6324 interact() offers no way to add any hooks to it.
6326 interact() offers no way to add any hooks to it.
6325
6327
6326 2001-12-23 Fernando Perez <fperez@colorado.edu>
6328 2001-12-23 Fernando Perez <fperez@colorado.edu>
6327
6329
6328 * setup.py: added check for 'MANIFEST' before trying to remove
6330 * setup.py: added check for 'MANIFEST' before trying to remove
6329 it. Thanks to Sean Reifschneider.
6331 it. Thanks to Sean Reifschneider.
6330
6332
6331 2001-12-22 Fernando Perez <fperez@colorado.edu>
6333 2001-12-22 Fernando Perez <fperez@colorado.edu>
6332
6334
6333 * Released 0.2.2.
6335 * Released 0.2.2.
6334
6336
6335 * Finished (reasonably) writing the manual. Later will add the
6337 * Finished (reasonably) writing the manual. Later will add the
6336 python-standard navigation stylesheets, but for the time being
6338 python-standard navigation stylesheets, but for the time being
6337 it's fairly complete. Distribution will include html and pdf
6339 it's fairly complete. Distribution will include html and pdf
6338 versions.
6340 versions.
6339
6341
6340 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
6342 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
6341 (MayaVi author).
6343 (MayaVi author).
6342
6344
6343 2001-12-21 Fernando Perez <fperez@colorado.edu>
6345 2001-12-21 Fernando Perez <fperez@colorado.edu>
6344
6346
6345 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
6347 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
6346 good public release, I think (with the manual and the distutils
6348 good public release, I think (with the manual and the distutils
6347 installer). The manual can use some work, but that can go
6349 installer). The manual can use some work, but that can go
6348 slowly. Otherwise I think it's quite nice for end users. Next
6350 slowly. Otherwise I think it's quite nice for end users. Next
6349 summer, rewrite the guts of it...
6351 summer, rewrite the guts of it...
6350
6352
6351 * Changed format of ipythonrc files to use whitespace as the
6353 * Changed format of ipythonrc files to use whitespace as the
6352 separator instead of an explicit '='. Cleaner.
6354 separator instead of an explicit '='. Cleaner.
6353
6355
6354 2001-12-20 Fernando Perez <fperez@colorado.edu>
6356 2001-12-20 Fernando Perez <fperez@colorado.edu>
6355
6357
6356 * Started a manual in LyX. For now it's just a quick merge of the
6358 * Started a manual in LyX. For now it's just a quick merge of the
6357 various internal docstrings and READMEs. Later it may grow into a
6359 various internal docstrings and READMEs. Later it may grow into a
6358 nice, full-blown manual.
6360 nice, full-blown manual.
6359
6361
6360 * Set up a distutils based installer. Installation should now be
6362 * Set up a distutils based installer. Installation should now be
6361 trivially simple for end-users.
6363 trivially simple for end-users.
6362
6364
6363 2001-12-11 Fernando Perez <fperez@colorado.edu>
6365 2001-12-11 Fernando Perez <fperez@colorado.edu>
6364
6366
6365 * Released 0.2.0. First public release, announced it at
6367 * Released 0.2.0. First public release, announced it at
6366 comp.lang.python. From now on, just bugfixes...
6368 comp.lang.python. From now on, just bugfixes...
6367
6369
6368 * Went through all the files, set copyright/license notices and
6370 * Went through all the files, set copyright/license notices and
6369 cleaned up things. Ready for release.
6371 cleaned up things. Ready for release.
6370
6372
6371 2001-12-10 Fernando Perez <fperez@colorado.edu>
6373 2001-12-10 Fernando Perez <fperez@colorado.edu>
6372
6374
6373 * Changed the first-time installer not to use tarfiles. It's more
6375 * Changed the first-time installer not to use tarfiles. It's more
6374 robust now and less unix-dependent. Also makes it easier for
6376 robust now and less unix-dependent. Also makes it easier for
6375 people to later upgrade versions.
6377 people to later upgrade versions.
6376
6378
6377 * Changed @exit to @abort to reflect the fact that it's pretty
6379 * Changed @exit to @abort to reflect the fact that it's pretty
6378 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6380 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6379 becomes significant only when IPyhton is embedded: in that case,
6381 becomes significant only when IPyhton is embedded: in that case,
6380 C-D closes IPython only, but @abort kills the enclosing program
6382 C-D closes IPython only, but @abort kills the enclosing program
6381 too (unless it had called IPython inside a try catching
6383 too (unless it had called IPython inside a try catching
6382 SystemExit).
6384 SystemExit).
6383
6385
6384 * Created Shell module which exposes the actuall IPython Shell
6386 * Created Shell module which exposes the actuall IPython Shell
6385 classes, currently the normal and the embeddable one. This at
6387 classes, currently the normal and the embeddable one. This at
6386 least offers a stable interface we won't need to change when
6388 least offers a stable interface we won't need to change when
6387 (later) the internals are rewritten. That rewrite will be confined
6389 (later) the internals are rewritten. That rewrite will be confined
6388 to iplib and ipmaker, but the Shell interface should remain as is.
6390 to iplib and ipmaker, but the Shell interface should remain as is.
6389
6391
6390 * Added embed module which offers an embeddable IPShell object,
6392 * Added embed module which offers an embeddable IPShell object,
6391 useful to fire up IPython *inside* a running program. Great for
6393 useful to fire up IPython *inside* a running program. Great for
6392 debugging or dynamical data analysis.
6394 debugging or dynamical data analysis.
6393
6395
6394 2001-12-08 Fernando Perez <fperez@colorado.edu>
6396 2001-12-08 Fernando Perez <fperez@colorado.edu>
6395
6397
6396 * Fixed small bug preventing seeing info from methods of defined
6398 * Fixed small bug preventing seeing info from methods of defined
6397 objects (incorrect namespace in _ofind()).
6399 objects (incorrect namespace in _ofind()).
6398
6400
6399 * Documentation cleanup. Moved the main usage docstrings to a
6401 * Documentation cleanup. Moved the main usage docstrings to a
6400 separate file, usage.py (cleaner to maintain, and hopefully in the
6402 separate file, usage.py (cleaner to maintain, and hopefully in the
6401 future some perlpod-like way of producing interactive, man and
6403 future some perlpod-like way of producing interactive, man and
6402 html docs out of it will be found).
6404 html docs out of it will be found).
6403
6405
6404 * Added @profile to see your profile at any time.
6406 * Added @profile to see your profile at any time.
6405
6407
6406 * Added @p as an alias for 'print'. It's especially convenient if
6408 * Added @p as an alias for 'print'. It's especially convenient if
6407 using automagic ('p x' prints x).
6409 using automagic ('p x' prints x).
6408
6410
6409 * Small cleanups and fixes after a pychecker run.
6411 * Small cleanups and fixes after a pychecker run.
6410
6412
6411 * Changed the @cd command to handle @cd - and @cd -<n> for
6413 * Changed the @cd command to handle @cd - and @cd -<n> for
6412 visiting any directory in _dh.
6414 visiting any directory in _dh.
6413
6415
6414 * Introduced _dh, a history of visited directories. @dhist prints
6416 * Introduced _dh, a history of visited directories. @dhist prints
6415 it out with numbers.
6417 it out with numbers.
6416
6418
6417 2001-12-07 Fernando Perez <fperez@colorado.edu>
6419 2001-12-07 Fernando Perez <fperez@colorado.edu>
6418
6420
6419 * Released 0.1.22
6421 * Released 0.1.22
6420
6422
6421 * Made initialization a bit more robust against invalid color
6423 * Made initialization a bit more robust against invalid color
6422 options in user input (exit, not traceback-crash).
6424 options in user input (exit, not traceback-crash).
6423
6425
6424 * Changed the bug crash reporter to write the report only in the
6426 * Changed the bug crash reporter to write the report only in the
6425 user's .ipython directory. That way IPython won't litter people's
6427 user's .ipython directory. That way IPython won't litter people's
6426 hard disks with crash files all over the place. Also print on
6428 hard disks with crash files all over the place. Also print on
6427 screen the necessary mail command.
6429 screen the necessary mail command.
6428
6430
6429 * With the new ultraTB, implemented LightBG color scheme for light
6431 * With the new ultraTB, implemented LightBG color scheme for light
6430 background terminals. A lot of people like white backgrounds, so I
6432 background terminals. A lot of people like white backgrounds, so I
6431 guess we should at least give them something readable.
6433 guess we should at least give them something readable.
6432
6434
6433 2001-12-06 Fernando Perez <fperez@colorado.edu>
6435 2001-12-06 Fernando Perez <fperez@colorado.edu>
6434
6436
6435 * Modified the structure of ultraTB. Now there's a proper class
6437 * Modified the structure of ultraTB. Now there's a proper class
6436 for tables of color schemes which allow adding schemes easily and
6438 for tables of color schemes which allow adding schemes easily and
6437 switching the active scheme without creating a new instance every
6439 switching the active scheme without creating a new instance every
6438 time (which was ridiculous). The syntax for creating new schemes
6440 time (which was ridiculous). The syntax for creating new schemes
6439 is also cleaner. I think ultraTB is finally done, with a clean
6441 is also cleaner. I think ultraTB is finally done, with a clean
6440 class structure. Names are also much cleaner (now there's proper
6442 class structure. Names are also much cleaner (now there's proper
6441 color tables, no need for every variable to also have 'color' in
6443 color tables, no need for every variable to also have 'color' in
6442 its name).
6444 its name).
6443
6445
6444 * Broke down genutils into separate files. Now genutils only
6446 * Broke down genutils into separate files. Now genutils only
6445 contains utility functions, and classes have been moved to their
6447 contains utility functions, and classes have been moved to their
6446 own files (they had enough independent functionality to warrant
6448 own files (they had enough independent functionality to warrant
6447 it): ConfigLoader, OutputTrap, Struct.
6449 it): ConfigLoader, OutputTrap, Struct.
6448
6450
6449 2001-12-05 Fernando Perez <fperez@colorado.edu>
6451 2001-12-05 Fernando Perez <fperez@colorado.edu>
6450
6452
6451 * IPython turns 21! Released version 0.1.21, as a candidate for
6453 * IPython turns 21! Released version 0.1.21, as a candidate for
6452 public consumption. If all goes well, release in a few days.
6454 public consumption. If all goes well, release in a few days.
6453
6455
6454 * Fixed path bug (files in Extensions/ directory wouldn't be found
6456 * Fixed path bug (files in Extensions/ directory wouldn't be found
6455 unless IPython/ was explicitly in sys.path).
6457 unless IPython/ was explicitly in sys.path).
6456
6458
6457 * Extended the FlexCompleter class as MagicCompleter to allow
6459 * Extended the FlexCompleter class as MagicCompleter to allow
6458 completion of @-starting lines.
6460 completion of @-starting lines.
6459
6461
6460 * Created __release__.py file as a central repository for release
6462 * Created __release__.py file as a central repository for release
6461 info that other files can read from.
6463 info that other files can read from.
6462
6464
6463 * Fixed small bug in logging: when logging was turned on in
6465 * Fixed small bug in logging: when logging was turned on in
6464 mid-session, old lines with special meanings (!@?) were being
6466 mid-session, old lines with special meanings (!@?) were being
6465 logged without the prepended comment, which is necessary since
6467 logged without the prepended comment, which is necessary since
6466 they are not truly valid python syntax. This should make session
6468 they are not truly valid python syntax. This should make session
6467 restores produce less errors.
6469 restores produce less errors.
6468
6470
6469 * The namespace cleanup forced me to make a FlexCompleter class
6471 * The namespace cleanup forced me to make a FlexCompleter class
6470 which is nothing but a ripoff of rlcompleter, but with selectable
6472 which is nothing but a ripoff of rlcompleter, but with selectable
6471 namespace (rlcompleter only works in __main__.__dict__). I'll try
6473 namespace (rlcompleter only works in __main__.__dict__). I'll try
6472 to submit a note to the authors to see if this change can be
6474 to submit a note to the authors to see if this change can be
6473 incorporated in future rlcompleter releases (Dec.6: done)
6475 incorporated in future rlcompleter releases (Dec.6: done)
6474
6476
6475 * More fixes to namespace handling. It was a mess! Now all
6477 * More fixes to namespace handling. It was a mess! Now all
6476 explicit references to __main__.__dict__ are gone (except when
6478 explicit references to __main__.__dict__ are gone (except when
6477 really needed) and everything is handled through the namespace
6479 really needed) and everything is handled through the namespace
6478 dicts in the IPython instance. We seem to be getting somewhere
6480 dicts in the IPython instance. We seem to be getting somewhere
6479 with this, finally...
6481 with this, finally...
6480
6482
6481 * Small documentation updates.
6483 * Small documentation updates.
6482
6484
6483 * Created the Extensions directory under IPython (with an
6485 * Created the Extensions directory under IPython (with an
6484 __init__.py). Put the PhysicalQ stuff there. This directory should
6486 __init__.py). Put the PhysicalQ stuff there. This directory should
6485 be used for all special-purpose extensions.
6487 be used for all special-purpose extensions.
6486
6488
6487 * File renaming:
6489 * File renaming:
6488 ipythonlib --> ipmaker
6490 ipythonlib --> ipmaker
6489 ipplib --> iplib
6491 ipplib --> iplib
6490 This makes a bit more sense in terms of what these files actually do.
6492 This makes a bit more sense in terms of what these files actually do.
6491
6493
6492 * Moved all the classes and functions in ipythonlib to ipplib, so
6494 * Moved all the classes and functions in ipythonlib to ipplib, so
6493 now ipythonlib only has make_IPython(). This will ease up its
6495 now ipythonlib only has make_IPython(). This will ease up its
6494 splitting in smaller functional chunks later.
6496 splitting in smaller functional chunks later.
6495
6497
6496 * Cleaned up (done, I think) output of @whos. Better column
6498 * Cleaned up (done, I think) output of @whos. Better column
6497 formatting, and now shows str(var) for as much as it can, which is
6499 formatting, and now shows str(var) for as much as it can, which is
6498 typically what one gets with a 'print var'.
6500 typically what one gets with a 'print var'.
6499
6501
6500 2001-12-04 Fernando Perez <fperez@colorado.edu>
6502 2001-12-04 Fernando Perez <fperez@colorado.edu>
6501
6503
6502 * Fixed namespace problems. Now builtin/IPyhton/user names get
6504 * Fixed namespace problems. Now builtin/IPyhton/user names get
6503 properly reported in their namespace. Internal namespace handling
6505 properly reported in their namespace. Internal namespace handling
6504 is finally getting decent (not perfect yet, but much better than
6506 is finally getting decent (not perfect yet, but much better than
6505 the ad-hoc mess we had).
6507 the ad-hoc mess we had).
6506
6508
6507 * Removed -exit option. If people just want to run a python
6509 * Removed -exit option. If people just want to run a python
6508 script, that's what the normal interpreter is for. Less
6510 script, that's what the normal interpreter is for. Less
6509 unnecessary options, less chances for bugs.
6511 unnecessary options, less chances for bugs.
6510
6512
6511 * Added a crash handler which generates a complete post-mortem if
6513 * Added a crash handler which generates a complete post-mortem if
6512 IPython crashes. This will help a lot in tracking bugs down the
6514 IPython crashes. This will help a lot in tracking bugs down the
6513 road.
6515 road.
6514
6516
6515 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6517 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6516 which were boud to functions being reassigned would bypass the
6518 which were boud to functions being reassigned would bypass the
6517 logger, breaking the sync of _il with the prompt counter. This
6519 logger, breaking the sync of _il with the prompt counter. This
6518 would then crash IPython later when a new line was logged.
6520 would then crash IPython later when a new line was logged.
6519
6521
6520 2001-12-02 Fernando Perez <fperez@colorado.edu>
6522 2001-12-02 Fernando Perez <fperez@colorado.edu>
6521
6523
6522 * Made IPython a package. This means people don't have to clutter
6524 * Made IPython a package. This means people don't have to clutter
6523 their sys.path with yet another directory. Changed the INSTALL
6525 their sys.path with yet another directory. Changed the INSTALL
6524 file accordingly.
6526 file accordingly.
6525
6527
6526 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6528 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6527 sorts its output (so @who shows it sorted) and @whos formats the
6529 sorts its output (so @who shows it sorted) and @whos formats the
6528 table according to the width of the first column. Nicer, easier to
6530 table according to the width of the first column. Nicer, easier to
6529 read. Todo: write a generic table_format() which takes a list of
6531 read. Todo: write a generic table_format() which takes a list of
6530 lists and prints it nicely formatted, with optional row/column
6532 lists and prints it nicely formatted, with optional row/column
6531 separators and proper padding and justification.
6533 separators and proper padding and justification.
6532
6534
6533 * Released 0.1.20
6535 * Released 0.1.20
6534
6536
6535 * Fixed bug in @log which would reverse the inputcache list (a
6537 * Fixed bug in @log which would reverse the inputcache list (a
6536 copy operation was missing).
6538 copy operation was missing).
6537
6539
6538 * Code cleanup. @config was changed to use page(). Better, since
6540 * Code cleanup. @config was changed to use page(). Better, since
6539 its output is always quite long.
6541 its output is always quite long.
6540
6542
6541 * Itpl is back as a dependency. I was having too many problems
6543 * Itpl is back as a dependency. I was having too many problems
6542 getting the parametric aliases to work reliably, and it's just
6544 getting the parametric aliases to work reliably, and it's just
6543 easier to code weird string operations with it than playing %()s
6545 easier to code weird string operations with it than playing %()s
6544 games. It's only ~6k, so I don't think it's too big a deal.
6546 games. It's only ~6k, so I don't think it's too big a deal.
6545
6547
6546 * Found (and fixed) a very nasty bug with history. !lines weren't
6548 * Found (and fixed) a very nasty bug with history. !lines weren't
6547 getting cached, and the out of sync caches would crash
6549 getting cached, and the out of sync caches would crash
6548 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6550 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6549 division of labor a bit better. Bug fixed, cleaner structure.
6551 division of labor a bit better. Bug fixed, cleaner structure.
6550
6552
6551 2001-12-01 Fernando Perez <fperez@colorado.edu>
6553 2001-12-01 Fernando Perez <fperez@colorado.edu>
6552
6554
6553 * Released 0.1.19
6555 * Released 0.1.19
6554
6556
6555 * Added option -n to @hist to prevent line number printing. Much
6557 * Added option -n to @hist to prevent line number printing. Much
6556 easier to copy/paste code this way.
6558 easier to copy/paste code this way.
6557
6559
6558 * Created global _il to hold the input list. Allows easy
6560 * Created global _il to hold the input list. Allows easy
6559 re-execution of blocks of code by slicing it (inspired by Janko's
6561 re-execution of blocks of code by slicing it (inspired by Janko's
6560 comment on 'macros').
6562 comment on 'macros').
6561
6563
6562 * Small fixes and doc updates.
6564 * Small fixes and doc updates.
6563
6565
6564 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6566 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6565 much too fragile with automagic. Handles properly multi-line
6567 much too fragile with automagic. Handles properly multi-line
6566 statements and takes parameters.
6568 statements and takes parameters.
6567
6569
6568 2001-11-30 Fernando Perez <fperez@colorado.edu>
6570 2001-11-30 Fernando Perez <fperez@colorado.edu>
6569
6571
6570 * Version 0.1.18 released.
6572 * Version 0.1.18 released.
6571
6573
6572 * Fixed nasty namespace bug in initial module imports.
6574 * Fixed nasty namespace bug in initial module imports.
6573
6575
6574 * Added copyright/license notes to all code files (except
6576 * Added copyright/license notes to all code files (except
6575 DPyGetOpt). For the time being, LGPL. That could change.
6577 DPyGetOpt). For the time being, LGPL. That could change.
6576
6578
6577 * Rewrote a much nicer README, updated INSTALL, cleaned up
6579 * Rewrote a much nicer README, updated INSTALL, cleaned up
6578 ipythonrc-* samples.
6580 ipythonrc-* samples.
6579
6581
6580 * Overall code/documentation cleanup. Basically ready for
6582 * Overall code/documentation cleanup. Basically ready for
6581 release. Only remaining thing: licence decision (LGPL?).
6583 release. Only remaining thing: licence decision (LGPL?).
6582
6584
6583 * Converted load_config to a class, ConfigLoader. Now recursion
6585 * Converted load_config to a class, ConfigLoader. Now recursion
6584 control is better organized. Doesn't include the same file twice.
6586 control is better organized. Doesn't include the same file twice.
6585
6587
6586 2001-11-29 Fernando Perez <fperez@colorado.edu>
6588 2001-11-29 Fernando Perez <fperez@colorado.edu>
6587
6589
6588 * Got input history working. Changed output history variables from
6590 * Got input history working. Changed output history variables from
6589 _p to _o so that _i is for input and _o for output. Just cleaner
6591 _p to _o so that _i is for input and _o for output. Just cleaner
6590 convention.
6592 convention.
6591
6593
6592 * Implemented parametric aliases. This pretty much allows the
6594 * Implemented parametric aliases. This pretty much allows the
6593 alias system to offer full-blown shell convenience, I think.
6595 alias system to offer full-blown shell convenience, I think.
6594
6596
6595 * Version 0.1.17 released, 0.1.18 opened.
6597 * Version 0.1.17 released, 0.1.18 opened.
6596
6598
6597 * dot_ipython/ipythonrc (alias): added documentation.
6599 * dot_ipython/ipythonrc (alias): added documentation.
6598 (xcolor): Fixed small bug (xcolors -> xcolor)
6600 (xcolor): Fixed small bug (xcolors -> xcolor)
6599
6601
6600 * Changed the alias system. Now alias is a magic command to define
6602 * Changed the alias system. Now alias is a magic command to define
6601 aliases just like the shell. Rationale: the builtin magics should
6603 aliases just like the shell. Rationale: the builtin magics should
6602 be there for things deeply connected to IPython's
6604 be there for things deeply connected to IPython's
6603 architecture. And this is a much lighter system for what I think
6605 architecture. And this is a much lighter system for what I think
6604 is the really important feature: allowing users to define quickly
6606 is the really important feature: allowing users to define quickly
6605 magics that will do shell things for them, so they can customize
6607 magics that will do shell things for them, so they can customize
6606 IPython easily to match their work habits. If someone is really
6608 IPython easily to match their work habits. If someone is really
6607 desperate to have another name for a builtin alias, they can
6609 desperate to have another name for a builtin alias, they can
6608 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6610 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6609 works.
6611 works.
6610
6612
6611 2001-11-28 Fernando Perez <fperez@colorado.edu>
6613 2001-11-28 Fernando Perez <fperez@colorado.edu>
6612
6614
6613 * Changed @file so that it opens the source file at the proper
6615 * Changed @file so that it opens the source file at the proper
6614 line. Since it uses less, if your EDITOR environment is
6616 line. Since it uses less, if your EDITOR environment is
6615 configured, typing v will immediately open your editor of choice
6617 configured, typing v will immediately open your editor of choice
6616 right at the line where the object is defined. Not as quick as
6618 right at the line where the object is defined. Not as quick as
6617 having a direct @edit command, but for all intents and purposes it
6619 having a direct @edit command, but for all intents and purposes it
6618 works. And I don't have to worry about writing @edit to deal with
6620 works. And I don't have to worry about writing @edit to deal with
6619 all the editors, less does that.
6621 all the editors, less does that.
6620
6622
6621 * Version 0.1.16 released, 0.1.17 opened.
6623 * Version 0.1.16 released, 0.1.17 opened.
6622
6624
6623 * Fixed some nasty bugs in the page/page_dumb combo that could
6625 * Fixed some nasty bugs in the page/page_dumb combo that could
6624 crash IPython.
6626 crash IPython.
6625
6627
6626 2001-11-27 Fernando Perez <fperez@colorado.edu>
6628 2001-11-27 Fernando Perez <fperez@colorado.edu>
6627
6629
6628 * Version 0.1.15 released, 0.1.16 opened.
6630 * Version 0.1.15 released, 0.1.16 opened.
6629
6631
6630 * Finally got ? and ?? to work for undefined things: now it's
6632 * Finally got ? and ?? to work for undefined things: now it's
6631 possible to type {}.get? and get information about the get method
6633 possible to type {}.get? and get information about the get method
6632 of dicts, or os.path? even if only os is defined (so technically
6634 of dicts, or os.path? even if only os is defined (so technically
6633 os.path isn't). Works at any level. For example, after import os,
6635 os.path isn't). Works at any level. For example, after import os,
6634 os?, os.path?, os.path.abspath? all work. This is great, took some
6636 os?, os.path?, os.path.abspath? all work. This is great, took some
6635 work in _ofind.
6637 work in _ofind.
6636
6638
6637 * Fixed more bugs with logging. The sanest way to do it was to add
6639 * Fixed more bugs with logging. The sanest way to do it was to add
6638 to @log a 'mode' parameter. Killed two in one shot (this mode
6640 to @log a 'mode' parameter. Killed two in one shot (this mode
6639 option was a request of Janko's). I think it's finally clean
6641 option was a request of Janko's). I think it's finally clean
6640 (famous last words).
6642 (famous last words).
6641
6643
6642 * Added a page_dumb() pager which does a decent job of paging on
6644 * Added a page_dumb() pager which does a decent job of paging on
6643 screen, if better things (like less) aren't available. One less
6645 screen, if better things (like less) aren't available. One less
6644 unix dependency (someday maybe somebody will port this to
6646 unix dependency (someday maybe somebody will port this to
6645 windows).
6647 windows).
6646
6648
6647 * Fixed problem in magic_log: would lock of logging out if log
6649 * Fixed problem in magic_log: would lock of logging out if log
6648 creation failed (because it would still think it had succeeded).
6650 creation failed (because it would still think it had succeeded).
6649
6651
6650 * Improved the page() function using curses to auto-detect screen
6652 * Improved the page() function using curses to auto-detect screen
6651 size. Now it can make a much better decision on whether to print
6653 size. Now it can make a much better decision on whether to print
6652 or page a string. Option screen_length was modified: a value 0
6654 or page a string. Option screen_length was modified: a value 0
6653 means auto-detect, and that's the default now.
6655 means auto-detect, and that's the default now.
6654
6656
6655 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6657 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6656 go out. I'll test it for a few days, then talk to Janko about
6658 go out. I'll test it for a few days, then talk to Janko about
6657 licences and announce it.
6659 licences and announce it.
6658
6660
6659 * Fixed the length of the auto-generated ---> prompt which appears
6661 * Fixed the length of the auto-generated ---> prompt which appears
6660 for auto-parens and auto-quotes. Getting this right isn't trivial,
6662 for auto-parens and auto-quotes. Getting this right isn't trivial,
6661 with all the color escapes, different prompt types and optional
6663 with all the color escapes, different prompt types and optional
6662 separators. But it seems to be working in all the combinations.
6664 separators. But it seems to be working in all the combinations.
6663
6665
6664 2001-11-26 Fernando Perez <fperez@colorado.edu>
6666 2001-11-26 Fernando Perez <fperez@colorado.edu>
6665
6667
6666 * Wrote a regexp filter to get option types from the option names
6668 * Wrote a regexp filter to get option types from the option names
6667 string. This eliminates the need to manually keep two duplicate
6669 string. This eliminates the need to manually keep two duplicate
6668 lists.
6670 lists.
6669
6671
6670 * Removed the unneeded check_option_names. Now options are handled
6672 * Removed the unneeded check_option_names. Now options are handled
6671 in a much saner manner and it's easy to visually check that things
6673 in a much saner manner and it's easy to visually check that things
6672 are ok.
6674 are ok.
6673
6675
6674 * Updated version numbers on all files I modified to carry a
6676 * Updated version numbers on all files I modified to carry a
6675 notice so Janko and Nathan have clear version markers.
6677 notice so Janko and Nathan have clear version markers.
6676
6678
6677 * Updated docstring for ultraTB with my changes. I should send
6679 * Updated docstring for ultraTB with my changes. I should send
6678 this to Nathan.
6680 this to Nathan.
6679
6681
6680 * Lots of small fixes. Ran everything through pychecker again.
6682 * Lots of small fixes. Ran everything through pychecker again.
6681
6683
6682 * Made loading of deep_reload an cmd line option. If it's not too
6684 * Made loading of deep_reload an cmd line option. If it's not too
6683 kosher, now people can just disable it. With -nodeep_reload it's
6685 kosher, now people can just disable it. With -nodeep_reload it's
6684 still available as dreload(), it just won't overwrite reload().
6686 still available as dreload(), it just won't overwrite reload().
6685
6687
6686 * Moved many options to the no| form (-opt and -noopt
6688 * Moved many options to the no| form (-opt and -noopt
6687 accepted). Cleaner.
6689 accepted). Cleaner.
6688
6690
6689 * Changed magic_log so that if called with no parameters, it uses
6691 * Changed magic_log so that if called with no parameters, it uses
6690 'rotate' mode. That way auto-generated logs aren't automatically
6692 'rotate' mode. That way auto-generated logs aren't automatically
6691 over-written. For normal logs, now a backup is made if it exists
6693 over-written. For normal logs, now a backup is made if it exists
6692 (only 1 level of backups). A new 'backup' mode was added to the
6694 (only 1 level of backups). A new 'backup' mode was added to the
6693 Logger class to support this. This was a request by Janko.
6695 Logger class to support this. This was a request by Janko.
6694
6696
6695 * Added @logoff/@logon to stop/restart an active log.
6697 * Added @logoff/@logon to stop/restart an active log.
6696
6698
6697 * Fixed a lot of bugs in log saving/replay. It was pretty
6699 * Fixed a lot of bugs in log saving/replay. It was pretty
6698 broken. Now special lines (!@,/) appear properly in the command
6700 broken. Now special lines (!@,/) appear properly in the command
6699 history after a log replay.
6701 history after a log replay.
6700
6702
6701 * Tried and failed to implement full session saving via pickle. My
6703 * Tried and failed to implement full session saving via pickle. My
6702 idea was to pickle __main__.__dict__, but modules can't be
6704 idea was to pickle __main__.__dict__, but modules can't be
6703 pickled. This would be a better alternative to replaying logs, but
6705 pickled. This would be a better alternative to replaying logs, but
6704 seems quite tricky to get to work. Changed -session to be called
6706 seems quite tricky to get to work. Changed -session to be called
6705 -logplay, which more accurately reflects what it does. And if we
6707 -logplay, which more accurately reflects what it does. And if we
6706 ever get real session saving working, -session is now available.
6708 ever get real session saving working, -session is now available.
6707
6709
6708 * Implemented color schemes for prompts also. As for tracebacks,
6710 * Implemented color schemes for prompts also. As for tracebacks,
6709 currently only NoColor and Linux are supported. But now the
6711 currently only NoColor and Linux are supported. But now the
6710 infrastructure is in place, based on a generic ColorScheme
6712 infrastructure is in place, based on a generic ColorScheme
6711 class. So writing and activating new schemes both for the prompts
6713 class. So writing and activating new schemes both for the prompts
6712 and the tracebacks should be straightforward.
6714 and the tracebacks should be straightforward.
6713
6715
6714 * Version 0.1.13 released, 0.1.14 opened.
6716 * Version 0.1.13 released, 0.1.14 opened.
6715
6717
6716 * Changed handling of options for output cache. Now counter is
6718 * Changed handling of options for output cache. Now counter is
6717 hardwired starting at 1 and one specifies the maximum number of
6719 hardwired starting at 1 and one specifies the maximum number of
6718 entries *in the outcache* (not the max prompt counter). This is
6720 entries *in the outcache* (not the max prompt counter). This is
6719 much better, since many statements won't increase the cache
6721 much better, since many statements won't increase the cache
6720 count. It also eliminated some confusing options, now there's only
6722 count. It also eliminated some confusing options, now there's only
6721 one: cache_size.
6723 one: cache_size.
6722
6724
6723 * Added 'alias' magic function and magic_alias option in the
6725 * Added 'alias' magic function and magic_alias option in the
6724 ipythonrc file. Now the user can easily define whatever names he
6726 ipythonrc file. Now the user can easily define whatever names he
6725 wants for the magic functions without having to play weird
6727 wants for the magic functions without having to play weird
6726 namespace games. This gives IPython a real shell-like feel.
6728 namespace games. This gives IPython a real shell-like feel.
6727
6729
6728 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6730 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6729 @ or not).
6731 @ or not).
6730
6732
6731 This was one of the last remaining 'visible' bugs (that I know
6733 This was one of the last remaining 'visible' bugs (that I know
6732 of). I think if I can clean up the session loading so it works
6734 of). I think if I can clean up the session loading so it works
6733 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6735 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6734 about licensing).
6736 about licensing).
6735
6737
6736 2001-11-25 Fernando Perez <fperez@colorado.edu>
6738 2001-11-25 Fernando Perez <fperez@colorado.edu>
6737
6739
6738 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6740 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6739 there's a cleaner distinction between what ? and ?? show.
6741 there's a cleaner distinction between what ? and ?? show.
6740
6742
6741 * Added screen_length option. Now the user can define his own
6743 * Added screen_length option. Now the user can define his own
6742 screen size for page() operations.
6744 screen size for page() operations.
6743
6745
6744 * Implemented magic shell-like functions with automatic code
6746 * Implemented magic shell-like functions with automatic code
6745 generation. Now adding another function is just a matter of adding
6747 generation. Now adding another function is just a matter of adding
6746 an entry to a dict, and the function is dynamically generated at
6748 an entry to a dict, and the function is dynamically generated at
6747 run-time. Python has some really cool features!
6749 run-time. Python has some really cool features!
6748
6750
6749 * Renamed many options to cleanup conventions a little. Now all
6751 * Renamed many options to cleanup conventions a little. Now all
6750 are lowercase, and only underscores where needed. Also in the code
6752 are lowercase, and only underscores where needed. Also in the code
6751 option name tables are clearer.
6753 option name tables are clearer.
6752
6754
6753 * Changed prompts a little. Now input is 'In [n]:' instead of
6755 * Changed prompts a little. Now input is 'In [n]:' instead of
6754 'In[n]:='. This allows it the numbers to be aligned with the
6756 'In[n]:='. This allows it the numbers to be aligned with the
6755 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6757 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6756 Python (it was a Mathematica thing). The '...' continuation prompt
6758 Python (it was a Mathematica thing). The '...' continuation prompt
6757 was also changed a little to align better.
6759 was also changed a little to align better.
6758
6760
6759 * Fixed bug when flushing output cache. Not all _p<n> variables
6761 * Fixed bug when flushing output cache. Not all _p<n> variables
6760 exist, so their deletion needs to be wrapped in a try:
6762 exist, so their deletion needs to be wrapped in a try:
6761
6763
6762 * Figured out how to properly use inspect.formatargspec() (it
6764 * Figured out how to properly use inspect.formatargspec() (it
6763 requires the args preceded by *). So I removed all the code from
6765 requires the args preceded by *). So I removed all the code from
6764 _get_pdef in Magic, which was just replicating that.
6766 _get_pdef in Magic, which was just replicating that.
6765
6767
6766 * Added test to prefilter to allow redefining magic function names
6768 * Added test to prefilter to allow redefining magic function names
6767 as variables. This is ok, since the @ form is always available,
6769 as variables. This is ok, since the @ form is always available,
6768 but whe should allow the user to define a variable called 'ls' if
6770 but whe should allow the user to define a variable called 'ls' if
6769 he needs it.
6771 he needs it.
6770
6772
6771 * Moved the ToDo information from README into a separate ToDo.
6773 * Moved the ToDo information from README into a separate ToDo.
6772
6774
6773 * General code cleanup and small bugfixes. I think it's close to a
6775 * General code cleanup and small bugfixes. I think it's close to a
6774 state where it can be released, obviously with a big 'beta'
6776 state where it can be released, obviously with a big 'beta'
6775 warning on it.
6777 warning on it.
6776
6778
6777 * Got the magic function split to work. Now all magics are defined
6779 * Got the magic function split to work. Now all magics are defined
6778 in a separate class. It just organizes things a bit, and now
6780 in a separate class. It just organizes things a bit, and now
6779 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6781 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6780 was too long).
6782 was too long).
6781
6783
6782 * Changed @clear to @reset to avoid potential confusions with
6784 * Changed @clear to @reset to avoid potential confusions with
6783 the shell command clear. Also renamed @cl to @clear, which does
6785 the shell command clear. Also renamed @cl to @clear, which does
6784 exactly what people expect it to from their shell experience.
6786 exactly what people expect it to from their shell experience.
6785
6787
6786 Added a check to the @reset command (since it's so
6788 Added a check to the @reset command (since it's so
6787 destructive, it's probably a good idea to ask for confirmation).
6789 destructive, it's probably a good idea to ask for confirmation).
6788 But now reset only works for full namespace resetting. Since the
6790 But now reset only works for full namespace resetting. Since the
6789 del keyword is already there for deleting a few specific
6791 del keyword is already there for deleting a few specific
6790 variables, I don't see the point of having a redundant magic
6792 variables, I don't see the point of having a redundant magic
6791 function for the same task.
6793 function for the same task.
6792
6794
6793 2001-11-24 Fernando Perez <fperez@colorado.edu>
6795 2001-11-24 Fernando Perez <fperez@colorado.edu>
6794
6796
6795 * Updated the builtin docs (esp. the ? ones).
6797 * Updated the builtin docs (esp. the ? ones).
6796
6798
6797 * Ran all the code through pychecker. Not terribly impressed with
6799 * Ran all the code through pychecker. Not terribly impressed with
6798 it: lots of spurious warnings and didn't really find anything of
6800 it: lots of spurious warnings and didn't really find anything of
6799 substance (just a few modules being imported and not used).
6801 substance (just a few modules being imported and not used).
6800
6802
6801 * Implemented the new ultraTB functionality into IPython. New
6803 * Implemented the new ultraTB functionality into IPython. New
6802 option: xcolors. This chooses color scheme. xmode now only selects
6804 option: xcolors. This chooses color scheme. xmode now only selects
6803 between Plain and Verbose. Better orthogonality.
6805 between Plain and Verbose. Better orthogonality.
6804
6806
6805 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6807 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6806 mode and color scheme for the exception handlers. Now it's
6808 mode and color scheme for the exception handlers. Now it's
6807 possible to have the verbose traceback with no coloring.
6809 possible to have the verbose traceback with no coloring.
6808
6810
6809 2001-11-23 Fernando Perez <fperez@colorado.edu>
6811 2001-11-23 Fernando Perez <fperez@colorado.edu>
6810
6812
6811 * Version 0.1.12 released, 0.1.13 opened.
6813 * Version 0.1.12 released, 0.1.13 opened.
6812
6814
6813 * Removed option to set auto-quote and auto-paren escapes by
6815 * Removed option to set auto-quote and auto-paren escapes by
6814 user. The chances of breaking valid syntax are just too high. If
6816 user. The chances of breaking valid syntax are just too high. If
6815 someone *really* wants, they can always dig into the code.
6817 someone *really* wants, they can always dig into the code.
6816
6818
6817 * Made prompt separators configurable.
6819 * Made prompt separators configurable.
6818
6820
6819 2001-11-22 Fernando Perez <fperez@colorado.edu>
6821 2001-11-22 Fernando Perez <fperez@colorado.edu>
6820
6822
6821 * Small bugfixes in many places.
6823 * Small bugfixes in many places.
6822
6824
6823 * Removed the MyCompleter class from ipplib. It seemed redundant
6825 * Removed the MyCompleter class from ipplib. It seemed redundant
6824 with the C-p,C-n history search functionality. Less code to
6826 with the C-p,C-n history search functionality. Less code to
6825 maintain.
6827 maintain.
6826
6828
6827 * Moved all the original ipython.py code into ipythonlib.py. Right
6829 * Moved all the original ipython.py code into ipythonlib.py. Right
6828 now it's just one big dump into a function called make_IPython, so
6830 now it's just one big dump into a function called make_IPython, so
6829 no real modularity has been gained. But at least it makes the
6831 no real modularity has been gained. But at least it makes the
6830 wrapper script tiny, and since ipythonlib is a module, it gets
6832 wrapper script tiny, and since ipythonlib is a module, it gets
6831 compiled and startup is much faster.
6833 compiled and startup is much faster.
6832
6834
6833 This is a reasobably 'deep' change, so we should test it for a
6835 This is a reasobably 'deep' change, so we should test it for a
6834 while without messing too much more with the code.
6836 while without messing too much more with the code.
6835
6837
6836 2001-11-21 Fernando Perez <fperez@colorado.edu>
6838 2001-11-21 Fernando Perez <fperez@colorado.edu>
6837
6839
6838 * Version 0.1.11 released, 0.1.12 opened for further work.
6840 * Version 0.1.11 released, 0.1.12 opened for further work.
6839
6841
6840 * Removed dependency on Itpl. It was only needed in one place. It
6842 * Removed dependency on Itpl. It was only needed in one place. It
6841 would be nice if this became part of python, though. It makes life
6843 would be nice if this became part of python, though. It makes life
6842 *a lot* easier in some cases.
6844 *a lot* easier in some cases.
6843
6845
6844 * Simplified the prefilter code a bit. Now all handlers are
6846 * Simplified the prefilter code a bit. Now all handlers are
6845 expected to explicitly return a value (at least a blank string).
6847 expected to explicitly return a value (at least a blank string).
6846
6848
6847 * Heavy edits in ipplib. Removed the help system altogether. Now
6849 * Heavy edits in ipplib. Removed the help system altogether. Now
6848 obj?/?? is used for inspecting objects, a magic @doc prints
6850 obj?/?? is used for inspecting objects, a magic @doc prints
6849 docstrings, and full-blown Python help is accessed via the 'help'
6851 docstrings, and full-blown Python help is accessed via the 'help'
6850 keyword. This cleans up a lot of code (less to maintain) and does
6852 keyword. This cleans up a lot of code (less to maintain) and does
6851 the job. Since 'help' is now a standard Python component, might as
6853 the job. Since 'help' is now a standard Python component, might as
6852 well use it and remove duplicate functionality.
6854 well use it and remove duplicate functionality.
6853
6855
6854 Also removed the option to use ipplib as a standalone program. By
6856 Also removed the option to use ipplib as a standalone program. By
6855 now it's too dependent on other parts of IPython to function alone.
6857 now it's too dependent on other parts of IPython to function alone.
6856
6858
6857 * Fixed bug in genutils.pager. It would crash if the pager was
6859 * Fixed bug in genutils.pager. It would crash if the pager was
6858 exited immediately after opening (broken pipe).
6860 exited immediately after opening (broken pipe).
6859
6861
6860 * Trimmed down the VerboseTB reporting a little. The header is
6862 * Trimmed down the VerboseTB reporting a little. The header is
6861 much shorter now and the repeated exception arguments at the end
6863 much shorter now and the repeated exception arguments at the end
6862 have been removed. For interactive use the old header seemed a bit
6864 have been removed. For interactive use the old header seemed a bit
6863 excessive.
6865 excessive.
6864
6866
6865 * Fixed small bug in output of @whos for variables with multi-word
6867 * Fixed small bug in output of @whos for variables with multi-word
6866 types (only first word was displayed).
6868 types (only first word was displayed).
6867
6869
6868 2001-11-17 Fernando Perez <fperez@colorado.edu>
6870 2001-11-17 Fernando Perez <fperez@colorado.edu>
6869
6871
6870 * Version 0.1.10 released, 0.1.11 opened for further work.
6872 * Version 0.1.10 released, 0.1.11 opened for further work.
6871
6873
6872 * Modified dirs and friends. dirs now *returns* the stack (not
6874 * Modified dirs and friends. dirs now *returns* the stack (not
6873 prints), so one can manipulate it as a variable. Convenient to
6875 prints), so one can manipulate it as a variable. Convenient to
6874 travel along many directories.
6876 travel along many directories.
6875
6877
6876 * Fixed bug in magic_pdef: would only work with functions with
6878 * Fixed bug in magic_pdef: would only work with functions with
6877 arguments with default values.
6879 arguments with default values.
6878
6880
6879 2001-11-14 Fernando Perez <fperez@colorado.edu>
6881 2001-11-14 Fernando Perez <fperez@colorado.edu>
6880
6882
6881 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6883 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6882 example with IPython. Various other minor fixes and cleanups.
6884 example with IPython. Various other minor fixes and cleanups.
6883
6885
6884 * Version 0.1.9 released, 0.1.10 opened for further work.
6886 * Version 0.1.9 released, 0.1.10 opened for further work.
6885
6887
6886 * Added sys.path to the list of directories searched in the
6888 * Added sys.path to the list of directories searched in the
6887 execfile= option. It used to be the current directory and the
6889 execfile= option. It used to be the current directory and the
6888 user's IPYTHONDIR only.
6890 user's IPYTHONDIR only.
6889
6891
6890 2001-11-13 Fernando Perez <fperez@colorado.edu>
6892 2001-11-13 Fernando Perez <fperez@colorado.edu>
6891
6893
6892 * Reinstated the raw_input/prefilter separation that Janko had
6894 * Reinstated the raw_input/prefilter separation that Janko had
6893 initially. This gives a more convenient setup for extending the
6895 initially. This gives a more convenient setup for extending the
6894 pre-processor from the outside: raw_input always gets a string,
6896 pre-processor from the outside: raw_input always gets a string,
6895 and prefilter has to process it. We can then redefine prefilter
6897 and prefilter has to process it. We can then redefine prefilter
6896 from the outside and implement extensions for special
6898 from the outside and implement extensions for special
6897 purposes.
6899 purposes.
6898
6900
6899 Today I got one for inputting PhysicalQuantity objects
6901 Today I got one for inputting PhysicalQuantity objects
6900 (from Scientific) without needing any function calls at
6902 (from Scientific) without needing any function calls at
6901 all. Extremely convenient, and it's all done as a user-level
6903 all. Extremely convenient, and it's all done as a user-level
6902 extension (no IPython code was touched). Now instead of:
6904 extension (no IPython code was touched). Now instead of:
6903 a = PhysicalQuantity(4.2,'m/s**2')
6905 a = PhysicalQuantity(4.2,'m/s**2')
6904 one can simply say
6906 one can simply say
6905 a = 4.2 m/s**2
6907 a = 4.2 m/s**2
6906 or even
6908 or even
6907 a = 4.2 m/s^2
6909 a = 4.2 m/s^2
6908
6910
6909 I use this, but it's also a proof of concept: IPython really is
6911 I use this, but it's also a proof of concept: IPython really is
6910 fully user-extensible, even at the level of the parsing of the
6912 fully user-extensible, even at the level of the parsing of the
6911 command line. It's not trivial, but it's perfectly doable.
6913 command line. It's not trivial, but it's perfectly doable.
6912
6914
6913 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6915 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6914 the problem of modules being loaded in the inverse order in which
6916 the problem of modules being loaded in the inverse order in which
6915 they were defined in
6917 they were defined in
6916
6918
6917 * Version 0.1.8 released, 0.1.9 opened for further work.
6919 * Version 0.1.8 released, 0.1.9 opened for further work.
6918
6920
6919 * Added magics pdef, source and file. They respectively show the
6921 * Added magics pdef, source and file. They respectively show the
6920 definition line ('prototype' in C), source code and full python
6922 definition line ('prototype' in C), source code and full python
6921 file for any callable object. The object inspector oinfo uses
6923 file for any callable object. The object inspector oinfo uses
6922 these to show the same information.
6924 these to show the same information.
6923
6925
6924 * Version 0.1.7 released, 0.1.8 opened for further work.
6926 * Version 0.1.7 released, 0.1.8 opened for further work.
6925
6927
6926 * Separated all the magic functions into a class called Magic. The
6928 * Separated all the magic functions into a class called Magic. The
6927 InteractiveShell class was becoming too big for Xemacs to handle
6929 InteractiveShell class was becoming too big for Xemacs to handle
6928 (de-indenting a line would lock it up for 10 seconds while it
6930 (de-indenting a line would lock it up for 10 seconds while it
6929 backtracked on the whole class!)
6931 backtracked on the whole class!)
6930
6932
6931 FIXME: didn't work. It can be done, but right now namespaces are
6933 FIXME: didn't work. It can be done, but right now namespaces are
6932 all messed up. Do it later (reverted it for now, so at least
6934 all messed up. Do it later (reverted it for now, so at least
6933 everything works as before).
6935 everything works as before).
6934
6936
6935 * Got the object introspection system (magic_oinfo) working! I
6937 * Got the object introspection system (magic_oinfo) working! I
6936 think this is pretty much ready for release to Janko, so he can
6938 think this is pretty much ready for release to Janko, so he can
6937 test it for a while and then announce it. Pretty much 100% of what
6939 test it for a while and then announce it. Pretty much 100% of what
6938 I wanted for the 'phase 1' release is ready. Happy, tired.
6940 I wanted for the 'phase 1' release is ready. Happy, tired.
6939
6941
6940 2001-11-12 Fernando Perez <fperez@colorado.edu>
6942 2001-11-12 Fernando Perez <fperez@colorado.edu>
6941
6943
6942 * Version 0.1.6 released, 0.1.7 opened for further work.
6944 * Version 0.1.6 released, 0.1.7 opened for further work.
6943
6945
6944 * Fixed bug in printing: it used to test for truth before
6946 * Fixed bug in printing: it used to test for truth before
6945 printing, so 0 wouldn't print. Now checks for None.
6947 printing, so 0 wouldn't print. Now checks for None.
6946
6948
6947 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6949 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6948 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6950 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6949 reaches by hand into the outputcache. Think of a better way to do
6951 reaches by hand into the outputcache. Think of a better way to do
6950 this later.
6952 this later.
6951
6953
6952 * Various small fixes thanks to Nathan's comments.
6954 * Various small fixes thanks to Nathan's comments.
6953
6955
6954 * Changed magic_pprint to magic_Pprint. This way it doesn't
6956 * Changed magic_pprint to magic_Pprint. This way it doesn't
6955 collide with pprint() and the name is consistent with the command
6957 collide with pprint() and the name is consistent with the command
6956 line option.
6958 line option.
6957
6959
6958 * Changed prompt counter behavior to be fully like
6960 * Changed prompt counter behavior to be fully like
6959 Mathematica's. That is, even input that doesn't return a result
6961 Mathematica's. That is, even input that doesn't return a result
6960 raises the prompt counter. The old behavior was kind of confusing
6962 raises the prompt counter. The old behavior was kind of confusing
6961 (getting the same prompt number several times if the operation
6963 (getting the same prompt number several times if the operation
6962 didn't return a result).
6964 didn't return a result).
6963
6965
6964 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6966 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6965
6967
6966 * Fixed -Classic mode (wasn't working anymore).
6968 * Fixed -Classic mode (wasn't working anymore).
6967
6969
6968 * Added colored prompts using Nathan's new code. Colors are
6970 * Added colored prompts using Nathan's new code. Colors are
6969 currently hardwired, they can be user-configurable. For
6971 currently hardwired, they can be user-configurable. For
6970 developers, they can be chosen in file ipythonlib.py, at the
6972 developers, they can be chosen in file ipythonlib.py, at the
6971 beginning of the CachedOutput class def.
6973 beginning of the CachedOutput class def.
6972
6974
6973 2001-11-11 Fernando Perez <fperez@colorado.edu>
6975 2001-11-11 Fernando Perez <fperez@colorado.edu>
6974
6976
6975 * Version 0.1.5 released, 0.1.6 opened for further work.
6977 * Version 0.1.5 released, 0.1.6 opened for further work.
6976
6978
6977 * Changed magic_env to *return* the environment as a dict (not to
6979 * Changed magic_env to *return* the environment as a dict (not to
6978 print it). This way it prints, but it can also be processed.
6980 print it). This way it prints, but it can also be processed.
6979
6981
6980 * Added Verbose exception reporting to interactive
6982 * Added Verbose exception reporting to interactive
6981 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6983 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6982 traceback. Had to make some changes to the ultraTB file. This is
6984 traceback. Had to make some changes to the ultraTB file. This is
6983 probably the last 'big' thing in my mental todo list. This ties
6985 probably the last 'big' thing in my mental todo list. This ties
6984 in with the next entry:
6986 in with the next entry:
6985
6987
6986 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6988 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6987 has to specify is Plain, Color or Verbose for all exception
6989 has to specify is Plain, Color or Verbose for all exception
6988 handling.
6990 handling.
6989
6991
6990 * Removed ShellServices option. All this can really be done via
6992 * Removed ShellServices option. All this can really be done via
6991 the magic system. It's easier to extend, cleaner and has automatic
6993 the magic system. It's easier to extend, cleaner and has automatic
6992 namespace protection and documentation.
6994 namespace protection and documentation.
6993
6995
6994 2001-11-09 Fernando Perez <fperez@colorado.edu>
6996 2001-11-09 Fernando Perez <fperez@colorado.edu>
6995
6997
6996 * Fixed bug in output cache flushing (missing parameter to
6998 * Fixed bug in output cache flushing (missing parameter to
6997 __init__). Other small bugs fixed (found using pychecker).
6999 __init__). Other small bugs fixed (found using pychecker).
6998
7000
6999 * Version 0.1.4 opened for bugfixing.
7001 * Version 0.1.4 opened for bugfixing.
7000
7002
7001 2001-11-07 Fernando Perez <fperez@colorado.edu>
7003 2001-11-07 Fernando Perez <fperez@colorado.edu>
7002
7004
7003 * Version 0.1.3 released, mainly because of the raw_input bug.
7005 * Version 0.1.3 released, mainly because of the raw_input bug.
7004
7006
7005 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
7007 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
7006 and when testing for whether things were callable, a call could
7008 and when testing for whether things were callable, a call could
7007 actually be made to certain functions. They would get called again
7009 actually be made to certain functions. They would get called again
7008 once 'really' executed, with a resulting double call. A disaster
7010 once 'really' executed, with a resulting double call. A disaster
7009 in many cases (list.reverse() would never work!).
7011 in many cases (list.reverse() would never work!).
7010
7012
7011 * Removed prefilter() function, moved its code to raw_input (which
7013 * Removed prefilter() function, moved its code to raw_input (which
7012 after all was just a near-empty caller for prefilter). This saves
7014 after all was just a near-empty caller for prefilter). This saves
7013 a function call on every prompt, and simplifies the class a tiny bit.
7015 a function call on every prompt, and simplifies the class a tiny bit.
7014
7016
7015 * Fix _ip to __ip name in magic example file.
7017 * Fix _ip to __ip name in magic example file.
7016
7018
7017 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
7019 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
7018 work with non-gnu versions of tar.
7020 work with non-gnu versions of tar.
7019
7021
7020 2001-11-06 Fernando Perez <fperez@colorado.edu>
7022 2001-11-06 Fernando Perez <fperez@colorado.edu>
7021
7023
7022 * Version 0.1.2. Just to keep track of the recent changes.
7024 * Version 0.1.2. Just to keep track of the recent changes.
7023
7025
7024 * Fixed nasty bug in output prompt routine. It used to check 'if
7026 * Fixed nasty bug in output prompt routine. It used to check 'if
7025 arg != None...'. Problem is, this fails if arg implements a
7027 arg != None...'. Problem is, this fails if arg implements a
7026 special comparison (__cmp__) which disallows comparing to
7028 special comparison (__cmp__) which disallows comparing to
7027 None. Found it when trying to use the PhysicalQuantity module from
7029 None. Found it when trying to use the PhysicalQuantity module from
7028 ScientificPython.
7030 ScientificPython.
7029
7031
7030 2001-11-05 Fernando Perez <fperez@colorado.edu>
7032 2001-11-05 Fernando Perez <fperez@colorado.edu>
7031
7033
7032 * Also added dirs. Now the pushd/popd/dirs family functions
7034 * Also added dirs. Now the pushd/popd/dirs family functions
7033 basically like the shell, with the added convenience of going home
7035 basically like the shell, with the added convenience of going home
7034 when called with no args.
7036 when called with no args.
7035
7037
7036 * pushd/popd slightly modified to mimic shell behavior more
7038 * pushd/popd slightly modified to mimic shell behavior more
7037 closely.
7039 closely.
7038
7040
7039 * Added env,pushd,popd from ShellServices as magic functions. I
7041 * Added env,pushd,popd from ShellServices as magic functions. I
7040 think the cleanest will be to port all desired functions from
7042 think the cleanest will be to port all desired functions from
7041 ShellServices as magics and remove ShellServices altogether. This
7043 ShellServices as magics and remove ShellServices altogether. This
7042 will provide a single, clean way of adding functionality
7044 will provide a single, clean way of adding functionality
7043 (shell-type or otherwise) to IP.
7045 (shell-type or otherwise) to IP.
7044
7046
7045 2001-11-04 Fernando Perez <fperez@colorado.edu>
7047 2001-11-04 Fernando Perez <fperez@colorado.edu>
7046
7048
7047 * Added .ipython/ directory to sys.path. This way users can keep
7049 * Added .ipython/ directory to sys.path. This way users can keep
7048 customizations there and access them via import.
7050 customizations there and access them via import.
7049
7051
7050 2001-11-03 Fernando Perez <fperez@colorado.edu>
7052 2001-11-03 Fernando Perez <fperez@colorado.edu>
7051
7053
7052 * Opened version 0.1.1 for new changes.
7054 * Opened version 0.1.1 for new changes.
7053
7055
7054 * Changed version number to 0.1.0: first 'public' release, sent to
7056 * Changed version number to 0.1.0: first 'public' release, sent to
7055 Nathan and Janko.
7057 Nathan and Janko.
7056
7058
7057 * Lots of small fixes and tweaks.
7059 * Lots of small fixes and tweaks.
7058
7060
7059 * Minor changes to whos format. Now strings are shown, snipped if
7061 * Minor changes to whos format. Now strings are shown, snipped if
7060 too long.
7062 too long.
7061
7063
7062 * Changed ShellServices to work on __main__ so they show up in @who
7064 * Changed ShellServices to work on __main__ so they show up in @who
7063
7065
7064 * Help also works with ? at the end of a line:
7066 * Help also works with ? at the end of a line:
7065 ?sin and sin?
7067 ?sin and sin?
7066 both produce the same effect. This is nice, as often I use the
7068 both produce the same effect. This is nice, as often I use the
7067 tab-complete to find the name of a method, but I used to then have
7069 tab-complete to find the name of a method, but I used to then have
7068 to go to the beginning of the line to put a ? if I wanted more
7070 to go to the beginning of the line to put a ? if I wanted more
7069 info. Now I can just add the ? and hit return. Convenient.
7071 info. Now I can just add the ? and hit return. Convenient.
7070
7072
7071 2001-11-02 Fernando Perez <fperez@colorado.edu>
7073 2001-11-02 Fernando Perez <fperez@colorado.edu>
7072
7074
7073 * Python version check (>=2.1) added.
7075 * Python version check (>=2.1) added.
7074
7076
7075 * Added LazyPython documentation. At this point the docs are quite
7077 * Added LazyPython documentation. At this point the docs are quite
7076 a mess. A cleanup is in order.
7078 a mess. A cleanup is in order.
7077
7079
7078 * Auto-installer created. For some bizarre reason, the zipfiles
7080 * Auto-installer created. For some bizarre reason, the zipfiles
7079 module isn't working on my system. So I made a tar version
7081 module isn't working on my system. So I made a tar version
7080 (hopefully the command line options in various systems won't kill
7082 (hopefully the command line options in various systems won't kill
7081 me).
7083 me).
7082
7084
7083 * Fixes to Struct in genutils. Now all dictionary-like methods are
7085 * Fixes to Struct in genutils. Now all dictionary-like methods are
7084 protected (reasonably).
7086 protected (reasonably).
7085
7087
7086 * Added pager function to genutils and changed ? to print usage
7088 * Added pager function to genutils and changed ? to print usage
7087 note through it (it was too long).
7089 note through it (it was too long).
7088
7090
7089 * Added the LazyPython functionality. Works great! I changed the
7091 * Added the LazyPython functionality. Works great! I changed the
7090 auto-quote escape to ';', it's on home row and next to '. But
7092 auto-quote escape to ';', it's on home row and next to '. But
7091 both auto-quote and auto-paren (still /) escapes are command-line
7093 both auto-quote and auto-paren (still /) escapes are command-line
7092 parameters.
7094 parameters.
7093
7095
7094
7096
7095 2001-11-01 Fernando Perez <fperez@colorado.edu>
7097 2001-11-01 Fernando Perez <fperez@colorado.edu>
7096
7098
7097 * Version changed to 0.0.7. Fairly large change: configuration now
7099 * Version changed to 0.0.7. Fairly large change: configuration now
7098 is all stored in a directory, by default .ipython. There, all
7100 is all stored in a directory, by default .ipython. There, all
7099 config files have normal looking names (not .names)
7101 config files have normal looking names (not .names)
7100
7102
7101 * Version 0.0.6 Released first to Lucas and Archie as a test
7103 * Version 0.0.6 Released first to Lucas and Archie as a test
7102 run. Since it's the first 'semi-public' release, change version to
7104 run. Since it's the first 'semi-public' release, change version to
7103 > 0.0.6 for any changes now.
7105 > 0.0.6 for any changes now.
7104
7106
7105 * Stuff I had put in the ipplib.py changelog:
7107 * Stuff I had put in the ipplib.py changelog:
7106
7108
7107 Changes to InteractiveShell:
7109 Changes to InteractiveShell:
7108
7110
7109 - Made the usage message a parameter.
7111 - Made the usage message a parameter.
7110
7112
7111 - Require the name of the shell variable to be given. It's a bit
7113 - Require the name of the shell variable to be given. It's a bit
7112 of a hack, but allows the name 'shell' not to be hardwired in the
7114 of a hack, but allows the name 'shell' not to be hardwired in the
7113 magic (@) handler, which is problematic b/c it requires
7115 magic (@) handler, which is problematic b/c it requires
7114 polluting the global namespace with 'shell'. This in turn is
7116 polluting the global namespace with 'shell'. This in turn is
7115 fragile: if a user redefines a variable called shell, things
7117 fragile: if a user redefines a variable called shell, things
7116 break.
7118 break.
7117
7119
7118 - magic @: all functions available through @ need to be defined
7120 - magic @: all functions available through @ need to be defined
7119 as magic_<name>, even though they can be called simply as
7121 as magic_<name>, even though they can be called simply as
7120 @<name>. This allows the special command @magic to gather
7122 @<name>. This allows the special command @magic to gather
7121 information automatically about all existing magic functions,
7123 information automatically about all existing magic functions,
7122 even if they are run-time user extensions, by parsing the shell
7124 even if they are run-time user extensions, by parsing the shell
7123 instance __dict__ looking for special magic_ names.
7125 instance __dict__ looking for special magic_ names.
7124
7126
7125 - mainloop: added *two* local namespace parameters. This allows
7127 - mainloop: added *two* local namespace parameters. This allows
7126 the class to differentiate between parameters which were there
7128 the class to differentiate between parameters which were there
7127 before and after command line initialization was processed. This
7129 before and after command line initialization was processed. This
7128 way, later @who can show things loaded at startup by the
7130 way, later @who can show things loaded at startup by the
7129 user. This trick was necessary to make session saving/reloading
7131 user. This trick was necessary to make session saving/reloading
7130 really work: ideally after saving/exiting/reloading a session,
7132 really work: ideally after saving/exiting/reloading a session,
7131 *everything* should look the same, including the output of @who. I
7133 *everything* should look the same, including the output of @who. I
7132 was only able to make this work with this double namespace
7134 was only able to make this work with this double namespace
7133 trick.
7135 trick.
7134
7136
7135 - added a header to the logfile which allows (almost) full
7137 - added a header to the logfile which allows (almost) full
7136 session restoring.
7138 session restoring.
7137
7139
7138 - prepend lines beginning with @ or !, with a and log
7140 - prepend lines beginning with @ or !, with a and log
7139 them. Why? !lines: may be useful to know what you did @lines:
7141 them. Why? !lines: may be useful to know what you did @lines:
7140 they may affect session state. So when restoring a session, at
7142 they may affect session state. So when restoring a session, at
7141 least inform the user of their presence. I couldn't quite get
7143 least inform the user of their presence. I couldn't quite get
7142 them to properly re-execute, but at least the user is warned.
7144 them to properly re-execute, but at least the user is warned.
7143
7145
7144 * Started ChangeLog.
7146 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now