##// END OF EJS Templates
- Fix exception name printing for Python 2.5.
fperez -
Show More
@@ -1,927 +1,933 b''
1 # -*- coding: utf-8 -*-
1 # -*- coding: utf-8 -*-
2 """
2 """
3 ultraTB.py -- Spice up your tracebacks!
3 ultraTB.py -- Spice up your tracebacks!
4
4
5 * ColorTB
5 * ColorTB
6 I've always found it a bit hard to visually parse tracebacks in Python. The
6 I've always found it a bit hard to visually parse tracebacks in Python. The
7 ColorTB class is a solution to that problem. It colors the different parts of a
7 ColorTB class is a solution to that problem. It colors the different parts of a
8 traceback in a manner similar to what you would expect from a syntax-highlighting
8 traceback in a manner similar to what you would expect from a syntax-highlighting
9 text editor.
9 text editor.
10
10
11 Installation instructions for ColorTB:
11 Installation instructions for ColorTB:
12 import sys,ultraTB
12 import sys,ultraTB
13 sys.excepthook = ultraTB.ColorTB()
13 sys.excepthook = ultraTB.ColorTB()
14
14
15 * VerboseTB
15 * VerboseTB
16 I've also included a port of Ka-Ping Yee's "cgitb.py" that produces all kinds
16 I've also included a port of Ka-Ping Yee's "cgitb.py" that produces all kinds
17 of useful info when a traceback occurs. Ping originally had it spit out HTML
17 of useful info when a traceback occurs. Ping originally had it spit out HTML
18 and intended it for CGI programmers, but why should they have all the fun? I
18 and intended it for CGI programmers, but why should they have all the fun? I
19 altered it to spit out colored text to the terminal. It's a bit overwhelming,
19 altered it to spit out colored text to the terminal. It's a bit overwhelming,
20 but kind of neat, and maybe useful for long-running programs that you believe
20 but kind of neat, and maybe useful for long-running programs that you believe
21 are bug-free. If a crash *does* occur in that type of program you want details.
21 are bug-free. If a crash *does* occur in that type of program you want details.
22 Give it a shot--you'll love it or you'll hate it.
22 Give it a shot--you'll love it or you'll hate it.
23
23
24 Note:
24 Note:
25
25
26 The Verbose mode prints the variables currently visible where the exception
26 The Verbose mode prints the variables currently visible where the exception
27 happened (shortening their strings if too long). This can potentially be
27 happened (shortening their strings if too long). This can potentially be
28 very slow, if you happen to have a huge data structure whose string
28 very slow, if you happen to have a huge data structure whose string
29 representation is complex to compute. Your computer may appear to freeze for
29 representation is complex to compute. Your computer may appear to freeze for
30 a while with cpu usage at 100%. If this occurs, you can cancel the traceback
30 a while with cpu usage at 100%. If this occurs, you can cancel the traceback
31 with Ctrl-C (maybe hitting it more than once).
31 with Ctrl-C (maybe hitting it more than once).
32
32
33 If you encounter this kind of situation often, you may want to use the
33 If you encounter this kind of situation often, you may want to use the
34 Verbose_novars mode instead of the regular Verbose, which avoids formatting
34 Verbose_novars mode instead of the regular Verbose, which avoids formatting
35 variables (but otherwise includes the information and context given by
35 variables (but otherwise includes the information and context given by
36 Verbose).
36 Verbose).
37
37
38
38
39 Installation instructions for ColorTB:
39 Installation instructions for ColorTB:
40 import sys,ultraTB
40 import sys,ultraTB
41 sys.excepthook = ultraTB.VerboseTB()
41 sys.excepthook = ultraTB.VerboseTB()
42
42
43 Note: Much of the code in this module was lifted verbatim from the standard
43 Note: Much of the code in this module was lifted verbatim from the standard
44 library module 'traceback.py' and Ka-Ping Yee's 'cgitb.py'.
44 library module 'traceback.py' and Ka-Ping Yee's 'cgitb.py'.
45
45
46 * Color schemes
46 * Color schemes
47 The colors are defined in the class TBTools through the use of the
47 The colors are defined in the class TBTools through the use of the
48 ColorSchemeTable class. Currently the following exist:
48 ColorSchemeTable class. Currently the following exist:
49
49
50 - NoColor: allows all of this module to be used in any terminal (the color
50 - NoColor: allows all of this module to be used in any terminal (the color
51 escapes are just dummy blank strings).
51 escapes are just dummy blank strings).
52
52
53 - Linux: is meant to look good in a terminal like the Linux console (black
53 - Linux: is meant to look good in a terminal like the Linux console (black
54 or very dark background).
54 or very dark background).
55
55
56 - LightBG: similar to Linux but swaps dark/light colors to be more readable
56 - LightBG: similar to Linux but swaps dark/light colors to be more readable
57 in light background terminals.
57 in light background terminals.
58
58
59 You can implement other color schemes easily, the syntax is fairly
59 You can implement other color schemes easily, the syntax is fairly
60 self-explanatory. Please send back new schemes you develop to the author for
60 self-explanatory. Please send back new schemes you develop to the author for
61 possible inclusion in future releases.
61 possible inclusion in future releases.
62
62
63 $Id: ultraTB.py 2156 2007-03-19 02:32:19Z fperez $"""
63 $Id: ultraTB.py 2419 2007-06-01 07:31:42Z fperez $"""
64
64
65 #*****************************************************************************
65 #*****************************************************************************
66 # Copyright (C) 2001 Nathaniel Gray <n8gray@caltech.edu>
66 # Copyright (C) 2001 Nathaniel Gray <n8gray@caltech.edu>
67 # Copyright (C) 2001-2004 Fernando Perez <fperez@colorado.edu>
67 # Copyright (C) 2001-2004 Fernando Perez <fperez@colorado.edu>
68 #
68 #
69 # Distributed under the terms of the BSD License. The full license is in
69 # Distributed under the terms of the BSD License. The full license is in
70 # the file COPYING, distributed as part of this software.
70 # the file COPYING, distributed as part of this software.
71 #*****************************************************************************
71 #*****************************************************************************
72
72
73 from IPython import Release
73 from IPython import Release
74 __author__ = '%s <%s>\n%s <%s>' % (Release.authors['Nathan']+
74 __author__ = '%s <%s>\n%s <%s>' % (Release.authors['Nathan']+
75 Release.authors['Fernando'])
75 Release.authors['Fernando'])
76 __license__ = Release.license
76 __license__ = Release.license
77
77
78 # Required modules
78 # Required modules
79 import inspect
79 import inspect
80 import keyword
80 import keyword
81 import linecache
81 import linecache
82 import os
82 import os
83 import pydoc
83 import pydoc
84 import string
84 import string
85 import sys
85 import sys
86 import time
86 import time
87 import tokenize
87 import tokenize
88 import traceback
88 import traceback
89 import types
89 import types
90
90
91 # IPython's own modules
91 # IPython's own modules
92 # Modified pdb which doesn't damage IPython's readline handling
92 # Modified pdb which doesn't damage IPython's readline handling
93 from IPython import Debugger, PyColorize
93 from IPython import Debugger, PyColorize
94 from IPython.ipstruct import Struct
94 from IPython.ipstruct import Struct
95 from IPython.excolors import ExceptionColors
95 from IPython.excolors import ExceptionColors
96 from IPython.genutils import Term,uniq_stable,error,info
96 from IPython.genutils import Term,uniq_stable,error,info
97
97
98 # Globals
98 # Globals
99 # amount of space to put line numbers before verbose tracebacks
99 # amount of space to put line numbers before verbose tracebacks
100 INDENT_SIZE = 8
100 INDENT_SIZE = 8
101
101
102 # Default color scheme. This is used, for example, by the traceback
102 # Default color scheme. This is used, for example, by the traceback
103 # formatter. When running in an actual IPython instance, the user's rc.colors
103 # formatter. When running in an actual IPython instance, the user's rc.colors
104 # value is used, but havinga module global makes this functionality available
104 # value is used, but havinga module global makes this functionality available
105 # to users of ultraTB who are NOT running inside ipython.
105 # to users of ultraTB who are NOT running inside ipython.
106 DEFAULT_SCHEME = 'NoColor'
106 DEFAULT_SCHEME = 'NoColor'
107
107
108 #---------------------------------------------------------------------------
108 #---------------------------------------------------------------------------
109 # Code begins
109 # Code begins
110
110
111 # Utility functions
111 # Utility functions
112 def inspect_error():
112 def inspect_error():
113 """Print a message about internal inspect errors.
113 """Print a message about internal inspect errors.
114
114
115 These are unfortunately quite common."""
115 These are unfortunately quite common."""
116
116
117 error('Internal Python error in the inspect module.\n'
117 error('Internal Python error in the inspect module.\n'
118 'Below is the traceback from this internal error.\n')
118 'Below is the traceback from this internal error.\n')
119
119
120 def _fixed_getinnerframes(etb, context=1,tb_offset=0):
120 def _fixed_getinnerframes(etb, context=1,tb_offset=0):
121 import linecache
121 import linecache
122 LNUM_POS, LINES_POS, INDEX_POS = 2, 4, 5
122 LNUM_POS, LINES_POS, INDEX_POS = 2, 4, 5
123
123
124 records = inspect.getinnerframes(etb, context)
124 records = inspect.getinnerframes(etb, context)
125
125
126 # If the error is at the console, don't build any context, since it would
126 # If the error is at the console, don't build any context, since it would
127 # otherwise produce 5 blank lines printed out (there is no file at the
127 # otherwise produce 5 blank lines printed out (there is no file at the
128 # console)
128 # console)
129 rec_check = records[tb_offset:]
129 rec_check = records[tb_offset:]
130 try:
130 try:
131 rname = rec_check[0][1]
131 rname = rec_check[0][1]
132 if rname == '<ipython console>' or rname.endswith('<string>'):
132 if rname == '<ipython console>' or rname.endswith('<string>'):
133 return rec_check
133 return rec_check
134 except IndexError:
134 except IndexError:
135 pass
135 pass
136
136
137 aux = traceback.extract_tb(etb)
137 aux = traceback.extract_tb(etb)
138 assert len(records) == len(aux)
138 assert len(records) == len(aux)
139 for i, (file, lnum, _, _) in zip(range(len(records)), aux):
139 for i, (file, lnum, _, _) in zip(range(len(records)), aux):
140 maybeStart = lnum-1 - context//2
140 maybeStart = lnum-1 - context//2
141 start = max(maybeStart, 0)
141 start = max(maybeStart, 0)
142 end = start + context
142 end = start + context
143 lines = linecache.getlines(file)[start:end]
143 lines = linecache.getlines(file)[start:end]
144 # pad with empty lines if necessary
144 # pad with empty lines if necessary
145 if maybeStart < 0:
145 if maybeStart < 0:
146 lines = (['\n'] * -maybeStart) + lines
146 lines = (['\n'] * -maybeStart) + lines
147 if len(lines) < context:
147 if len(lines) < context:
148 lines += ['\n'] * (context - len(lines))
148 lines += ['\n'] * (context - len(lines))
149 buf = list(records[i])
149 buf = list(records[i])
150 buf[LNUM_POS] = lnum
150 buf[LNUM_POS] = lnum
151 buf[INDEX_POS] = lnum - 1 - start
151 buf[INDEX_POS] = lnum - 1 - start
152 buf[LINES_POS] = lines
152 buf[LINES_POS] = lines
153 records[i] = tuple(buf)
153 records[i] = tuple(buf)
154 return records[tb_offset:]
154 return records[tb_offset:]
155
155
156 # Helper function -- largely belongs to VerboseTB, but we need the same
156 # Helper function -- largely belongs to VerboseTB, but we need the same
157 # functionality to produce a pseudo verbose TB for SyntaxErrors, so that they
157 # functionality to produce a pseudo verbose TB for SyntaxErrors, so that they
158 # can be recognized properly by ipython.el's py-traceback-line-re
158 # can be recognized properly by ipython.el's py-traceback-line-re
159 # (SyntaxErrors have to be treated specially because they have no traceback)
159 # (SyntaxErrors have to be treated specially because they have no traceback)
160
160
161 _parser = PyColorize.Parser()
161 _parser = PyColorize.Parser()
162
162
163 def _formatTracebackLines(lnum, index, lines, Colors, lvals=None,scheme=None):
163 def _formatTracebackLines(lnum, index, lines, Colors, lvals=None,scheme=None):
164 numbers_width = INDENT_SIZE - 1
164 numbers_width = INDENT_SIZE - 1
165 res = []
165 res = []
166 i = lnum - index
166 i = lnum - index
167
167
168 # This lets us get fully syntax-highlighted tracebacks.
168 # This lets us get fully syntax-highlighted tracebacks.
169 if scheme is None:
169 if scheme is None:
170 try:
170 try:
171 scheme = __IPYTHON__.rc.colors
171 scheme = __IPYTHON__.rc.colors
172 except:
172 except:
173 scheme = DEFAULT_SCHEME
173 scheme = DEFAULT_SCHEME
174 _line_format = _parser.format2
174 _line_format = _parser.format2
175
175
176 for line in lines:
176 for line in lines:
177 new_line, err = _line_format(line,'str',scheme)
177 new_line, err = _line_format(line,'str',scheme)
178 if not err: line = new_line
178 if not err: line = new_line
179
179
180 if i == lnum:
180 if i == lnum:
181 # This is the line with the error
181 # This is the line with the error
182 pad = numbers_width - len(str(i))
182 pad = numbers_width - len(str(i))
183 if pad >= 3:
183 if pad >= 3:
184 marker = '-'*(pad-3) + '-> '
184 marker = '-'*(pad-3) + '-> '
185 elif pad == 2:
185 elif pad == 2:
186 marker = '> '
186 marker = '> '
187 elif pad == 1:
187 elif pad == 1:
188 marker = '>'
188 marker = '>'
189 else:
189 else:
190 marker = ''
190 marker = ''
191 num = marker + str(i)
191 num = marker + str(i)
192 line = '%s%s%s %s%s' %(Colors.linenoEm, num,
192 line = '%s%s%s %s%s' %(Colors.linenoEm, num,
193 Colors.line, line, Colors.Normal)
193 Colors.line, line, Colors.Normal)
194 else:
194 else:
195 num = '%*s' % (numbers_width,i)
195 num = '%*s' % (numbers_width,i)
196 line = '%s%s%s %s' %(Colors.lineno, num,
196 line = '%s%s%s %s' %(Colors.lineno, num,
197 Colors.Normal, line)
197 Colors.Normal, line)
198
198
199 res.append(line)
199 res.append(line)
200 if lvals and i == lnum:
200 if lvals and i == lnum:
201 res.append(lvals + '\n')
201 res.append(lvals + '\n')
202 i = i + 1
202 i = i + 1
203 return res
203 return res
204
204
205
205
206 #---------------------------------------------------------------------------
206 #---------------------------------------------------------------------------
207 # Module classes
207 # Module classes
208 class TBTools:
208 class TBTools:
209 """Basic tools used by all traceback printer classes."""
209 """Basic tools used by all traceback printer classes."""
210
210
211 def __init__(self,color_scheme = 'NoColor',call_pdb=False):
211 def __init__(self,color_scheme = 'NoColor',call_pdb=False):
212 # Whether to call the interactive pdb debugger after printing
212 # Whether to call the interactive pdb debugger after printing
213 # tracebacks or not
213 # tracebacks or not
214 self.call_pdb = call_pdb
214 self.call_pdb = call_pdb
215
215
216 # Create color table
216 # Create color table
217 self.color_scheme_table = ExceptionColors
217 self.color_scheme_table = ExceptionColors
218
218
219 self.set_colors(color_scheme)
219 self.set_colors(color_scheme)
220 self.old_scheme = color_scheme # save initial value for toggles
220 self.old_scheme = color_scheme # save initial value for toggles
221
221
222 if call_pdb:
222 if call_pdb:
223 self.pdb = Debugger.Pdb(self.color_scheme_table.active_scheme_name)
223 self.pdb = Debugger.Pdb(self.color_scheme_table.active_scheme_name)
224 else:
224 else:
225 self.pdb = None
225 self.pdb = None
226
226
227 def set_colors(self,*args,**kw):
227 def set_colors(self,*args,**kw):
228 """Shorthand access to the color table scheme selector method."""
228 """Shorthand access to the color table scheme selector method."""
229
229
230 # Set own color table
230 # Set own color table
231 self.color_scheme_table.set_active_scheme(*args,**kw)
231 self.color_scheme_table.set_active_scheme(*args,**kw)
232 # for convenience, set Colors to the active scheme
232 # for convenience, set Colors to the active scheme
233 self.Colors = self.color_scheme_table.active_colors
233 self.Colors = self.color_scheme_table.active_colors
234 # Also set colors of debugger
234 # Also set colors of debugger
235 if hasattr(self,'pdb') and self.pdb is not None:
235 if hasattr(self,'pdb') and self.pdb is not None:
236 self.pdb.set_colors(*args,**kw)
236 self.pdb.set_colors(*args,**kw)
237
237
238 def color_toggle(self):
238 def color_toggle(self):
239 """Toggle between the currently active color scheme and NoColor."""
239 """Toggle between the currently active color scheme and NoColor."""
240
240
241 if self.color_scheme_table.active_scheme_name == 'NoColor':
241 if self.color_scheme_table.active_scheme_name == 'NoColor':
242 self.color_scheme_table.set_active_scheme(self.old_scheme)
242 self.color_scheme_table.set_active_scheme(self.old_scheme)
243 self.Colors = self.color_scheme_table.active_colors
243 self.Colors = self.color_scheme_table.active_colors
244 else:
244 else:
245 self.old_scheme = self.color_scheme_table.active_scheme_name
245 self.old_scheme = self.color_scheme_table.active_scheme_name
246 self.color_scheme_table.set_active_scheme('NoColor')
246 self.color_scheme_table.set_active_scheme('NoColor')
247 self.Colors = self.color_scheme_table.active_colors
247 self.Colors = self.color_scheme_table.active_colors
248
248
249 #---------------------------------------------------------------------------
249 #---------------------------------------------------------------------------
250 class ListTB(TBTools):
250 class ListTB(TBTools):
251 """Print traceback information from a traceback list, with optional color.
251 """Print traceback information from a traceback list, with optional color.
252
252
253 Calling: requires 3 arguments:
253 Calling: requires 3 arguments:
254 (etype, evalue, elist)
254 (etype, evalue, elist)
255 as would be obtained by:
255 as would be obtained by:
256 etype, evalue, tb = sys.exc_info()
256 etype, evalue, tb = sys.exc_info()
257 if tb:
257 if tb:
258 elist = traceback.extract_tb(tb)
258 elist = traceback.extract_tb(tb)
259 else:
259 else:
260 elist = None
260 elist = None
261
261
262 It can thus be used by programs which need to process the traceback before
262 It can thus be used by programs which need to process the traceback before
263 printing (such as console replacements based on the code module from the
263 printing (such as console replacements based on the code module from the
264 standard library).
264 standard library).
265
265
266 Because they are meant to be called without a full traceback (only a
266 Because they are meant to be called without a full traceback (only a
267 list), instances of this class can't call the interactive pdb debugger."""
267 list), instances of this class can't call the interactive pdb debugger."""
268
268
269 def __init__(self,color_scheme = 'NoColor'):
269 def __init__(self,color_scheme = 'NoColor'):
270 TBTools.__init__(self,color_scheme = color_scheme,call_pdb=0)
270 TBTools.__init__(self,color_scheme = color_scheme,call_pdb=0)
271
271
272 def __call__(self, etype, value, elist):
272 def __call__(self, etype, value, elist):
273 Term.cout.flush()
273 Term.cout.flush()
274 Term.cerr.flush()
274 Term.cerr.flush()
275 print >> Term.cerr, self.text(etype,value,elist)
275 print >> Term.cerr, self.text(etype,value,elist)
276
276
277 def text(self,etype, value, elist,context=5):
277 def text(self,etype, value, elist,context=5):
278 """Return a color formatted string with the traceback info."""
278 """Return a color formatted string with the traceback info."""
279
279
280 Colors = self.Colors
280 Colors = self.Colors
281 out_string = ['%s%s%s\n' % (Colors.topline,'-'*60,Colors.Normal)]
281 out_string = ['%s%s%s\n' % (Colors.topline,'-'*60,Colors.Normal)]
282 if elist:
282 if elist:
283 out_string.append('Traceback %s(most recent call last)%s:' % \
283 out_string.append('Traceback %s(most recent call last)%s:' % \
284 (Colors.normalEm, Colors.Normal) + '\n')
284 (Colors.normalEm, Colors.Normal) + '\n')
285 out_string.extend(self._format_list(elist))
285 out_string.extend(self._format_list(elist))
286 lines = self._format_exception_only(etype, value)
286 lines = self._format_exception_only(etype, value)
287 for line in lines[:-1]:
287 for line in lines[:-1]:
288 out_string.append(" "+line)
288 out_string.append(" "+line)
289 out_string.append(lines[-1])
289 out_string.append(lines[-1])
290 return ''.join(out_string)
290 return ''.join(out_string)
291
291
292 def _format_list(self, extracted_list):
292 def _format_list(self, extracted_list):
293 """Format a list of traceback entry tuples for printing.
293 """Format a list of traceback entry tuples for printing.
294
294
295 Given a list of tuples as returned by extract_tb() or
295 Given a list of tuples as returned by extract_tb() or
296 extract_stack(), return a list of strings ready for printing.
296 extract_stack(), return a list of strings ready for printing.
297 Each string in the resulting list corresponds to the item with the
297 Each string in the resulting list corresponds to the item with the
298 same index in the argument list. Each string ends in a newline;
298 same index in the argument list. Each string ends in a newline;
299 the strings may contain internal newlines as well, for those items
299 the strings may contain internal newlines as well, for those items
300 whose source text line is not None.
300 whose source text line is not None.
301
301
302 Lifted almost verbatim from traceback.py
302 Lifted almost verbatim from traceback.py
303 """
303 """
304
304
305 Colors = self.Colors
305 Colors = self.Colors
306 list = []
306 list = []
307 for filename, lineno, name, line in extracted_list[:-1]:
307 for filename, lineno, name, line in extracted_list[:-1]:
308 item = ' File %s"%s"%s, line %s%d%s, in %s%s%s\n' % \
308 item = ' File %s"%s"%s, line %s%d%s, in %s%s%s\n' % \
309 (Colors.filename, filename, Colors.Normal,
309 (Colors.filename, filename, Colors.Normal,
310 Colors.lineno, lineno, Colors.Normal,
310 Colors.lineno, lineno, Colors.Normal,
311 Colors.name, name, Colors.Normal)
311 Colors.name, name, Colors.Normal)
312 if line:
312 if line:
313 item = item + ' %s\n' % line.strip()
313 item = item + ' %s\n' % line.strip()
314 list.append(item)
314 list.append(item)
315 # Emphasize the last entry
315 # Emphasize the last entry
316 filename, lineno, name, line = extracted_list[-1]
316 filename, lineno, name, line = extracted_list[-1]
317 item = '%s File %s"%s"%s, line %s%d%s, in %s%s%s%s\n' % \
317 item = '%s File %s"%s"%s, line %s%d%s, in %s%s%s%s\n' % \
318 (Colors.normalEm,
318 (Colors.normalEm,
319 Colors.filenameEm, filename, Colors.normalEm,
319 Colors.filenameEm, filename, Colors.normalEm,
320 Colors.linenoEm, lineno, Colors.normalEm,
320 Colors.linenoEm, lineno, Colors.normalEm,
321 Colors.nameEm, name, Colors.normalEm,
321 Colors.nameEm, name, Colors.normalEm,
322 Colors.Normal)
322 Colors.Normal)
323 if line:
323 if line:
324 item = item + '%s %s%s\n' % (Colors.line, line.strip(),
324 item = item + '%s %s%s\n' % (Colors.line, line.strip(),
325 Colors.Normal)
325 Colors.Normal)
326 list.append(item)
326 list.append(item)
327 return list
327 return list
328
328
329 def _format_exception_only(self, etype, value):
329 def _format_exception_only(self, etype, value):
330 """Format the exception part of a traceback.
330 """Format the exception part of a traceback.
331
331
332 The arguments are the exception type and value such as given by
332 The arguments are the exception type and value such as given by
333 sys.exc_info()[:2]. The return value is a list of strings, each ending
333 sys.exc_info()[:2]. The return value is a list of strings, each ending
334 in a newline. Normally, the list contains a single string; however,
334 in a newline. Normally, the list contains a single string; however,
335 for SyntaxError exceptions, it contains several lines that (when
335 for SyntaxError exceptions, it contains several lines that (when
336 printed) display detailed information about where the syntax error
336 printed) display detailed information about where the syntax error
337 occurred. The message indicating which exception occurred is the
337 occurred. The message indicating which exception occurred is the
338 always last string in the list.
338 always last string in the list.
339
339
340 Also lifted nearly verbatim from traceback.py
340 Also lifted nearly verbatim from traceback.py
341 """
341 """
342
342
343 Colors = self.Colors
343 Colors = self.Colors
344 list = []
344 list = []
345 if type(etype) == types.ClassType:
345 try:
346 stype = Colors.excName + etype.__name__ + Colors.Normal
346 stype = Colors.excName + etype.__name__ + Colors.Normal
347 else:
347 except AttributeError:
348 stype = etype # String exceptions don't get special coloring
348 stype = etype # String exceptions don't get special coloring
349 if value is None:
349 if value is None:
350 list.append( str(stype) + '\n')
350 list.append( str(stype) + '\n')
351 else:
351 else:
352 if etype is SyntaxError:
352 if etype is SyntaxError:
353 try:
353 try:
354 msg, (filename, lineno, offset, line) = value
354 msg, (filename, lineno, offset, line) = value
355 except:
355 except:
356 pass
356 pass
357 else:
357 else:
358 #print 'filename is',filename # dbg
358 #print 'filename is',filename # dbg
359 if not filename: filename = "<string>"
359 if not filename: filename = "<string>"
360 list.append('%s File %s"%s"%s, line %s%d%s\n' % \
360 list.append('%s File %s"%s"%s, line %s%d%s\n' % \
361 (Colors.normalEm,
361 (Colors.normalEm,
362 Colors.filenameEm, filename, Colors.normalEm,
362 Colors.filenameEm, filename, Colors.normalEm,
363 Colors.linenoEm, lineno, Colors.Normal ))
363 Colors.linenoEm, lineno, Colors.Normal ))
364 if line is not None:
364 if line is not None:
365 i = 0
365 i = 0
366 while i < len(line) and line[i].isspace():
366 while i < len(line) and line[i].isspace():
367 i = i+1
367 i = i+1
368 list.append('%s %s%s\n' % (Colors.line,
368 list.append('%s %s%s\n' % (Colors.line,
369 line.strip(),
369 line.strip(),
370 Colors.Normal))
370 Colors.Normal))
371 if offset is not None:
371 if offset is not None:
372 s = ' '
372 s = ' '
373 for c in line[i:offset-1]:
373 for c in line[i:offset-1]:
374 if c.isspace():
374 if c.isspace():
375 s = s + c
375 s = s + c
376 else:
376 else:
377 s = s + ' '
377 s = s + ' '
378 list.append('%s%s^%s\n' % (Colors.caret, s,
378 list.append('%s%s^%s\n' % (Colors.caret, s,
379 Colors.Normal) )
379 Colors.Normal) )
380 value = msg
380 value = msg
381 s = self._some_str(value)
381 s = self._some_str(value)
382 if s:
382 if s:
383 list.append('%s%s:%s %s\n' % (str(stype), Colors.excName,
383 list.append('%s%s:%s %s\n' % (str(stype), Colors.excName,
384 Colors.Normal, s))
384 Colors.Normal, s))
385 else:
385 else:
386 list.append('%s\n' % str(stype))
386 list.append('%s\n' % str(stype))
387 return list
387 return list
388
388
389 def _some_str(self, value):
389 def _some_str(self, value):
390 # Lifted from traceback.py
390 # Lifted from traceback.py
391 try:
391 try:
392 return str(value)
392 return str(value)
393 except:
393 except:
394 return '<unprintable %s object>' % type(value).__name__
394 return '<unprintable %s object>' % type(value).__name__
395
395
396 #----------------------------------------------------------------------------
396 #----------------------------------------------------------------------------
397 class VerboseTB(TBTools):
397 class VerboseTB(TBTools):
398 """A port of Ka-Ping Yee's cgitb.py module that outputs color text instead
398 """A port of Ka-Ping Yee's cgitb.py module that outputs color text instead
399 of HTML. Requires inspect and pydoc. Crazy, man.
399 of HTML. Requires inspect and pydoc. Crazy, man.
400
400
401 Modified version which optionally strips the topmost entries from the
401 Modified version which optionally strips the topmost entries from the
402 traceback, to be used with alternate interpreters (because their own code
402 traceback, to be used with alternate interpreters (because their own code
403 would appear in the traceback)."""
403 would appear in the traceback)."""
404
404
405 def __init__(self,color_scheme = 'Linux',tb_offset=0,long_header=0,
405 def __init__(self,color_scheme = 'Linux',tb_offset=0,long_header=0,
406 call_pdb = 0, include_vars=1):
406 call_pdb = 0, include_vars=1):
407 """Specify traceback offset, headers and color scheme.
407 """Specify traceback offset, headers and color scheme.
408
408
409 Define how many frames to drop from the tracebacks. Calling it with
409 Define how many frames to drop from the tracebacks. Calling it with
410 tb_offset=1 allows use of this handler in interpreters which will have
410 tb_offset=1 allows use of this handler in interpreters which will have
411 their own code at the top of the traceback (VerboseTB will first
411 their own code at the top of the traceback (VerboseTB will first
412 remove that frame before printing the traceback info)."""
412 remove that frame before printing the traceback info)."""
413 TBTools.__init__(self,color_scheme=color_scheme,call_pdb=call_pdb)
413 TBTools.__init__(self,color_scheme=color_scheme,call_pdb=call_pdb)
414 self.tb_offset = tb_offset
414 self.tb_offset = tb_offset
415 self.long_header = long_header
415 self.long_header = long_header
416 self.include_vars = include_vars
416 self.include_vars = include_vars
417
417
418 def text(self, etype, evalue, etb, context=5):
418 def text(self, etype, evalue, etb, context=5):
419 """Return a nice text document describing the traceback."""
419 """Return a nice text document describing the traceback."""
420
420
421 # some locals
421 # some locals
422 try:
423 etype = etype.__name__
424 except AttributeError:
425 pass
422 Colors = self.Colors # just a shorthand + quicker name lookup
426 Colors = self.Colors # just a shorthand + quicker name lookup
423 ColorsNormal = Colors.Normal # used a lot
427 ColorsNormal = Colors.Normal # used a lot
424 col_scheme = self.color_scheme_table.active_scheme_name
428 col_scheme = self.color_scheme_table.active_scheme_name
425 indent = ' '*INDENT_SIZE
429 indent = ' '*INDENT_SIZE
426 exc = '%s%s%s' % (Colors.excName, str(etype), ColorsNormal)
427 em_normal = '%s\n%s%s' % (Colors.valEm, indent,ColorsNormal)
430 em_normal = '%s\n%s%s' % (Colors.valEm, indent,ColorsNormal)
428 undefined = '%sundefined%s' % (Colors.em, ColorsNormal)
431 undefined = '%sundefined%s' % (Colors.em, ColorsNormal)
432 exc = '%s%s%s' % (Colors.excName,etype,ColorsNormal)
429
433
430 # some internal-use functions
434 # some internal-use functions
431 def text_repr(value):
435 def text_repr(value):
432 """Hopefully pretty robust repr equivalent."""
436 """Hopefully pretty robust repr equivalent."""
433 # this is pretty horrible but should always return *something*
437 # this is pretty horrible but should always return *something*
434 try:
438 try:
435 return pydoc.text.repr(value)
439 return pydoc.text.repr(value)
436 except KeyboardInterrupt:
440 except KeyboardInterrupt:
437 raise
441 raise
438 except:
442 except:
439 try:
443 try:
440 return repr(value)
444 return repr(value)
441 except KeyboardInterrupt:
445 except KeyboardInterrupt:
442 raise
446 raise
443 except:
447 except:
444 try:
448 try:
445 # all still in an except block so we catch
449 # all still in an except block so we catch
446 # getattr raising
450 # getattr raising
447 name = getattr(value, '__name__', None)
451 name = getattr(value, '__name__', None)
448 if name:
452 if name:
449 # ick, recursion
453 # ick, recursion
450 return text_repr(name)
454 return text_repr(name)
451 klass = getattr(value, '__class__', None)
455 klass = getattr(value, '__class__', None)
452 if klass:
456 if klass:
453 return '%s instance' % text_repr(klass)
457 return '%s instance' % text_repr(klass)
454 except KeyboardInterrupt:
458 except KeyboardInterrupt:
455 raise
459 raise
456 except:
460 except:
457 return 'UNRECOVERABLE REPR FAILURE'
461 return 'UNRECOVERABLE REPR FAILURE'
458 def eqrepr(value, repr=text_repr): return '=%s' % repr(value)
462 def eqrepr(value, repr=text_repr): return '=%s' % repr(value)
459 def nullrepr(value, repr=text_repr): return ''
463 def nullrepr(value, repr=text_repr): return ''
460
464
461 # meat of the code begins
465 # meat of the code begins
462 if type(etype) is types.ClassType:
466 try:
463 etype = etype.__name__
467 etype = etype.__name__
468 except AttributeError:
469 pass
464
470
465 if self.long_header:
471 if self.long_header:
466 # Header with the exception type, python version, and date
472 # Header with the exception type, python version, and date
467 pyver = 'Python ' + string.split(sys.version)[0] + ': ' + sys.executable
473 pyver = 'Python ' + string.split(sys.version)[0] + ': ' + sys.executable
468 date = time.ctime(time.time())
474 date = time.ctime(time.time())
469
475
470 head = '%s%s%s\n%s%s%s\n%s' % (Colors.topline, '-'*75, ColorsNormal,
476 head = '%s%s%s\n%s%s%s\n%s' % (Colors.topline, '-'*75, ColorsNormal,
471 exc, ' '*(75-len(str(etype))-len(pyver)),
477 exc, ' '*(75-len(str(etype))-len(pyver)),
472 pyver, string.rjust(date, 75) )
478 pyver, string.rjust(date, 75) )
473 head += "\nA problem occured executing Python code. Here is the sequence of function"\
479 head += "\nA problem occured executing Python code. Here is the sequence of function"\
474 "\ncalls leading up to the error, with the most recent (innermost) call last."
480 "\ncalls leading up to the error, with the most recent (innermost) call last."
475 else:
481 else:
476 # Simplified header
482 # Simplified header
477 head = '%s%s%s\n%s%s' % (Colors.topline, '-'*75, ColorsNormal,exc,
483 head = '%s%s%s\n%s%s' % (Colors.topline, '-'*75, ColorsNormal,exc,
478 string.rjust('Traceback (most recent call last)',
484 string.rjust('Traceback (most recent call last)',
479 75 - len(str(etype)) ) )
485 75 - len(str(etype)) ) )
480 frames = []
486 frames = []
481 # Flush cache before calling inspect. This helps alleviate some of the
487 # Flush cache before calling inspect. This helps alleviate some of the
482 # problems with python 2.3's inspect.py.
488 # problems with python 2.3's inspect.py.
483 linecache.checkcache()
489 linecache.checkcache()
484 # Drop topmost frames if requested
490 # Drop topmost frames if requested
485 try:
491 try:
486 # Try the default getinnerframes and Alex's: Alex's fixes some
492 # Try the default getinnerframes and Alex's: Alex's fixes some
487 # problems, but it generates empty tracebacks for console errors
493 # problems, but it generates empty tracebacks for console errors
488 # (5 blanks lines) where none should be returned.
494 # (5 blanks lines) where none should be returned.
489 #records = inspect.getinnerframes(etb, context)[self.tb_offset:]
495 #records = inspect.getinnerframes(etb, context)[self.tb_offset:]
490 #print 'python records:', records # dbg
496 #print 'python records:', records # dbg
491 records = _fixed_getinnerframes(etb, context,self.tb_offset)
497 records = _fixed_getinnerframes(etb, context,self.tb_offset)
492 #print 'alex records:', records # dbg
498 #print 'alex records:', records # dbg
493 except:
499 except:
494
500
495 # FIXME: I've been getting many crash reports from python 2.3
501 # FIXME: I've been getting many crash reports from python 2.3
496 # users, traceable to inspect.py. If I can find a small test-case
502 # users, traceable to inspect.py. If I can find a small test-case
497 # to reproduce this, I should either write a better workaround or
503 # to reproduce this, I should either write a better workaround or
498 # file a bug report against inspect (if that's the real problem).
504 # file a bug report against inspect (if that's the real problem).
499 # So far, I haven't been able to find an isolated example to
505 # So far, I haven't been able to find an isolated example to
500 # reproduce the problem.
506 # reproduce the problem.
501 inspect_error()
507 inspect_error()
502 traceback.print_exc(file=Term.cerr)
508 traceback.print_exc(file=Term.cerr)
503 info('\nUnfortunately, your original traceback can not be constructed.\n')
509 info('\nUnfortunately, your original traceback can not be constructed.\n')
504 return ''
510 return ''
505
511
506 # build some color string templates outside these nested loops
512 # build some color string templates outside these nested loops
507 tpl_link = '%s%%s%s' % (Colors.filenameEm,ColorsNormal)
513 tpl_link = '%s%%s%s' % (Colors.filenameEm,ColorsNormal)
508 tpl_call = 'in %s%%s%s%%s%s' % (Colors.vName, Colors.valEm,
514 tpl_call = 'in %s%%s%s%%s%s' % (Colors.vName, Colors.valEm,
509 ColorsNormal)
515 ColorsNormal)
510 tpl_call_fail = 'in %s%%s%s(***failed resolving arguments***)%s' % \
516 tpl_call_fail = 'in %s%%s%s(***failed resolving arguments***)%s' % \
511 (Colors.vName, Colors.valEm, ColorsNormal)
517 (Colors.vName, Colors.valEm, ColorsNormal)
512 tpl_local_var = '%s%%s%s' % (Colors.vName, ColorsNormal)
518 tpl_local_var = '%s%%s%s' % (Colors.vName, ColorsNormal)
513 tpl_global_var = '%sglobal%s %s%%s%s' % (Colors.em, ColorsNormal,
519 tpl_global_var = '%sglobal%s %s%%s%s' % (Colors.em, ColorsNormal,
514 Colors.vName, ColorsNormal)
520 Colors.vName, ColorsNormal)
515 tpl_name_val = '%%s %s= %%s%s' % (Colors.valEm, ColorsNormal)
521 tpl_name_val = '%%s %s= %%s%s' % (Colors.valEm, ColorsNormal)
516 tpl_line = '%s%%s%s %%s' % (Colors.lineno, ColorsNormal)
522 tpl_line = '%s%%s%s %%s' % (Colors.lineno, ColorsNormal)
517 tpl_line_em = '%s%%s%s %%s%s' % (Colors.linenoEm,Colors.line,
523 tpl_line_em = '%s%%s%s %%s%s' % (Colors.linenoEm,Colors.line,
518 ColorsNormal)
524 ColorsNormal)
519
525
520 # now, loop over all records printing context and info
526 # now, loop over all records printing context and info
521 abspath = os.path.abspath
527 abspath = os.path.abspath
522 for frame, file, lnum, func, lines, index in records:
528 for frame, file, lnum, func, lines, index in records:
523 #print '*** record:',file,lnum,func,lines,index # dbg
529 #print '*** record:',file,lnum,func,lines,index # dbg
524 try:
530 try:
525 file = file and abspath(file) or '?'
531 file = file and abspath(file) or '?'
526 except OSError:
532 except OSError:
527 # if file is '<console>' or something not in the filesystem,
533 # if file is '<console>' or something not in the filesystem,
528 # the abspath call will throw an OSError. Just ignore it and
534 # the abspath call will throw an OSError. Just ignore it and
529 # keep the original file string.
535 # keep the original file string.
530 pass
536 pass
531 link = tpl_link % file
537 link = tpl_link % file
532 try:
538 try:
533 args, varargs, varkw, locals = inspect.getargvalues(frame)
539 args, varargs, varkw, locals = inspect.getargvalues(frame)
534 except:
540 except:
535 # This can happen due to a bug in python2.3. We should be
541 # This can happen due to a bug in python2.3. We should be
536 # able to remove this try/except when 2.4 becomes a
542 # able to remove this try/except when 2.4 becomes a
537 # requirement. Bug details at http://python.org/sf/1005466
543 # requirement. Bug details at http://python.org/sf/1005466
538 inspect_error()
544 inspect_error()
539 traceback.print_exc(file=Term.cerr)
545 traceback.print_exc(file=Term.cerr)
540 info("\nIPython's exception reporting continues...\n")
546 info("\nIPython's exception reporting continues...\n")
541
547
542 if func == '?':
548 if func == '?':
543 call = ''
549 call = ''
544 else:
550 else:
545 # Decide whether to include variable details or not
551 # Decide whether to include variable details or not
546 var_repr = self.include_vars and eqrepr or nullrepr
552 var_repr = self.include_vars and eqrepr or nullrepr
547 try:
553 try:
548 call = tpl_call % (func,inspect.formatargvalues(args,
554 call = tpl_call % (func,inspect.formatargvalues(args,
549 varargs, varkw,
555 varargs, varkw,
550 locals,formatvalue=var_repr))
556 locals,formatvalue=var_repr))
551 except KeyError:
557 except KeyError:
552 # Very odd crash from inspect.formatargvalues(). The
558 # Very odd crash from inspect.formatargvalues(). The
553 # scenario under which it appeared was a call to
559 # scenario under which it appeared was a call to
554 # view(array,scale) in NumTut.view.view(), where scale had
560 # view(array,scale) in NumTut.view.view(), where scale had
555 # been defined as a scalar (it should be a tuple). Somehow
561 # been defined as a scalar (it should be a tuple). Somehow
556 # inspect messes up resolving the argument list of view()
562 # inspect messes up resolving the argument list of view()
557 # and barfs out. At some point I should dig into this one
563 # and barfs out. At some point I should dig into this one
558 # and file a bug report about it.
564 # and file a bug report about it.
559 inspect_error()
565 inspect_error()
560 traceback.print_exc(file=Term.cerr)
566 traceback.print_exc(file=Term.cerr)
561 info("\nIPython's exception reporting continues...\n")
567 info("\nIPython's exception reporting continues...\n")
562 call = tpl_call_fail % func
568 call = tpl_call_fail % func
563
569
564 # Initialize a list of names on the current line, which the
570 # Initialize a list of names on the current line, which the
565 # tokenizer below will populate.
571 # tokenizer below will populate.
566 names = []
572 names = []
567
573
568 def tokeneater(token_type, token, start, end, line):
574 def tokeneater(token_type, token, start, end, line):
569 """Stateful tokeneater which builds dotted names.
575 """Stateful tokeneater which builds dotted names.
570
576
571 The list of names it appends to (from the enclosing scope) can
577 The list of names it appends to (from the enclosing scope) can
572 contain repeated composite names. This is unavoidable, since
578 contain repeated composite names. This is unavoidable, since
573 there is no way to disambguate partial dotted structures until
579 there is no way to disambguate partial dotted structures until
574 the full list is known. The caller is responsible for pruning
580 the full list is known. The caller is responsible for pruning
575 the final list of duplicates before using it."""
581 the final list of duplicates before using it."""
576
582
577 # build composite names
583 # build composite names
578 if token == '.':
584 if token == '.':
579 try:
585 try:
580 names[-1] += '.'
586 names[-1] += '.'
581 # store state so the next token is added for x.y.z names
587 # store state so the next token is added for x.y.z names
582 tokeneater.name_cont = True
588 tokeneater.name_cont = True
583 return
589 return
584 except IndexError:
590 except IndexError:
585 pass
591 pass
586 if token_type == tokenize.NAME and token not in keyword.kwlist:
592 if token_type == tokenize.NAME and token not in keyword.kwlist:
587 if tokeneater.name_cont:
593 if tokeneater.name_cont:
588 # Dotted names
594 # Dotted names
589 names[-1] += token
595 names[-1] += token
590 tokeneater.name_cont = False
596 tokeneater.name_cont = False
591 else:
597 else:
592 # Regular new names. We append everything, the caller
598 # Regular new names. We append everything, the caller
593 # will be responsible for pruning the list later. It's
599 # will be responsible for pruning the list later. It's
594 # very tricky to try to prune as we go, b/c composite
600 # very tricky to try to prune as we go, b/c composite
595 # names can fool us. The pruning at the end is easy
601 # names can fool us. The pruning at the end is easy
596 # to do (or the caller can print a list with repeated
602 # to do (or the caller can print a list with repeated
597 # names if so desired.
603 # names if so desired.
598 names.append(token)
604 names.append(token)
599 elif token_type == tokenize.NEWLINE:
605 elif token_type == tokenize.NEWLINE:
600 raise IndexError
606 raise IndexError
601 # we need to store a bit of state in the tokenizer to build
607 # we need to store a bit of state in the tokenizer to build
602 # dotted names
608 # dotted names
603 tokeneater.name_cont = False
609 tokeneater.name_cont = False
604
610
605 def linereader(file=file, lnum=[lnum], getline=linecache.getline):
611 def linereader(file=file, lnum=[lnum], getline=linecache.getline):
606 line = getline(file, lnum[0])
612 line = getline(file, lnum[0])
607 lnum[0] += 1
613 lnum[0] += 1
608 return line
614 return line
609
615
610 # Build the list of names on this line of code where the exception
616 # Build the list of names on this line of code where the exception
611 # occurred.
617 # occurred.
612 try:
618 try:
613 # This builds the names list in-place by capturing it from the
619 # This builds the names list in-place by capturing it from the
614 # enclosing scope.
620 # enclosing scope.
615 tokenize.tokenize(linereader, tokeneater)
621 tokenize.tokenize(linereader, tokeneater)
616 except IndexError:
622 except IndexError:
617 # signals exit of tokenizer
623 # signals exit of tokenizer
618 pass
624 pass
619 except tokenize.TokenError,msg:
625 except tokenize.TokenError,msg:
620 _m = ("An unexpected error occurred while tokenizing input\n"
626 _m = ("An unexpected error occurred while tokenizing input\n"
621 "The following traceback may be corrupted or invalid\n"
627 "The following traceback may be corrupted or invalid\n"
622 "The error message is: %s\n" % msg)
628 "The error message is: %s\n" % msg)
623 error(_m)
629 error(_m)
624
630
625 # prune names list of duplicates, but keep the right order
631 # prune names list of duplicates, but keep the right order
626 unique_names = uniq_stable(names)
632 unique_names = uniq_stable(names)
627
633
628 # Start loop over vars
634 # Start loop over vars
629 lvals = []
635 lvals = []
630 if self.include_vars:
636 if self.include_vars:
631 for name_full in unique_names:
637 for name_full in unique_names:
632 name_base = name_full.split('.',1)[0]
638 name_base = name_full.split('.',1)[0]
633 if name_base in frame.f_code.co_varnames:
639 if name_base in frame.f_code.co_varnames:
634 if locals.has_key(name_base):
640 if locals.has_key(name_base):
635 try:
641 try:
636 value = repr(eval(name_full,locals))
642 value = repr(eval(name_full,locals))
637 except:
643 except:
638 value = undefined
644 value = undefined
639 else:
645 else:
640 value = undefined
646 value = undefined
641 name = tpl_local_var % name_full
647 name = tpl_local_var % name_full
642 else:
648 else:
643 if frame.f_globals.has_key(name_base):
649 if frame.f_globals.has_key(name_base):
644 try:
650 try:
645 value = repr(eval(name_full,frame.f_globals))
651 value = repr(eval(name_full,frame.f_globals))
646 except:
652 except:
647 value = undefined
653 value = undefined
648 else:
654 else:
649 value = undefined
655 value = undefined
650 name = tpl_global_var % name_full
656 name = tpl_global_var % name_full
651 lvals.append(tpl_name_val % (name,value))
657 lvals.append(tpl_name_val % (name,value))
652 if lvals:
658 if lvals:
653 lvals = '%s%s' % (indent,em_normal.join(lvals))
659 lvals = '%s%s' % (indent,em_normal.join(lvals))
654 else:
660 else:
655 lvals = ''
661 lvals = ''
656
662
657 level = '%s %s\n' % (link,call)
663 level = '%s %s\n' % (link,call)
658
664
659 if index is None:
665 if index is None:
660 frames.append(level)
666 frames.append(level)
661 else:
667 else:
662 frames.append('%s%s' % (level,''.join(
668 frames.append('%s%s' % (level,''.join(
663 _formatTracebackLines(lnum,index,lines,Colors,lvals,
669 _formatTracebackLines(lnum,index,lines,Colors,lvals,
664 col_scheme))))
670 col_scheme))))
665
671
666 # Get (safely) a string form of the exception info
672 # Get (safely) a string form of the exception info
667 try:
673 try:
668 etype_str,evalue_str = map(str,(etype,evalue))
674 etype_str,evalue_str = map(str,(etype,evalue))
669 except:
675 except:
670 # User exception is improperly defined.
676 # User exception is improperly defined.
671 etype,evalue = str,sys.exc_info()[:2]
677 etype,evalue = str,sys.exc_info()[:2]
672 etype_str,evalue_str = map(str,(etype,evalue))
678 etype_str,evalue_str = map(str,(etype,evalue))
673 # ... and format it
679 # ... and format it
674 exception = ['%s%s%s: %s' % (Colors.excName, etype_str,
680 exception = ['%s%s%s: %s' % (Colors.excName, etype_str,
675 ColorsNormal, evalue_str)]
681 ColorsNormal, evalue_str)]
676 if type(evalue) is types.InstanceType:
682 if type(evalue) is types.InstanceType:
677 try:
683 try:
678 names = [w for w in dir(evalue) if isinstance(w, basestring)]
684 names = [w for w in dir(evalue) if isinstance(w, basestring)]
679 except:
685 except:
680 # Every now and then, an object with funny inernals blows up
686 # Every now and then, an object with funny inernals blows up
681 # when dir() is called on it. We do the best we can to report
687 # when dir() is called on it. We do the best we can to report
682 # the problem and continue
688 # the problem and continue
683 _m = '%sException reporting error (object with broken dir())%s:'
689 _m = '%sException reporting error (object with broken dir())%s:'
684 exception.append(_m % (Colors.excName,ColorsNormal))
690 exception.append(_m % (Colors.excName,ColorsNormal))
685 etype_str,evalue_str = map(str,sys.exc_info()[:2])
691 etype_str,evalue_str = map(str,sys.exc_info()[:2])
686 exception.append('%s%s%s: %s' % (Colors.excName,etype_str,
692 exception.append('%s%s%s: %s' % (Colors.excName,etype_str,
687 ColorsNormal, evalue_str))
693 ColorsNormal, evalue_str))
688 names = []
694 names = []
689 for name in names:
695 for name in names:
690 value = text_repr(getattr(evalue, name))
696 value = text_repr(getattr(evalue, name))
691 exception.append('\n%s%s = %s' % (indent, name, value))
697 exception.append('\n%s%s = %s' % (indent, name, value))
692 # return all our info assembled as a single string
698 # return all our info assembled as a single string
693 return '%s\n\n%s\n%s' % (head,'\n'.join(frames),''.join(exception[0]) )
699 return '%s\n\n%s\n%s' % (head,'\n'.join(frames),''.join(exception[0]) )
694
700
695 def debugger(self,force=False):
701 def debugger(self,force=False):
696 """Call up the pdb debugger if desired, always clean up the tb
702 """Call up the pdb debugger if desired, always clean up the tb
697 reference.
703 reference.
698
704
699 Keywords:
705 Keywords:
700
706
701 - force(False): by default, this routine checks the instance call_pdb
707 - force(False): by default, this routine checks the instance call_pdb
702 flag and does not actually invoke the debugger if the flag is false.
708 flag and does not actually invoke the debugger if the flag is false.
703 The 'force' option forces the debugger to activate even if the flag
709 The 'force' option forces the debugger to activate even if the flag
704 is false.
710 is false.
705
711
706 If the call_pdb flag is set, the pdb interactive debugger is
712 If the call_pdb flag is set, the pdb interactive debugger is
707 invoked. In all cases, the self.tb reference to the current traceback
713 invoked. In all cases, the self.tb reference to the current traceback
708 is deleted to prevent lingering references which hamper memory
714 is deleted to prevent lingering references which hamper memory
709 management.
715 management.
710
716
711 Note that each call to pdb() does an 'import readline', so if your app
717 Note that each call to pdb() does an 'import readline', so if your app
712 requires a special setup for the readline completers, you'll have to
718 requires a special setup for the readline completers, you'll have to
713 fix that by hand after invoking the exception handler."""
719 fix that by hand after invoking the exception handler."""
714
720
715 if force or self.call_pdb:
721 if force or self.call_pdb:
716 if self.pdb is None:
722 if self.pdb is None:
717 self.pdb = Debugger.Pdb(
723 self.pdb = Debugger.Pdb(
718 self.color_scheme_table.active_scheme_name)
724 self.color_scheme_table.active_scheme_name)
719 # the system displayhook may have changed, restore the original
725 # the system displayhook may have changed, restore the original
720 # for pdb
726 # for pdb
721 dhook = sys.displayhook
727 dhook = sys.displayhook
722 sys.displayhook = sys.__displayhook__
728 sys.displayhook = sys.__displayhook__
723 self.pdb.reset()
729 self.pdb.reset()
724 # Find the right frame so we don't pop up inside ipython itself
730 # Find the right frame so we don't pop up inside ipython itself
725 if hasattr(self,'tb'):
731 if hasattr(self,'tb'):
726 etb = self.tb
732 etb = self.tb
727 else:
733 else:
728 etb = self.tb = sys.last_traceback
734 etb = self.tb = sys.last_traceback
729 while self.tb.tb_next is not None:
735 while self.tb.tb_next is not None:
730 self.tb = self.tb.tb_next
736 self.tb = self.tb.tb_next
731 try:
737 try:
732 if etb and etb.tb_next:
738 if etb and etb.tb_next:
733 etb = etb.tb_next
739 etb = etb.tb_next
734 self.pdb.botframe = etb.tb_frame
740 self.pdb.botframe = etb.tb_frame
735 self.pdb.interaction(self.tb.tb_frame, self.tb)
741 self.pdb.interaction(self.tb.tb_frame, self.tb)
736 finally:
742 finally:
737 sys.displayhook = dhook
743 sys.displayhook = dhook
738
744
739 if hasattr(self,'tb'):
745 if hasattr(self,'tb'):
740 del self.tb
746 del self.tb
741
747
742 def handler(self, info=None):
748 def handler(self, info=None):
743 (etype, evalue, etb) = info or sys.exc_info()
749 (etype, evalue, etb) = info or sys.exc_info()
744 self.tb = etb
750 self.tb = etb
745 Term.cout.flush()
751 Term.cout.flush()
746 Term.cerr.flush()
752 Term.cerr.flush()
747 print >> Term.cerr, self.text(etype, evalue, etb)
753 print >> Term.cerr, self.text(etype, evalue, etb)
748
754
749 # Changed so an instance can just be called as VerboseTB_inst() and print
755 # Changed so an instance can just be called as VerboseTB_inst() and print
750 # out the right info on its own.
756 # out the right info on its own.
751 def __call__(self, etype=None, evalue=None, etb=None):
757 def __call__(self, etype=None, evalue=None, etb=None):
752 """This hook can replace sys.excepthook (for Python 2.1 or higher)."""
758 """This hook can replace sys.excepthook (for Python 2.1 or higher)."""
753 if etb is None:
759 if etb is None:
754 self.handler()
760 self.handler()
755 else:
761 else:
756 self.handler((etype, evalue, etb))
762 self.handler((etype, evalue, etb))
757 self.debugger()
763 self.debugger()
758
764
759 #----------------------------------------------------------------------------
765 #----------------------------------------------------------------------------
760 class FormattedTB(VerboseTB,ListTB):
766 class FormattedTB(VerboseTB,ListTB):
761 """Subclass ListTB but allow calling with a traceback.
767 """Subclass ListTB but allow calling with a traceback.
762
768
763 It can thus be used as a sys.excepthook for Python > 2.1.
769 It can thus be used as a sys.excepthook for Python > 2.1.
764
770
765 Also adds 'Context' and 'Verbose' modes, not available in ListTB.
771 Also adds 'Context' and 'Verbose' modes, not available in ListTB.
766
772
767 Allows a tb_offset to be specified. This is useful for situations where
773 Allows a tb_offset to be specified. This is useful for situations where
768 one needs to remove a number of topmost frames from the traceback (such as
774 one needs to remove a number of topmost frames from the traceback (such as
769 occurs with python programs that themselves execute other python code,
775 occurs with python programs that themselves execute other python code,
770 like Python shells). """
776 like Python shells). """
771
777
772 def __init__(self, mode = 'Plain', color_scheme='Linux',
778 def __init__(self, mode = 'Plain', color_scheme='Linux',
773 tb_offset = 0,long_header=0,call_pdb=0,include_vars=0):
779 tb_offset = 0,long_header=0,call_pdb=0,include_vars=0):
774
780
775 # NEVER change the order of this list. Put new modes at the end:
781 # NEVER change the order of this list. Put new modes at the end:
776 self.valid_modes = ['Plain','Context','Verbose']
782 self.valid_modes = ['Plain','Context','Verbose']
777 self.verbose_modes = self.valid_modes[1:3]
783 self.verbose_modes = self.valid_modes[1:3]
778
784
779 VerboseTB.__init__(self,color_scheme,tb_offset,long_header,
785 VerboseTB.__init__(self,color_scheme,tb_offset,long_header,
780 call_pdb=call_pdb,include_vars=include_vars)
786 call_pdb=call_pdb,include_vars=include_vars)
781 self.set_mode(mode)
787 self.set_mode(mode)
782
788
783 def _extract_tb(self,tb):
789 def _extract_tb(self,tb):
784 if tb:
790 if tb:
785 return traceback.extract_tb(tb)
791 return traceback.extract_tb(tb)
786 else:
792 else:
787 return None
793 return None
788
794
789 def text(self, etype, value, tb,context=5,mode=None):
795 def text(self, etype, value, tb,context=5,mode=None):
790 """Return formatted traceback.
796 """Return formatted traceback.
791
797
792 If the optional mode parameter is given, it overrides the current
798 If the optional mode parameter is given, it overrides the current
793 mode."""
799 mode."""
794
800
795 if mode is None:
801 if mode is None:
796 mode = self.mode
802 mode = self.mode
797 if mode in self.verbose_modes:
803 if mode in self.verbose_modes:
798 # verbose modes need a full traceback
804 # verbose modes need a full traceback
799 return VerboseTB.text(self,etype, value, tb,context=5)
805 return VerboseTB.text(self,etype, value, tb,context=5)
800 else:
806 else:
801 # We must check the source cache because otherwise we can print
807 # We must check the source cache because otherwise we can print
802 # out-of-date source code.
808 # out-of-date source code.
803 linecache.checkcache()
809 linecache.checkcache()
804 # Now we can extract and format the exception
810 # Now we can extract and format the exception
805 elist = self._extract_tb(tb)
811 elist = self._extract_tb(tb)
806 if len(elist) > self.tb_offset:
812 if len(elist) > self.tb_offset:
807 del elist[:self.tb_offset]
813 del elist[:self.tb_offset]
808 return ListTB.text(self,etype,value,elist)
814 return ListTB.text(self,etype,value,elist)
809
815
810 def set_mode(self,mode=None):
816 def set_mode(self,mode=None):
811 """Switch to the desired mode.
817 """Switch to the desired mode.
812
818
813 If mode is not specified, cycles through the available modes."""
819 If mode is not specified, cycles through the available modes."""
814
820
815 if not mode:
821 if not mode:
816 new_idx = ( self.valid_modes.index(self.mode) + 1 ) % \
822 new_idx = ( self.valid_modes.index(self.mode) + 1 ) % \
817 len(self.valid_modes)
823 len(self.valid_modes)
818 self.mode = self.valid_modes[new_idx]
824 self.mode = self.valid_modes[new_idx]
819 elif mode not in self.valid_modes:
825 elif mode not in self.valid_modes:
820 raise ValueError, 'Unrecognized mode in FormattedTB: <'+mode+'>\n'\
826 raise ValueError, 'Unrecognized mode in FormattedTB: <'+mode+'>\n'\
821 'Valid modes: '+str(self.valid_modes)
827 'Valid modes: '+str(self.valid_modes)
822 else:
828 else:
823 self.mode = mode
829 self.mode = mode
824 # include variable details only in 'Verbose' mode
830 # include variable details only in 'Verbose' mode
825 self.include_vars = (self.mode == self.valid_modes[2])
831 self.include_vars = (self.mode == self.valid_modes[2])
826
832
827 # some convenient shorcuts
833 # some convenient shorcuts
828 def plain(self):
834 def plain(self):
829 self.set_mode(self.valid_modes[0])
835 self.set_mode(self.valid_modes[0])
830
836
831 def context(self):
837 def context(self):
832 self.set_mode(self.valid_modes[1])
838 self.set_mode(self.valid_modes[1])
833
839
834 def verbose(self):
840 def verbose(self):
835 self.set_mode(self.valid_modes[2])
841 self.set_mode(self.valid_modes[2])
836
842
837 #----------------------------------------------------------------------------
843 #----------------------------------------------------------------------------
838 class AutoFormattedTB(FormattedTB):
844 class AutoFormattedTB(FormattedTB):
839 """A traceback printer which can be called on the fly.
845 """A traceback printer which can be called on the fly.
840
846
841 It will find out about exceptions by itself.
847 It will find out about exceptions by itself.
842
848
843 A brief example:
849 A brief example:
844
850
845 AutoTB = AutoFormattedTB(mode = 'Verbose',color_scheme='Linux')
851 AutoTB = AutoFormattedTB(mode = 'Verbose',color_scheme='Linux')
846 try:
852 try:
847 ...
853 ...
848 except:
854 except:
849 AutoTB() # or AutoTB(out=logfile) where logfile is an open file object
855 AutoTB() # or AutoTB(out=logfile) where logfile is an open file object
850 """
856 """
851 def __call__(self,etype=None,evalue=None,etb=None,
857 def __call__(self,etype=None,evalue=None,etb=None,
852 out=None,tb_offset=None):
858 out=None,tb_offset=None):
853 """Print out a formatted exception traceback.
859 """Print out a formatted exception traceback.
854
860
855 Optional arguments:
861 Optional arguments:
856 - out: an open file-like object to direct output to.
862 - out: an open file-like object to direct output to.
857
863
858 - tb_offset: the number of frames to skip over in the stack, on a
864 - tb_offset: the number of frames to skip over in the stack, on a
859 per-call basis (this overrides temporarily the instance's tb_offset
865 per-call basis (this overrides temporarily the instance's tb_offset
860 given at initialization time. """
866 given at initialization time. """
861
867
862 if out is None:
868 if out is None:
863 out = Term.cerr
869 out = Term.cerr
864 Term.cout.flush()
870 Term.cout.flush()
865 out.flush()
871 out.flush()
866 if tb_offset is not None:
872 if tb_offset is not None:
867 tb_offset, self.tb_offset = self.tb_offset, tb_offset
873 tb_offset, self.tb_offset = self.tb_offset, tb_offset
868 print >> out, self.text(etype, evalue, etb)
874 print >> out, self.text(etype, evalue, etb)
869 self.tb_offset = tb_offset
875 self.tb_offset = tb_offset
870 else:
876 else:
871 print >> out, self.text(etype, evalue, etb)
877 print >> out, self.text(etype, evalue, etb)
872 self.debugger()
878 self.debugger()
873
879
874 def text(self,etype=None,value=None,tb=None,context=5,mode=None):
880 def text(self,etype=None,value=None,tb=None,context=5,mode=None):
875 if etype is None:
881 if etype is None:
876 etype,value,tb = sys.exc_info()
882 etype,value,tb = sys.exc_info()
877 self.tb = tb
883 self.tb = tb
878 return FormattedTB.text(self,etype,value,tb,context=5,mode=mode)
884 return FormattedTB.text(self,etype,value,tb,context=5,mode=mode)
879
885
880 #---------------------------------------------------------------------------
886 #---------------------------------------------------------------------------
881 # A simple class to preserve Nathan's original functionality.
887 # A simple class to preserve Nathan's original functionality.
882 class ColorTB(FormattedTB):
888 class ColorTB(FormattedTB):
883 """Shorthand to initialize a FormattedTB in Linux colors mode."""
889 """Shorthand to initialize a FormattedTB in Linux colors mode."""
884 def __init__(self,color_scheme='Linux',call_pdb=0):
890 def __init__(self,color_scheme='Linux',call_pdb=0):
885 FormattedTB.__init__(self,color_scheme=color_scheme,
891 FormattedTB.__init__(self,color_scheme=color_scheme,
886 call_pdb=call_pdb)
892 call_pdb=call_pdb)
887
893
888 #----------------------------------------------------------------------------
894 #----------------------------------------------------------------------------
889 # module testing (minimal)
895 # module testing (minimal)
890 if __name__ == "__main__":
896 if __name__ == "__main__":
891 def spam(c, (d, e)):
897 def spam(c, (d, e)):
892 x = c + d
898 x = c + d
893 y = c * d
899 y = c * d
894 foo(x, y)
900 foo(x, y)
895
901
896 def foo(a, b, bar=1):
902 def foo(a, b, bar=1):
897 eggs(a, b + bar)
903 eggs(a, b + bar)
898
904
899 def eggs(f, g, z=globals()):
905 def eggs(f, g, z=globals()):
900 h = f + g
906 h = f + g
901 i = f - g
907 i = f - g
902 return h / i
908 return h / i
903
909
904 print ''
910 print ''
905 print '*** Before ***'
911 print '*** Before ***'
906 try:
912 try:
907 print spam(1, (2, 3))
913 print spam(1, (2, 3))
908 except:
914 except:
909 traceback.print_exc()
915 traceback.print_exc()
910 print ''
916 print ''
911
917
912 handler = ColorTB()
918 handler = ColorTB()
913 print '*** ColorTB ***'
919 print '*** ColorTB ***'
914 try:
920 try:
915 print spam(1, (2, 3))
921 print spam(1, (2, 3))
916 except:
922 except:
917 apply(handler, sys.exc_info() )
923 apply(handler, sys.exc_info() )
918 print ''
924 print ''
919
925
920 handler = VerboseTB()
926 handler = VerboseTB()
921 print '*** VerboseTB ***'
927 print '*** VerboseTB ***'
922 try:
928 try:
923 print spam(1, (2, 3))
929 print spam(1, (2, 3))
924 except:
930 except:
925 apply(handler, sys.exc_info() )
931 apply(handler, sys.exc_info() )
926 print ''
932 print ''
927
933
@@ -1,6785 +1,6791 b''
1 2007-06-01 Fernando Perez <Fernando.Perez@colorado.edu>
2
3 * IPython/ultraTB.py (VerboseTB.text): update printing of
4 exception types for Python 2.5 (now all exceptions in the stdlib
5 are new-style classes).
6
1 2007-05-31 Walter Doerwald <walter@livinglogic.de>
7 2007-05-31 Walter Doerwald <walter@livinglogic.de>
2
8
3 * IPython/Extensions/igrid.py: Add new commands refresh and
9 * IPython/Extensions/igrid.py: Add new commands refresh and
4 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
10 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
5 the iterator once (refresh) or after every x seconds (refresh_timer).
11 the iterator once (refresh) or after every x seconds (refresh_timer).
6 Add a working implementation of "searchexpression", where the text
12 Add a working implementation of "searchexpression", where the text
7 entered is not the text to search for, but an expression that must
13 entered is not the text to search for, but an expression that must
8 be true. Added display of shortcuts to the menu. Added commands "pickinput"
14 be true. Added display of shortcuts to the menu. Added commands "pickinput"
9 and "pickinputattr" that put the object or attribute under the cursor
15 and "pickinputattr" that put the object or attribute under the cursor
10 in the input line. Split the statusbar to be able to display the currently
16 in the input line. Split the statusbar to be able to display the currently
11 active refresh interval. (Patch by Nik Tautenhahn)
17 active refresh interval. (Patch by Nik Tautenhahn)
12
18
13 2007-05-29 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
19 2007-05-29 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
14
20
15 * fixing set_term_title to use ctypes as default
21 * fixing set_term_title to use ctypes as default
16
22
17 * fixing set_term_title fallback to work when curent dir
23 * fixing set_term_title fallback to work when curent dir
18 is on a windows network share
24 is on a windows network share
19
25
20 2007-05-28 Ville Vainio <vivainio@gmail.com>
26 2007-05-28 Ville Vainio <vivainio@gmail.com>
21
27
22 * %cpaste: strip + with > from left (diffs).
28 * %cpaste: strip + with > from left (diffs).
23
29
24 * iplib.py: Fix crash when readline not installed
30 * iplib.py: Fix crash when readline not installed
25
31
26 2007-05-26 Ville Vainio <vivainio@gmail.com>
32 2007-05-26 Ville Vainio <vivainio@gmail.com>
27
33
28 * generics.py: intruduce easy to extend result_display generic
34 * generics.py: intruduce easy to extend result_display generic
29 function (using simplegeneric.py).
35 function (using simplegeneric.py).
30
36
31 * Fixed the append functionality of %set.
37 * Fixed the append functionality of %set.
32
38
33 2007-05-25 Ville Vainio <vivainio@gmail.com>
39 2007-05-25 Ville Vainio <vivainio@gmail.com>
34
40
35 * New magic: %rep (fetch / run old commands from history)
41 * New magic: %rep (fetch / run old commands from history)
36
42
37 * New extension: mglob (%mglob magic), for powerful glob / find /filter
43 * New extension: mglob (%mglob magic), for powerful glob / find /filter
38 like functionality
44 like functionality
39
45
40 % maghistory.py: %hist -g PATTERM greps the history for pattern
46 % maghistory.py: %hist -g PATTERM greps the history for pattern
41
47
42 2007-05-24 Walter Doerwald <walter@livinglogic.de>
48 2007-05-24 Walter Doerwald <walter@livinglogic.de>
43
49
44 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
50 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
45 browse the IPython input history
51 browse the IPython input history
46
52
47 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
53 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
48 (mapped to "i") can be used to put the object under the curser in the input
54 (mapped to "i") can be used to put the object under the curser in the input
49 line. pickinputattr (mapped to "I") does the same for the attribute under
55 line. pickinputattr (mapped to "I") does the same for the attribute under
50 the cursor.
56 the cursor.
51
57
52 2007-05-24 Ville Vainio <vivainio@gmail.com>
58 2007-05-24 Ville Vainio <vivainio@gmail.com>
53
59
54 * Grand magic cleansing (changeset [2380]):
60 * Grand magic cleansing (changeset [2380]):
55
61
56 * Introduce ipy_legacy.py where the following magics were
62 * Introduce ipy_legacy.py where the following magics were
57 moved:
63 moved:
58
64
59 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
65 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
60
66
61 If you need them, either use default profile or "import ipy_legacy"
67 If you need them, either use default profile or "import ipy_legacy"
62 in your ipy_user_conf.py
68 in your ipy_user_conf.py
63
69
64 * Move sh and scipy profile to Extensions from UserConfig. this implies
70 * Move sh and scipy profile to Extensions from UserConfig. this implies
65 you should not edit them, but you don't need to run %upgrade when
71 you should not edit them, but you don't need to run %upgrade when
66 upgrading IPython anymore.
72 upgrading IPython anymore.
67
73
68 * %hist/%history now operates in "raw" mode by default. To get the old
74 * %hist/%history now operates in "raw" mode by default. To get the old
69 behaviour, run '%hist -n' (native mode).
75 behaviour, run '%hist -n' (native mode).
70
76
71 * split ipy_stock_completers.py to ipy_stock_completers.py and
77 * split ipy_stock_completers.py to ipy_stock_completers.py and
72 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
78 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
73 installed as default.
79 installed as default.
74
80
75 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
81 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
76 handling.
82 handling.
77
83
78 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
84 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
79 input if readline is available.
85 input if readline is available.
80
86
81 2007-05-23 Ville Vainio <vivainio@gmail.com>
87 2007-05-23 Ville Vainio <vivainio@gmail.com>
82
88
83 * macro.py: %store uses __getstate__ properly
89 * macro.py: %store uses __getstate__ properly
84
90
85 * exesetup.py: added new setup script for creating
91 * exesetup.py: added new setup script for creating
86 standalone IPython executables with py2exe (i.e.
92 standalone IPython executables with py2exe (i.e.
87 no python installation required).
93 no python installation required).
88
94
89 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
95 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
90 its place.
96 its place.
91
97
92 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
98 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
93
99
94 2007-05-21 Ville Vainio <vivainio@gmail.com>
100 2007-05-21 Ville Vainio <vivainio@gmail.com>
95
101
96 * platutil_win32.py (set_term_title): handle
102 * platutil_win32.py (set_term_title): handle
97 failure of 'title' system call properly.
103 failure of 'title' system call properly.
98
104
99 2007-05-17 Walter Doerwald <walter@livinglogic.de>
105 2007-05-17 Walter Doerwald <walter@livinglogic.de>
100
106
101 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
107 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
102 (Bug detected by Paul Mueller).
108 (Bug detected by Paul Mueller).
103
109
104 2007-05-16 Ville Vainio <vivainio@gmail.com>
110 2007-05-16 Ville Vainio <vivainio@gmail.com>
105
111
106 * ipy_profile_sci.py, ipython_win_post_install.py: Create
112 * ipy_profile_sci.py, ipython_win_post_install.py: Create
107 new "sci" profile, effectively a modern version of the old
113 new "sci" profile, effectively a modern version of the old
108 "scipy" profile (which is now slated for deprecation).
114 "scipy" profile (which is now slated for deprecation).
109
115
110 2007-05-15 Ville Vainio <vivainio@gmail.com>
116 2007-05-15 Ville Vainio <vivainio@gmail.com>
111
117
112 * pycolorize.py, pycolor.1: Paul Mueller's patches that
118 * pycolorize.py, pycolor.1: Paul Mueller's patches that
113 make pycolorize read input from stdin when run without arguments.
119 make pycolorize read input from stdin when run without arguments.
114
120
115 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
121 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
116
122
117 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
123 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
118 it in sh profile (instead of ipy_system_conf.py).
124 it in sh profile (instead of ipy_system_conf.py).
119
125
120 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
126 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
121 aliases are now lower case on windows (MyCommand.exe => mycommand).
127 aliases are now lower case on windows (MyCommand.exe => mycommand).
122
128
123 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
129 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
124 Macros are now callable objects that inherit from ipapi.IPyAutocall,
130 Macros are now callable objects that inherit from ipapi.IPyAutocall,
125 i.e. get autocalled regardless of system autocall setting.
131 i.e. get autocalled regardless of system autocall setting.
126
132
127 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
133 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
128
134
129 * IPython/rlineimpl.py: check for clear_history in readline and
135 * IPython/rlineimpl.py: check for clear_history in readline and
130 make it a dummy no-op if not available. This function isn't
136 make it a dummy no-op if not available. This function isn't
131 guaranteed to be in the API and appeared in Python 2.4, so we need
137 guaranteed to be in the API and appeared in Python 2.4, so we need
132 to check it ourselves. Also, clean up this file quite a bit.
138 to check it ourselves. Also, clean up this file quite a bit.
133
139
134 * ipython.1: update man page and full manual with information
140 * ipython.1: update man page and full manual with information
135 about threads (remove outdated warning). Closes #151.
141 about threads (remove outdated warning). Closes #151.
136
142
137 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
143 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
138
144
139 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
145 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
140 in trunk (note that this made it into the 0.8.1 release already,
146 in trunk (note that this made it into the 0.8.1 release already,
141 but the changelogs didn't get coordinated). Many thanks to Gael
147 but the changelogs didn't get coordinated). Many thanks to Gael
142 Varoquaux <gael.varoquaux-AT-normalesup.org>
148 Varoquaux <gael.varoquaux-AT-normalesup.org>
143
149
144 2007-05-09 *** Released version 0.8.1
150 2007-05-09 *** Released version 0.8.1
145
151
146 2007-05-10 Walter Doerwald <walter@livinglogic.de>
152 2007-05-10 Walter Doerwald <walter@livinglogic.de>
147
153
148 * IPython/Extensions/igrid.py: Incorporate html help into
154 * IPython/Extensions/igrid.py: Incorporate html help into
149 the module, so we don't have to search for the file.
155 the module, so we don't have to search for the file.
150
156
151 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
157 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
152
158
153 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
159 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
154
160
155 2007-04-30 Ville Vainio <vivainio@gmail.com>
161 2007-04-30 Ville Vainio <vivainio@gmail.com>
156
162
157 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
163 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
158 user has illegal (non-ascii) home directory name
164 user has illegal (non-ascii) home directory name
159
165
160 2007-04-27 Ville Vainio <vivainio@gmail.com>
166 2007-04-27 Ville Vainio <vivainio@gmail.com>
161
167
162 * platutils_win32.py: implement set_term_title for windows
168 * platutils_win32.py: implement set_term_title for windows
163
169
164 * Update version number
170 * Update version number
165
171
166 * ipy_profile_sh.py: more informative prompt (2 dir levels)
172 * ipy_profile_sh.py: more informative prompt (2 dir levels)
167
173
168 2007-04-26 Walter Doerwald <walter@livinglogic.de>
174 2007-04-26 Walter Doerwald <walter@livinglogic.de>
169
175
170 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
176 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
171 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
177 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
172 bug discovered by Ville).
178 bug discovered by Ville).
173
179
174 2007-04-26 Ville Vainio <vivainio@gmail.com>
180 2007-04-26 Ville Vainio <vivainio@gmail.com>
175
181
176 * Extensions/ipy_completers.py: Olivier's module completer now
182 * Extensions/ipy_completers.py: Olivier's module completer now
177 saves the list of root modules if it takes > 4 secs on the first run.
183 saves the list of root modules if it takes > 4 secs on the first run.
178
184
179 * Magic.py (%rehashx): %rehashx now clears the completer cache
185 * Magic.py (%rehashx): %rehashx now clears the completer cache
180
186
181
187
182 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
188 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
183
189
184 * ipython.el: fix incorrect color scheme, reported by Stefan.
190 * ipython.el: fix incorrect color scheme, reported by Stefan.
185 Closes #149.
191 Closes #149.
186
192
187 * IPython/PyColorize.py (Parser.format2): fix state-handling
193 * IPython/PyColorize.py (Parser.format2): fix state-handling
188 logic. I still don't like how that code handles state, but at
194 logic. I still don't like how that code handles state, but at
189 least now it should be correct, if inelegant. Closes #146.
195 least now it should be correct, if inelegant. Closes #146.
190
196
191 2007-04-25 Ville Vainio <vivainio@gmail.com>
197 2007-04-25 Ville Vainio <vivainio@gmail.com>
192
198
193 * Extensions/ipy_which.py: added extension for %which magic, works
199 * Extensions/ipy_which.py: added extension for %which magic, works
194 a lot like unix 'which' but also finds and expands aliases, and
200 a lot like unix 'which' but also finds and expands aliases, and
195 allows wildcards.
201 allows wildcards.
196
202
197 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
203 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
198 as opposed to returning nothing.
204 as opposed to returning nothing.
199
205
200 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
206 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
201 ipy_stock_completers on default profile, do import on sh profile.
207 ipy_stock_completers on default profile, do import on sh profile.
202
208
203 2007-04-22 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
209 2007-04-22 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
204
210
205 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
211 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
206 like ipython.py foo.py which raised a IndexError.
212 like ipython.py foo.py which raised a IndexError.
207
213
208 2007-04-21 Ville Vainio <vivainio@gmail.com>
214 2007-04-21 Ville Vainio <vivainio@gmail.com>
209
215
210 * Extensions/ipy_extutil.py: added extension to manage other ipython
216 * Extensions/ipy_extutil.py: added extension to manage other ipython
211 extensions. Now only supports 'ls' == list extensions.
217 extensions. Now only supports 'ls' == list extensions.
212
218
213 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
219 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
214
220
215 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
221 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
216 would prevent use of the exception system outside of a running
222 would prevent use of the exception system outside of a running
217 IPython instance.
223 IPython instance.
218
224
219 2007-04-20 Ville Vainio <vivainio@gmail.com>
225 2007-04-20 Ville Vainio <vivainio@gmail.com>
220
226
221 * Extensions/ipy_render.py: added extension for easy
227 * Extensions/ipy_render.py: added extension for easy
222 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
228 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
223 'Iptl' template notation,
229 'Iptl' template notation,
224
230
225 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
231 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
226 safer & faster 'import' completer.
232 safer & faster 'import' completer.
227
233
228 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
234 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
229 and _ip.defalias(name, command).
235 and _ip.defalias(name, command).
230
236
231 * Extensions/ipy_exportdb.py: New extension for exporting all the
237 * Extensions/ipy_exportdb.py: New extension for exporting all the
232 %store'd data in a portable format (normal ipapi calls like
238 %store'd data in a portable format (normal ipapi calls like
233 defmacro() etc.)
239 defmacro() etc.)
234
240
235 2007-04-19 Ville Vainio <vivainio@gmail.com>
241 2007-04-19 Ville Vainio <vivainio@gmail.com>
236
242
237 * upgrade_dir.py: skip junk files like *.pyc
243 * upgrade_dir.py: skip junk files like *.pyc
238
244
239 * Release.py: version number to 0.8.1
245 * Release.py: version number to 0.8.1
240
246
241 2007-04-18 Ville Vainio <vivainio@gmail.com>
247 2007-04-18 Ville Vainio <vivainio@gmail.com>
242
248
243 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
249 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
244 and later on win32.
250 and later on win32.
245
251
246 2007-04-16 Ville Vainio <vivainio@gmail.com>
252 2007-04-16 Ville Vainio <vivainio@gmail.com>
247
253
248 * iplib.py (showtraceback): Do not crash when running w/o readline.
254 * iplib.py (showtraceback): Do not crash when running w/o readline.
249
255
250 2007-04-12 Walter Doerwald <walter@livinglogic.de>
256 2007-04-12 Walter Doerwald <walter@livinglogic.de>
251
257
252 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
258 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
253 sorted (case sensitive with files and dirs mixed).
259 sorted (case sensitive with files and dirs mixed).
254
260
255 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
261 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
256
262
257 * IPython/Release.py (version): Open trunk for 0.8.1 development.
263 * IPython/Release.py (version): Open trunk for 0.8.1 development.
258
264
259 2007-04-10 *** Released version 0.8.0
265 2007-04-10 *** Released version 0.8.0
260
266
261 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
267 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
262
268
263 * Tag 0.8.0 for release.
269 * Tag 0.8.0 for release.
264
270
265 * IPython/iplib.py (reloadhist): add API function to cleanly
271 * IPython/iplib.py (reloadhist): add API function to cleanly
266 reload the readline history, which was growing inappropriately on
272 reload the readline history, which was growing inappropriately on
267 every %run call.
273 every %run call.
268
274
269 * win32_manual_post_install.py (run): apply last part of Nicolas
275 * win32_manual_post_install.py (run): apply last part of Nicolas
270 Pernetty's patch (I'd accidentally applied it in a different
276 Pernetty's patch (I'd accidentally applied it in a different
271 directory and this particular file didn't get patched).
277 directory and this particular file didn't get patched).
272
278
273 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
279 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
274
280
275 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
281 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
276 find the main thread id and use the proper API call. Thanks to
282 find the main thread id and use the proper API call. Thanks to
277 Stefan for the fix.
283 Stefan for the fix.
278
284
279 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
285 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
280 unit tests to reflect fixed ticket #52, and add more tests sent by
286 unit tests to reflect fixed ticket #52, and add more tests sent by
281 him.
287 him.
282
288
283 * IPython/iplib.py (raw_input): restore the readline completer
289 * IPython/iplib.py (raw_input): restore the readline completer
284 state on every input, in case third-party code messed it up.
290 state on every input, in case third-party code messed it up.
285 (_prefilter): revert recent addition of early-escape checks which
291 (_prefilter): revert recent addition of early-escape checks which
286 prevent many valid alias calls from working.
292 prevent many valid alias calls from working.
287
293
288 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
294 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
289 flag for sigint handler so we don't run a full signal() call on
295 flag for sigint handler so we don't run a full signal() call on
290 each runcode access.
296 each runcode access.
291
297
292 * IPython/Magic.py (magic_whos): small improvement to diagnostic
298 * IPython/Magic.py (magic_whos): small improvement to diagnostic
293 message.
299 message.
294
300
295 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
301 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
296
302
297 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
303 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
298 asynchronous exceptions working, i.e., Ctrl-C can actually
304 asynchronous exceptions working, i.e., Ctrl-C can actually
299 interrupt long-running code in the multithreaded shells.
305 interrupt long-running code in the multithreaded shells.
300
306
301 This is using Tomer Filiba's great ctypes-based trick:
307 This is using Tomer Filiba's great ctypes-based trick:
302 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
308 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
303 this in the past, but hadn't been able to make it work before. So
309 this in the past, but hadn't been able to make it work before. So
304 far it looks like it's actually running, but this needs more
310 far it looks like it's actually running, but this needs more
305 testing. If it really works, I'll be *very* happy, and we'll owe
311 testing. If it really works, I'll be *very* happy, and we'll owe
306 a huge thank you to Tomer. My current implementation is ugly,
312 a huge thank you to Tomer. My current implementation is ugly,
307 hackish and uses nasty globals, but I don't want to try and clean
313 hackish and uses nasty globals, but I don't want to try and clean
308 anything up until we know if it actually works.
314 anything up until we know if it actually works.
309
315
310 NOTE: this feature needs ctypes to work. ctypes is included in
316 NOTE: this feature needs ctypes to work. ctypes is included in
311 Python2.5, but 2.4 users will need to manually install it. This
317 Python2.5, but 2.4 users will need to manually install it. This
312 feature makes multi-threaded shells so much more usable that it's
318 feature makes multi-threaded shells so much more usable that it's
313 a minor price to pay (ctypes is very easy to install, already a
319 a minor price to pay (ctypes is very easy to install, already a
314 requirement for win32 and available in major linux distros).
320 requirement for win32 and available in major linux distros).
315
321
316 2007-04-04 Ville Vainio <vivainio@gmail.com>
322 2007-04-04 Ville Vainio <vivainio@gmail.com>
317
323
318 * Extensions/ipy_completers.py, ipy_stock_completers.py:
324 * Extensions/ipy_completers.py, ipy_stock_completers.py:
319 Moved implementations of 'bundled' completers to ipy_completers.py,
325 Moved implementations of 'bundled' completers to ipy_completers.py,
320 they are only enabled in ipy_stock_completers.py.
326 they are only enabled in ipy_stock_completers.py.
321
327
322 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
328 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
323
329
324 * IPython/PyColorize.py (Parser.format2): Fix identation of
330 * IPython/PyColorize.py (Parser.format2): Fix identation of
325 colorzied output and return early if color scheme is NoColor, to
331 colorzied output and return early if color scheme is NoColor, to
326 avoid unnecessary and expensive tokenization. Closes #131.
332 avoid unnecessary and expensive tokenization. Closes #131.
327
333
328 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
334 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
329
335
330 * IPython/Debugger.py: disable the use of pydb version 1.17. It
336 * IPython/Debugger.py: disable the use of pydb version 1.17. It
331 has a critical bug (a missing import that makes post-mortem not
337 has a critical bug (a missing import that makes post-mortem not
332 work at all). Unfortunately as of this time, this is the version
338 work at all). Unfortunately as of this time, this is the version
333 shipped with Ubuntu Edgy, so quite a few people have this one. I
339 shipped with Ubuntu Edgy, so quite a few people have this one. I
334 hope Edgy will update to a more recent package.
340 hope Edgy will update to a more recent package.
335
341
336 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
342 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
337
343
338 * IPython/iplib.py (_prefilter): close #52, second part of a patch
344 * IPython/iplib.py (_prefilter): close #52, second part of a patch
339 set by Stefan (only the first part had been applied before).
345 set by Stefan (only the first part had been applied before).
340
346
341 * IPython/Extensions/ipy_stock_completers.py (module_completer):
347 * IPython/Extensions/ipy_stock_completers.py (module_completer):
342 remove usage of the dangerous pkgutil.walk_packages(). See
348 remove usage of the dangerous pkgutil.walk_packages(). See
343 details in comments left in the code.
349 details in comments left in the code.
344
350
345 * IPython/Magic.py (magic_whos): add support for numpy arrays
351 * IPython/Magic.py (magic_whos): add support for numpy arrays
346 similar to what we had for Numeric.
352 similar to what we had for Numeric.
347
353
348 * IPython/completer.py (IPCompleter.complete): extend the
354 * IPython/completer.py (IPCompleter.complete): extend the
349 complete() call API to support completions by other mechanisms
355 complete() call API to support completions by other mechanisms
350 than readline. Closes #109.
356 than readline. Closes #109.
351
357
352 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
358 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
353 protect against a bug in Python's execfile(). Closes #123.
359 protect against a bug in Python's execfile(). Closes #123.
354
360
355 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
361 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
356
362
357 * IPython/iplib.py (split_user_input): ensure that when splitting
363 * IPython/iplib.py (split_user_input): ensure that when splitting
358 user input, the part that can be treated as a python name is pure
364 user input, the part that can be treated as a python name is pure
359 ascii (Python identifiers MUST be pure ascii). Part of the
365 ascii (Python identifiers MUST be pure ascii). Part of the
360 ongoing Unicode support work.
366 ongoing Unicode support work.
361
367
362 * IPython/Prompts.py (prompt_specials_color): Add \N for the
368 * IPython/Prompts.py (prompt_specials_color): Add \N for the
363 actual prompt number, without any coloring. This allows users to
369 actual prompt number, without any coloring. This allows users to
364 produce numbered prompts with their own colors. Added after a
370 produce numbered prompts with their own colors. Added after a
365 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
371 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
366
372
367 2007-03-31 Walter Doerwald <walter@livinglogic.de>
373 2007-03-31 Walter Doerwald <walter@livinglogic.de>
368
374
369 * IPython/Extensions/igrid.py: Map the return key
375 * IPython/Extensions/igrid.py: Map the return key
370 to enter() and shift-return to enterattr().
376 to enter() and shift-return to enterattr().
371
377
372 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
378 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
373
379
374 * IPython/Magic.py (magic_psearch): add unicode support by
380 * IPython/Magic.py (magic_psearch): add unicode support by
375 encoding to ascii the input, since this routine also only deals
381 encoding to ascii the input, since this routine also only deals
376 with valid Python names. Fixes a bug reported by Stefan.
382 with valid Python names. Fixes a bug reported by Stefan.
377
383
378 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
384 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
379
385
380 * IPython/Magic.py (_inspect): convert unicode input into ascii
386 * IPython/Magic.py (_inspect): convert unicode input into ascii
381 before trying to evaluate it as a Python identifier. This fixes a
387 before trying to evaluate it as a Python identifier. This fixes a
382 problem that the new unicode support had introduced when analyzing
388 problem that the new unicode support had introduced when analyzing
383 long definition lines for functions.
389 long definition lines for functions.
384
390
385 2007-03-24 Walter Doerwald <walter@livinglogic.de>
391 2007-03-24 Walter Doerwald <walter@livinglogic.de>
386
392
387 * IPython/Extensions/igrid.py: Fix picking. Using
393 * IPython/Extensions/igrid.py: Fix picking. Using
388 igrid with wxPython 2.6 and -wthread should work now.
394 igrid with wxPython 2.6 and -wthread should work now.
389 igrid.display() simply tries to create a frame without
395 igrid.display() simply tries to create a frame without
390 an application. Only if this fails an application is created.
396 an application. Only if this fails an application is created.
391
397
392 2007-03-23 Walter Doerwald <walter@livinglogic.de>
398 2007-03-23 Walter Doerwald <walter@livinglogic.de>
393
399
394 * IPython/Extensions/path.py: Updated to version 2.2.
400 * IPython/Extensions/path.py: Updated to version 2.2.
395
401
396 2007-03-23 Ville Vainio <vivainio@gmail.com>
402 2007-03-23 Ville Vainio <vivainio@gmail.com>
397
403
398 * iplib.py: recursive alias expansion now works better, so that
404 * iplib.py: recursive alias expansion now works better, so that
399 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
405 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
400 doesn't trip up the process, if 'd' has been aliased to 'ls'.
406 doesn't trip up the process, if 'd' has been aliased to 'ls'.
401
407
402 * Extensions/ipy_gnuglobal.py added, provides %global magic
408 * Extensions/ipy_gnuglobal.py added, provides %global magic
403 for users of http://www.gnu.org/software/global
409 for users of http://www.gnu.org/software/global
404
410
405 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
411 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
406 Closes #52. Patch by Stefan van der Walt.
412 Closes #52. Patch by Stefan van der Walt.
407
413
408 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
414 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
409
415
410 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
416 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
411 respect the __file__ attribute when using %run. Thanks to a bug
417 respect the __file__ attribute when using %run. Thanks to a bug
412 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
418 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
413
419
414 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
420 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
415
421
416 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
422 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
417 input. Patch sent by Stefan.
423 input. Patch sent by Stefan.
418
424
419 2007-03-20 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
425 2007-03-20 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
420 * IPython/Extensions/ipy_stock_completer.py
426 * IPython/Extensions/ipy_stock_completer.py
421 shlex_split, fix bug in shlex_split. len function
427 shlex_split, fix bug in shlex_split. len function
422 call was missing an if statement. Caused shlex_split to
428 call was missing an if statement. Caused shlex_split to
423 sometimes return "" as last element.
429 sometimes return "" as last element.
424
430
425 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
431 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
426
432
427 * IPython/completer.py
433 * IPython/completer.py
428 (IPCompleter.file_matches.single_dir_expand): fix a problem
434 (IPCompleter.file_matches.single_dir_expand): fix a problem
429 reported by Stefan, where directories containign a single subdir
435 reported by Stefan, where directories containign a single subdir
430 would be completed too early.
436 would be completed too early.
431
437
432 * IPython/Shell.py (_load_pylab): Make the execution of 'from
438 * IPython/Shell.py (_load_pylab): Make the execution of 'from
433 pylab import *' when -pylab is given be optional. A new flag,
439 pylab import *' when -pylab is given be optional. A new flag,
434 pylab_import_all controls this behavior, the default is True for
440 pylab_import_all controls this behavior, the default is True for
435 backwards compatibility.
441 backwards compatibility.
436
442
437 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
443 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
438 modified) R. Bernstein's patch for fully syntax highlighted
444 modified) R. Bernstein's patch for fully syntax highlighted
439 tracebacks. The functionality is also available under ultraTB for
445 tracebacks. The functionality is also available under ultraTB for
440 non-ipython users (someone using ultraTB but outside an ipython
446 non-ipython users (someone using ultraTB but outside an ipython
441 session). They can select the color scheme by setting the
447 session). They can select the color scheme by setting the
442 module-level global DEFAULT_SCHEME. The highlight functionality
448 module-level global DEFAULT_SCHEME. The highlight functionality
443 also works when debugging.
449 also works when debugging.
444
450
445 * IPython/genutils.py (IOStream.close): small patch by
451 * IPython/genutils.py (IOStream.close): small patch by
446 R. Bernstein for improved pydb support.
452 R. Bernstein for improved pydb support.
447
453
448 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
454 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
449 DaveS <davls@telus.net> to improve support of debugging under
455 DaveS <davls@telus.net> to improve support of debugging under
450 NTEmacs, including improved pydb behavior.
456 NTEmacs, including improved pydb behavior.
451
457
452 * IPython/Magic.py (magic_prun): Fix saving of profile info for
458 * IPython/Magic.py (magic_prun): Fix saving of profile info for
453 Python 2.5, where the stats object API changed a little. Thanks
459 Python 2.5, where the stats object API changed a little. Thanks
454 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
460 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
455
461
456 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
462 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
457 Pernetty's patch to improve support for (X)Emacs under Win32.
463 Pernetty's patch to improve support for (X)Emacs under Win32.
458
464
459 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
465 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
460
466
461 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
467 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
462 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
468 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
463 a report by Nik Tautenhahn.
469 a report by Nik Tautenhahn.
464
470
465 2007-03-16 Walter Doerwald <walter@livinglogic.de>
471 2007-03-16 Walter Doerwald <walter@livinglogic.de>
466
472
467 * setup.py: Add the igrid help files to the list of data files
473 * setup.py: Add the igrid help files to the list of data files
468 to be installed alongside igrid.
474 to be installed alongside igrid.
469 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
475 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
470 Show the input object of the igrid browser as the window tile.
476 Show the input object of the igrid browser as the window tile.
471 Show the object the cursor is on in the statusbar.
477 Show the object the cursor is on in the statusbar.
472
478
473 2007-03-15 Ville Vainio <vivainio@gmail.com>
479 2007-03-15 Ville Vainio <vivainio@gmail.com>
474
480
475 * Extensions/ipy_stock_completers.py: Fixed exception
481 * Extensions/ipy_stock_completers.py: Fixed exception
476 on mismatching quotes in %run completer. Patch by
482 on mismatching quotes in %run completer. Patch by
477 JοΏ½rgen Stenarson. Closes #127.
483 JοΏ½rgen Stenarson. Closes #127.
478
484
479 2007-03-14 Ville Vainio <vivainio@gmail.com>
485 2007-03-14 Ville Vainio <vivainio@gmail.com>
480
486
481 * Extensions/ext_rehashdir.py: Do not do auto_alias
487 * Extensions/ext_rehashdir.py: Do not do auto_alias
482 in %rehashdir, it clobbers %store'd aliases.
488 in %rehashdir, it clobbers %store'd aliases.
483
489
484 * UserConfig/ipy_profile_sh.py: envpersist.py extension
490 * UserConfig/ipy_profile_sh.py: envpersist.py extension
485 (beefed up %env) imported for sh profile.
491 (beefed up %env) imported for sh profile.
486
492
487 2007-03-10 Walter Doerwald <walter@livinglogic.de>
493 2007-03-10 Walter Doerwald <walter@livinglogic.de>
488
494
489 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
495 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
490 as the default browser.
496 as the default browser.
491 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
497 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
492 As igrid displays all attributes it ever encounters, fetch() (which has
498 As igrid displays all attributes it ever encounters, fetch() (which has
493 been renamed to _fetch()) doesn't have to recalculate the display attributes
499 been renamed to _fetch()) doesn't have to recalculate the display attributes
494 every time a new item is fetched. This should speed up scrolling.
500 every time a new item is fetched. This should speed up scrolling.
495
501
496 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
502 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
497
503
498 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
504 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
499 Schmolck's recently reported tab-completion bug (my previous one
505 Schmolck's recently reported tab-completion bug (my previous one
500 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
506 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
501
507
502 2007-03-09 Walter Doerwald <walter@livinglogic.de>
508 2007-03-09 Walter Doerwald <walter@livinglogic.de>
503
509
504 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
510 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
505 Close help window if exiting igrid.
511 Close help window if exiting igrid.
506
512
507 2007-03-02 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
513 2007-03-02 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
508
514
509 * IPython/Extensions/ipy_defaults.py: Check if readline is available
515 * IPython/Extensions/ipy_defaults.py: Check if readline is available
510 before calling functions from readline.
516 before calling functions from readline.
511
517
512 2007-03-02 Walter Doerwald <walter@livinglogic.de>
518 2007-03-02 Walter Doerwald <walter@livinglogic.de>
513
519
514 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
520 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
515 igrid is a wxPython-based display object for ipipe. If your system has
521 igrid is a wxPython-based display object for ipipe. If your system has
516 wx installed igrid will be the default display. Without wx ipipe falls
522 wx installed igrid will be the default display. Without wx ipipe falls
517 back to ibrowse (which needs curses). If no curses is installed ipipe
523 back to ibrowse (which needs curses). If no curses is installed ipipe
518 falls back to idump.
524 falls back to idump.
519
525
520 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
526 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
521
527
522 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
528 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
523 my changes from yesterday, they introduced bugs. Will reactivate
529 my changes from yesterday, they introduced bugs. Will reactivate
524 once I get a correct solution, which will be much easier thanks to
530 once I get a correct solution, which will be much easier thanks to
525 Dan Milstein's new prefilter test suite.
531 Dan Milstein's new prefilter test suite.
526
532
527 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
533 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
528
534
529 * IPython/iplib.py (split_user_input): fix input splitting so we
535 * IPython/iplib.py (split_user_input): fix input splitting so we
530 don't attempt attribute accesses on things that can't possibly be
536 don't attempt attribute accesses on things that can't possibly be
531 valid Python attributes. After a bug report by Alex Schmolck.
537 valid Python attributes. After a bug report by Alex Schmolck.
532 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
538 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
533 %magic with explicit % prefix.
539 %magic with explicit % prefix.
534
540
535 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
541 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
536
542
537 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
543 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
538 avoid a DeprecationWarning from GTK.
544 avoid a DeprecationWarning from GTK.
539
545
540 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
546 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
541
547
542 * IPython/genutils.py (clock): I modified clock() to return total
548 * IPython/genutils.py (clock): I modified clock() to return total
543 time, user+system. This is a more commonly needed metric. I also
549 time, user+system. This is a more commonly needed metric. I also
544 introduced the new clocku/clocks to get only user/system time if
550 introduced the new clocku/clocks to get only user/system time if
545 one wants those instead.
551 one wants those instead.
546
552
547 ***WARNING: API CHANGE*** clock() used to return only user time,
553 ***WARNING: API CHANGE*** clock() used to return only user time,
548 so if you want exactly the same results as before, use clocku
554 so if you want exactly the same results as before, use clocku
549 instead.
555 instead.
550
556
551 2007-02-22 Ville Vainio <vivainio@gmail.com>
557 2007-02-22 Ville Vainio <vivainio@gmail.com>
552
558
553 * IPython/Extensions/ipy_p4.py: Extension for improved
559 * IPython/Extensions/ipy_p4.py: Extension for improved
554 p4 (perforce version control system) experience.
560 p4 (perforce version control system) experience.
555 Adds %p4 magic with p4 command completion and
561 Adds %p4 magic with p4 command completion and
556 automatic -G argument (marshall output as python dict)
562 automatic -G argument (marshall output as python dict)
557
563
558 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
564 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
559
565
560 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
566 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
561 stop marks.
567 stop marks.
562 (ClearingMixin): a simple mixin to easily make a Demo class clear
568 (ClearingMixin): a simple mixin to easily make a Demo class clear
563 the screen in between blocks and have empty marquees. The
569 the screen in between blocks and have empty marquees. The
564 ClearDemo and ClearIPDemo classes that use it are included.
570 ClearDemo and ClearIPDemo classes that use it are included.
565
571
566 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
572 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
567
573
568 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
574 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
569 protect against exceptions at Python shutdown time. Patch
575 protect against exceptions at Python shutdown time. Patch
570 sumbmitted to upstream.
576 sumbmitted to upstream.
571
577
572 2007-02-14 Walter Doerwald <walter@livinglogic.de>
578 2007-02-14 Walter Doerwald <walter@livinglogic.de>
573
579
574 * IPython/Extensions/ibrowse.py: If entering the first object level
580 * IPython/Extensions/ibrowse.py: If entering the first object level
575 (i.e. the object for which the browser has been started) fails,
581 (i.e. the object for which the browser has been started) fails,
576 now the error is raised directly (aborting the browser) instead of
582 now the error is raised directly (aborting the browser) instead of
577 running into an empty levels list later.
583 running into an empty levels list later.
578
584
579 2007-02-03 Walter Doerwald <walter@livinglogic.de>
585 2007-02-03 Walter Doerwald <walter@livinglogic.de>
580
586
581 * IPython/Extensions/ipipe.py: Add an xrepr implementation
587 * IPython/Extensions/ipipe.py: Add an xrepr implementation
582 for the noitem object.
588 for the noitem object.
583
589
584 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
590 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
585
591
586 * IPython/completer.py (Completer.attr_matches): Fix small
592 * IPython/completer.py (Completer.attr_matches): Fix small
587 tab-completion bug with Enthought Traits objects with units.
593 tab-completion bug with Enthought Traits objects with units.
588 Thanks to a bug report by Tom Denniston
594 Thanks to a bug report by Tom Denniston
589 <tom.denniston-AT-alum.dartmouth.org>.
595 <tom.denniston-AT-alum.dartmouth.org>.
590
596
591 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
597 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
592
598
593 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
599 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
594 bug where only .ipy or .py would be completed. Once the first
600 bug where only .ipy or .py would be completed. Once the first
595 argument to %run has been given, all completions are valid because
601 argument to %run has been given, all completions are valid because
596 they are the arguments to the script, which may well be non-python
602 they are the arguments to the script, which may well be non-python
597 filenames.
603 filenames.
598
604
599 * IPython/irunner.py (InteractiveRunner.run_source): major updates
605 * IPython/irunner.py (InteractiveRunner.run_source): major updates
600 to irunner to allow it to correctly support real doctesting of
606 to irunner to allow it to correctly support real doctesting of
601 out-of-process ipython code.
607 out-of-process ipython code.
602
608
603 * IPython/Magic.py (magic_cd): Make the setting of the terminal
609 * IPython/Magic.py (magic_cd): Make the setting of the terminal
604 title an option (-noterm_title) because it completely breaks
610 title an option (-noterm_title) because it completely breaks
605 doctesting.
611 doctesting.
606
612
607 * IPython/demo.py: fix IPythonDemo class that was not actually working.
613 * IPython/demo.py: fix IPythonDemo class that was not actually working.
608
614
609 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
615 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
610
616
611 * IPython/irunner.py (main): fix small bug where extensions were
617 * IPython/irunner.py (main): fix small bug where extensions were
612 not being correctly recognized.
618 not being correctly recognized.
613
619
614 2007-01-23 Walter Doerwald <walter@livinglogic.de>
620 2007-01-23 Walter Doerwald <walter@livinglogic.de>
615
621
616 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
622 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
617 a string containing a single line yields the string itself as the
623 a string containing a single line yields the string itself as the
618 only item.
624 only item.
619
625
620 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
626 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
621 object if it's the same as the one on the last level (This avoids
627 object if it's the same as the one on the last level (This avoids
622 infinite recursion for one line strings).
628 infinite recursion for one line strings).
623
629
624 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
630 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
625
631
626 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
632 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
627 all output streams before printing tracebacks. This ensures that
633 all output streams before printing tracebacks. This ensures that
628 user output doesn't end up interleaved with traceback output.
634 user output doesn't end up interleaved with traceback output.
629
635
630 2007-01-10 Ville Vainio <vivainio@gmail.com>
636 2007-01-10 Ville Vainio <vivainio@gmail.com>
631
637
632 * Extensions/envpersist.py: Turbocharged %env that remembers
638 * Extensions/envpersist.py: Turbocharged %env that remembers
633 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
639 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
634 "%env VISUAL=jed".
640 "%env VISUAL=jed".
635
641
636 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
642 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
637
643
638 * IPython/iplib.py (showtraceback): ensure that we correctly call
644 * IPython/iplib.py (showtraceback): ensure that we correctly call
639 custom handlers in all cases (some with pdb were slipping through,
645 custom handlers in all cases (some with pdb were slipping through,
640 but I'm not exactly sure why).
646 but I'm not exactly sure why).
641
647
642 * IPython/Debugger.py (Tracer.__init__): added new class to
648 * IPython/Debugger.py (Tracer.__init__): added new class to
643 support set_trace-like usage of IPython's enhanced debugger.
649 support set_trace-like usage of IPython's enhanced debugger.
644
650
645 2006-12-24 Ville Vainio <vivainio@gmail.com>
651 2006-12-24 Ville Vainio <vivainio@gmail.com>
646
652
647 * ipmaker.py: more informative message when ipy_user_conf
653 * ipmaker.py: more informative message when ipy_user_conf
648 import fails (suggest running %upgrade).
654 import fails (suggest running %upgrade).
649
655
650 * tools/run_ipy_in_profiler.py: Utility to see where
656 * tools/run_ipy_in_profiler.py: Utility to see where
651 the time during IPython startup is spent.
657 the time during IPython startup is spent.
652
658
653 2006-12-20 Ville Vainio <vivainio@gmail.com>
659 2006-12-20 Ville Vainio <vivainio@gmail.com>
654
660
655 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
661 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
656
662
657 * ipapi.py: Add new ipapi method, expand_alias.
663 * ipapi.py: Add new ipapi method, expand_alias.
658
664
659 * Release.py: Bump up version to 0.7.4.svn
665 * Release.py: Bump up version to 0.7.4.svn
660
666
661 2006-12-17 Ville Vainio <vivainio@gmail.com>
667 2006-12-17 Ville Vainio <vivainio@gmail.com>
662
668
663 * Extensions/jobctrl.py: Fixed &cmd arg arg...
669 * Extensions/jobctrl.py: Fixed &cmd arg arg...
664 to work properly on posix too
670 to work properly on posix too
665
671
666 * Release.py: Update revnum (version is still just 0.7.3).
672 * Release.py: Update revnum (version is still just 0.7.3).
667
673
668 2006-12-15 Ville Vainio <vivainio@gmail.com>
674 2006-12-15 Ville Vainio <vivainio@gmail.com>
669
675
670 * scripts/ipython_win_post_install: create ipython.py in
676 * scripts/ipython_win_post_install: create ipython.py in
671 prefix + "/scripts".
677 prefix + "/scripts".
672
678
673 * Release.py: Update version to 0.7.3.
679 * Release.py: Update version to 0.7.3.
674
680
675 2006-12-14 Ville Vainio <vivainio@gmail.com>
681 2006-12-14 Ville Vainio <vivainio@gmail.com>
676
682
677 * scripts/ipython_win_post_install: Overwrite old shortcuts
683 * scripts/ipython_win_post_install: Overwrite old shortcuts
678 if they already exist
684 if they already exist
679
685
680 * Release.py: release 0.7.3rc2
686 * Release.py: release 0.7.3rc2
681
687
682 2006-12-13 Ville Vainio <vivainio@gmail.com>
688 2006-12-13 Ville Vainio <vivainio@gmail.com>
683
689
684 * Branch and update Release.py for 0.7.3rc1
690 * Branch and update Release.py for 0.7.3rc1
685
691
686 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
692 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
687
693
688 * IPython/Shell.py (IPShellWX): update for current WX naming
694 * IPython/Shell.py (IPShellWX): update for current WX naming
689 conventions, to avoid a deprecation warning with current WX
695 conventions, to avoid a deprecation warning with current WX
690 versions. Thanks to a report by Danny Shevitz.
696 versions. Thanks to a report by Danny Shevitz.
691
697
692 2006-12-12 Ville Vainio <vivainio@gmail.com>
698 2006-12-12 Ville Vainio <vivainio@gmail.com>
693
699
694 * ipmaker.py: apply david cournapeau's patch to make
700 * ipmaker.py: apply david cournapeau's patch to make
695 import_some work properly even when ipythonrc does
701 import_some work properly even when ipythonrc does
696 import_some on empty list (it was an old bug!).
702 import_some on empty list (it was an old bug!).
697
703
698 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
704 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
699 Add deprecation note to ipythonrc and a url to wiki
705 Add deprecation note to ipythonrc and a url to wiki
700 in ipy_user_conf.py
706 in ipy_user_conf.py
701
707
702
708
703 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
709 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
704 as if it was typed on IPython command prompt, i.e.
710 as if it was typed on IPython command prompt, i.e.
705 as IPython script.
711 as IPython script.
706
712
707 * example-magic.py, magic_grepl.py: remove outdated examples
713 * example-magic.py, magic_grepl.py: remove outdated examples
708
714
709 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
715 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
710
716
711 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
717 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
712 is called before any exception has occurred.
718 is called before any exception has occurred.
713
719
714 2006-12-08 Ville Vainio <vivainio@gmail.com>
720 2006-12-08 Ville Vainio <vivainio@gmail.com>
715
721
716 * Extensions/ipy_stock_completers.py: fix cd completer
722 * Extensions/ipy_stock_completers.py: fix cd completer
717 to translate /'s to \'s again.
723 to translate /'s to \'s again.
718
724
719 * completer.py: prevent traceback on file completions w/
725 * completer.py: prevent traceback on file completions w/
720 backslash.
726 backslash.
721
727
722 * Release.py: Update release number to 0.7.3b3 for release
728 * Release.py: Update release number to 0.7.3b3 for release
723
729
724 2006-12-07 Ville Vainio <vivainio@gmail.com>
730 2006-12-07 Ville Vainio <vivainio@gmail.com>
725
731
726 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
732 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
727 while executing external code. Provides more shell-like behaviour
733 while executing external code. Provides more shell-like behaviour
728 and overall better response to ctrl + C / ctrl + break.
734 and overall better response to ctrl + C / ctrl + break.
729
735
730 * tools/make_tarball.py: new script to create tarball straight from svn
736 * tools/make_tarball.py: new script to create tarball straight from svn
731 (setup.py sdist doesn't work on win32).
737 (setup.py sdist doesn't work on win32).
732
738
733 * Extensions/ipy_stock_completers.py: fix cd completer to give up
739 * Extensions/ipy_stock_completers.py: fix cd completer to give up
734 on dirnames with spaces and use the default completer instead.
740 on dirnames with spaces and use the default completer instead.
735
741
736 * Revision.py: Change version to 0.7.3b2 for release.
742 * Revision.py: Change version to 0.7.3b2 for release.
737
743
738 2006-12-05 Ville Vainio <vivainio@gmail.com>
744 2006-12-05 Ville Vainio <vivainio@gmail.com>
739
745
740 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
746 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
741 pydb patch 4 (rm debug printing, py 2.5 checking)
747 pydb patch 4 (rm debug printing, py 2.5 checking)
742
748
743 2006-11-30 Walter Doerwald <walter@livinglogic.de>
749 2006-11-30 Walter Doerwald <walter@livinglogic.de>
744 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
750 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
745 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
751 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
746 "refreshfind" (mapped to "R") does the same but tries to go back to the same
752 "refreshfind" (mapped to "R") does the same but tries to go back to the same
747 object the cursor was on before the refresh. The command "markrange" is
753 object the cursor was on before the refresh. The command "markrange" is
748 mapped to "%" now.
754 mapped to "%" now.
749 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
755 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
750
756
751 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
757 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
752
758
753 * IPython/Magic.py (magic_debug): new %debug magic to activate the
759 * IPython/Magic.py (magic_debug): new %debug magic to activate the
754 interactive debugger on the last traceback, without having to call
760 interactive debugger on the last traceback, without having to call
755 %pdb and rerun your code. Made minor changes in various modules,
761 %pdb and rerun your code. Made minor changes in various modules,
756 should automatically recognize pydb if available.
762 should automatically recognize pydb if available.
757
763
758 2006-11-28 Ville Vainio <vivainio@gmail.com>
764 2006-11-28 Ville Vainio <vivainio@gmail.com>
759
765
760 * completer.py: If the text start with !, show file completions
766 * completer.py: If the text start with !, show file completions
761 properly. This helps when trying to complete command name
767 properly. This helps when trying to complete command name
762 for shell escapes.
768 for shell escapes.
763
769
764 2006-11-27 Ville Vainio <vivainio@gmail.com>
770 2006-11-27 Ville Vainio <vivainio@gmail.com>
765
771
766 * ipy_stock_completers.py: bzr completer submitted by Stefan van
772 * ipy_stock_completers.py: bzr completer submitted by Stefan van
767 der Walt. Clean up svn and hg completers by using a common
773 der Walt. Clean up svn and hg completers by using a common
768 vcs_completer.
774 vcs_completer.
769
775
770 2006-11-26 Ville Vainio <vivainio@gmail.com>
776 2006-11-26 Ville Vainio <vivainio@gmail.com>
771
777
772 * Remove ipconfig and %config; you should use _ip.options structure
778 * Remove ipconfig and %config; you should use _ip.options structure
773 directly instead!
779 directly instead!
774
780
775 * genutils.py: add wrap_deprecated function for deprecating callables
781 * genutils.py: add wrap_deprecated function for deprecating callables
776
782
777 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
783 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
778 _ip.system instead. ipalias is redundant.
784 _ip.system instead. ipalias is redundant.
779
785
780 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
786 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
781 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
787 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
782 explicit.
788 explicit.
783
789
784 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
790 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
785 completer. Try it by entering 'hg ' and pressing tab.
791 completer. Try it by entering 'hg ' and pressing tab.
786
792
787 * macro.py: Give Macro a useful __repr__ method
793 * macro.py: Give Macro a useful __repr__ method
788
794
789 * Magic.py: %whos abbreviates the typename of Macro for brevity.
795 * Magic.py: %whos abbreviates the typename of Macro for brevity.
790
796
791 2006-11-24 Walter Doerwald <walter@livinglogic.de>
797 2006-11-24 Walter Doerwald <walter@livinglogic.de>
792 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
798 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
793 we don't get a duplicate ipipe module, where registration of the xrepr
799 we don't get a duplicate ipipe module, where registration of the xrepr
794 implementation for Text is useless.
800 implementation for Text is useless.
795
801
796 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
802 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
797
803
798 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
804 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
799
805
800 2006-11-24 Ville Vainio <vivainio@gmail.com>
806 2006-11-24 Ville Vainio <vivainio@gmail.com>
801
807
802 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
808 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
803 try to use "cProfile" instead of the slower pure python
809 try to use "cProfile" instead of the slower pure python
804 "profile"
810 "profile"
805
811
806 2006-11-23 Ville Vainio <vivainio@gmail.com>
812 2006-11-23 Ville Vainio <vivainio@gmail.com>
807
813
808 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
814 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
809 Qt+IPython+Designer link in documentation.
815 Qt+IPython+Designer link in documentation.
810
816
811 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
817 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
812 correct Pdb object to %pydb.
818 correct Pdb object to %pydb.
813
819
814
820
815 2006-11-22 Walter Doerwald <walter@livinglogic.de>
821 2006-11-22 Walter Doerwald <walter@livinglogic.de>
816 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
822 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
817 generic xrepr(), otherwise the list implementation would kick in.
823 generic xrepr(), otherwise the list implementation would kick in.
818
824
819 2006-11-21 Ville Vainio <vivainio@gmail.com>
825 2006-11-21 Ville Vainio <vivainio@gmail.com>
820
826
821 * upgrade_dir.py: Now actually overwrites a nonmodified user file
827 * upgrade_dir.py: Now actually overwrites a nonmodified user file
822 with one from UserConfig.
828 with one from UserConfig.
823
829
824 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
830 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
825 it was missing which broke the sh profile.
831 it was missing which broke the sh profile.
826
832
827 * completer.py: file completer now uses explicit '/' instead
833 * completer.py: file completer now uses explicit '/' instead
828 of os.path.join, expansion of 'foo' was broken on win32
834 of os.path.join, expansion of 'foo' was broken on win32
829 if there was one directory with name 'foobar'.
835 if there was one directory with name 'foobar'.
830
836
831 * A bunch of patches from Kirill Smelkov:
837 * A bunch of patches from Kirill Smelkov:
832
838
833 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
839 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
834
840
835 * [patch 7/9] Implement %page -r (page in raw mode) -
841 * [patch 7/9] Implement %page -r (page in raw mode) -
836
842
837 * [patch 5/9] ScientificPython webpage has moved
843 * [patch 5/9] ScientificPython webpage has moved
838
844
839 * [patch 4/9] The manual mentions %ds, should be %dhist
845 * [patch 4/9] The manual mentions %ds, should be %dhist
840
846
841 * [patch 3/9] Kill old bits from %prun doc.
847 * [patch 3/9] Kill old bits from %prun doc.
842
848
843 * [patch 1/9] Fix typos here and there.
849 * [patch 1/9] Fix typos here and there.
844
850
845 2006-11-08 Ville Vainio <vivainio@gmail.com>
851 2006-11-08 Ville Vainio <vivainio@gmail.com>
846
852
847 * completer.py (attr_matches): catch all exceptions raised
853 * completer.py (attr_matches): catch all exceptions raised
848 by eval of expr with dots.
854 by eval of expr with dots.
849
855
850 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
856 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
851
857
852 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
858 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
853 input if it starts with whitespace. This allows you to paste
859 input if it starts with whitespace. This allows you to paste
854 indented input from any editor without manually having to type in
860 indented input from any editor without manually having to type in
855 the 'if 1:', which is convenient when working interactively.
861 the 'if 1:', which is convenient when working interactively.
856 Slightly modifed version of a patch by Bo Peng
862 Slightly modifed version of a patch by Bo Peng
857 <bpeng-AT-rice.edu>.
863 <bpeng-AT-rice.edu>.
858
864
859 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
865 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
860
866
861 * IPython/irunner.py (main): modified irunner so it automatically
867 * IPython/irunner.py (main): modified irunner so it automatically
862 recognizes the right runner to use based on the extension (.py for
868 recognizes the right runner to use based on the extension (.py for
863 python, .ipy for ipython and .sage for sage).
869 python, .ipy for ipython and .sage for sage).
864
870
865 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
871 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
866 visible in ipapi as ip.config(), to programatically control the
872 visible in ipapi as ip.config(), to programatically control the
867 internal rc object. There's an accompanying %config magic for
873 internal rc object. There's an accompanying %config magic for
868 interactive use, which has been enhanced to match the
874 interactive use, which has been enhanced to match the
869 funtionality in ipconfig.
875 funtionality in ipconfig.
870
876
871 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
877 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
872 so it's not just a toggle, it now takes an argument. Add support
878 so it's not just a toggle, it now takes an argument. Add support
873 for a customizable header when making system calls, as the new
879 for a customizable header when making system calls, as the new
874 system_header variable in the ipythonrc file.
880 system_header variable in the ipythonrc file.
875
881
876 2006-11-03 Walter Doerwald <walter@livinglogic.de>
882 2006-11-03 Walter Doerwald <walter@livinglogic.de>
877
883
878 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
884 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
879 generic functions (using Philip J. Eby's simplegeneric package).
885 generic functions (using Philip J. Eby's simplegeneric package).
880 This makes it possible to customize the display of third-party classes
886 This makes it possible to customize the display of third-party classes
881 without having to monkeypatch them. xiter() no longer supports a mode
887 without having to monkeypatch them. xiter() no longer supports a mode
882 argument and the XMode class has been removed. The same functionality can
888 argument and the XMode class has been removed. The same functionality can
883 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
889 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
884 One consequence of the switch to generic functions is that xrepr() and
890 One consequence of the switch to generic functions is that xrepr() and
885 xattrs() implementation must define the default value for the mode
891 xattrs() implementation must define the default value for the mode
886 argument themselves and xattrs() implementations must return real
892 argument themselves and xattrs() implementations must return real
887 descriptors.
893 descriptors.
888
894
889 * IPython/external: This new subpackage will contain all third-party
895 * IPython/external: This new subpackage will contain all third-party
890 packages that are bundled with IPython. (The first one is simplegeneric).
896 packages that are bundled with IPython. (The first one is simplegeneric).
891
897
892 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
898 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
893 directory which as been dropped in r1703.
899 directory which as been dropped in r1703.
894
900
895 * IPython/Extensions/ipipe.py (iless): Fixed.
901 * IPython/Extensions/ipipe.py (iless): Fixed.
896
902
897 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
903 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
898
904
899 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
905 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
900
906
901 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
907 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
902 handling in variable expansion so that shells and magics recognize
908 handling in variable expansion so that shells and magics recognize
903 function local scopes correctly. Bug reported by Brian.
909 function local scopes correctly. Bug reported by Brian.
904
910
905 * scripts/ipython: remove the very first entry in sys.path which
911 * scripts/ipython: remove the very first entry in sys.path which
906 Python auto-inserts for scripts, so that sys.path under IPython is
912 Python auto-inserts for scripts, so that sys.path under IPython is
907 as similar as possible to that under plain Python.
913 as similar as possible to that under plain Python.
908
914
909 * IPython/completer.py (IPCompleter.file_matches): Fix
915 * IPython/completer.py (IPCompleter.file_matches): Fix
910 tab-completion so that quotes are not closed unless the completion
916 tab-completion so that quotes are not closed unless the completion
911 is unambiguous. After a request by Stefan. Minor cleanups in
917 is unambiguous. After a request by Stefan. Minor cleanups in
912 ipy_stock_completers.
918 ipy_stock_completers.
913
919
914 2006-11-02 Ville Vainio <vivainio@gmail.com>
920 2006-11-02 Ville Vainio <vivainio@gmail.com>
915
921
916 * ipy_stock_completers.py: Add %run and %cd completers.
922 * ipy_stock_completers.py: Add %run and %cd completers.
917
923
918 * completer.py: Try running custom completer for both
924 * completer.py: Try running custom completer for both
919 "foo" and "%foo" if the command is just "foo". Ignore case
925 "foo" and "%foo" if the command is just "foo". Ignore case
920 when filtering possible completions.
926 when filtering possible completions.
921
927
922 * UserConfig/ipy_user_conf.py: install stock completers as default
928 * UserConfig/ipy_user_conf.py: install stock completers as default
923
929
924 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
930 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
925 simplified readline history save / restore through a wrapper
931 simplified readline history save / restore through a wrapper
926 function
932 function
927
933
928
934
929 2006-10-31 Ville Vainio <vivainio@gmail.com>
935 2006-10-31 Ville Vainio <vivainio@gmail.com>
930
936
931 * strdispatch.py, completer.py, ipy_stock_completers.py:
937 * strdispatch.py, completer.py, ipy_stock_completers.py:
932 Allow str_key ("command") in completer hooks. Implement
938 Allow str_key ("command") in completer hooks. Implement
933 trivial completer for 'import' (stdlib modules only). Rename
939 trivial completer for 'import' (stdlib modules only). Rename
934 ipy_linux_package_managers.py to ipy_stock_completers.py.
940 ipy_linux_package_managers.py to ipy_stock_completers.py.
935 SVN completer.
941 SVN completer.
936
942
937 * Extensions/ledit.py: %magic line editor for easily and
943 * Extensions/ledit.py: %magic line editor for easily and
938 incrementally manipulating lists of strings. The magic command
944 incrementally manipulating lists of strings. The magic command
939 name is %led.
945 name is %led.
940
946
941 2006-10-30 Ville Vainio <vivainio@gmail.com>
947 2006-10-30 Ville Vainio <vivainio@gmail.com>
942
948
943 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
949 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
944 Bernsteins's patches for pydb integration.
950 Bernsteins's patches for pydb integration.
945 http://bashdb.sourceforge.net/pydb/
951 http://bashdb.sourceforge.net/pydb/
946
952
947 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
953 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
948 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
954 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
949 custom completer hook to allow the users to implement their own
955 custom completer hook to allow the users to implement their own
950 completers. See ipy_linux_package_managers.py for example. The
956 completers. See ipy_linux_package_managers.py for example. The
951 hook name is 'complete_command'.
957 hook name is 'complete_command'.
952
958
953 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
959 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
954
960
955 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
961 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
956 Numeric leftovers.
962 Numeric leftovers.
957
963
958 * ipython.el (py-execute-region): apply Stefan's patch to fix
964 * ipython.el (py-execute-region): apply Stefan's patch to fix
959 garbled results if the python shell hasn't been previously started.
965 garbled results if the python shell hasn't been previously started.
960
966
961 * IPython/genutils.py (arg_split): moved to genutils, since it's a
967 * IPython/genutils.py (arg_split): moved to genutils, since it's a
962 pretty generic function and useful for other things.
968 pretty generic function and useful for other things.
963
969
964 * IPython/OInspect.py (getsource): Add customizable source
970 * IPython/OInspect.py (getsource): Add customizable source
965 extractor. After a request/patch form W. Stein (SAGE).
971 extractor. After a request/patch form W. Stein (SAGE).
966
972
967 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
973 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
968 window size to a more reasonable value from what pexpect does,
974 window size to a more reasonable value from what pexpect does,
969 since their choice causes wrapping bugs with long input lines.
975 since their choice causes wrapping bugs with long input lines.
970
976
971 2006-10-28 Ville Vainio <vivainio@gmail.com>
977 2006-10-28 Ville Vainio <vivainio@gmail.com>
972
978
973 * Magic.py (%run): Save and restore the readline history from
979 * Magic.py (%run): Save and restore the readline history from
974 file around %run commands to prevent side effects from
980 file around %run commands to prevent side effects from
975 %runned programs that might use readline (e.g. pydb).
981 %runned programs that might use readline (e.g. pydb).
976
982
977 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
983 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
978 invoking the pydb enhanced debugger.
984 invoking the pydb enhanced debugger.
979
985
980 2006-10-23 Walter Doerwald <walter@livinglogic.de>
986 2006-10-23 Walter Doerwald <walter@livinglogic.de>
981
987
982 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
988 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
983 call the base class method and propagate the return value to
989 call the base class method and propagate the return value to
984 ifile. This is now done by path itself.
990 ifile. This is now done by path itself.
985
991
986 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
992 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
987
993
988 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
994 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
989 api: set_crash_handler(), to expose the ability to change the
995 api: set_crash_handler(), to expose the ability to change the
990 internal crash handler.
996 internal crash handler.
991
997
992 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
998 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
993 the various parameters of the crash handler so that apps using
999 the various parameters of the crash handler so that apps using
994 IPython as their engine can customize crash handling. Ipmlemented
1000 IPython as their engine can customize crash handling. Ipmlemented
995 at the request of SAGE.
1001 at the request of SAGE.
996
1002
997 2006-10-14 Ville Vainio <vivainio@gmail.com>
1003 2006-10-14 Ville Vainio <vivainio@gmail.com>
998
1004
999 * Magic.py, ipython.el: applied first "safe" part of Rocky
1005 * Magic.py, ipython.el: applied first "safe" part of Rocky
1000 Bernstein's patch set for pydb integration.
1006 Bernstein's patch set for pydb integration.
1001
1007
1002 * Magic.py (%unalias, %alias): %store'd aliases can now be
1008 * Magic.py (%unalias, %alias): %store'd aliases can now be
1003 removed with '%unalias'. %alias w/o args now shows most
1009 removed with '%unalias'. %alias w/o args now shows most
1004 interesting (stored / manually defined) aliases last
1010 interesting (stored / manually defined) aliases last
1005 where they catch the eye w/o scrolling.
1011 where they catch the eye w/o scrolling.
1006
1012
1007 * Magic.py (%rehashx), ext_rehashdir.py: files with
1013 * Magic.py (%rehashx), ext_rehashdir.py: files with
1008 'py' extension are always considered executable, even
1014 'py' extension are always considered executable, even
1009 when not in PATHEXT environment variable.
1015 when not in PATHEXT environment variable.
1010
1016
1011 2006-10-12 Ville Vainio <vivainio@gmail.com>
1017 2006-10-12 Ville Vainio <vivainio@gmail.com>
1012
1018
1013 * jobctrl.py: Add new "jobctrl" extension for spawning background
1019 * jobctrl.py: Add new "jobctrl" extension for spawning background
1014 processes with "&find /". 'import jobctrl' to try it out. Requires
1020 processes with "&find /". 'import jobctrl' to try it out. Requires
1015 'subprocess' module, standard in python 2.4+.
1021 'subprocess' module, standard in python 2.4+.
1016
1022
1017 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1023 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1018 so if foo -> bar and bar -> baz, then foo -> baz.
1024 so if foo -> bar and bar -> baz, then foo -> baz.
1019
1025
1020 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1026 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1021
1027
1022 * IPython/Magic.py (Magic.parse_options): add a new posix option
1028 * IPython/Magic.py (Magic.parse_options): add a new posix option
1023 to allow parsing of input args in magics that doesn't strip quotes
1029 to allow parsing of input args in magics that doesn't strip quotes
1024 (if posix=False). This also closes %timeit bug reported by
1030 (if posix=False). This also closes %timeit bug reported by
1025 Stefan.
1031 Stefan.
1026
1032
1027 2006-10-03 Ville Vainio <vivainio@gmail.com>
1033 2006-10-03 Ville Vainio <vivainio@gmail.com>
1028
1034
1029 * iplib.py (raw_input, interact): Return ValueError catching for
1035 * iplib.py (raw_input, interact): Return ValueError catching for
1030 raw_input. Fixes infinite loop for sys.stdin.close() or
1036 raw_input. Fixes infinite loop for sys.stdin.close() or
1031 sys.stdout.close().
1037 sys.stdout.close().
1032
1038
1033 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1039 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1034
1040
1035 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1041 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1036 to help in handling doctests. irunner is now pretty useful for
1042 to help in handling doctests. irunner is now pretty useful for
1037 running standalone scripts and simulate a full interactive session
1043 running standalone scripts and simulate a full interactive session
1038 in a format that can be then pasted as a doctest.
1044 in a format that can be then pasted as a doctest.
1039
1045
1040 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1046 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1041 on top of the default (useless) ones. This also fixes the nasty
1047 on top of the default (useless) ones. This also fixes the nasty
1042 way in which 2.5's Quitter() exits (reverted [1785]).
1048 way in which 2.5's Quitter() exits (reverted [1785]).
1043
1049
1044 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1050 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1045 2.5.
1051 2.5.
1046
1052
1047 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1053 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1048 color scheme is updated as well when color scheme is changed
1054 color scheme is updated as well when color scheme is changed
1049 interactively.
1055 interactively.
1050
1056
1051 2006-09-27 Ville Vainio <vivainio@gmail.com>
1057 2006-09-27 Ville Vainio <vivainio@gmail.com>
1052
1058
1053 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1059 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1054 infinite loop and just exit. It's a hack, but will do for a while.
1060 infinite loop and just exit. It's a hack, but will do for a while.
1055
1061
1056 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1062 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1057
1063
1058 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1064 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1059 the constructor, this makes it possible to get a list of only directories
1065 the constructor, this makes it possible to get a list of only directories
1060 or only files.
1066 or only files.
1061
1067
1062 2006-08-12 Ville Vainio <vivainio@gmail.com>
1068 2006-08-12 Ville Vainio <vivainio@gmail.com>
1063
1069
1064 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1070 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1065 they broke unittest
1071 they broke unittest
1066
1072
1067 2006-08-11 Ville Vainio <vivainio@gmail.com>
1073 2006-08-11 Ville Vainio <vivainio@gmail.com>
1068
1074
1069 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1075 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1070 by resolving issue properly, i.e. by inheriting FakeModule
1076 by resolving issue properly, i.e. by inheriting FakeModule
1071 from types.ModuleType. Pickling ipython interactive data
1077 from types.ModuleType. Pickling ipython interactive data
1072 should still work as usual (testing appreciated).
1078 should still work as usual (testing appreciated).
1073
1079
1074 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1080 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1075
1081
1076 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1082 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1077 running under python 2.3 with code from 2.4 to fix a bug with
1083 running under python 2.3 with code from 2.4 to fix a bug with
1078 help(). Reported by the Debian maintainers, Norbert Tretkowski
1084 help(). Reported by the Debian maintainers, Norbert Tretkowski
1079 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1085 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1080 <afayolle-AT-debian.org>.
1086 <afayolle-AT-debian.org>.
1081
1087
1082 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1088 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1083
1089
1084 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1090 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1085 (which was displaying "quit" twice).
1091 (which was displaying "quit" twice).
1086
1092
1087 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1093 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1088
1094
1089 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1095 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1090 the mode argument).
1096 the mode argument).
1091
1097
1092 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1098 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1093
1099
1094 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1100 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1095 not running under IPython.
1101 not running under IPython.
1096
1102
1097 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1103 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1098 and make it iterable (iterating over the attribute itself). Add two new
1104 and make it iterable (iterating over the attribute itself). Add two new
1099 magic strings for __xattrs__(): If the string starts with "-", the attribute
1105 magic strings for __xattrs__(): If the string starts with "-", the attribute
1100 will not be displayed in ibrowse's detail view (but it can still be
1106 will not be displayed in ibrowse's detail view (but it can still be
1101 iterated over). This makes it possible to add attributes that are large
1107 iterated over). This makes it possible to add attributes that are large
1102 lists or generator methods to the detail view. Replace magic attribute names
1108 lists or generator methods to the detail view. Replace magic attribute names
1103 and _attrname() and _getattr() with "descriptors": For each type of magic
1109 and _attrname() and _getattr() with "descriptors": For each type of magic
1104 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1110 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1105 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1111 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1106 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1112 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1107 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1113 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1108 are still supported.
1114 are still supported.
1109
1115
1110 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1116 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1111 fails in ibrowse.fetch(), the exception object is added as the last item
1117 fails in ibrowse.fetch(), the exception object is added as the last item
1112 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1118 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1113 a generator throws an exception midway through execution.
1119 a generator throws an exception midway through execution.
1114
1120
1115 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1121 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1116 encoding into methods.
1122 encoding into methods.
1117
1123
1118 2006-07-26 Ville Vainio <vivainio@gmail.com>
1124 2006-07-26 Ville Vainio <vivainio@gmail.com>
1119
1125
1120 * iplib.py: history now stores multiline input as single
1126 * iplib.py: history now stores multiline input as single
1121 history entries. Patch by Jorgen Cederlof.
1127 history entries. Patch by Jorgen Cederlof.
1122
1128
1123 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1129 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1124
1130
1125 * IPython/Extensions/ibrowse.py: Make cursor visible over
1131 * IPython/Extensions/ibrowse.py: Make cursor visible over
1126 non existing attributes.
1132 non existing attributes.
1127
1133
1128 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1134 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1129
1135
1130 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1136 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1131 error output of the running command doesn't mess up the screen.
1137 error output of the running command doesn't mess up the screen.
1132
1138
1133 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1139 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1134
1140
1135 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1141 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1136 argument. This sorts the items themselves.
1142 argument. This sorts the items themselves.
1137
1143
1138 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1144 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1139
1145
1140 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1146 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1141 Compile expression strings into code objects. This should speed
1147 Compile expression strings into code objects. This should speed
1142 up ifilter and friends somewhat.
1148 up ifilter and friends somewhat.
1143
1149
1144 2006-07-08 Ville Vainio <vivainio@gmail.com>
1150 2006-07-08 Ville Vainio <vivainio@gmail.com>
1145
1151
1146 * Magic.py: %cpaste now strips > from the beginning of lines
1152 * Magic.py: %cpaste now strips > from the beginning of lines
1147 to ease pasting quoted code from emails. Contributed by
1153 to ease pasting quoted code from emails. Contributed by
1148 Stefan van der Walt.
1154 Stefan van der Walt.
1149
1155
1150 2006-06-29 Ville Vainio <vivainio@gmail.com>
1156 2006-06-29 Ville Vainio <vivainio@gmail.com>
1151
1157
1152 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1158 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1153 mode, patch contributed by Darren Dale. NEEDS TESTING!
1159 mode, patch contributed by Darren Dale. NEEDS TESTING!
1154
1160
1155 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1161 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1156
1162
1157 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1163 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1158 a blue background. Fix fetching new display rows when the browser
1164 a blue background. Fix fetching new display rows when the browser
1159 scrolls more than a screenful (e.g. by using the goto command).
1165 scrolls more than a screenful (e.g. by using the goto command).
1160
1166
1161 2006-06-27 Ville Vainio <vivainio@gmail.com>
1167 2006-06-27 Ville Vainio <vivainio@gmail.com>
1162
1168
1163 * Magic.py (_inspect, _ofind) Apply David Huard's
1169 * Magic.py (_inspect, _ofind) Apply David Huard's
1164 patch for displaying the correct docstring for 'property'
1170 patch for displaying the correct docstring for 'property'
1165 attributes.
1171 attributes.
1166
1172
1167 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1173 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1168
1174
1169 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1175 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1170 commands into the methods implementing them.
1176 commands into the methods implementing them.
1171
1177
1172 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1178 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1173
1179
1174 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1180 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1175 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1181 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1176 autoindent support was authored by Jin Liu.
1182 autoindent support was authored by Jin Liu.
1177
1183
1178 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1184 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1179
1185
1180 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1186 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1181 for keymaps with a custom class that simplifies handling.
1187 for keymaps with a custom class that simplifies handling.
1182
1188
1183 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1189 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1184
1190
1185 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1191 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1186 resizing. This requires Python 2.5 to work.
1192 resizing. This requires Python 2.5 to work.
1187
1193
1188 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1194 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1189
1195
1190 * IPython/Extensions/ibrowse.py: Add two new commands to
1196 * IPython/Extensions/ibrowse.py: Add two new commands to
1191 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1197 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1192 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1198 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1193 attributes again. Remapped the help command to "?". Display
1199 attributes again. Remapped the help command to "?". Display
1194 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1200 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1195 as keys for the "home" and "end" commands. Add three new commands
1201 as keys for the "home" and "end" commands. Add three new commands
1196 to the input mode for "find" and friends: "delend" (CTRL-K)
1202 to the input mode for "find" and friends: "delend" (CTRL-K)
1197 deletes to the end of line. "incsearchup" searches upwards in the
1203 deletes to the end of line. "incsearchup" searches upwards in the
1198 command history for an input that starts with the text before the cursor.
1204 command history for an input that starts with the text before the cursor.
1199 "incsearchdown" does the same downwards. Removed a bogus mapping of
1205 "incsearchdown" does the same downwards. Removed a bogus mapping of
1200 the x key to "delete".
1206 the x key to "delete".
1201
1207
1202 2006-06-15 Ville Vainio <vivainio@gmail.com>
1208 2006-06-15 Ville Vainio <vivainio@gmail.com>
1203
1209
1204 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1210 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1205 used to create prompts dynamically, instead of the "old" way of
1211 used to create prompts dynamically, instead of the "old" way of
1206 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1212 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1207 way still works (it's invoked by the default hook), of course.
1213 way still works (it's invoked by the default hook), of course.
1208
1214
1209 * Prompts.py: added generate_output_prompt hook for altering output
1215 * Prompts.py: added generate_output_prompt hook for altering output
1210 prompt
1216 prompt
1211
1217
1212 * Release.py: Changed version string to 0.7.3.svn.
1218 * Release.py: Changed version string to 0.7.3.svn.
1213
1219
1214 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1220 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1215
1221
1216 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1222 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1217 the call to fetch() always tries to fetch enough data for at least one
1223 the call to fetch() always tries to fetch enough data for at least one
1218 full screen. This makes it possible to simply call moveto(0,0,True) in
1224 full screen. This makes it possible to simply call moveto(0,0,True) in
1219 the constructor. Fix typos and removed the obsolete goto attribute.
1225 the constructor. Fix typos and removed the obsolete goto attribute.
1220
1226
1221 2006-06-12 Ville Vainio <vivainio@gmail.com>
1227 2006-06-12 Ville Vainio <vivainio@gmail.com>
1222
1228
1223 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1229 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1224 allowing $variable interpolation within multiline statements,
1230 allowing $variable interpolation within multiline statements,
1225 though so far only with "sh" profile for a testing period.
1231 though so far only with "sh" profile for a testing period.
1226 The patch also enables splitting long commands with \ but it
1232 The patch also enables splitting long commands with \ but it
1227 doesn't work properly yet.
1233 doesn't work properly yet.
1228
1234
1229 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1235 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1230
1236
1231 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1237 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1232 input history and the position of the cursor in the input history for
1238 input history and the position of the cursor in the input history for
1233 the find, findbackwards and goto command.
1239 the find, findbackwards and goto command.
1234
1240
1235 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1241 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1236
1242
1237 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1243 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1238 implements the basic functionality of browser commands that require
1244 implements the basic functionality of browser commands that require
1239 input. Reimplement the goto, find and findbackwards commands as
1245 input. Reimplement the goto, find and findbackwards commands as
1240 subclasses of _CommandInput. Add an input history and keymaps to those
1246 subclasses of _CommandInput. Add an input history and keymaps to those
1241 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1247 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1242 execute commands.
1248 execute commands.
1243
1249
1244 2006-06-07 Ville Vainio <vivainio@gmail.com>
1250 2006-06-07 Ville Vainio <vivainio@gmail.com>
1245
1251
1246 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1252 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1247 running the batch files instead of leaving the session open.
1253 running the batch files instead of leaving the session open.
1248
1254
1249 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1255 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1250
1256
1251 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1257 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1252 the original fix was incomplete. Patch submitted by W. Maier.
1258 the original fix was incomplete. Patch submitted by W. Maier.
1253
1259
1254 2006-06-07 Ville Vainio <vivainio@gmail.com>
1260 2006-06-07 Ville Vainio <vivainio@gmail.com>
1255
1261
1256 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1262 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1257 Confirmation prompts can be supressed by 'quiet' option.
1263 Confirmation prompts can be supressed by 'quiet' option.
1258 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1264 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1259
1265
1260 2006-06-06 *** Released version 0.7.2
1266 2006-06-06 *** Released version 0.7.2
1261
1267
1262 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1268 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1263
1269
1264 * IPython/Release.py (version): Made 0.7.2 final for release.
1270 * IPython/Release.py (version): Made 0.7.2 final for release.
1265 Repo tagged and release cut.
1271 Repo tagged and release cut.
1266
1272
1267 2006-06-05 Ville Vainio <vivainio@gmail.com>
1273 2006-06-05 Ville Vainio <vivainio@gmail.com>
1268
1274
1269 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1275 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1270 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1276 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1271
1277
1272 * upgrade_dir.py: try import 'path' module a bit harder
1278 * upgrade_dir.py: try import 'path' module a bit harder
1273 (for %upgrade)
1279 (for %upgrade)
1274
1280
1275 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1281 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1276
1282
1277 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1283 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1278 instead of looping 20 times.
1284 instead of looping 20 times.
1279
1285
1280 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1286 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1281 correctly at initialization time. Bug reported by Krishna Mohan
1287 correctly at initialization time. Bug reported by Krishna Mohan
1282 Gundu <gkmohan-AT-gmail.com> on the user list.
1288 Gundu <gkmohan-AT-gmail.com> on the user list.
1283
1289
1284 * IPython/Release.py (version): Mark 0.7.2 version to start
1290 * IPython/Release.py (version): Mark 0.7.2 version to start
1285 testing for release on 06/06.
1291 testing for release on 06/06.
1286
1292
1287 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1293 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1288
1294
1289 * scripts/irunner: thin script interface so users don't have to
1295 * scripts/irunner: thin script interface so users don't have to
1290 find the module and call it as an executable, since modules rarely
1296 find the module and call it as an executable, since modules rarely
1291 live in people's PATH.
1297 live in people's PATH.
1292
1298
1293 * IPython/irunner.py (InteractiveRunner.__init__): added
1299 * IPython/irunner.py (InteractiveRunner.__init__): added
1294 delaybeforesend attribute to control delays with newer versions of
1300 delaybeforesend attribute to control delays with newer versions of
1295 pexpect. Thanks to detailed help from pexpect's author, Noah
1301 pexpect. Thanks to detailed help from pexpect's author, Noah
1296 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1302 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1297 correctly (it works in NoColor mode).
1303 correctly (it works in NoColor mode).
1298
1304
1299 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1305 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1300 SAGE list, from improper log() calls.
1306 SAGE list, from improper log() calls.
1301
1307
1302 2006-05-31 Ville Vainio <vivainio@gmail.com>
1308 2006-05-31 Ville Vainio <vivainio@gmail.com>
1303
1309
1304 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1310 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1305 with args in parens to work correctly with dirs that have spaces.
1311 with args in parens to work correctly with dirs that have spaces.
1306
1312
1307 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1313 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1308
1314
1309 * IPython/Logger.py (Logger.logstart): add option to log raw input
1315 * IPython/Logger.py (Logger.logstart): add option to log raw input
1310 instead of the processed one. A -r flag was added to the
1316 instead of the processed one. A -r flag was added to the
1311 %logstart magic used for controlling logging.
1317 %logstart magic used for controlling logging.
1312
1318
1313 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1319 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1314
1320
1315 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1321 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1316 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1322 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1317 recognize the option. After a bug report by Will Maier. This
1323 recognize the option. After a bug report by Will Maier. This
1318 closes #64 (will do it after confirmation from W. Maier).
1324 closes #64 (will do it after confirmation from W. Maier).
1319
1325
1320 * IPython/irunner.py: New module to run scripts as if manually
1326 * IPython/irunner.py: New module to run scripts as if manually
1321 typed into an interactive environment, based on pexpect. After a
1327 typed into an interactive environment, based on pexpect. After a
1322 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1328 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1323 ipython-user list. Simple unittests in the tests/ directory.
1329 ipython-user list. Simple unittests in the tests/ directory.
1324
1330
1325 * tools/release: add Will Maier, OpenBSD port maintainer, to
1331 * tools/release: add Will Maier, OpenBSD port maintainer, to
1326 recepients list. We are now officially part of the OpenBSD ports:
1332 recepients list. We are now officially part of the OpenBSD ports:
1327 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1333 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1328 work.
1334 work.
1329
1335
1330 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1336 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1331
1337
1332 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1338 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1333 so that it doesn't break tkinter apps.
1339 so that it doesn't break tkinter apps.
1334
1340
1335 * IPython/iplib.py (_prefilter): fix bug where aliases would
1341 * IPython/iplib.py (_prefilter): fix bug where aliases would
1336 shadow variables when autocall was fully off. Reported by SAGE
1342 shadow variables when autocall was fully off. Reported by SAGE
1337 author William Stein.
1343 author William Stein.
1338
1344
1339 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1345 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1340 at what detail level strings are computed when foo? is requested.
1346 at what detail level strings are computed when foo? is requested.
1341 This allows users to ask for example that the string form of an
1347 This allows users to ask for example that the string form of an
1342 object is only computed when foo?? is called, or even never, by
1348 object is only computed when foo?? is called, or even never, by
1343 setting the object_info_string_level >= 2 in the configuration
1349 setting the object_info_string_level >= 2 in the configuration
1344 file. This new option has been added and documented. After a
1350 file. This new option has been added and documented. After a
1345 request by SAGE to be able to control the printing of very large
1351 request by SAGE to be able to control the printing of very large
1346 objects more easily.
1352 objects more easily.
1347
1353
1348 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1354 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1349
1355
1350 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1356 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1351 from sys.argv, to be 100% consistent with how Python itself works
1357 from sys.argv, to be 100% consistent with how Python itself works
1352 (as seen for example with python -i file.py). After a bug report
1358 (as seen for example with python -i file.py). After a bug report
1353 by Jeffrey Collins.
1359 by Jeffrey Collins.
1354
1360
1355 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1361 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1356 nasty bug which was preventing custom namespaces with -pylab,
1362 nasty bug which was preventing custom namespaces with -pylab,
1357 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1363 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1358 compatibility (long gone from mpl).
1364 compatibility (long gone from mpl).
1359
1365
1360 * IPython/ipapi.py (make_session): name change: create->make. We
1366 * IPython/ipapi.py (make_session): name change: create->make. We
1361 use make in other places (ipmaker,...), it's shorter and easier to
1367 use make in other places (ipmaker,...), it's shorter and easier to
1362 type and say, etc. I'm trying to clean things before 0.7.2 so
1368 type and say, etc. I'm trying to clean things before 0.7.2 so
1363 that I can keep things stable wrt to ipapi in the chainsaw branch.
1369 that I can keep things stable wrt to ipapi in the chainsaw branch.
1364
1370
1365 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1371 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1366 python-mode recognizes our debugger mode. Add support for
1372 python-mode recognizes our debugger mode. Add support for
1367 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1373 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1368 <m.liu.jin-AT-gmail.com> originally written by
1374 <m.liu.jin-AT-gmail.com> originally written by
1369 doxgen-AT-newsmth.net (with minor modifications for xemacs
1375 doxgen-AT-newsmth.net (with minor modifications for xemacs
1370 compatibility)
1376 compatibility)
1371
1377
1372 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1378 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1373 tracebacks when walking the stack so that the stack tracking system
1379 tracebacks when walking the stack so that the stack tracking system
1374 in emacs' python-mode can identify the frames correctly.
1380 in emacs' python-mode can identify the frames correctly.
1375
1381
1376 * IPython/ipmaker.py (make_IPython): make the internal (and
1382 * IPython/ipmaker.py (make_IPython): make the internal (and
1377 default config) autoedit_syntax value false by default. Too many
1383 default config) autoedit_syntax value false by default. Too many
1378 users have complained to me (both on and off-list) about problems
1384 users have complained to me (both on and off-list) about problems
1379 with this option being on by default, so I'm making it default to
1385 with this option being on by default, so I'm making it default to
1380 off. It can still be enabled by anyone via the usual mechanisms.
1386 off. It can still be enabled by anyone via the usual mechanisms.
1381
1387
1382 * IPython/completer.py (Completer.attr_matches): add support for
1388 * IPython/completer.py (Completer.attr_matches): add support for
1383 PyCrust-style _getAttributeNames magic method. Patch contributed
1389 PyCrust-style _getAttributeNames magic method. Patch contributed
1384 by <mscott-AT-goldenspud.com>. Closes #50.
1390 by <mscott-AT-goldenspud.com>. Closes #50.
1385
1391
1386 * IPython/iplib.py (InteractiveShell.__init__): remove the
1392 * IPython/iplib.py (InteractiveShell.__init__): remove the
1387 deletion of exit/quit from __builtin__, which can break
1393 deletion of exit/quit from __builtin__, which can break
1388 third-party tools like the Zope debugging console. The
1394 third-party tools like the Zope debugging console. The
1389 %exit/%quit magics remain. In general, it's probably a good idea
1395 %exit/%quit magics remain. In general, it's probably a good idea
1390 not to delete anything from __builtin__, since we never know what
1396 not to delete anything from __builtin__, since we never know what
1391 that will break. In any case, python now (for 2.5) will support
1397 that will break. In any case, python now (for 2.5) will support
1392 'real' exit/quit, so this issue is moot. Closes #55.
1398 'real' exit/quit, so this issue is moot. Closes #55.
1393
1399
1394 * IPython/genutils.py (with_obj): rename the 'with' function to
1400 * IPython/genutils.py (with_obj): rename the 'with' function to
1395 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1401 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1396 becomes a language keyword. Closes #53.
1402 becomes a language keyword. Closes #53.
1397
1403
1398 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1404 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1399 __file__ attribute to this so it fools more things into thinking
1405 __file__ attribute to this so it fools more things into thinking
1400 it is a real module. Closes #59.
1406 it is a real module. Closes #59.
1401
1407
1402 * IPython/Magic.py (magic_edit): add -n option to open the editor
1408 * IPython/Magic.py (magic_edit): add -n option to open the editor
1403 at a specific line number. After a patch by Stefan van der Walt.
1409 at a specific line number. After a patch by Stefan van der Walt.
1404
1410
1405 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1411 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1406
1412
1407 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1413 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1408 reason the file could not be opened. After automatic crash
1414 reason the file could not be opened. After automatic crash
1409 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1415 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1410 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1416 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1411 (_should_recompile): Don't fire editor if using %bg, since there
1417 (_should_recompile): Don't fire editor if using %bg, since there
1412 is no file in the first place. From the same report as above.
1418 is no file in the first place. From the same report as above.
1413 (raw_input): protect against faulty third-party prefilters. After
1419 (raw_input): protect against faulty third-party prefilters. After
1414 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1420 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1415 while running under SAGE.
1421 while running under SAGE.
1416
1422
1417 2006-05-23 Ville Vainio <vivainio@gmail.com>
1423 2006-05-23 Ville Vainio <vivainio@gmail.com>
1418
1424
1419 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1425 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1420 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1426 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1421 now returns None (again), unless dummy is specifically allowed by
1427 now returns None (again), unless dummy is specifically allowed by
1422 ipapi.get(allow_dummy=True).
1428 ipapi.get(allow_dummy=True).
1423
1429
1424 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1430 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1425
1431
1426 * IPython: remove all 2.2-compatibility objects and hacks from
1432 * IPython: remove all 2.2-compatibility objects and hacks from
1427 everywhere, since we only support 2.3 at this point. Docs
1433 everywhere, since we only support 2.3 at this point. Docs
1428 updated.
1434 updated.
1429
1435
1430 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1436 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1431 Anything requiring extra validation can be turned into a Python
1437 Anything requiring extra validation can be turned into a Python
1432 property in the future. I used a property for the db one b/c
1438 property in the future. I used a property for the db one b/c
1433 there was a nasty circularity problem with the initialization
1439 there was a nasty circularity problem with the initialization
1434 order, which right now I don't have time to clean up.
1440 order, which right now I don't have time to clean up.
1435
1441
1436 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1442 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1437 another locking bug reported by Jorgen. I'm not 100% sure though,
1443 another locking bug reported by Jorgen. I'm not 100% sure though,
1438 so more testing is needed...
1444 so more testing is needed...
1439
1445
1440 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1446 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1441
1447
1442 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1448 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1443 local variables from any routine in user code (typically executed
1449 local variables from any routine in user code (typically executed
1444 with %run) directly into the interactive namespace. Very useful
1450 with %run) directly into the interactive namespace. Very useful
1445 when doing complex debugging.
1451 when doing complex debugging.
1446 (IPythonNotRunning): Changed the default None object to a dummy
1452 (IPythonNotRunning): Changed the default None object to a dummy
1447 whose attributes can be queried as well as called without
1453 whose attributes can be queried as well as called without
1448 exploding, to ease writing code which works transparently both in
1454 exploding, to ease writing code which works transparently both in
1449 and out of ipython and uses some of this API.
1455 and out of ipython and uses some of this API.
1450
1456
1451 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1457 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1452
1458
1453 * IPython/hooks.py (result_display): Fix the fact that our display
1459 * IPython/hooks.py (result_display): Fix the fact that our display
1454 hook was using str() instead of repr(), as the default python
1460 hook was using str() instead of repr(), as the default python
1455 console does. This had gone unnoticed b/c it only happened if
1461 console does. This had gone unnoticed b/c it only happened if
1456 %Pprint was off, but the inconsistency was there.
1462 %Pprint was off, but the inconsistency was there.
1457
1463
1458 2006-05-15 Ville Vainio <vivainio@gmail.com>
1464 2006-05-15 Ville Vainio <vivainio@gmail.com>
1459
1465
1460 * Oinspect.py: Only show docstring for nonexisting/binary files
1466 * Oinspect.py: Only show docstring for nonexisting/binary files
1461 when doing object??, closing ticket #62
1467 when doing object??, closing ticket #62
1462
1468
1463 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1469 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1464
1470
1465 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1471 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1466 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1472 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1467 was being released in a routine which hadn't checked if it had
1473 was being released in a routine which hadn't checked if it had
1468 been the one to acquire it.
1474 been the one to acquire it.
1469
1475
1470 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1476 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1471
1477
1472 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1478 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1473
1479
1474 2006-04-11 Ville Vainio <vivainio@gmail.com>
1480 2006-04-11 Ville Vainio <vivainio@gmail.com>
1475
1481
1476 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1482 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1477 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1483 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1478 prefilters, allowing stuff like magics and aliases in the file.
1484 prefilters, allowing stuff like magics and aliases in the file.
1479
1485
1480 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1486 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1481 added. Supported now are "%clear in" and "%clear out" (clear input and
1487 added. Supported now are "%clear in" and "%clear out" (clear input and
1482 output history, respectively). Also fixed CachedOutput.flush to
1488 output history, respectively). Also fixed CachedOutput.flush to
1483 properly flush the output cache.
1489 properly flush the output cache.
1484
1490
1485 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1491 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1486 half-success (and fail explicitly).
1492 half-success (and fail explicitly).
1487
1493
1488 2006-03-28 Ville Vainio <vivainio@gmail.com>
1494 2006-03-28 Ville Vainio <vivainio@gmail.com>
1489
1495
1490 * iplib.py: Fix quoting of aliases so that only argless ones
1496 * iplib.py: Fix quoting of aliases so that only argless ones
1491 are quoted
1497 are quoted
1492
1498
1493 2006-03-28 Ville Vainio <vivainio@gmail.com>
1499 2006-03-28 Ville Vainio <vivainio@gmail.com>
1494
1500
1495 * iplib.py: Quote aliases with spaces in the name.
1501 * iplib.py: Quote aliases with spaces in the name.
1496 "c:\program files\blah\bin" is now legal alias target.
1502 "c:\program files\blah\bin" is now legal alias target.
1497
1503
1498 * ext_rehashdir.py: Space no longer allowed as arg
1504 * ext_rehashdir.py: Space no longer allowed as arg
1499 separator, since space is legal in path names.
1505 separator, since space is legal in path names.
1500
1506
1501 2006-03-16 Ville Vainio <vivainio@gmail.com>
1507 2006-03-16 Ville Vainio <vivainio@gmail.com>
1502
1508
1503 * upgrade_dir.py: Take path.py from Extensions, correcting
1509 * upgrade_dir.py: Take path.py from Extensions, correcting
1504 %upgrade magic
1510 %upgrade magic
1505
1511
1506 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1512 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1507
1513
1508 * hooks.py: Only enclose editor binary in quotes if legal and
1514 * hooks.py: Only enclose editor binary in quotes if legal and
1509 necessary (space in the name, and is an existing file). Fixes a bug
1515 necessary (space in the name, and is an existing file). Fixes a bug
1510 reported by Zachary Pincus.
1516 reported by Zachary Pincus.
1511
1517
1512 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1518 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1513
1519
1514 * Manual: thanks to a tip on proper color handling for Emacs, by
1520 * Manual: thanks to a tip on proper color handling for Emacs, by
1515 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1521 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1516
1522
1517 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1523 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1518 by applying the provided patch. Thanks to Liu Jin
1524 by applying the provided patch. Thanks to Liu Jin
1519 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1525 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1520 XEmacs/Linux, I'm trusting the submitter that it actually helps
1526 XEmacs/Linux, I'm trusting the submitter that it actually helps
1521 under win32/GNU Emacs. Will revisit if any problems are reported.
1527 under win32/GNU Emacs. Will revisit if any problems are reported.
1522
1528
1523 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1529 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1524
1530
1525 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1531 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1526 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1532 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1527
1533
1528 2006-03-12 Ville Vainio <vivainio@gmail.com>
1534 2006-03-12 Ville Vainio <vivainio@gmail.com>
1529
1535
1530 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1536 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1531 Torsten Marek.
1537 Torsten Marek.
1532
1538
1533 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1539 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1534
1540
1535 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1541 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1536 line ranges works again.
1542 line ranges works again.
1537
1543
1538 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1544 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1539
1545
1540 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1546 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1541 and friends, after a discussion with Zach Pincus on ipython-user.
1547 and friends, after a discussion with Zach Pincus on ipython-user.
1542 I'm not 100% sure, but after thinking about it quite a bit, it may
1548 I'm not 100% sure, but after thinking about it quite a bit, it may
1543 be OK. Testing with the multithreaded shells didn't reveal any
1549 be OK. Testing with the multithreaded shells didn't reveal any
1544 problems, but let's keep an eye out.
1550 problems, but let's keep an eye out.
1545
1551
1546 In the process, I fixed a few things which were calling
1552 In the process, I fixed a few things which were calling
1547 self.InteractiveTB() directly (like safe_execfile), which is a
1553 self.InteractiveTB() directly (like safe_execfile), which is a
1548 mistake: ALL exception reporting should be done by calling
1554 mistake: ALL exception reporting should be done by calling
1549 self.showtraceback(), which handles state and tab-completion and
1555 self.showtraceback(), which handles state and tab-completion and
1550 more.
1556 more.
1551
1557
1552 2006-03-01 Ville Vainio <vivainio@gmail.com>
1558 2006-03-01 Ville Vainio <vivainio@gmail.com>
1553
1559
1554 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1560 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1555 To use, do "from ipipe import *".
1561 To use, do "from ipipe import *".
1556
1562
1557 2006-02-24 Ville Vainio <vivainio@gmail.com>
1563 2006-02-24 Ville Vainio <vivainio@gmail.com>
1558
1564
1559 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1565 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1560 "cleanly" and safely than the older upgrade mechanism.
1566 "cleanly" and safely than the older upgrade mechanism.
1561
1567
1562 2006-02-21 Ville Vainio <vivainio@gmail.com>
1568 2006-02-21 Ville Vainio <vivainio@gmail.com>
1563
1569
1564 * Magic.py: %save works again.
1570 * Magic.py: %save works again.
1565
1571
1566 2006-02-15 Ville Vainio <vivainio@gmail.com>
1572 2006-02-15 Ville Vainio <vivainio@gmail.com>
1567
1573
1568 * Magic.py: %Pprint works again
1574 * Magic.py: %Pprint works again
1569
1575
1570 * Extensions/ipy_sane_defaults.py: Provide everything provided
1576 * Extensions/ipy_sane_defaults.py: Provide everything provided
1571 in default ipythonrc, to make it possible to have a completely empty
1577 in default ipythonrc, to make it possible to have a completely empty
1572 ipythonrc (and thus completely rc-file free configuration)
1578 ipythonrc (and thus completely rc-file free configuration)
1573
1579
1574 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1580 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1575
1581
1576 * IPython/hooks.py (editor): quote the call to the editor command,
1582 * IPython/hooks.py (editor): quote the call to the editor command,
1577 to allow commands with spaces in them. Problem noted by watching
1583 to allow commands with spaces in them. Problem noted by watching
1578 Ian Oswald's video about textpad under win32 at
1584 Ian Oswald's video about textpad under win32 at
1579 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1585 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1580
1586
1581 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1587 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1582 describing magics (we haven't used @ for a loong time).
1588 describing magics (we haven't used @ for a loong time).
1583
1589
1584 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1590 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1585 contributed by marienz to close
1591 contributed by marienz to close
1586 http://www.scipy.net/roundup/ipython/issue53.
1592 http://www.scipy.net/roundup/ipython/issue53.
1587
1593
1588 2006-02-10 Ville Vainio <vivainio@gmail.com>
1594 2006-02-10 Ville Vainio <vivainio@gmail.com>
1589
1595
1590 * genutils.py: getoutput now works in win32 too
1596 * genutils.py: getoutput now works in win32 too
1591
1597
1592 * completer.py: alias and magic completion only invoked
1598 * completer.py: alias and magic completion only invoked
1593 at the first "item" in the line, to avoid "cd %store"
1599 at the first "item" in the line, to avoid "cd %store"
1594 nonsense.
1600 nonsense.
1595
1601
1596 2006-02-09 Ville Vainio <vivainio@gmail.com>
1602 2006-02-09 Ville Vainio <vivainio@gmail.com>
1597
1603
1598 * test/*: Added a unit testing framework (finally).
1604 * test/*: Added a unit testing framework (finally).
1599 '%run runtests.py' to run test_*.
1605 '%run runtests.py' to run test_*.
1600
1606
1601 * ipapi.py: Exposed runlines and set_custom_exc
1607 * ipapi.py: Exposed runlines and set_custom_exc
1602
1608
1603 2006-02-07 Ville Vainio <vivainio@gmail.com>
1609 2006-02-07 Ville Vainio <vivainio@gmail.com>
1604
1610
1605 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1611 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1606 instead use "f(1 2)" as before.
1612 instead use "f(1 2)" as before.
1607
1613
1608 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1614 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1609
1615
1610 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1616 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1611 facilities, for demos processed by the IPython input filter
1617 facilities, for demos processed by the IPython input filter
1612 (IPythonDemo), and for running a script one-line-at-a-time as a
1618 (IPythonDemo), and for running a script one-line-at-a-time as a
1613 demo, both for pure Python (LineDemo) and for IPython-processed
1619 demo, both for pure Python (LineDemo) and for IPython-processed
1614 input (IPythonLineDemo). After a request by Dave Kohel, from the
1620 input (IPythonLineDemo). After a request by Dave Kohel, from the
1615 SAGE team.
1621 SAGE team.
1616 (Demo.edit): added an edit() method to the demo objects, to edit
1622 (Demo.edit): added an edit() method to the demo objects, to edit
1617 the in-memory copy of the last executed block.
1623 the in-memory copy of the last executed block.
1618
1624
1619 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1625 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1620 processing to %edit, %macro and %save. These commands can now be
1626 processing to %edit, %macro and %save. These commands can now be
1621 invoked on the unprocessed input as it was typed by the user
1627 invoked on the unprocessed input as it was typed by the user
1622 (without any prefilters applied). After requests by the SAGE team
1628 (without any prefilters applied). After requests by the SAGE team
1623 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1629 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1624
1630
1625 2006-02-01 Ville Vainio <vivainio@gmail.com>
1631 2006-02-01 Ville Vainio <vivainio@gmail.com>
1626
1632
1627 * setup.py, eggsetup.py: easy_install ipython==dev works
1633 * setup.py, eggsetup.py: easy_install ipython==dev works
1628 correctly now (on Linux)
1634 correctly now (on Linux)
1629
1635
1630 * ipy_user_conf,ipmaker: user config changes, removed spurious
1636 * ipy_user_conf,ipmaker: user config changes, removed spurious
1631 warnings
1637 warnings
1632
1638
1633 * iplib: if rc.banner is string, use it as is.
1639 * iplib: if rc.banner is string, use it as is.
1634
1640
1635 * Magic: %pycat accepts a string argument and pages it's contents.
1641 * Magic: %pycat accepts a string argument and pages it's contents.
1636
1642
1637
1643
1638 2006-01-30 Ville Vainio <vivainio@gmail.com>
1644 2006-01-30 Ville Vainio <vivainio@gmail.com>
1639
1645
1640 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
1646 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
1641 Now %store and bookmarks work through PickleShare, meaning that
1647 Now %store and bookmarks work through PickleShare, meaning that
1642 concurrent access is possible and all ipython sessions see the
1648 concurrent access is possible and all ipython sessions see the
1643 same database situation all the time, instead of snapshot of
1649 same database situation all the time, instead of snapshot of
1644 the situation when the session was started. Hence, %bookmark
1650 the situation when the session was started. Hence, %bookmark
1645 results are immediately accessible from othes sessions. The database
1651 results are immediately accessible from othes sessions. The database
1646 is also available for use by user extensions. See:
1652 is also available for use by user extensions. See:
1647 http://www.python.org/pypi/pickleshare
1653 http://www.python.org/pypi/pickleshare
1648
1654
1649 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
1655 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
1650
1656
1651 * aliases can now be %store'd
1657 * aliases can now be %store'd
1652
1658
1653 * path.py moved to Extensions so that pickleshare does not need
1659 * path.py moved to Extensions so that pickleshare does not need
1654 IPython-specific import. Extensions added to pythonpath right
1660 IPython-specific import. Extensions added to pythonpath right
1655 at __init__.
1661 at __init__.
1656
1662
1657 * iplib.py: ipalias deprecated/redundant; aliases are converted and
1663 * iplib.py: ipalias deprecated/redundant; aliases are converted and
1658 called with _ip.system and the pre-transformed command string.
1664 called with _ip.system and the pre-transformed command string.
1659
1665
1660 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
1666 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
1661
1667
1662 * IPython/iplib.py (interact): Fix that we were not catching
1668 * IPython/iplib.py (interact): Fix that we were not catching
1663 KeyboardInterrupt exceptions properly. I'm not quite sure why the
1669 KeyboardInterrupt exceptions properly. I'm not quite sure why the
1664 logic here had to change, but it's fixed now.
1670 logic here had to change, but it's fixed now.
1665
1671
1666 2006-01-29 Ville Vainio <vivainio@gmail.com>
1672 2006-01-29 Ville Vainio <vivainio@gmail.com>
1667
1673
1668 * iplib.py: Try to import pyreadline on Windows.
1674 * iplib.py: Try to import pyreadline on Windows.
1669
1675
1670 2006-01-27 Ville Vainio <vivainio@gmail.com>
1676 2006-01-27 Ville Vainio <vivainio@gmail.com>
1671
1677
1672 * iplib.py: Expose ipapi as _ip in builtin namespace.
1678 * iplib.py: Expose ipapi as _ip in builtin namespace.
1673 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
1679 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
1674 and ip_set_hook (-> _ip.set_hook) redundant. % and !
1680 and ip_set_hook (-> _ip.set_hook) redundant. % and !
1675 syntax now produce _ip.* variant of the commands.
1681 syntax now produce _ip.* variant of the commands.
1676
1682
1677 * "_ip.options().autoedit_syntax = 2" automatically throws
1683 * "_ip.options().autoedit_syntax = 2" automatically throws
1678 user to editor for syntax error correction without prompting.
1684 user to editor for syntax error correction without prompting.
1679
1685
1680 2006-01-27 Ville Vainio <vivainio@gmail.com>
1686 2006-01-27 Ville Vainio <vivainio@gmail.com>
1681
1687
1682 * ipmaker.py: Give "realistic" sys.argv for scripts (without
1688 * ipmaker.py: Give "realistic" sys.argv for scripts (without
1683 'ipython' at argv[0]) executed through command line.
1689 'ipython' at argv[0]) executed through command line.
1684 NOTE: this DEPRECATES calling ipython with multiple scripts
1690 NOTE: this DEPRECATES calling ipython with multiple scripts
1685 ("ipython a.py b.py c.py")
1691 ("ipython a.py b.py c.py")
1686
1692
1687 * iplib.py, hooks.py: Added configurable input prefilter,
1693 * iplib.py, hooks.py: Added configurable input prefilter,
1688 named 'input_prefilter'. See ext_rescapture.py for example
1694 named 'input_prefilter'. See ext_rescapture.py for example
1689 usage.
1695 usage.
1690
1696
1691 * ext_rescapture.py, Magic.py: Better system command output capture
1697 * ext_rescapture.py, Magic.py: Better system command output capture
1692 through 'var = !ls' (deprecates user-visible %sc). Same notation
1698 through 'var = !ls' (deprecates user-visible %sc). Same notation
1693 applies for magics, 'var = %alias' assigns alias list to var.
1699 applies for magics, 'var = %alias' assigns alias list to var.
1694
1700
1695 * ipapi.py: added meta() for accessing extension-usable data store.
1701 * ipapi.py: added meta() for accessing extension-usable data store.
1696
1702
1697 * iplib.py: added InteractiveShell.getapi(). New magics should be
1703 * iplib.py: added InteractiveShell.getapi(). New magics should be
1698 written doing self.getapi() instead of using the shell directly.
1704 written doing self.getapi() instead of using the shell directly.
1699
1705
1700 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
1706 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
1701 %store foo >> ~/myfoo.txt to store variables to files (in clean
1707 %store foo >> ~/myfoo.txt to store variables to files (in clean
1702 textual form, not a restorable pickle).
1708 textual form, not a restorable pickle).
1703
1709
1704 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
1710 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
1705
1711
1706 * usage.py, Magic.py: added %quickref
1712 * usage.py, Magic.py: added %quickref
1707
1713
1708 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
1714 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
1709
1715
1710 * GetoptErrors when invoking magics etc. with wrong args
1716 * GetoptErrors when invoking magics etc. with wrong args
1711 are now more helpful:
1717 are now more helpful:
1712 GetoptError: option -l not recognized (allowed: "qb" )
1718 GetoptError: option -l not recognized (allowed: "qb" )
1713
1719
1714 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
1720 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
1715
1721
1716 * IPython/demo.py (Demo.show): Flush stdout after each block, so
1722 * IPython/demo.py (Demo.show): Flush stdout after each block, so
1717 computationally intensive blocks don't appear to stall the demo.
1723 computationally intensive blocks don't appear to stall the demo.
1718
1724
1719 2006-01-24 Ville Vainio <vivainio@gmail.com>
1725 2006-01-24 Ville Vainio <vivainio@gmail.com>
1720
1726
1721 * iplib.py, hooks.py: 'result_display' hook can return a non-None
1727 * iplib.py, hooks.py: 'result_display' hook can return a non-None
1722 value to manipulate resulting history entry.
1728 value to manipulate resulting history entry.
1723
1729
1724 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
1730 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
1725 to instance methods of IPApi class, to make extending an embedded
1731 to instance methods of IPApi class, to make extending an embedded
1726 IPython feasible. See ext_rehashdir.py for example usage.
1732 IPython feasible. See ext_rehashdir.py for example usage.
1727
1733
1728 * Merged 1071-1076 from branches/0.7.1
1734 * Merged 1071-1076 from branches/0.7.1
1729
1735
1730
1736
1731 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
1737 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
1732
1738
1733 * tools/release (daystamp): Fix build tools to use the new
1739 * tools/release (daystamp): Fix build tools to use the new
1734 eggsetup.py script to build lightweight eggs.
1740 eggsetup.py script to build lightweight eggs.
1735
1741
1736 * Applied changesets 1062 and 1064 before 0.7.1 release.
1742 * Applied changesets 1062 and 1064 before 0.7.1 release.
1737
1743
1738 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
1744 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
1739 see the raw input history (without conversions like %ls ->
1745 see the raw input history (without conversions like %ls ->
1740 ipmagic("ls")). After a request from W. Stein, SAGE
1746 ipmagic("ls")). After a request from W. Stein, SAGE
1741 (http://modular.ucsd.edu/sage) developer. This information is
1747 (http://modular.ucsd.edu/sage) developer. This information is
1742 stored in the input_hist_raw attribute of the IPython instance, so
1748 stored in the input_hist_raw attribute of the IPython instance, so
1743 developers can access it if needed (it's an InputList instance).
1749 developers can access it if needed (it's an InputList instance).
1744
1750
1745 * Versionstring = 0.7.2.svn
1751 * Versionstring = 0.7.2.svn
1746
1752
1747 * eggsetup.py: A separate script for constructing eggs, creates
1753 * eggsetup.py: A separate script for constructing eggs, creates
1748 proper launch scripts even on Windows (an .exe file in
1754 proper launch scripts even on Windows (an .exe file in
1749 \python24\scripts).
1755 \python24\scripts).
1750
1756
1751 * ipapi.py: launch_new_instance, launch entry point needed for the
1757 * ipapi.py: launch_new_instance, launch entry point needed for the
1752 egg.
1758 egg.
1753
1759
1754 2006-01-23 Ville Vainio <vivainio@gmail.com>
1760 2006-01-23 Ville Vainio <vivainio@gmail.com>
1755
1761
1756 * Added %cpaste magic for pasting python code
1762 * Added %cpaste magic for pasting python code
1757
1763
1758 2006-01-22 Ville Vainio <vivainio@gmail.com>
1764 2006-01-22 Ville Vainio <vivainio@gmail.com>
1759
1765
1760 * Merge from branches/0.7.1 into trunk, revs 1052-1057
1766 * Merge from branches/0.7.1 into trunk, revs 1052-1057
1761
1767
1762 * Versionstring = 0.7.2.svn
1768 * Versionstring = 0.7.2.svn
1763
1769
1764 * eggsetup.py: A separate script for constructing eggs, creates
1770 * eggsetup.py: A separate script for constructing eggs, creates
1765 proper launch scripts even on Windows (an .exe file in
1771 proper launch scripts even on Windows (an .exe file in
1766 \python24\scripts).
1772 \python24\scripts).
1767
1773
1768 * ipapi.py: launch_new_instance, launch entry point needed for the
1774 * ipapi.py: launch_new_instance, launch entry point needed for the
1769 egg.
1775 egg.
1770
1776
1771 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
1777 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
1772
1778
1773 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
1779 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
1774 %pfile foo would print the file for foo even if it was a binary.
1780 %pfile foo would print the file for foo even if it was a binary.
1775 Now, extensions '.so' and '.dll' are skipped.
1781 Now, extensions '.so' and '.dll' are skipped.
1776
1782
1777 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
1783 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
1778 bug, where macros would fail in all threaded modes. I'm not 100%
1784 bug, where macros would fail in all threaded modes. I'm not 100%
1779 sure, so I'm going to put out an rc instead of making a release
1785 sure, so I'm going to put out an rc instead of making a release
1780 today, and wait for feedback for at least a few days.
1786 today, and wait for feedback for at least a few days.
1781
1787
1782 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
1788 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
1783 it...) the handling of pasting external code with autoindent on.
1789 it...) the handling of pasting external code with autoindent on.
1784 To get out of a multiline input, the rule will appear for most
1790 To get out of a multiline input, the rule will appear for most
1785 users unchanged: two blank lines or change the indent level
1791 users unchanged: two blank lines or change the indent level
1786 proposed by IPython. But there is a twist now: you can
1792 proposed by IPython. But there is a twist now: you can
1787 add/subtract only *one or two spaces*. If you add/subtract three
1793 add/subtract only *one or two spaces*. If you add/subtract three
1788 or more (unless you completely delete the line), IPython will
1794 or more (unless you completely delete the line), IPython will
1789 accept that line, and you'll need to enter a second one of pure
1795 accept that line, and you'll need to enter a second one of pure
1790 whitespace. I know it sounds complicated, but I can't find a
1796 whitespace. I know it sounds complicated, but I can't find a
1791 different solution that covers all the cases, with the right
1797 different solution that covers all the cases, with the right
1792 heuristics. Hopefully in actual use, nobody will really notice
1798 heuristics. Hopefully in actual use, nobody will really notice
1793 all these strange rules and things will 'just work'.
1799 all these strange rules and things will 'just work'.
1794
1800
1795 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
1801 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
1796
1802
1797 * IPython/iplib.py (interact): catch exceptions which can be
1803 * IPython/iplib.py (interact): catch exceptions which can be
1798 triggered asynchronously by signal handlers. Thanks to an
1804 triggered asynchronously by signal handlers. Thanks to an
1799 automatic crash report, submitted by Colin Kingsley
1805 automatic crash report, submitted by Colin Kingsley
1800 <tercel-AT-gentoo.org>.
1806 <tercel-AT-gentoo.org>.
1801
1807
1802 2006-01-20 Ville Vainio <vivainio@gmail.com>
1808 2006-01-20 Ville Vainio <vivainio@gmail.com>
1803
1809
1804 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
1810 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
1805 (%rehashdir, very useful, try it out) of how to extend ipython
1811 (%rehashdir, very useful, try it out) of how to extend ipython
1806 with new magics. Also added Extensions dir to pythonpath to make
1812 with new magics. Also added Extensions dir to pythonpath to make
1807 importing extensions easy.
1813 importing extensions easy.
1808
1814
1809 * %store now complains when trying to store interactively declared
1815 * %store now complains when trying to store interactively declared
1810 classes / instances of those classes.
1816 classes / instances of those classes.
1811
1817
1812 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
1818 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
1813 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
1819 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
1814 if they exist, and ipy_user_conf.py with some defaults is created for
1820 if they exist, and ipy_user_conf.py with some defaults is created for
1815 the user.
1821 the user.
1816
1822
1817 * Startup rehashing done by the config file, not InterpreterExec.
1823 * Startup rehashing done by the config file, not InterpreterExec.
1818 This means system commands are available even without selecting the
1824 This means system commands are available even without selecting the
1819 pysh profile. It's the sensible default after all.
1825 pysh profile. It's the sensible default after all.
1820
1826
1821 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
1827 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
1822
1828
1823 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
1829 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
1824 multiline code with autoindent on working. But I am really not
1830 multiline code with autoindent on working. But I am really not
1825 sure, so this needs more testing. Will commit a debug-enabled
1831 sure, so this needs more testing. Will commit a debug-enabled
1826 version for now, while I test it some more, so that Ville and
1832 version for now, while I test it some more, so that Ville and
1827 others may also catch any problems. Also made
1833 others may also catch any problems. Also made
1828 self.indent_current_str() a method, to ensure that there's no
1834 self.indent_current_str() a method, to ensure that there's no
1829 chance of the indent space count and the corresponding string
1835 chance of the indent space count and the corresponding string
1830 falling out of sync. All code needing the string should just call
1836 falling out of sync. All code needing the string should just call
1831 the method.
1837 the method.
1832
1838
1833 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
1839 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
1834
1840
1835 * IPython/Magic.py (magic_edit): fix check for when users don't
1841 * IPython/Magic.py (magic_edit): fix check for when users don't
1836 save their output files, the try/except was in the wrong section.
1842 save their output files, the try/except was in the wrong section.
1837
1843
1838 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1844 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1839
1845
1840 * IPython/Magic.py (magic_run): fix __file__ global missing from
1846 * IPython/Magic.py (magic_run): fix __file__ global missing from
1841 script's namespace when executed via %run. After a report by
1847 script's namespace when executed via %run. After a report by
1842 Vivian.
1848 Vivian.
1843
1849
1844 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
1850 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
1845 when using python 2.4. The parent constructor changed in 2.4, and
1851 when using python 2.4. The parent constructor changed in 2.4, and
1846 we need to track it directly (we can't call it, as it messes up
1852 we need to track it directly (we can't call it, as it messes up
1847 readline and tab-completion inside our pdb would stop working).
1853 readline and tab-completion inside our pdb would stop working).
1848 After a bug report by R. Bernstein <rocky-AT-panix.com>.
1854 After a bug report by R. Bernstein <rocky-AT-panix.com>.
1849
1855
1850 2006-01-16 Ville Vainio <vivainio@gmail.com>
1856 2006-01-16 Ville Vainio <vivainio@gmail.com>
1851
1857
1852 * Ipython/magic.py: Reverted back to old %edit functionality
1858 * Ipython/magic.py: Reverted back to old %edit functionality
1853 that returns file contents on exit.
1859 that returns file contents on exit.
1854
1860
1855 * IPython/path.py: Added Jason Orendorff's "path" module to
1861 * IPython/path.py: Added Jason Orendorff's "path" module to
1856 IPython tree, http://www.jorendorff.com/articles/python/path/.
1862 IPython tree, http://www.jorendorff.com/articles/python/path/.
1857 You can get path objects conveniently through %sc, and !!, e.g.:
1863 You can get path objects conveniently through %sc, and !!, e.g.:
1858 sc files=ls
1864 sc files=ls
1859 for p in files.paths: # or files.p
1865 for p in files.paths: # or files.p
1860 print p,p.mtime
1866 print p,p.mtime
1861
1867
1862 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
1868 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
1863 now work again without considering the exclusion regexp -
1869 now work again without considering the exclusion regexp -
1864 hence, things like ',foo my/path' turn to 'foo("my/path")'
1870 hence, things like ',foo my/path' turn to 'foo("my/path")'
1865 instead of syntax error.
1871 instead of syntax error.
1866
1872
1867
1873
1868 2006-01-14 Ville Vainio <vivainio@gmail.com>
1874 2006-01-14 Ville Vainio <vivainio@gmail.com>
1869
1875
1870 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
1876 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
1871 ipapi decorators for python 2.4 users, options() provides access to rc
1877 ipapi decorators for python 2.4 users, options() provides access to rc
1872 data.
1878 data.
1873
1879
1874 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
1880 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
1875 as path separators (even on Linux ;-). Space character after
1881 as path separators (even on Linux ;-). Space character after
1876 backslash (as yielded by tab completer) is still space;
1882 backslash (as yielded by tab completer) is still space;
1877 "%cd long\ name" works as expected.
1883 "%cd long\ name" works as expected.
1878
1884
1879 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
1885 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
1880 as "chain of command", with priority. API stays the same,
1886 as "chain of command", with priority. API stays the same,
1881 TryNext exception raised by a hook function signals that
1887 TryNext exception raised by a hook function signals that
1882 current hook failed and next hook should try handling it, as
1888 current hook failed and next hook should try handling it, as
1883 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
1889 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
1884 requested configurable display hook, which is now implemented.
1890 requested configurable display hook, which is now implemented.
1885
1891
1886 2006-01-13 Ville Vainio <vivainio@gmail.com>
1892 2006-01-13 Ville Vainio <vivainio@gmail.com>
1887
1893
1888 * IPython/platutils*.py: platform specific utility functions,
1894 * IPython/platutils*.py: platform specific utility functions,
1889 so far only set_term_title is implemented (change terminal
1895 so far only set_term_title is implemented (change terminal
1890 label in windowing systems). %cd now changes the title to
1896 label in windowing systems). %cd now changes the title to
1891 current dir.
1897 current dir.
1892
1898
1893 * IPython/Release.py: Added myself to "authors" list,
1899 * IPython/Release.py: Added myself to "authors" list,
1894 had to create new files.
1900 had to create new files.
1895
1901
1896 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
1902 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
1897 shell escape; not a known bug but had potential to be one in the
1903 shell escape; not a known bug but had potential to be one in the
1898 future.
1904 future.
1899
1905
1900 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
1906 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
1901 extension API for IPython! See the module for usage example. Fix
1907 extension API for IPython! See the module for usage example. Fix
1902 OInspect for docstring-less magic functions.
1908 OInspect for docstring-less magic functions.
1903
1909
1904
1910
1905 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
1911 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
1906
1912
1907 * IPython/iplib.py (raw_input): temporarily deactivate all
1913 * IPython/iplib.py (raw_input): temporarily deactivate all
1908 attempts at allowing pasting of code with autoindent on. It
1914 attempts at allowing pasting of code with autoindent on. It
1909 introduced bugs (reported by Prabhu) and I can't seem to find a
1915 introduced bugs (reported by Prabhu) and I can't seem to find a
1910 robust combination which works in all cases. Will have to revisit
1916 robust combination which works in all cases. Will have to revisit
1911 later.
1917 later.
1912
1918
1913 * IPython/genutils.py: remove isspace() function. We've dropped
1919 * IPython/genutils.py: remove isspace() function. We've dropped
1914 2.2 compatibility, so it's OK to use the string method.
1920 2.2 compatibility, so it's OK to use the string method.
1915
1921
1916 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1922 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1917
1923
1918 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
1924 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
1919 matching what NOT to autocall on, to include all python binary
1925 matching what NOT to autocall on, to include all python binary
1920 operators (including things like 'and', 'or', 'is' and 'in').
1926 operators (including things like 'and', 'or', 'is' and 'in').
1921 Prompted by a bug report on 'foo & bar', but I realized we had
1927 Prompted by a bug report on 'foo & bar', but I realized we had
1922 many more potential bug cases with other operators. The regexp is
1928 many more potential bug cases with other operators. The regexp is
1923 self.re_exclude_auto, it's fairly commented.
1929 self.re_exclude_auto, it's fairly commented.
1924
1930
1925 2006-01-12 Ville Vainio <vivainio@gmail.com>
1931 2006-01-12 Ville Vainio <vivainio@gmail.com>
1926
1932
1927 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
1933 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
1928 Prettified and hardened string/backslash quoting with ipsystem(),
1934 Prettified and hardened string/backslash quoting with ipsystem(),
1929 ipalias() and ipmagic(). Now even \ characters are passed to
1935 ipalias() and ipmagic(). Now even \ characters are passed to
1930 %magics, !shell escapes and aliases exactly as they are in the
1936 %magics, !shell escapes and aliases exactly as they are in the
1931 ipython command line. Should improve backslash experience,
1937 ipython command line. Should improve backslash experience,
1932 particularly in Windows (path delimiter for some commands that
1938 particularly in Windows (path delimiter for some commands that
1933 won't understand '/'), but Unix benefits as well (regexps). %cd
1939 won't understand '/'), but Unix benefits as well (regexps). %cd
1934 magic still doesn't support backslash path delimiters, though. Also
1940 magic still doesn't support backslash path delimiters, though. Also
1935 deleted all pretense of supporting multiline command strings in
1941 deleted all pretense of supporting multiline command strings in
1936 !system or %magic commands. Thanks to Jerry McRae for suggestions.
1942 !system or %magic commands. Thanks to Jerry McRae for suggestions.
1937
1943
1938 * doc/build_doc_instructions.txt added. Documentation on how to
1944 * doc/build_doc_instructions.txt added. Documentation on how to
1939 use doc/update_manual.py, added yesterday. Both files contributed
1945 use doc/update_manual.py, added yesterday. Both files contributed
1940 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
1946 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
1941 doc/*.sh for deprecation at a later date.
1947 doc/*.sh for deprecation at a later date.
1942
1948
1943 * /ipython.py Added ipython.py to root directory for
1949 * /ipython.py Added ipython.py to root directory for
1944 zero-installation (tar xzvf ipython.tgz; cd ipython; python
1950 zero-installation (tar xzvf ipython.tgz; cd ipython; python
1945 ipython.py) and development convenience (no need to keep doing
1951 ipython.py) and development convenience (no need to keep doing
1946 "setup.py install" between changes).
1952 "setup.py install" between changes).
1947
1953
1948 * Made ! and !! shell escapes work (again) in multiline expressions:
1954 * Made ! and !! shell escapes work (again) in multiline expressions:
1949 if 1:
1955 if 1:
1950 !ls
1956 !ls
1951 !!ls
1957 !!ls
1952
1958
1953 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1959 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1954
1960
1955 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
1961 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
1956 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
1962 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
1957 module in case-insensitive installation. Was causing crashes
1963 module in case-insensitive installation. Was causing crashes
1958 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
1964 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
1959
1965
1960 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
1966 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
1961 <marienz-AT-gentoo.org>, closes
1967 <marienz-AT-gentoo.org>, closes
1962 http://www.scipy.net/roundup/ipython/issue51.
1968 http://www.scipy.net/roundup/ipython/issue51.
1963
1969
1964 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
1970 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
1965
1971
1966 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
1972 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
1967 problem of excessive CPU usage under *nix and keyboard lag under
1973 problem of excessive CPU usage under *nix and keyboard lag under
1968 win32.
1974 win32.
1969
1975
1970 2006-01-10 *** Released version 0.7.0
1976 2006-01-10 *** Released version 0.7.0
1971
1977
1972 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
1978 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
1973
1979
1974 * IPython/Release.py (revision): tag version number to 0.7.0,
1980 * IPython/Release.py (revision): tag version number to 0.7.0,
1975 ready for release.
1981 ready for release.
1976
1982
1977 * IPython/Magic.py (magic_edit): Add print statement to %edit so
1983 * IPython/Magic.py (magic_edit): Add print statement to %edit so
1978 it informs the user of the name of the temp. file used. This can
1984 it informs the user of the name of the temp. file used. This can
1979 help if you decide later to reuse that same file, so you know
1985 help if you decide later to reuse that same file, so you know
1980 where to copy the info from.
1986 where to copy the info from.
1981
1987
1982 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
1988 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
1983
1989
1984 * setup_bdist_egg.py: little script to build an egg. Added
1990 * setup_bdist_egg.py: little script to build an egg. Added
1985 support in the release tools as well.
1991 support in the release tools as well.
1986
1992
1987 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
1993 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
1988
1994
1989 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
1995 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
1990 version selection (new -wxversion command line and ipythonrc
1996 version selection (new -wxversion command line and ipythonrc
1991 parameter). Patch contributed by Arnd Baecker
1997 parameter). Patch contributed by Arnd Baecker
1992 <arnd.baecker-AT-web.de>.
1998 <arnd.baecker-AT-web.de>.
1993
1999
1994 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2000 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1995 embedded instances, for variables defined at the interactive
2001 embedded instances, for variables defined at the interactive
1996 prompt of the embedded ipython. Reported by Arnd.
2002 prompt of the embedded ipython. Reported by Arnd.
1997
2003
1998 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
2004 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
1999 it can be used as a (stateful) toggle, or with a direct parameter.
2005 it can be used as a (stateful) toggle, or with a direct parameter.
2000
2006
2001 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2007 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2002 could be triggered in certain cases and cause the traceback
2008 could be triggered in certain cases and cause the traceback
2003 printer not to work.
2009 printer not to work.
2004
2010
2005 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2011 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2006
2012
2007 * IPython/iplib.py (_should_recompile): Small fix, closes
2013 * IPython/iplib.py (_should_recompile): Small fix, closes
2008 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2014 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2009
2015
2010 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2016 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2011
2017
2012 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2018 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2013 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2019 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2014 Moad for help with tracking it down.
2020 Moad for help with tracking it down.
2015
2021
2016 * IPython/iplib.py (handle_auto): fix autocall handling for
2022 * IPython/iplib.py (handle_auto): fix autocall handling for
2017 objects which support BOTH __getitem__ and __call__ (so that f [x]
2023 objects which support BOTH __getitem__ and __call__ (so that f [x]
2018 is left alone, instead of becoming f([x]) automatically).
2024 is left alone, instead of becoming f([x]) automatically).
2019
2025
2020 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2026 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2021 Ville's patch.
2027 Ville's patch.
2022
2028
2023 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2029 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2024
2030
2025 * IPython/iplib.py (handle_auto): changed autocall semantics to
2031 * IPython/iplib.py (handle_auto): changed autocall semantics to
2026 include 'smart' mode, where the autocall transformation is NOT
2032 include 'smart' mode, where the autocall transformation is NOT
2027 applied if there are no arguments on the line. This allows you to
2033 applied if there are no arguments on the line. This allows you to
2028 just type 'foo' if foo is a callable to see its internal form,
2034 just type 'foo' if foo is a callable to see its internal form,
2029 instead of having it called with no arguments (typically a
2035 instead of having it called with no arguments (typically a
2030 mistake). The old 'full' autocall still exists: for that, you
2036 mistake). The old 'full' autocall still exists: for that, you
2031 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2037 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2032
2038
2033 * IPython/completer.py (Completer.attr_matches): add
2039 * IPython/completer.py (Completer.attr_matches): add
2034 tab-completion support for Enthoughts' traits. After a report by
2040 tab-completion support for Enthoughts' traits. After a report by
2035 Arnd and a patch by Prabhu.
2041 Arnd and a patch by Prabhu.
2036
2042
2037 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2043 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2038
2044
2039 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2045 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2040 Schmolck's patch to fix inspect.getinnerframes().
2046 Schmolck's patch to fix inspect.getinnerframes().
2041
2047
2042 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2048 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2043 for embedded instances, regarding handling of namespaces and items
2049 for embedded instances, regarding handling of namespaces and items
2044 added to the __builtin__ one. Multiple embedded instances and
2050 added to the __builtin__ one. Multiple embedded instances and
2045 recursive embeddings should work better now (though I'm not sure
2051 recursive embeddings should work better now (though I'm not sure
2046 I've got all the corner cases fixed, that code is a bit of a brain
2052 I've got all the corner cases fixed, that code is a bit of a brain
2047 twister).
2053 twister).
2048
2054
2049 * IPython/Magic.py (magic_edit): added support to edit in-memory
2055 * IPython/Magic.py (magic_edit): added support to edit in-memory
2050 macros (automatically creates the necessary temp files). %edit
2056 macros (automatically creates the necessary temp files). %edit
2051 also doesn't return the file contents anymore, it's just noise.
2057 also doesn't return the file contents anymore, it's just noise.
2052
2058
2053 * IPython/completer.py (Completer.attr_matches): revert change to
2059 * IPython/completer.py (Completer.attr_matches): revert change to
2054 complete only on attributes listed in __all__. I realized it
2060 complete only on attributes listed in __all__. I realized it
2055 cripples the tab-completion system as a tool for exploring the
2061 cripples the tab-completion system as a tool for exploring the
2056 internals of unknown libraries (it renders any non-__all__
2062 internals of unknown libraries (it renders any non-__all__
2057 attribute off-limits). I got bit by this when trying to see
2063 attribute off-limits). I got bit by this when trying to see
2058 something inside the dis module.
2064 something inside the dis module.
2059
2065
2060 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2066 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2061
2067
2062 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2068 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2063 namespace for users and extension writers to hold data in. This
2069 namespace for users and extension writers to hold data in. This
2064 follows the discussion in
2070 follows the discussion in
2065 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2071 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2066
2072
2067 * IPython/completer.py (IPCompleter.complete): small patch to help
2073 * IPython/completer.py (IPCompleter.complete): small patch to help
2068 tab-completion under Emacs, after a suggestion by John Barnard
2074 tab-completion under Emacs, after a suggestion by John Barnard
2069 <barnarj-AT-ccf.org>.
2075 <barnarj-AT-ccf.org>.
2070
2076
2071 * IPython/Magic.py (Magic.extract_input_slices): added support for
2077 * IPython/Magic.py (Magic.extract_input_slices): added support for
2072 the slice notation in magics to use N-M to represent numbers N...M
2078 the slice notation in magics to use N-M to represent numbers N...M
2073 (closed endpoints). This is used by %macro and %save.
2079 (closed endpoints). This is used by %macro and %save.
2074
2080
2075 * IPython/completer.py (Completer.attr_matches): for modules which
2081 * IPython/completer.py (Completer.attr_matches): for modules which
2076 define __all__, complete only on those. After a patch by Jeffrey
2082 define __all__, complete only on those. After a patch by Jeffrey
2077 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2083 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2078 speed up this routine.
2084 speed up this routine.
2079
2085
2080 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2086 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2081 don't know if this is the end of it, but the behavior now is
2087 don't know if this is the end of it, but the behavior now is
2082 certainly much more correct. Note that coupled with macros,
2088 certainly much more correct. Note that coupled with macros,
2083 slightly surprising (at first) behavior may occur: a macro will in
2089 slightly surprising (at first) behavior may occur: a macro will in
2084 general expand to multiple lines of input, so upon exiting, the
2090 general expand to multiple lines of input, so upon exiting, the
2085 in/out counters will both be bumped by the corresponding amount
2091 in/out counters will both be bumped by the corresponding amount
2086 (as if the macro's contents had been typed interactively). Typing
2092 (as if the macro's contents had been typed interactively). Typing
2087 %hist will reveal the intermediate (silently processed) lines.
2093 %hist will reveal the intermediate (silently processed) lines.
2088
2094
2089 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2095 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2090 pickle to fail (%run was overwriting __main__ and not restoring
2096 pickle to fail (%run was overwriting __main__ and not restoring
2091 it, but pickle relies on __main__ to operate).
2097 it, but pickle relies on __main__ to operate).
2092
2098
2093 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2099 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2094 using properties, but forgot to make the main InteractiveShell
2100 using properties, but forgot to make the main InteractiveShell
2095 class a new-style class. Properties fail silently, and
2101 class a new-style class. Properties fail silently, and
2096 mysteriously, with old-style class (getters work, but
2102 mysteriously, with old-style class (getters work, but
2097 setters don't do anything).
2103 setters don't do anything).
2098
2104
2099 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2105 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2100
2106
2101 * IPython/Magic.py (magic_history): fix history reporting bug (I
2107 * IPython/Magic.py (magic_history): fix history reporting bug (I
2102 know some nasties are still there, I just can't seem to find a
2108 know some nasties are still there, I just can't seem to find a
2103 reproducible test case to track them down; the input history is
2109 reproducible test case to track them down; the input history is
2104 falling out of sync...)
2110 falling out of sync...)
2105
2111
2106 * IPython/iplib.py (handle_shell_escape): fix bug where both
2112 * IPython/iplib.py (handle_shell_escape): fix bug where both
2107 aliases and system accesses where broken for indented code (such
2113 aliases and system accesses where broken for indented code (such
2108 as loops).
2114 as loops).
2109
2115
2110 * IPython/genutils.py (shell): fix small but critical bug for
2116 * IPython/genutils.py (shell): fix small but critical bug for
2111 win32 system access.
2117 win32 system access.
2112
2118
2113 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2119 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2114
2120
2115 * IPython/iplib.py (showtraceback): remove use of the
2121 * IPython/iplib.py (showtraceback): remove use of the
2116 sys.last_{type/value/traceback} structures, which are non
2122 sys.last_{type/value/traceback} structures, which are non
2117 thread-safe.
2123 thread-safe.
2118 (_prefilter): change control flow to ensure that we NEVER
2124 (_prefilter): change control flow to ensure that we NEVER
2119 introspect objects when autocall is off. This will guarantee that
2125 introspect objects when autocall is off. This will guarantee that
2120 having an input line of the form 'x.y', where access to attribute
2126 having an input line of the form 'x.y', where access to attribute
2121 'y' has side effects, doesn't trigger the side effect TWICE. It
2127 'y' has side effects, doesn't trigger the side effect TWICE. It
2122 is important to note that, with autocall on, these side effects
2128 is important to note that, with autocall on, these side effects
2123 can still happen.
2129 can still happen.
2124 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2130 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2125 trio. IPython offers these three kinds of special calls which are
2131 trio. IPython offers these three kinds of special calls which are
2126 not python code, and it's a good thing to have their call method
2132 not python code, and it's a good thing to have their call method
2127 be accessible as pure python functions (not just special syntax at
2133 be accessible as pure python functions (not just special syntax at
2128 the command line). It gives us a better internal implementation
2134 the command line). It gives us a better internal implementation
2129 structure, as well as exposing these for user scripting more
2135 structure, as well as exposing these for user scripting more
2130 cleanly.
2136 cleanly.
2131
2137
2132 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2138 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2133 file. Now that they'll be more likely to be used with the
2139 file. Now that they'll be more likely to be used with the
2134 persistance system (%store), I want to make sure their module path
2140 persistance system (%store), I want to make sure their module path
2135 doesn't change in the future, so that we don't break things for
2141 doesn't change in the future, so that we don't break things for
2136 users' persisted data.
2142 users' persisted data.
2137
2143
2138 * IPython/iplib.py (autoindent_update): move indentation
2144 * IPython/iplib.py (autoindent_update): move indentation
2139 management into the _text_ processing loop, not the keyboard
2145 management into the _text_ processing loop, not the keyboard
2140 interactive one. This is necessary to correctly process non-typed
2146 interactive one. This is necessary to correctly process non-typed
2141 multiline input (such as macros).
2147 multiline input (such as macros).
2142
2148
2143 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2149 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2144 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2150 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2145 which was producing problems in the resulting manual.
2151 which was producing problems in the resulting manual.
2146 (magic_whos): improve reporting of instances (show their class,
2152 (magic_whos): improve reporting of instances (show their class,
2147 instead of simply printing 'instance' which isn't terribly
2153 instead of simply printing 'instance' which isn't terribly
2148 informative).
2154 informative).
2149
2155
2150 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2156 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2151 (minor mods) to support network shares under win32.
2157 (minor mods) to support network shares under win32.
2152
2158
2153 * IPython/winconsole.py (get_console_size): add new winconsole
2159 * IPython/winconsole.py (get_console_size): add new winconsole
2154 module and fixes to page_dumb() to improve its behavior under
2160 module and fixes to page_dumb() to improve its behavior under
2155 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2161 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2156
2162
2157 * IPython/Magic.py (Macro): simplified Macro class to just
2163 * IPython/Magic.py (Macro): simplified Macro class to just
2158 subclass list. We've had only 2.2 compatibility for a very long
2164 subclass list. We've had only 2.2 compatibility for a very long
2159 time, yet I was still avoiding subclassing the builtin types. No
2165 time, yet I was still avoiding subclassing the builtin types. No
2160 more (I'm also starting to use properties, though I won't shift to
2166 more (I'm also starting to use properties, though I won't shift to
2161 2.3-specific features quite yet).
2167 2.3-specific features quite yet).
2162 (magic_store): added Ville's patch for lightweight variable
2168 (magic_store): added Ville's patch for lightweight variable
2163 persistence, after a request on the user list by Matt Wilkie
2169 persistence, after a request on the user list by Matt Wilkie
2164 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2170 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2165 details.
2171 details.
2166
2172
2167 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2173 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2168 changed the default logfile name from 'ipython.log' to
2174 changed the default logfile name from 'ipython.log' to
2169 'ipython_log.py'. These logs are real python files, and now that
2175 'ipython_log.py'. These logs are real python files, and now that
2170 we have much better multiline support, people are more likely to
2176 we have much better multiline support, people are more likely to
2171 want to use them as such. Might as well name them correctly.
2177 want to use them as such. Might as well name them correctly.
2172
2178
2173 * IPython/Magic.py: substantial cleanup. While we can't stop
2179 * IPython/Magic.py: substantial cleanup. While we can't stop
2174 using magics as mixins, due to the existing customizations 'out
2180 using magics as mixins, due to the existing customizations 'out
2175 there' which rely on the mixin naming conventions, at least I
2181 there' which rely on the mixin naming conventions, at least I
2176 cleaned out all cross-class name usage. So once we are OK with
2182 cleaned out all cross-class name usage. So once we are OK with
2177 breaking compatibility, the two systems can be separated.
2183 breaking compatibility, the two systems can be separated.
2178
2184
2179 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2185 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2180 anymore, and the class is a fair bit less hideous as well. New
2186 anymore, and the class is a fair bit less hideous as well. New
2181 features were also introduced: timestamping of input, and logging
2187 features were also introduced: timestamping of input, and logging
2182 of output results. These are user-visible with the -t and -o
2188 of output results. These are user-visible with the -t and -o
2183 options to %logstart. Closes
2189 options to %logstart. Closes
2184 http://www.scipy.net/roundup/ipython/issue11 and a request by
2190 http://www.scipy.net/roundup/ipython/issue11 and a request by
2185 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2191 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2186
2192
2187 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2193 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2188
2194
2189 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2195 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2190 better handle backslashes in paths. See the thread 'More Windows
2196 better handle backslashes in paths. See the thread 'More Windows
2191 questions part 2 - \/ characters revisited' on the iypthon user
2197 questions part 2 - \/ characters revisited' on the iypthon user
2192 list:
2198 list:
2193 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2199 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2194
2200
2195 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2201 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2196
2202
2197 (InteractiveShell.__init__): change threaded shells to not use the
2203 (InteractiveShell.__init__): change threaded shells to not use the
2198 ipython crash handler. This was causing more problems than not,
2204 ipython crash handler. This was causing more problems than not,
2199 as exceptions in the main thread (GUI code, typically) would
2205 as exceptions in the main thread (GUI code, typically) would
2200 always show up as a 'crash', when they really weren't.
2206 always show up as a 'crash', when they really weren't.
2201
2207
2202 The colors and exception mode commands (%colors/%xmode) have been
2208 The colors and exception mode commands (%colors/%xmode) have been
2203 synchronized to also take this into account, so users can get
2209 synchronized to also take this into account, so users can get
2204 verbose exceptions for their threaded code as well. I also added
2210 verbose exceptions for their threaded code as well. I also added
2205 support for activating pdb inside this exception handler as well,
2211 support for activating pdb inside this exception handler as well,
2206 so now GUI authors can use IPython's enhanced pdb at runtime.
2212 so now GUI authors can use IPython's enhanced pdb at runtime.
2207
2213
2208 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2214 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2209 true by default, and add it to the shipped ipythonrc file. Since
2215 true by default, and add it to the shipped ipythonrc file. Since
2210 this asks the user before proceeding, I think it's OK to make it
2216 this asks the user before proceeding, I think it's OK to make it
2211 true by default.
2217 true by default.
2212
2218
2213 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2219 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2214 of the previous special-casing of input in the eval loop. I think
2220 of the previous special-casing of input in the eval loop. I think
2215 this is cleaner, as they really are commands and shouldn't have
2221 this is cleaner, as they really are commands and shouldn't have
2216 a special role in the middle of the core code.
2222 a special role in the middle of the core code.
2217
2223
2218 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2224 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2219
2225
2220 * IPython/iplib.py (edit_syntax_error): added support for
2226 * IPython/iplib.py (edit_syntax_error): added support for
2221 automatically reopening the editor if the file had a syntax error
2227 automatically reopening the editor if the file had a syntax error
2222 in it. Thanks to scottt who provided the patch at:
2228 in it. Thanks to scottt who provided the patch at:
2223 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2229 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2224 version committed).
2230 version committed).
2225
2231
2226 * IPython/iplib.py (handle_normal): add suport for multi-line
2232 * IPython/iplib.py (handle_normal): add suport for multi-line
2227 input with emtpy lines. This fixes
2233 input with emtpy lines. This fixes
2228 http://www.scipy.net/roundup/ipython/issue43 and a similar
2234 http://www.scipy.net/roundup/ipython/issue43 and a similar
2229 discussion on the user list.
2235 discussion on the user list.
2230
2236
2231 WARNING: a behavior change is necessarily introduced to support
2237 WARNING: a behavior change is necessarily introduced to support
2232 blank lines: now a single blank line with whitespace does NOT
2238 blank lines: now a single blank line with whitespace does NOT
2233 break the input loop, which means that when autoindent is on, by
2239 break the input loop, which means that when autoindent is on, by
2234 default hitting return on the next (indented) line does NOT exit.
2240 default hitting return on the next (indented) line does NOT exit.
2235
2241
2236 Instead, to exit a multiline input you can either have:
2242 Instead, to exit a multiline input you can either have:
2237
2243
2238 - TWO whitespace lines (just hit return again), or
2244 - TWO whitespace lines (just hit return again), or
2239 - a single whitespace line of a different length than provided
2245 - a single whitespace line of a different length than provided
2240 by the autoindent (add or remove a space).
2246 by the autoindent (add or remove a space).
2241
2247
2242 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2248 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2243 module to better organize all readline-related functionality.
2249 module to better organize all readline-related functionality.
2244 I've deleted FlexCompleter and put all completion clases here.
2250 I've deleted FlexCompleter and put all completion clases here.
2245
2251
2246 * IPython/iplib.py (raw_input): improve indentation management.
2252 * IPython/iplib.py (raw_input): improve indentation management.
2247 It is now possible to paste indented code with autoindent on, and
2253 It is now possible to paste indented code with autoindent on, and
2248 the code is interpreted correctly (though it still looks bad on
2254 the code is interpreted correctly (though it still looks bad on
2249 screen, due to the line-oriented nature of ipython).
2255 screen, due to the line-oriented nature of ipython).
2250 (MagicCompleter.complete): change behavior so that a TAB key on an
2256 (MagicCompleter.complete): change behavior so that a TAB key on an
2251 otherwise empty line actually inserts a tab, instead of completing
2257 otherwise empty line actually inserts a tab, instead of completing
2252 on the entire global namespace. This makes it easier to use the
2258 on the entire global namespace. This makes it easier to use the
2253 TAB key for indentation. After a request by Hans Meine
2259 TAB key for indentation. After a request by Hans Meine
2254 <hans_meine-AT-gmx.net>
2260 <hans_meine-AT-gmx.net>
2255 (_prefilter): add support so that typing plain 'exit' or 'quit'
2261 (_prefilter): add support so that typing plain 'exit' or 'quit'
2256 does a sensible thing. Originally I tried to deviate as little as
2262 does a sensible thing. Originally I tried to deviate as little as
2257 possible from the default python behavior, but even that one may
2263 possible from the default python behavior, but even that one may
2258 change in this direction (thread on python-dev to that effect).
2264 change in this direction (thread on python-dev to that effect).
2259 Regardless, ipython should do the right thing even if CPython's
2265 Regardless, ipython should do the right thing even if CPython's
2260 '>>>' prompt doesn't.
2266 '>>>' prompt doesn't.
2261 (InteractiveShell): removed subclassing code.InteractiveConsole
2267 (InteractiveShell): removed subclassing code.InteractiveConsole
2262 class. By now we'd overridden just about all of its methods: I've
2268 class. By now we'd overridden just about all of its methods: I've
2263 copied the remaining two over, and now ipython is a standalone
2269 copied the remaining two over, and now ipython is a standalone
2264 class. This will provide a clearer picture for the chainsaw
2270 class. This will provide a clearer picture for the chainsaw
2265 branch refactoring.
2271 branch refactoring.
2266
2272
2267 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2273 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2268
2274
2269 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2275 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2270 failures for objects which break when dir() is called on them.
2276 failures for objects which break when dir() is called on them.
2271
2277
2272 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2278 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2273 distinct local and global namespaces in the completer API. This
2279 distinct local and global namespaces in the completer API. This
2274 change allows us to properly handle completion with distinct
2280 change allows us to properly handle completion with distinct
2275 scopes, including in embedded instances (this had never really
2281 scopes, including in embedded instances (this had never really
2276 worked correctly).
2282 worked correctly).
2277
2283
2278 Note: this introduces a change in the constructor for
2284 Note: this introduces a change in the constructor for
2279 MagicCompleter, as a new global_namespace parameter is now the
2285 MagicCompleter, as a new global_namespace parameter is now the
2280 second argument (the others were bumped one position).
2286 second argument (the others were bumped one position).
2281
2287
2282 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2288 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2283
2289
2284 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2290 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2285 embedded instances (which can be done now thanks to Vivian's
2291 embedded instances (which can be done now thanks to Vivian's
2286 frame-handling fixes for pdb).
2292 frame-handling fixes for pdb).
2287 (InteractiveShell.__init__): Fix namespace handling problem in
2293 (InteractiveShell.__init__): Fix namespace handling problem in
2288 embedded instances. We were overwriting __main__ unconditionally,
2294 embedded instances. We were overwriting __main__ unconditionally,
2289 and this should only be done for 'full' (non-embedded) IPython;
2295 and this should only be done for 'full' (non-embedded) IPython;
2290 embedded instances must respect the caller's __main__. Thanks to
2296 embedded instances must respect the caller's __main__. Thanks to
2291 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2297 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2292
2298
2293 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2299 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2294
2300
2295 * setup.py: added download_url to setup(). This registers the
2301 * setup.py: added download_url to setup(). This registers the
2296 download address at PyPI, which is not only useful to humans
2302 download address at PyPI, which is not only useful to humans
2297 browsing the site, but is also picked up by setuptools (the Eggs
2303 browsing the site, but is also picked up by setuptools (the Eggs
2298 machinery). Thanks to Ville and R. Kern for the info/discussion
2304 machinery). Thanks to Ville and R. Kern for the info/discussion
2299 on this.
2305 on this.
2300
2306
2301 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2307 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2302
2308
2303 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2309 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2304 This brings a lot of nice functionality to the pdb mode, which now
2310 This brings a lot of nice functionality to the pdb mode, which now
2305 has tab-completion, syntax highlighting, and better stack handling
2311 has tab-completion, syntax highlighting, and better stack handling
2306 than before. Many thanks to Vivian De Smedt
2312 than before. Many thanks to Vivian De Smedt
2307 <vivian-AT-vdesmedt.com> for the original patches.
2313 <vivian-AT-vdesmedt.com> for the original patches.
2308
2314
2309 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2315 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2310
2316
2311 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2317 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2312 sequence to consistently accept the banner argument. The
2318 sequence to consistently accept the banner argument. The
2313 inconsistency was tripping SAGE, thanks to Gary Zablackis
2319 inconsistency was tripping SAGE, thanks to Gary Zablackis
2314 <gzabl-AT-yahoo.com> for the report.
2320 <gzabl-AT-yahoo.com> for the report.
2315
2321
2316 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2322 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2317
2323
2318 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2324 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2319 Fix bug where a naked 'alias' call in the ipythonrc file would
2325 Fix bug where a naked 'alias' call in the ipythonrc file would
2320 cause a crash. Bug reported by Jorgen Stenarson.
2326 cause a crash. Bug reported by Jorgen Stenarson.
2321
2327
2322 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2328 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2323
2329
2324 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2330 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2325 startup time.
2331 startup time.
2326
2332
2327 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2333 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2328 instances had introduced a bug with globals in normal code. Now
2334 instances had introduced a bug with globals in normal code. Now
2329 it's working in all cases.
2335 it's working in all cases.
2330
2336
2331 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2337 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2332 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2338 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2333 has been introduced to set the default case sensitivity of the
2339 has been introduced to set the default case sensitivity of the
2334 searches. Users can still select either mode at runtime on a
2340 searches. Users can still select either mode at runtime on a
2335 per-search basis.
2341 per-search basis.
2336
2342
2337 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2343 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2338
2344
2339 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2345 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2340 attributes in wildcard searches for subclasses. Modified version
2346 attributes in wildcard searches for subclasses. Modified version
2341 of a patch by Jorgen.
2347 of a patch by Jorgen.
2342
2348
2343 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2349 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2344
2350
2345 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2351 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2346 embedded instances. I added a user_global_ns attribute to the
2352 embedded instances. I added a user_global_ns attribute to the
2347 InteractiveShell class to handle this.
2353 InteractiveShell class to handle this.
2348
2354
2349 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2355 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2350
2356
2351 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2357 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2352 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2358 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2353 (reported under win32, but may happen also in other platforms).
2359 (reported under win32, but may happen also in other platforms).
2354 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2360 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2355
2361
2356 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2362 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2357
2363
2358 * IPython/Magic.py (magic_psearch): new support for wildcard
2364 * IPython/Magic.py (magic_psearch): new support for wildcard
2359 patterns. Now, typing ?a*b will list all names which begin with a
2365 patterns. Now, typing ?a*b will list all names which begin with a
2360 and end in b, for example. The %psearch magic has full
2366 and end in b, for example. The %psearch magic has full
2361 docstrings. Many thanks to JΓΆrgen Stenarson
2367 docstrings. Many thanks to JΓΆrgen Stenarson
2362 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2368 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2363 implementing this functionality.
2369 implementing this functionality.
2364
2370
2365 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2371 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2366
2372
2367 * Manual: fixed long-standing annoyance of double-dashes (as in
2373 * Manual: fixed long-standing annoyance of double-dashes (as in
2368 --prefix=~, for example) being stripped in the HTML version. This
2374 --prefix=~, for example) being stripped in the HTML version. This
2369 is a latex2html bug, but a workaround was provided. Many thanks
2375 is a latex2html bug, but a workaround was provided. Many thanks
2370 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2376 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2371 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2377 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2372 rolling. This seemingly small issue had tripped a number of users
2378 rolling. This seemingly small issue had tripped a number of users
2373 when first installing, so I'm glad to see it gone.
2379 when first installing, so I'm glad to see it gone.
2374
2380
2375 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2381 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2376
2382
2377 * IPython/Extensions/numeric_formats.py: fix missing import,
2383 * IPython/Extensions/numeric_formats.py: fix missing import,
2378 reported by Stephen Walton.
2384 reported by Stephen Walton.
2379
2385
2380 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2386 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2381
2387
2382 * IPython/demo.py: finish demo module, fully documented now.
2388 * IPython/demo.py: finish demo module, fully documented now.
2383
2389
2384 * IPython/genutils.py (file_read): simple little utility to read a
2390 * IPython/genutils.py (file_read): simple little utility to read a
2385 file and ensure it's closed afterwards.
2391 file and ensure it's closed afterwards.
2386
2392
2387 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2393 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2388
2394
2389 * IPython/demo.py (Demo.__init__): added support for individually
2395 * IPython/demo.py (Demo.__init__): added support for individually
2390 tagging blocks for automatic execution.
2396 tagging blocks for automatic execution.
2391
2397
2392 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2398 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2393 syntax-highlighted python sources, requested by John.
2399 syntax-highlighted python sources, requested by John.
2394
2400
2395 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2401 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2396
2402
2397 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2403 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2398 finishing.
2404 finishing.
2399
2405
2400 * IPython/genutils.py (shlex_split): moved from Magic to here,
2406 * IPython/genutils.py (shlex_split): moved from Magic to here,
2401 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2407 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2402
2408
2403 * IPython/demo.py (Demo.__init__): added support for silent
2409 * IPython/demo.py (Demo.__init__): added support for silent
2404 blocks, improved marks as regexps, docstrings written.
2410 blocks, improved marks as regexps, docstrings written.
2405 (Demo.__init__): better docstring, added support for sys.argv.
2411 (Demo.__init__): better docstring, added support for sys.argv.
2406
2412
2407 * IPython/genutils.py (marquee): little utility used by the demo
2413 * IPython/genutils.py (marquee): little utility used by the demo
2408 code, handy in general.
2414 code, handy in general.
2409
2415
2410 * IPython/demo.py (Demo.__init__): new class for interactive
2416 * IPython/demo.py (Demo.__init__): new class for interactive
2411 demos. Not documented yet, I just wrote it in a hurry for
2417 demos. Not documented yet, I just wrote it in a hurry for
2412 scipy'05. Will docstring later.
2418 scipy'05. Will docstring later.
2413
2419
2414 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2420 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2415
2421
2416 * IPython/Shell.py (sigint_handler): Drastic simplification which
2422 * IPython/Shell.py (sigint_handler): Drastic simplification which
2417 also seems to make Ctrl-C work correctly across threads! This is
2423 also seems to make Ctrl-C work correctly across threads! This is
2418 so simple, that I can't beleive I'd missed it before. Needs more
2424 so simple, that I can't beleive I'd missed it before. Needs more
2419 testing, though.
2425 testing, though.
2420 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2426 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2421 like this before...
2427 like this before...
2422
2428
2423 * IPython/genutils.py (get_home_dir): add protection against
2429 * IPython/genutils.py (get_home_dir): add protection against
2424 non-dirs in win32 registry.
2430 non-dirs in win32 registry.
2425
2431
2426 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2432 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2427 bug where dict was mutated while iterating (pysh crash).
2433 bug where dict was mutated while iterating (pysh crash).
2428
2434
2429 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2435 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2430
2436
2431 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2437 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2432 spurious newlines added by this routine. After a report by
2438 spurious newlines added by this routine. After a report by
2433 F. Mantegazza.
2439 F. Mantegazza.
2434
2440
2435 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2441 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2436
2442
2437 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2443 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2438 calls. These were a leftover from the GTK 1.x days, and can cause
2444 calls. These were a leftover from the GTK 1.x days, and can cause
2439 problems in certain cases (after a report by John Hunter).
2445 problems in certain cases (after a report by John Hunter).
2440
2446
2441 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2447 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2442 os.getcwd() fails at init time. Thanks to patch from David Remahl
2448 os.getcwd() fails at init time. Thanks to patch from David Remahl
2443 <chmod007-AT-mac.com>.
2449 <chmod007-AT-mac.com>.
2444 (InteractiveShell.__init__): prevent certain special magics from
2450 (InteractiveShell.__init__): prevent certain special magics from
2445 being shadowed by aliases. Closes
2451 being shadowed by aliases. Closes
2446 http://www.scipy.net/roundup/ipython/issue41.
2452 http://www.scipy.net/roundup/ipython/issue41.
2447
2453
2448 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2454 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2449
2455
2450 * IPython/iplib.py (InteractiveShell.complete): Added new
2456 * IPython/iplib.py (InteractiveShell.complete): Added new
2451 top-level completion method to expose the completion mechanism
2457 top-level completion method to expose the completion mechanism
2452 beyond readline-based environments.
2458 beyond readline-based environments.
2453
2459
2454 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2460 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2455
2461
2456 * tools/ipsvnc (svnversion): fix svnversion capture.
2462 * tools/ipsvnc (svnversion): fix svnversion capture.
2457
2463
2458 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2464 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2459 attribute to self, which was missing. Before, it was set by a
2465 attribute to self, which was missing. Before, it was set by a
2460 routine which in certain cases wasn't being called, so the
2466 routine which in certain cases wasn't being called, so the
2461 instance could end up missing the attribute. This caused a crash.
2467 instance could end up missing the attribute. This caused a crash.
2462 Closes http://www.scipy.net/roundup/ipython/issue40.
2468 Closes http://www.scipy.net/roundup/ipython/issue40.
2463
2469
2464 2005-08-16 Fernando Perez <fperez@colorado.edu>
2470 2005-08-16 Fernando Perez <fperez@colorado.edu>
2465
2471
2466 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2472 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2467 contains non-string attribute. Closes
2473 contains non-string attribute. Closes
2468 http://www.scipy.net/roundup/ipython/issue38.
2474 http://www.scipy.net/roundup/ipython/issue38.
2469
2475
2470 2005-08-14 Fernando Perez <fperez@colorado.edu>
2476 2005-08-14 Fernando Perez <fperez@colorado.edu>
2471
2477
2472 * tools/ipsvnc: Minor improvements, to add changeset info.
2478 * tools/ipsvnc: Minor improvements, to add changeset info.
2473
2479
2474 2005-08-12 Fernando Perez <fperez@colorado.edu>
2480 2005-08-12 Fernando Perez <fperez@colorado.edu>
2475
2481
2476 * IPython/iplib.py (runsource): remove self.code_to_run_src
2482 * IPython/iplib.py (runsource): remove self.code_to_run_src
2477 attribute. I realized this is nothing more than
2483 attribute. I realized this is nothing more than
2478 '\n'.join(self.buffer), and having the same data in two different
2484 '\n'.join(self.buffer), and having the same data in two different
2479 places is just asking for synchronization bugs. This may impact
2485 places is just asking for synchronization bugs. This may impact
2480 people who have custom exception handlers, so I need to warn
2486 people who have custom exception handlers, so I need to warn
2481 ipython-dev about it (F. Mantegazza may use them).
2487 ipython-dev about it (F. Mantegazza may use them).
2482
2488
2483 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2489 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2484
2490
2485 * IPython/genutils.py: fix 2.2 compatibility (generators)
2491 * IPython/genutils.py: fix 2.2 compatibility (generators)
2486
2492
2487 2005-07-18 Fernando Perez <fperez@colorado.edu>
2493 2005-07-18 Fernando Perez <fperez@colorado.edu>
2488
2494
2489 * IPython/genutils.py (get_home_dir): fix to help users with
2495 * IPython/genutils.py (get_home_dir): fix to help users with
2490 invalid $HOME under win32.
2496 invalid $HOME under win32.
2491
2497
2492 2005-07-17 Fernando Perez <fperez@colorado.edu>
2498 2005-07-17 Fernando Perez <fperez@colorado.edu>
2493
2499
2494 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2500 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2495 some old hacks and clean up a bit other routines; code should be
2501 some old hacks and clean up a bit other routines; code should be
2496 simpler and a bit faster.
2502 simpler and a bit faster.
2497
2503
2498 * IPython/iplib.py (interact): removed some last-resort attempts
2504 * IPython/iplib.py (interact): removed some last-resort attempts
2499 to survive broken stdout/stderr. That code was only making it
2505 to survive broken stdout/stderr. That code was only making it
2500 harder to abstract out the i/o (necessary for gui integration),
2506 harder to abstract out the i/o (necessary for gui integration),
2501 and the crashes it could prevent were extremely rare in practice
2507 and the crashes it could prevent were extremely rare in practice
2502 (besides being fully user-induced in a pretty violent manner).
2508 (besides being fully user-induced in a pretty violent manner).
2503
2509
2504 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2510 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2505 Nothing major yet, but the code is simpler to read; this should
2511 Nothing major yet, but the code is simpler to read; this should
2506 make it easier to do more serious modifications in the future.
2512 make it easier to do more serious modifications in the future.
2507
2513
2508 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2514 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2509 which broke in .15 (thanks to a report by Ville).
2515 which broke in .15 (thanks to a report by Ville).
2510
2516
2511 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2517 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2512 be quite correct, I know next to nothing about unicode). This
2518 be quite correct, I know next to nothing about unicode). This
2513 will allow unicode strings to be used in prompts, amongst other
2519 will allow unicode strings to be used in prompts, amongst other
2514 cases. It also will prevent ipython from crashing when unicode
2520 cases. It also will prevent ipython from crashing when unicode
2515 shows up unexpectedly in many places. If ascii encoding fails, we
2521 shows up unexpectedly in many places. If ascii encoding fails, we
2516 assume utf_8. Currently the encoding is not a user-visible
2522 assume utf_8. Currently the encoding is not a user-visible
2517 setting, though it could be made so if there is demand for it.
2523 setting, though it could be made so if there is demand for it.
2518
2524
2519 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2525 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2520
2526
2521 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2527 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2522
2528
2523 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2529 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2524
2530
2525 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2531 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2526 code can work transparently for 2.2/2.3.
2532 code can work transparently for 2.2/2.3.
2527
2533
2528 2005-07-16 Fernando Perez <fperez@colorado.edu>
2534 2005-07-16 Fernando Perez <fperez@colorado.edu>
2529
2535
2530 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2536 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2531 out of the color scheme table used for coloring exception
2537 out of the color scheme table used for coloring exception
2532 tracebacks. This allows user code to add new schemes at runtime.
2538 tracebacks. This allows user code to add new schemes at runtime.
2533 This is a minimally modified version of the patch at
2539 This is a minimally modified version of the patch at
2534 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2540 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2535 for the contribution.
2541 for the contribution.
2536
2542
2537 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2543 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2538 slightly modified version of the patch in
2544 slightly modified version of the patch in
2539 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2545 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2540 to remove the previous try/except solution (which was costlier).
2546 to remove the previous try/except solution (which was costlier).
2541 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2547 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2542
2548
2543 2005-06-08 Fernando Perez <fperez@colorado.edu>
2549 2005-06-08 Fernando Perez <fperez@colorado.edu>
2544
2550
2545 * IPython/iplib.py (write/write_err): Add methods to abstract all
2551 * IPython/iplib.py (write/write_err): Add methods to abstract all
2546 I/O a bit more.
2552 I/O a bit more.
2547
2553
2548 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2554 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2549 warning, reported by Aric Hagberg, fix by JD Hunter.
2555 warning, reported by Aric Hagberg, fix by JD Hunter.
2550
2556
2551 2005-06-02 *** Released version 0.6.15
2557 2005-06-02 *** Released version 0.6.15
2552
2558
2553 2005-06-01 Fernando Perez <fperez@colorado.edu>
2559 2005-06-01 Fernando Perez <fperez@colorado.edu>
2554
2560
2555 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2561 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2556 tab-completion of filenames within open-quoted strings. Note that
2562 tab-completion of filenames within open-quoted strings. Note that
2557 this requires that in ~/.ipython/ipythonrc, users change the
2563 this requires that in ~/.ipython/ipythonrc, users change the
2558 readline delimiters configuration to read:
2564 readline delimiters configuration to read:
2559
2565
2560 readline_remove_delims -/~
2566 readline_remove_delims -/~
2561
2567
2562
2568
2563 2005-05-31 *** Released version 0.6.14
2569 2005-05-31 *** Released version 0.6.14
2564
2570
2565 2005-05-29 Fernando Perez <fperez@colorado.edu>
2571 2005-05-29 Fernando Perez <fperez@colorado.edu>
2566
2572
2567 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2573 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2568 with files not on the filesystem. Reported by Eliyahu Sandler
2574 with files not on the filesystem. Reported by Eliyahu Sandler
2569 <eli@gondolin.net>
2575 <eli@gondolin.net>
2570
2576
2571 2005-05-22 Fernando Perez <fperez@colorado.edu>
2577 2005-05-22 Fernando Perez <fperez@colorado.edu>
2572
2578
2573 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2579 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2574 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2580 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2575
2581
2576 2005-05-19 Fernando Perez <fperez@colorado.edu>
2582 2005-05-19 Fernando Perez <fperez@colorado.edu>
2577
2583
2578 * IPython/iplib.py (safe_execfile): close a file which could be
2584 * IPython/iplib.py (safe_execfile): close a file which could be
2579 left open (causing problems in win32, which locks open files).
2585 left open (causing problems in win32, which locks open files).
2580 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2586 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2581
2587
2582 2005-05-18 Fernando Perez <fperez@colorado.edu>
2588 2005-05-18 Fernando Perez <fperez@colorado.edu>
2583
2589
2584 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2590 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2585 keyword arguments correctly to safe_execfile().
2591 keyword arguments correctly to safe_execfile().
2586
2592
2587 2005-05-13 Fernando Perez <fperez@colorado.edu>
2593 2005-05-13 Fernando Perez <fperez@colorado.edu>
2588
2594
2589 * ipython.1: Added info about Qt to manpage, and threads warning
2595 * ipython.1: Added info about Qt to manpage, and threads warning
2590 to usage page (invoked with --help).
2596 to usage page (invoked with --help).
2591
2597
2592 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2598 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2593 new matcher (it goes at the end of the priority list) to do
2599 new matcher (it goes at the end of the priority list) to do
2594 tab-completion on named function arguments. Submitted by George
2600 tab-completion on named function arguments. Submitted by George
2595 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2601 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2596 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2602 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2597 for more details.
2603 for more details.
2598
2604
2599 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2605 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2600 SystemExit exceptions in the script being run. Thanks to a report
2606 SystemExit exceptions in the script being run. Thanks to a report
2601 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2607 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2602 producing very annoying behavior when running unit tests.
2608 producing very annoying behavior when running unit tests.
2603
2609
2604 2005-05-12 Fernando Perez <fperez@colorado.edu>
2610 2005-05-12 Fernando Perez <fperez@colorado.edu>
2605
2611
2606 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2612 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2607 which I'd broken (again) due to a changed regexp. In the process,
2613 which I'd broken (again) due to a changed regexp. In the process,
2608 added ';' as an escape to auto-quote the whole line without
2614 added ';' as an escape to auto-quote the whole line without
2609 splitting its arguments. Thanks to a report by Jerry McRae
2615 splitting its arguments. Thanks to a report by Jerry McRae
2610 <qrs0xyc02-AT-sneakemail.com>.
2616 <qrs0xyc02-AT-sneakemail.com>.
2611
2617
2612 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2618 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2613 possible crashes caused by a TokenError. Reported by Ed Schofield
2619 possible crashes caused by a TokenError. Reported by Ed Schofield
2614 <schofield-AT-ftw.at>.
2620 <schofield-AT-ftw.at>.
2615
2621
2616 2005-05-06 Fernando Perez <fperez@colorado.edu>
2622 2005-05-06 Fernando Perez <fperez@colorado.edu>
2617
2623
2618 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2624 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2619
2625
2620 2005-04-29 Fernando Perez <fperez@colorado.edu>
2626 2005-04-29 Fernando Perez <fperez@colorado.edu>
2621
2627
2622 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2628 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2623 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2629 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2624 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2630 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2625 which provides support for Qt interactive usage (similar to the
2631 which provides support for Qt interactive usage (similar to the
2626 existing one for WX and GTK). This had been often requested.
2632 existing one for WX and GTK). This had been often requested.
2627
2633
2628 2005-04-14 *** Released version 0.6.13
2634 2005-04-14 *** Released version 0.6.13
2629
2635
2630 2005-04-08 Fernando Perez <fperez@colorado.edu>
2636 2005-04-08 Fernando Perez <fperez@colorado.edu>
2631
2637
2632 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2638 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2633 from _ofind, which gets called on almost every input line. Now,
2639 from _ofind, which gets called on almost every input line. Now,
2634 we only try to get docstrings if they are actually going to be
2640 we only try to get docstrings if they are actually going to be
2635 used (the overhead of fetching unnecessary docstrings can be
2641 used (the overhead of fetching unnecessary docstrings can be
2636 noticeable for certain objects, such as Pyro proxies).
2642 noticeable for certain objects, such as Pyro proxies).
2637
2643
2638 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2644 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2639 for completers. For some reason I had been passing them the state
2645 for completers. For some reason I had been passing them the state
2640 variable, which completers never actually need, and was in
2646 variable, which completers never actually need, and was in
2641 conflict with the rlcompleter API. Custom completers ONLY need to
2647 conflict with the rlcompleter API. Custom completers ONLY need to
2642 take the text parameter.
2648 take the text parameter.
2643
2649
2644 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
2650 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
2645 work correctly in pysh. I've also moved all the logic which used
2651 work correctly in pysh. I've also moved all the logic which used
2646 to be in pysh.py here, which will prevent problems with future
2652 to be in pysh.py here, which will prevent problems with future
2647 upgrades. However, this time I must warn users to update their
2653 upgrades. However, this time I must warn users to update their
2648 pysh profile to include the line
2654 pysh profile to include the line
2649
2655
2650 import_all IPython.Extensions.InterpreterExec
2656 import_all IPython.Extensions.InterpreterExec
2651
2657
2652 because otherwise things won't work for them. They MUST also
2658 because otherwise things won't work for them. They MUST also
2653 delete pysh.py and the line
2659 delete pysh.py and the line
2654
2660
2655 execfile pysh.py
2661 execfile pysh.py
2656
2662
2657 from their ipythonrc-pysh.
2663 from their ipythonrc-pysh.
2658
2664
2659 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
2665 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
2660 robust in the face of objects whose dir() returns non-strings
2666 robust in the face of objects whose dir() returns non-strings
2661 (which it shouldn't, but some broken libs like ITK do). Thanks to
2667 (which it shouldn't, but some broken libs like ITK do). Thanks to
2662 a patch by John Hunter (implemented differently, though). Also
2668 a patch by John Hunter (implemented differently, though). Also
2663 minor improvements by using .extend instead of + on lists.
2669 minor improvements by using .extend instead of + on lists.
2664
2670
2665 * pysh.py:
2671 * pysh.py:
2666
2672
2667 2005-04-06 Fernando Perez <fperez@colorado.edu>
2673 2005-04-06 Fernando Perez <fperez@colorado.edu>
2668
2674
2669 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
2675 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
2670 by default, so that all users benefit from it. Those who don't
2676 by default, so that all users benefit from it. Those who don't
2671 want it can still turn it off.
2677 want it can still turn it off.
2672
2678
2673 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
2679 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
2674 config file, I'd forgotten about this, so users were getting it
2680 config file, I'd forgotten about this, so users were getting it
2675 off by default.
2681 off by default.
2676
2682
2677 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
2683 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
2678 consistency. Now magics can be called in multiline statements,
2684 consistency. Now magics can be called in multiline statements,
2679 and python variables can be expanded in magic calls via $var.
2685 and python variables can be expanded in magic calls via $var.
2680 This makes the magic system behave just like aliases or !system
2686 This makes the magic system behave just like aliases or !system
2681 calls.
2687 calls.
2682
2688
2683 2005-03-28 Fernando Perez <fperez@colorado.edu>
2689 2005-03-28 Fernando Perez <fperez@colorado.edu>
2684
2690
2685 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
2691 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
2686 expensive string additions for building command. Add support for
2692 expensive string additions for building command. Add support for
2687 trailing ';' when autocall is used.
2693 trailing ';' when autocall is used.
2688
2694
2689 2005-03-26 Fernando Perez <fperez@colorado.edu>
2695 2005-03-26 Fernando Perez <fperez@colorado.edu>
2690
2696
2691 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
2697 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
2692 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
2698 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
2693 ipython.el robust against prompts with any number of spaces
2699 ipython.el robust against prompts with any number of spaces
2694 (including 0) after the ':' character.
2700 (including 0) after the ':' character.
2695
2701
2696 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
2702 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
2697 continuation prompt, which misled users to think the line was
2703 continuation prompt, which misled users to think the line was
2698 already indented. Closes debian Bug#300847, reported to me by
2704 already indented. Closes debian Bug#300847, reported to me by
2699 Norbert Tretkowski <tretkowski-AT-inittab.de>.
2705 Norbert Tretkowski <tretkowski-AT-inittab.de>.
2700
2706
2701 2005-03-23 Fernando Perez <fperez@colorado.edu>
2707 2005-03-23 Fernando Perez <fperez@colorado.edu>
2702
2708
2703 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
2709 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
2704 properly aligned if they have embedded newlines.
2710 properly aligned if they have embedded newlines.
2705
2711
2706 * IPython/iplib.py (runlines): Add a public method to expose
2712 * IPython/iplib.py (runlines): Add a public method to expose
2707 IPython's code execution machinery, so that users can run strings
2713 IPython's code execution machinery, so that users can run strings
2708 as if they had been typed at the prompt interactively.
2714 as if they had been typed at the prompt interactively.
2709 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
2715 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
2710 methods which can call the system shell, but with python variable
2716 methods which can call the system shell, but with python variable
2711 expansion. The three such methods are: __IPYTHON__.system,
2717 expansion. The three such methods are: __IPYTHON__.system,
2712 .getoutput and .getoutputerror. These need to be documented in a
2718 .getoutput and .getoutputerror. These need to be documented in a
2713 'public API' section (to be written) of the manual.
2719 'public API' section (to be written) of the manual.
2714
2720
2715 2005-03-20 Fernando Perez <fperez@colorado.edu>
2721 2005-03-20 Fernando Perez <fperez@colorado.edu>
2716
2722
2717 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
2723 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
2718 for custom exception handling. This is quite powerful, and it
2724 for custom exception handling. This is quite powerful, and it
2719 allows for user-installable exception handlers which can trap
2725 allows for user-installable exception handlers which can trap
2720 custom exceptions at runtime and treat them separately from
2726 custom exceptions at runtime and treat them separately from
2721 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
2727 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
2722 Mantegazza <mantegazza-AT-ill.fr>.
2728 Mantegazza <mantegazza-AT-ill.fr>.
2723 (InteractiveShell.set_custom_completer): public API function to
2729 (InteractiveShell.set_custom_completer): public API function to
2724 add new completers at runtime.
2730 add new completers at runtime.
2725
2731
2726 2005-03-19 Fernando Perez <fperez@colorado.edu>
2732 2005-03-19 Fernando Perez <fperez@colorado.edu>
2727
2733
2728 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
2734 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
2729 allow objects which provide their docstrings via non-standard
2735 allow objects which provide their docstrings via non-standard
2730 mechanisms (like Pyro proxies) to still be inspected by ipython's
2736 mechanisms (like Pyro proxies) to still be inspected by ipython's
2731 ? system.
2737 ? system.
2732
2738
2733 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
2739 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
2734 automatic capture system. I tried quite hard to make it work
2740 automatic capture system. I tried quite hard to make it work
2735 reliably, and simply failed. I tried many combinations with the
2741 reliably, and simply failed. I tried many combinations with the
2736 subprocess module, but eventually nothing worked in all needed
2742 subprocess module, but eventually nothing worked in all needed
2737 cases (not blocking stdin for the child, duplicating stdout
2743 cases (not blocking stdin for the child, duplicating stdout
2738 without blocking, etc). The new %sc/%sx still do capture to these
2744 without blocking, etc). The new %sc/%sx still do capture to these
2739 magical list/string objects which make shell use much more
2745 magical list/string objects which make shell use much more
2740 conveninent, so not all is lost.
2746 conveninent, so not all is lost.
2741
2747
2742 XXX - FIX MANUAL for the change above!
2748 XXX - FIX MANUAL for the change above!
2743
2749
2744 (runsource): I copied code.py's runsource() into ipython to modify
2750 (runsource): I copied code.py's runsource() into ipython to modify
2745 it a bit. Now the code object and source to be executed are
2751 it a bit. Now the code object and source to be executed are
2746 stored in ipython. This makes this info accessible to third-party
2752 stored in ipython. This makes this info accessible to third-party
2747 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
2753 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
2748 Mantegazza <mantegazza-AT-ill.fr>.
2754 Mantegazza <mantegazza-AT-ill.fr>.
2749
2755
2750 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
2756 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
2751 history-search via readline (like C-p/C-n). I'd wanted this for a
2757 history-search via readline (like C-p/C-n). I'd wanted this for a
2752 long time, but only recently found out how to do it. For users
2758 long time, but only recently found out how to do it. For users
2753 who already have their ipythonrc files made and want this, just
2759 who already have their ipythonrc files made and want this, just
2754 add:
2760 add:
2755
2761
2756 readline_parse_and_bind "\e[A": history-search-backward
2762 readline_parse_and_bind "\e[A": history-search-backward
2757 readline_parse_and_bind "\e[B": history-search-forward
2763 readline_parse_and_bind "\e[B": history-search-forward
2758
2764
2759 2005-03-18 Fernando Perez <fperez@colorado.edu>
2765 2005-03-18 Fernando Perez <fperez@colorado.edu>
2760
2766
2761 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
2767 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
2762 LSString and SList classes which allow transparent conversions
2768 LSString and SList classes which allow transparent conversions
2763 between list mode and whitespace-separated string.
2769 between list mode and whitespace-separated string.
2764 (magic_r): Fix recursion problem in %r.
2770 (magic_r): Fix recursion problem in %r.
2765
2771
2766 * IPython/genutils.py (LSString): New class to be used for
2772 * IPython/genutils.py (LSString): New class to be used for
2767 automatic storage of the results of all alias/system calls in _o
2773 automatic storage of the results of all alias/system calls in _o
2768 and _e (stdout/err). These provide a .l/.list attribute which
2774 and _e (stdout/err). These provide a .l/.list attribute which
2769 does automatic splitting on newlines. This means that for most
2775 does automatic splitting on newlines. This means that for most
2770 uses, you'll never need to do capturing of output with %sc/%sx
2776 uses, you'll never need to do capturing of output with %sc/%sx
2771 anymore, since ipython keeps this always done for you. Note that
2777 anymore, since ipython keeps this always done for you. Note that
2772 only the LAST results are stored, the _o/e variables are
2778 only the LAST results are stored, the _o/e variables are
2773 overwritten on each call. If you need to save their contents
2779 overwritten on each call. If you need to save their contents
2774 further, simply bind them to any other name.
2780 further, simply bind them to any other name.
2775
2781
2776 2005-03-17 Fernando Perez <fperez@colorado.edu>
2782 2005-03-17 Fernando Perez <fperez@colorado.edu>
2777
2783
2778 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
2784 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
2779 prompt namespace handling.
2785 prompt namespace handling.
2780
2786
2781 2005-03-16 Fernando Perez <fperez@colorado.edu>
2787 2005-03-16 Fernando Perez <fperez@colorado.edu>
2782
2788
2783 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
2789 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
2784 classic prompts to be '>>> ' (final space was missing, and it
2790 classic prompts to be '>>> ' (final space was missing, and it
2785 trips the emacs python mode).
2791 trips the emacs python mode).
2786 (BasePrompt.__str__): Added safe support for dynamic prompt
2792 (BasePrompt.__str__): Added safe support for dynamic prompt
2787 strings. Now you can set your prompt string to be '$x', and the
2793 strings. Now you can set your prompt string to be '$x', and the
2788 value of x will be printed from your interactive namespace. The
2794 value of x will be printed from your interactive namespace. The
2789 interpolation syntax includes the full Itpl support, so
2795 interpolation syntax includes the full Itpl support, so
2790 ${foo()+x+bar()} is a valid prompt string now, and the function
2796 ${foo()+x+bar()} is a valid prompt string now, and the function
2791 calls will be made at runtime.
2797 calls will be made at runtime.
2792
2798
2793 2005-03-15 Fernando Perez <fperez@colorado.edu>
2799 2005-03-15 Fernando Perez <fperez@colorado.edu>
2794
2800
2795 * IPython/Magic.py (magic_history): renamed %hist to %history, to
2801 * IPython/Magic.py (magic_history): renamed %hist to %history, to
2796 avoid name clashes in pylab. %hist still works, it just forwards
2802 avoid name clashes in pylab. %hist still works, it just forwards
2797 the call to %history.
2803 the call to %history.
2798
2804
2799 2005-03-02 *** Released version 0.6.12
2805 2005-03-02 *** Released version 0.6.12
2800
2806
2801 2005-03-02 Fernando Perez <fperez@colorado.edu>
2807 2005-03-02 Fernando Perez <fperez@colorado.edu>
2802
2808
2803 * IPython/iplib.py (handle_magic): log magic calls properly as
2809 * IPython/iplib.py (handle_magic): log magic calls properly as
2804 ipmagic() function calls.
2810 ipmagic() function calls.
2805
2811
2806 * IPython/Magic.py (magic_time): Improved %time to support
2812 * IPython/Magic.py (magic_time): Improved %time to support
2807 statements and provide wall-clock as well as CPU time.
2813 statements and provide wall-clock as well as CPU time.
2808
2814
2809 2005-02-27 Fernando Perez <fperez@colorado.edu>
2815 2005-02-27 Fernando Perez <fperez@colorado.edu>
2810
2816
2811 * IPython/hooks.py: New hooks module, to expose user-modifiable
2817 * IPython/hooks.py: New hooks module, to expose user-modifiable
2812 IPython functionality in a clean manner. For now only the editor
2818 IPython functionality in a clean manner. For now only the editor
2813 hook is actually written, and other thigns which I intend to turn
2819 hook is actually written, and other thigns which I intend to turn
2814 into proper hooks aren't yet there. The display and prefilter
2820 into proper hooks aren't yet there. The display and prefilter
2815 stuff, for example, should be hooks. But at least now the
2821 stuff, for example, should be hooks. But at least now the
2816 framework is in place, and the rest can be moved here with more
2822 framework is in place, and the rest can be moved here with more
2817 time later. IPython had had a .hooks variable for a long time for
2823 time later. IPython had had a .hooks variable for a long time for
2818 this purpose, but I'd never actually used it for anything.
2824 this purpose, but I'd never actually used it for anything.
2819
2825
2820 2005-02-26 Fernando Perez <fperez@colorado.edu>
2826 2005-02-26 Fernando Perez <fperez@colorado.edu>
2821
2827
2822 * IPython/ipmaker.py (make_IPython): make the default ipython
2828 * IPython/ipmaker.py (make_IPython): make the default ipython
2823 directory be called _ipython under win32, to follow more the
2829 directory be called _ipython under win32, to follow more the
2824 naming peculiarities of that platform (where buggy software like
2830 naming peculiarities of that platform (where buggy software like
2825 Visual Sourcesafe breaks with .named directories). Reported by
2831 Visual Sourcesafe breaks with .named directories). Reported by
2826 Ville Vainio.
2832 Ville Vainio.
2827
2833
2828 2005-02-23 Fernando Perez <fperez@colorado.edu>
2834 2005-02-23 Fernando Perez <fperez@colorado.edu>
2829
2835
2830 * IPython/iplib.py (InteractiveShell.__init__): removed a few
2836 * IPython/iplib.py (InteractiveShell.__init__): removed a few
2831 auto_aliases for win32 which were causing problems. Users can
2837 auto_aliases for win32 which were causing problems. Users can
2832 define the ones they personally like.
2838 define the ones they personally like.
2833
2839
2834 2005-02-21 Fernando Perez <fperez@colorado.edu>
2840 2005-02-21 Fernando Perez <fperez@colorado.edu>
2835
2841
2836 * IPython/Magic.py (magic_time): new magic to time execution of
2842 * IPython/Magic.py (magic_time): new magic to time execution of
2837 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
2843 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
2838
2844
2839 2005-02-19 Fernando Perez <fperez@colorado.edu>
2845 2005-02-19 Fernando Perez <fperez@colorado.edu>
2840
2846
2841 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
2847 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
2842 into keys (for prompts, for example).
2848 into keys (for prompts, for example).
2843
2849
2844 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
2850 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
2845 prompts in case users want them. This introduces a small behavior
2851 prompts in case users want them. This introduces a small behavior
2846 change: ipython does not automatically add a space to all prompts
2852 change: ipython does not automatically add a space to all prompts
2847 anymore. To get the old prompts with a space, users should add it
2853 anymore. To get the old prompts with a space, users should add it
2848 manually to their ipythonrc file, so for example prompt_in1 should
2854 manually to their ipythonrc file, so for example prompt_in1 should
2849 now read 'In [\#]: ' instead of 'In [\#]:'.
2855 now read 'In [\#]: ' instead of 'In [\#]:'.
2850 (BasePrompt.__init__): New option prompts_pad_left (only in rc
2856 (BasePrompt.__init__): New option prompts_pad_left (only in rc
2851 file) to control left-padding of secondary prompts.
2857 file) to control left-padding of secondary prompts.
2852
2858
2853 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
2859 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
2854 the profiler can't be imported. Fix for Debian, which removed
2860 the profiler can't be imported. Fix for Debian, which removed
2855 profile.py because of License issues. I applied a slightly
2861 profile.py because of License issues. I applied a slightly
2856 modified version of the original Debian patch at
2862 modified version of the original Debian patch at
2857 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
2863 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
2858
2864
2859 2005-02-17 Fernando Perez <fperez@colorado.edu>
2865 2005-02-17 Fernando Perez <fperez@colorado.edu>
2860
2866
2861 * IPython/genutils.py (native_line_ends): Fix bug which would
2867 * IPython/genutils.py (native_line_ends): Fix bug which would
2862 cause improper line-ends under win32 b/c I was not opening files
2868 cause improper line-ends under win32 b/c I was not opening files
2863 in binary mode. Bug report and fix thanks to Ville.
2869 in binary mode. Bug report and fix thanks to Ville.
2864
2870
2865 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
2871 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
2866 trying to catch spurious foo[1] autocalls. My fix actually broke
2872 trying to catch spurious foo[1] autocalls. My fix actually broke
2867 ',/' autoquote/call with explicit escape (bad regexp).
2873 ',/' autoquote/call with explicit escape (bad regexp).
2868
2874
2869 2005-02-15 *** Released version 0.6.11
2875 2005-02-15 *** Released version 0.6.11
2870
2876
2871 2005-02-14 Fernando Perez <fperez@colorado.edu>
2877 2005-02-14 Fernando Perez <fperez@colorado.edu>
2872
2878
2873 * IPython/background_jobs.py: New background job management
2879 * IPython/background_jobs.py: New background job management
2874 subsystem. This is implemented via a new set of classes, and
2880 subsystem. This is implemented via a new set of classes, and
2875 IPython now provides a builtin 'jobs' object for background job
2881 IPython now provides a builtin 'jobs' object for background job
2876 execution. A convenience %bg magic serves as a lightweight
2882 execution. A convenience %bg magic serves as a lightweight
2877 frontend for starting the more common type of calls. This was
2883 frontend for starting the more common type of calls. This was
2878 inspired by discussions with B. Granger and the BackgroundCommand
2884 inspired by discussions with B. Granger and the BackgroundCommand
2879 class described in the book Python Scripting for Computational
2885 class described in the book Python Scripting for Computational
2880 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
2886 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
2881 (although ultimately no code from this text was used, as IPython's
2887 (although ultimately no code from this text was used, as IPython's
2882 system is a separate implementation).
2888 system is a separate implementation).
2883
2889
2884 * IPython/iplib.py (MagicCompleter.python_matches): add new option
2890 * IPython/iplib.py (MagicCompleter.python_matches): add new option
2885 to control the completion of single/double underscore names
2891 to control the completion of single/double underscore names
2886 separately. As documented in the example ipytonrc file, the
2892 separately. As documented in the example ipytonrc file, the
2887 readline_omit__names variable can now be set to 2, to omit even
2893 readline_omit__names variable can now be set to 2, to omit even
2888 single underscore names. Thanks to a patch by Brian Wong
2894 single underscore names. Thanks to a patch by Brian Wong
2889 <BrianWong-AT-AirgoNetworks.Com>.
2895 <BrianWong-AT-AirgoNetworks.Com>.
2890 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
2896 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
2891 be autocalled as foo([1]) if foo were callable. A problem for
2897 be autocalled as foo([1]) if foo were callable. A problem for
2892 things which are both callable and implement __getitem__.
2898 things which are both callable and implement __getitem__.
2893 (init_readline): Fix autoindentation for win32. Thanks to a patch
2899 (init_readline): Fix autoindentation for win32. Thanks to a patch
2894 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
2900 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
2895
2901
2896 2005-02-12 Fernando Perez <fperez@colorado.edu>
2902 2005-02-12 Fernando Perez <fperez@colorado.edu>
2897
2903
2898 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
2904 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
2899 which I had written long ago to sort out user error messages which
2905 which I had written long ago to sort out user error messages which
2900 may occur during startup. This seemed like a good idea initially,
2906 may occur during startup. This seemed like a good idea initially,
2901 but it has proven a disaster in retrospect. I don't want to
2907 but it has proven a disaster in retrospect. I don't want to
2902 change much code for now, so my fix is to set the internal 'debug'
2908 change much code for now, so my fix is to set the internal 'debug'
2903 flag to true everywhere, whose only job was precisely to control
2909 flag to true everywhere, whose only job was precisely to control
2904 this subsystem. This closes issue 28 (as well as avoiding all
2910 this subsystem. This closes issue 28 (as well as avoiding all
2905 sorts of strange hangups which occur from time to time).
2911 sorts of strange hangups which occur from time to time).
2906
2912
2907 2005-02-07 Fernando Perez <fperez@colorado.edu>
2913 2005-02-07 Fernando Perez <fperez@colorado.edu>
2908
2914
2909 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
2915 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
2910 previous call produced a syntax error.
2916 previous call produced a syntax error.
2911
2917
2912 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2918 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2913 classes without constructor.
2919 classes without constructor.
2914
2920
2915 2005-02-06 Fernando Perez <fperez@colorado.edu>
2921 2005-02-06 Fernando Perez <fperez@colorado.edu>
2916
2922
2917 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
2923 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
2918 completions with the results of each matcher, so we return results
2924 completions with the results of each matcher, so we return results
2919 to the user from all namespaces. This breaks with ipython
2925 to the user from all namespaces. This breaks with ipython
2920 tradition, but I think it's a nicer behavior. Now you get all
2926 tradition, but I think it's a nicer behavior. Now you get all
2921 possible completions listed, from all possible namespaces (python,
2927 possible completions listed, from all possible namespaces (python,
2922 filesystem, magics...) After a request by John Hunter
2928 filesystem, magics...) After a request by John Hunter
2923 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2929 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2924
2930
2925 2005-02-05 Fernando Perez <fperez@colorado.edu>
2931 2005-02-05 Fernando Perez <fperez@colorado.edu>
2926
2932
2927 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
2933 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
2928 the call had quote characters in it (the quotes were stripped).
2934 the call had quote characters in it (the quotes were stripped).
2929
2935
2930 2005-01-31 Fernando Perez <fperez@colorado.edu>
2936 2005-01-31 Fernando Perez <fperez@colorado.edu>
2931
2937
2932 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
2938 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
2933 Itpl.itpl() to make the code more robust against psyco
2939 Itpl.itpl() to make the code more robust against psyco
2934 optimizations.
2940 optimizations.
2935
2941
2936 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
2942 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
2937 of causing an exception. Quicker, cleaner.
2943 of causing an exception. Quicker, cleaner.
2938
2944
2939 2005-01-28 Fernando Perez <fperez@colorado.edu>
2945 2005-01-28 Fernando Perez <fperez@colorado.edu>
2940
2946
2941 * scripts/ipython_win_post_install.py (install): hardcode
2947 * scripts/ipython_win_post_install.py (install): hardcode
2942 sys.prefix+'python.exe' as the executable path. It turns out that
2948 sys.prefix+'python.exe' as the executable path. It turns out that
2943 during the post-installation run, sys.executable resolves to the
2949 during the post-installation run, sys.executable resolves to the
2944 name of the binary installer! I should report this as a distutils
2950 name of the binary installer! I should report this as a distutils
2945 bug, I think. I updated the .10 release with this tiny fix, to
2951 bug, I think. I updated the .10 release with this tiny fix, to
2946 avoid annoying the lists further.
2952 avoid annoying the lists further.
2947
2953
2948 2005-01-27 *** Released version 0.6.10
2954 2005-01-27 *** Released version 0.6.10
2949
2955
2950 2005-01-27 Fernando Perez <fperez@colorado.edu>
2956 2005-01-27 Fernando Perez <fperez@colorado.edu>
2951
2957
2952 * IPython/numutils.py (norm): Added 'inf' as optional name for
2958 * IPython/numutils.py (norm): Added 'inf' as optional name for
2953 L-infinity norm, included references to mathworld.com for vector
2959 L-infinity norm, included references to mathworld.com for vector
2954 norm definitions.
2960 norm definitions.
2955 (amin/amax): added amin/amax for array min/max. Similar to what
2961 (amin/amax): added amin/amax for array min/max. Similar to what
2956 pylab ships with after the recent reorganization of names.
2962 pylab ships with after the recent reorganization of names.
2957 (spike/spike_odd): removed deprecated spike/spike_odd functions.
2963 (spike/spike_odd): removed deprecated spike/spike_odd functions.
2958
2964
2959 * ipython.el: committed Alex's recent fixes and improvements.
2965 * ipython.el: committed Alex's recent fixes and improvements.
2960 Tested with python-mode from CVS, and it looks excellent. Since
2966 Tested with python-mode from CVS, and it looks excellent. Since
2961 python-mode hasn't released anything in a while, I'm temporarily
2967 python-mode hasn't released anything in a while, I'm temporarily
2962 putting a copy of today's CVS (v 4.70) of python-mode in:
2968 putting a copy of today's CVS (v 4.70) of python-mode in:
2963 http://ipython.scipy.org/tmp/python-mode.el
2969 http://ipython.scipy.org/tmp/python-mode.el
2964
2970
2965 * scripts/ipython_win_post_install.py (install): Win32 fix to use
2971 * scripts/ipython_win_post_install.py (install): Win32 fix to use
2966 sys.executable for the executable name, instead of assuming it's
2972 sys.executable for the executable name, instead of assuming it's
2967 called 'python.exe' (the post-installer would have produced broken
2973 called 'python.exe' (the post-installer would have produced broken
2968 setups on systems with a differently named python binary).
2974 setups on systems with a differently named python binary).
2969
2975
2970 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
2976 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
2971 references to os.linesep, to make the code more
2977 references to os.linesep, to make the code more
2972 platform-independent. This is also part of the win32 coloring
2978 platform-independent. This is also part of the win32 coloring
2973 fixes.
2979 fixes.
2974
2980
2975 * IPython/genutils.py (page_dumb): Remove attempts to chop long
2981 * IPython/genutils.py (page_dumb): Remove attempts to chop long
2976 lines, which actually cause coloring bugs because the length of
2982 lines, which actually cause coloring bugs because the length of
2977 the line is very difficult to correctly compute with embedded
2983 the line is very difficult to correctly compute with embedded
2978 escapes. This was the source of all the coloring problems under
2984 escapes. This was the source of all the coloring problems under
2979 Win32. I think that _finally_, Win32 users have a properly
2985 Win32. I think that _finally_, Win32 users have a properly
2980 working ipython in all respects. This would never have happened
2986 working ipython in all respects. This would never have happened
2981 if not for Gary Bishop and Viktor Ransmayr's great help and work.
2987 if not for Gary Bishop and Viktor Ransmayr's great help and work.
2982
2988
2983 2005-01-26 *** Released version 0.6.9
2989 2005-01-26 *** Released version 0.6.9
2984
2990
2985 2005-01-25 Fernando Perez <fperez@colorado.edu>
2991 2005-01-25 Fernando Perez <fperez@colorado.edu>
2986
2992
2987 * setup.py: finally, we have a true Windows installer, thanks to
2993 * setup.py: finally, we have a true Windows installer, thanks to
2988 the excellent work of Viktor Ransmayr
2994 the excellent work of Viktor Ransmayr
2989 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
2995 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
2990 Windows users. The setup routine is quite a bit cleaner thanks to
2996 Windows users. The setup routine is quite a bit cleaner thanks to
2991 this, and the post-install script uses the proper functions to
2997 this, and the post-install script uses the proper functions to
2992 allow a clean de-installation using the standard Windows Control
2998 allow a clean de-installation using the standard Windows Control
2993 Panel.
2999 Panel.
2994
3000
2995 * IPython/genutils.py (get_home_dir): changed to use the $HOME
3001 * IPython/genutils.py (get_home_dir): changed to use the $HOME
2996 environment variable under all OSes (including win32) if
3002 environment variable under all OSes (including win32) if
2997 available. This will give consistency to win32 users who have set
3003 available. This will give consistency to win32 users who have set
2998 this variable for any reason. If os.environ['HOME'] fails, the
3004 this variable for any reason. If os.environ['HOME'] fails, the
2999 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3005 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3000
3006
3001 2005-01-24 Fernando Perez <fperez@colorado.edu>
3007 2005-01-24 Fernando Perez <fperez@colorado.edu>
3002
3008
3003 * IPython/numutils.py (empty_like): add empty_like(), similar to
3009 * IPython/numutils.py (empty_like): add empty_like(), similar to
3004 zeros_like() but taking advantage of the new empty() Numeric routine.
3010 zeros_like() but taking advantage of the new empty() Numeric routine.
3005
3011
3006 2005-01-23 *** Released version 0.6.8
3012 2005-01-23 *** Released version 0.6.8
3007
3013
3008 2005-01-22 Fernando Perez <fperez@colorado.edu>
3014 2005-01-22 Fernando Perez <fperez@colorado.edu>
3009
3015
3010 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3016 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3011 automatic show() calls. After discussing things with JDH, it
3017 automatic show() calls. After discussing things with JDH, it
3012 turns out there are too many corner cases where this can go wrong.
3018 turns out there are too many corner cases where this can go wrong.
3013 It's best not to try to be 'too smart', and simply have ipython
3019 It's best not to try to be 'too smart', and simply have ipython
3014 reproduce as much as possible the default behavior of a normal
3020 reproduce as much as possible the default behavior of a normal
3015 python shell.
3021 python shell.
3016
3022
3017 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3023 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3018 line-splitting regexp and _prefilter() to avoid calling getattr()
3024 line-splitting regexp and _prefilter() to avoid calling getattr()
3019 on assignments. This closes
3025 on assignments. This closes
3020 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3026 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3021 readline uses getattr(), so a simple <TAB> keypress is still
3027 readline uses getattr(), so a simple <TAB> keypress is still
3022 enough to trigger getattr() calls on an object.
3028 enough to trigger getattr() calls on an object.
3023
3029
3024 2005-01-21 Fernando Perez <fperez@colorado.edu>
3030 2005-01-21 Fernando Perez <fperez@colorado.edu>
3025
3031
3026 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3032 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3027 docstring under pylab so it doesn't mask the original.
3033 docstring under pylab so it doesn't mask the original.
3028
3034
3029 2005-01-21 *** Released version 0.6.7
3035 2005-01-21 *** Released version 0.6.7
3030
3036
3031 2005-01-21 Fernando Perez <fperez@colorado.edu>
3037 2005-01-21 Fernando Perez <fperez@colorado.edu>
3032
3038
3033 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3039 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3034 signal handling for win32 users in multithreaded mode.
3040 signal handling for win32 users in multithreaded mode.
3035
3041
3036 2005-01-17 Fernando Perez <fperez@colorado.edu>
3042 2005-01-17 Fernando Perez <fperez@colorado.edu>
3037
3043
3038 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3044 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3039 instances with no __init__. After a crash report by Norbert Nemec
3045 instances with no __init__. After a crash report by Norbert Nemec
3040 <Norbert-AT-nemec-online.de>.
3046 <Norbert-AT-nemec-online.de>.
3041
3047
3042 2005-01-14 Fernando Perez <fperez@colorado.edu>
3048 2005-01-14 Fernando Perez <fperez@colorado.edu>
3043
3049
3044 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3050 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3045 names for verbose exceptions, when multiple dotted names and the
3051 names for verbose exceptions, when multiple dotted names and the
3046 'parent' object were present on the same line.
3052 'parent' object were present on the same line.
3047
3053
3048 2005-01-11 Fernando Perez <fperez@colorado.edu>
3054 2005-01-11 Fernando Perez <fperez@colorado.edu>
3049
3055
3050 * IPython/genutils.py (flag_calls): new utility to trap and flag
3056 * IPython/genutils.py (flag_calls): new utility to trap and flag
3051 calls in functions. I need it to clean up matplotlib support.
3057 calls in functions. I need it to clean up matplotlib support.
3052 Also removed some deprecated code in genutils.
3058 Also removed some deprecated code in genutils.
3053
3059
3054 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3060 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3055 that matplotlib scripts called with %run, which don't call show()
3061 that matplotlib scripts called with %run, which don't call show()
3056 themselves, still have their plotting windows open.
3062 themselves, still have their plotting windows open.
3057
3063
3058 2005-01-05 Fernando Perez <fperez@colorado.edu>
3064 2005-01-05 Fernando Perez <fperez@colorado.edu>
3059
3065
3060 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3066 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3061 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3067 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3062
3068
3063 2004-12-19 Fernando Perez <fperez@colorado.edu>
3069 2004-12-19 Fernando Perez <fperez@colorado.edu>
3064
3070
3065 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3071 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3066 parent_runcode, which was an eyesore. The same result can be
3072 parent_runcode, which was an eyesore. The same result can be
3067 obtained with Python's regular superclass mechanisms.
3073 obtained with Python's regular superclass mechanisms.
3068
3074
3069 2004-12-17 Fernando Perez <fperez@colorado.edu>
3075 2004-12-17 Fernando Perez <fperez@colorado.edu>
3070
3076
3071 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3077 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3072 reported by Prabhu.
3078 reported by Prabhu.
3073 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3079 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3074 sys.stderr) instead of explicitly calling sys.stderr. This helps
3080 sys.stderr) instead of explicitly calling sys.stderr. This helps
3075 maintain our I/O abstractions clean, for future GUI embeddings.
3081 maintain our I/O abstractions clean, for future GUI embeddings.
3076
3082
3077 * IPython/genutils.py (info): added new utility for sys.stderr
3083 * IPython/genutils.py (info): added new utility for sys.stderr
3078 unified info message handling (thin wrapper around warn()).
3084 unified info message handling (thin wrapper around warn()).
3079
3085
3080 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3086 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3081 composite (dotted) names on verbose exceptions.
3087 composite (dotted) names on verbose exceptions.
3082 (VerboseTB.nullrepr): harden against another kind of errors which
3088 (VerboseTB.nullrepr): harden against another kind of errors which
3083 Python's inspect module can trigger, and which were crashing
3089 Python's inspect module can trigger, and which were crashing
3084 IPython. Thanks to a report by Marco Lombardi
3090 IPython. Thanks to a report by Marco Lombardi
3085 <mlombard-AT-ma010192.hq.eso.org>.
3091 <mlombard-AT-ma010192.hq.eso.org>.
3086
3092
3087 2004-12-13 *** Released version 0.6.6
3093 2004-12-13 *** Released version 0.6.6
3088
3094
3089 2004-12-12 Fernando Perez <fperez@colorado.edu>
3095 2004-12-12 Fernando Perez <fperez@colorado.edu>
3090
3096
3091 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3097 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3092 generated by pygtk upon initialization if it was built without
3098 generated by pygtk upon initialization if it was built without
3093 threads (for matplotlib users). After a crash reported by
3099 threads (for matplotlib users). After a crash reported by
3094 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3100 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3095
3101
3096 * IPython/ipmaker.py (make_IPython): fix small bug in the
3102 * IPython/ipmaker.py (make_IPython): fix small bug in the
3097 import_some parameter for multiple imports.
3103 import_some parameter for multiple imports.
3098
3104
3099 * IPython/iplib.py (ipmagic): simplified the interface of
3105 * IPython/iplib.py (ipmagic): simplified the interface of
3100 ipmagic() to take a single string argument, just as it would be
3106 ipmagic() to take a single string argument, just as it would be
3101 typed at the IPython cmd line.
3107 typed at the IPython cmd line.
3102 (ipalias): Added new ipalias() with an interface identical to
3108 (ipalias): Added new ipalias() with an interface identical to
3103 ipmagic(). This completes exposing a pure python interface to the
3109 ipmagic(). This completes exposing a pure python interface to the
3104 alias and magic system, which can be used in loops or more complex
3110 alias and magic system, which can be used in loops or more complex
3105 code where IPython's automatic line mangling is not active.
3111 code where IPython's automatic line mangling is not active.
3106
3112
3107 * IPython/genutils.py (timing): changed interface of timing to
3113 * IPython/genutils.py (timing): changed interface of timing to
3108 simply run code once, which is the most common case. timings()
3114 simply run code once, which is the most common case. timings()
3109 remains unchanged, for the cases where you want multiple runs.
3115 remains unchanged, for the cases where you want multiple runs.
3110
3116
3111 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3117 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3112 bug where Python2.2 crashes with exec'ing code which does not end
3118 bug where Python2.2 crashes with exec'ing code which does not end
3113 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3119 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3114 before.
3120 before.
3115
3121
3116 2004-12-10 Fernando Perez <fperez@colorado.edu>
3122 2004-12-10 Fernando Perez <fperez@colorado.edu>
3117
3123
3118 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3124 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3119 -t to -T, to accomodate the new -t flag in %run (the %run and
3125 -t to -T, to accomodate the new -t flag in %run (the %run and
3120 %prun options are kind of intermixed, and it's not easy to change
3126 %prun options are kind of intermixed, and it's not easy to change
3121 this with the limitations of python's getopt).
3127 this with the limitations of python's getopt).
3122
3128
3123 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3129 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3124 the execution of scripts. It's not as fine-tuned as timeit.py,
3130 the execution of scripts. It's not as fine-tuned as timeit.py,
3125 but it works from inside ipython (and under 2.2, which lacks
3131 but it works from inside ipython (and under 2.2, which lacks
3126 timeit.py). Optionally a number of runs > 1 can be given for
3132 timeit.py). Optionally a number of runs > 1 can be given for
3127 timing very short-running code.
3133 timing very short-running code.
3128
3134
3129 * IPython/genutils.py (uniq_stable): new routine which returns a
3135 * IPython/genutils.py (uniq_stable): new routine which returns a
3130 list of unique elements in any iterable, but in stable order of
3136 list of unique elements in any iterable, but in stable order of
3131 appearance. I needed this for the ultraTB fixes, and it's a handy
3137 appearance. I needed this for the ultraTB fixes, and it's a handy
3132 utility.
3138 utility.
3133
3139
3134 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3140 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3135 dotted names in Verbose exceptions. This had been broken since
3141 dotted names in Verbose exceptions. This had been broken since
3136 the very start, now x.y will properly be printed in a Verbose
3142 the very start, now x.y will properly be printed in a Verbose
3137 traceback, instead of x being shown and y appearing always as an
3143 traceback, instead of x being shown and y appearing always as an
3138 'undefined global'. Getting this to work was a bit tricky,
3144 'undefined global'. Getting this to work was a bit tricky,
3139 because by default python tokenizers are stateless. Saved by
3145 because by default python tokenizers are stateless. Saved by
3140 python's ability to easily add a bit of state to an arbitrary
3146 python's ability to easily add a bit of state to an arbitrary
3141 function (without needing to build a full-blown callable object).
3147 function (without needing to build a full-blown callable object).
3142
3148
3143 Also big cleanup of this code, which had horrendous runtime
3149 Also big cleanup of this code, which had horrendous runtime
3144 lookups of zillions of attributes for colorization. Moved all
3150 lookups of zillions of attributes for colorization. Moved all
3145 this code into a few templates, which make it cleaner and quicker.
3151 this code into a few templates, which make it cleaner and quicker.
3146
3152
3147 Printout quality was also improved for Verbose exceptions: one
3153 Printout quality was also improved for Verbose exceptions: one
3148 variable per line, and memory addresses are printed (this can be
3154 variable per line, and memory addresses are printed (this can be
3149 quite handy in nasty debugging situations, which is what Verbose
3155 quite handy in nasty debugging situations, which is what Verbose
3150 is for).
3156 is for).
3151
3157
3152 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3158 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3153 the command line as scripts to be loaded by embedded instances.
3159 the command line as scripts to be loaded by embedded instances.
3154 Doing so has the potential for an infinite recursion if there are
3160 Doing so has the potential for an infinite recursion if there are
3155 exceptions thrown in the process. This fixes a strange crash
3161 exceptions thrown in the process. This fixes a strange crash
3156 reported by Philippe MULLER <muller-AT-irit.fr>.
3162 reported by Philippe MULLER <muller-AT-irit.fr>.
3157
3163
3158 2004-12-09 Fernando Perez <fperez@colorado.edu>
3164 2004-12-09 Fernando Perez <fperez@colorado.edu>
3159
3165
3160 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3166 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3161 to reflect new names in matplotlib, which now expose the
3167 to reflect new names in matplotlib, which now expose the
3162 matlab-compatible interface via a pylab module instead of the
3168 matlab-compatible interface via a pylab module instead of the
3163 'matlab' name. The new code is backwards compatible, so users of
3169 'matlab' name. The new code is backwards compatible, so users of
3164 all matplotlib versions are OK. Patch by J. Hunter.
3170 all matplotlib versions are OK. Patch by J. Hunter.
3165
3171
3166 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3172 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3167 of __init__ docstrings for instances (class docstrings are already
3173 of __init__ docstrings for instances (class docstrings are already
3168 automatically printed). Instances with customized docstrings
3174 automatically printed). Instances with customized docstrings
3169 (indep. of the class) are also recognized and all 3 separate
3175 (indep. of the class) are also recognized and all 3 separate
3170 docstrings are printed (instance, class, constructor). After some
3176 docstrings are printed (instance, class, constructor). After some
3171 comments/suggestions by J. Hunter.
3177 comments/suggestions by J. Hunter.
3172
3178
3173 2004-12-05 Fernando Perez <fperez@colorado.edu>
3179 2004-12-05 Fernando Perez <fperez@colorado.edu>
3174
3180
3175 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3181 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3176 warnings when tab-completion fails and triggers an exception.
3182 warnings when tab-completion fails and triggers an exception.
3177
3183
3178 2004-12-03 Fernando Perez <fperez@colorado.edu>
3184 2004-12-03 Fernando Perez <fperez@colorado.edu>
3179
3185
3180 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3186 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3181 be triggered when using 'run -p'. An incorrect option flag was
3187 be triggered when using 'run -p'. An incorrect option flag was
3182 being set ('d' instead of 'D').
3188 being set ('d' instead of 'D').
3183 (manpage): fix missing escaped \- sign.
3189 (manpage): fix missing escaped \- sign.
3184
3190
3185 2004-11-30 *** Released version 0.6.5
3191 2004-11-30 *** Released version 0.6.5
3186
3192
3187 2004-11-30 Fernando Perez <fperez@colorado.edu>
3193 2004-11-30 Fernando Perez <fperez@colorado.edu>
3188
3194
3189 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3195 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3190 setting with -d option.
3196 setting with -d option.
3191
3197
3192 * setup.py (docfiles): Fix problem where the doc glob I was using
3198 * setup.py (docfiles): Fix problem where the doc glob I was using
3193 was COMPLETELY BROKEN. It was giving the right files by pure
3199 was COMPLETELY BROKEN. It was giving the right files by pure
3194 accident, but failed once I tried to include ipython.el. Note:
3200 accident, but failed once I tried to include ipython.el. Note:
3195 glob() does NOT allow you to do exclusion on multiple endings!
3201 glob() does NOT allow you to do exclusion on multiple endings!
3196
3202
3197 2004-11-29 Fernando Perez <fperez@colorado.edu>
3203 2004-11-29 Fernando Perez <fperez@colorado.edu>
3198
3204
3199 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3205 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3200 the manpage as the source. Better formatting & consistency.
3206 the manpage as the source. Better formatting & consistency.
3201
3207
3202 * IPython/Magic.py (magic_run): Added new -d option, to run
3208 * IPython/Magic.py (magic_run): Added new -d option, to run
3203 scripts under the control of the python pdb debugger. Note that
3209 scripts under the control of the python pdb debugger. Note that
3204 this required changing the %prun option -d to -D, to avoid a clash
3210 this required changing the %prun option -d to -D, to avoid a clash
3205 (since %run must pass options to %prun, and getopt is too dumb to
3211 (since %run must pass options to %prun, and getopt is too dumb to
3206 handle options with string values with embedded spaces). Thanks
3212 handle options with string values with embedded spaces). Thanks
3207 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3213 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3208 (magic_who_ls): added type matching to %who and %whos, so that one
3214 (magic_who_ls): added type matching to %who and %whos, so that one
3209 can filter their output to only include variables of certain
3215 can filter their output to only include variables of certain
3210 types. Another suggestion by Matthew.
3216 types. Another suggestion by Matthew.
3211 (magic_whos): Added memory summaries in kb and Mb for arrays.
3217 (magic_whos): Added memory summaries in kb and Mb for arrays.
3212 (magic_who): Improve formatting (break lines every 9 vars).
3218 (magic_who): Improve formatting (break lines every 9 vars).
3213
3219
3214 2004-11-28 Fernando Perez <fperez@colorado.edu>
3220 2004-11-28 Fernando Perez <fperez@colorado.edu>
3215
3221
3216 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3222 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3217 cache when empty lines were present.
3223 cache when empty lines were present.
3218
3224
3219 2004-11-24 Fernando Perez <fperez@colorado.edu>
3225 2004-11-24 Fernando Perez <fperez@colorado.edu>
3220
3226
3221 * IPython/usage.py (__doc__): document the re-activated threading
3227 * IPython/usage.py (__doc__): document the re-activated threading
3222 options for WX and GTK.
3228 options for WX and GTK.
3223
3229
3224 2004-11-23 Fernando Perez <fperez@colorado.edu>
3230 2004-11-23 Fernando Perez <fperez@colorado.edu>
3225
3231
3226 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3232 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3227 the -wthread and -gthread options, along with a new -tk one to try
3233 the -wthread and -gthread options, along with a new -tk one to try
3228 and coordinate Tk threading with wx/gtk. The tk support is very
3234 and coordinate Tk threading with wx/gtk. The tk support is very
3229 platform dependent, since it seems to require Tcl and Tk to be
3235 platform dependent, since it seems to require Tcl and Tk to be
3230 built with threads (Fedora1/2 appears NOT to have it, but in
3236 built with threads (Fedora1/2 appears NOT to have it, but in
3231 Prabhu's Debian boxes it works OK). But even with some Tk
3237 Prabhu's Debian boxes it works OK). But even with some Tk
3232 limitations, this is a great improvement.
3238 limitations, this is a great improvement.
3233
3239
3234 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3240 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3235 info in user prompts. Patch by Prabhu.
3241 info in user prompts. Patch by Prabhu.
3236
3242
3237 2004-11-18 Fernando Perez <fperez@colorado.edu>
3243 2004-11-18 Fernando Perez <fperez@colorado.edu>
3238
3244
3239 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3245 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3240 EOFErrors and bail, to avoid infinite loops if a non-terminating
3246 EOFErrors and bail, to avoid infinite loops if a non-terminating
3241 file is fed into ipython. Patch submitted in issue 19 by user,
3247 file is fed into ipython. Patch submitted in issue 19 by user,
3242 many thanks.
3248 many thanks.
3243
3249
3244 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3250 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3245 autoquote/parens in continuation prompts, which can cause lots of
3251 autoquote/parens in continuation prompts, which can cause lots of
3246 problems. Closes roundup issue 20.
3252 problems. Closes roundup issue 20.
3247
3253
3248 2004-11-17 Fernando Perez <fperez@colorado.edu>
3254 2004-11-17 Fernando Perez <fperez@colorado.edu>
3249
3255
3250 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3256 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3251 reported as debian bug #280505. I'm not sure my local changelog
3257 reported as debian bug #280505. I'm not sure my local changelog
3252 entry has the proper debian format (Jack?).
3258 entry has the proper debian format (Jack?).
3253
3259
3254 2004-11-08 *** Released version 0.6.4
3260 2004-11-08 *** Released version 0.6.4
3255
3261
3256 2004-11-08 Fernando Perez <fperez@colorado.edu>
3262 2004-11-08 Fernando Perez <fperez@colorado.edu>
3257
3263
3258 * IPython/iplib.py (init_readline): Fix exit message for Windows
3264 * IPython/iplib.py (init_readline): Fix exit message for Windows
3259 when readline is active. Thanks to a report by Eric Jones
3265 when readline is active. Thanks to a report by Eric Jones
3260 <eric-AT-enthought.com>.
3266 <eric-AT-enthought.com>.
3261
3267
3262 2004-11-07 Fernando Perez <fperez@colorado.edu>
3268 2004-11-07 Fernando Perez <fperez@colorado.edu>
3263
3269
3264 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3270 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3265 sometimes seen by win2k/cygwin users.
3271 sometimes seen by win2k/cygwin users.
3266
3272
3267 2004-11-06 Fernando Perez <fperez@colorado.edu>
3273 2004-11-06 Fernando Perez <fperez@colorado.edu>
3268
3274
3269 * IPython/iplib.py (interact): Change the handling of %Exit from
3275 * IPython/iplib.py (interact): Change the handling of %Exit from
3270 trying to propagate a SystemExit to an internal ipython flag.
3276 trying to propagate a SystemExit to an internal ipython flag.
3271 This is less elegant than using Python's exception mechanism, but
3277 This is less elegant than using Python's exception mechanism, but
3272 I can't get that to work reliably with threads, so under -pylab
3278 I can't get that to work reliably with threads, so under -pylab
3273 %Exit was hanging IPython. Cross-thread exception handling is
3279 %Exit was hanging IPython. Cross-thread exception handling is
3274 really a bitch. Thaks to a bug report by Stephen Walton
3280 really a bitch. Thaks to a bug report by Stephen Walton
3275 <stephen.walton-AT-csun.edu>.
3281 <stephen.walton-AT-csun.edu>.
3276
3282
3277 2004-11-04 Fernando Perez <fperez@colorado.edu>
3283 2004-11-04 Fernando Perez <fperez@colorado.edu>
3278
3284
3279 * IPython/iplib.py (raw_input_original): store a pointer to the
3285 * IPython/iplib.py (raw_input_original): store a pointer to the
3280 true raw_input to harden against code which can modify it
3286 true raw_input to harden against code which can modify it
3281 (wx.py.PyShell does this and would otherwise crash ipython).
3287 (wx.py.PyShell does this and would otherwise crash ipython).
3282 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3288 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3283
3289
3284 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3290 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3285 Ctrl-C problem, which does not mess up the input line.
3291 Ctrl-C problem, which does not mess up the input line.
3286
3292
3287 2004-11-03 Fernando Perez <fperez@colorado.edu>
3293 2004-11-03 Fernando Perez <fperez@colorado.edu>
3288
3294
3289 * IPython/Release.py: Changed licensing to BSD, in all files.
3295 * IPython/Release.py: Changed licensing to BSD, in all files.
3290 (name): lowercase name for tarball/RPM release.
3296 (name): lowercase name for tarball/RPM release.
3291
3297
3292 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3298 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3293 use throughout ipython.
3299 use throughout ipython.
3294
3300
3295 * IPython/Magic.py (Magic._ofind): Switch to using the new
3301 * IPython/Magic.py (Magic._ofind): Switch to using the new
3296 OInspect.getdoc() function.
3302 OInspect.getdoc() function.
3297
3303
3298 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3304 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3299 of the line currently being canceled via Ctrl-C. It's extremely
3305 of the line currently being canceled via Ctrl-C. It's extremely
3300 ugly, but I don't know how to do it better (the problem is one of
3306 ugly, but I don't know how to do it better (the problem is one of
3301 handling cross-thread exceptions).
3307 handling cross-thread exceptions).
3302
3308
3303 2004-10-28 Fernando Perez <fperez@colorado.edu>
3309 2004-10-28 Fernando Perez <fperez@colorado.edu>
3304
3310
3305 * IPython/Shell.py (signal_handler): add signal handlers to trap
3311 * IPython/Shell.py (signal_handler): add signal handlers to trap
3306 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3312 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3307 report by Francesc Alted.
3313 report by Francesc Alted.
3308
3314
3309 2004-10-21 Fernando Perez <fperez@colorado.edu>
3315 2004-10-21 Fernando Perez <fperez@colorado.edu>
3310
3316
3311 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3317 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3312 to % for pysh syntax extensions.
3318 to % for pysh syntax extensions.
3313
3319
3314 2004-10-09 Fernando Perez <fperez@colorado.edu>
3320 2004-10-09 Fernando Perez <fperez@colorado.edu>
3315
3321
3316 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3322 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3317 arrays to print a more useful summary, without calling str(arr).
3323 arrays to print a more useful summary, without calling str(arr).
3318 This avoids the problem of extremely lengthy computations which
3324 This avoids the problem of extremely lengthy computations which
3319 occur if arr is large, and appear to the user as a system lockup
3325 occur if arr is large, and appear to the user as a system lockup
3320 with 100% cpu activity. After a suggestion by Kristian Sandberg
3326 with 100% cpu activity. After a suggestion by Kristian Sandberg
3321 <Kristian.Sandberg@colorado.edu>.
3327 <Kristian.Sandberg@colorado.edu>.
3322 (Magic.__init__): fix bug in global magic escapes not being
3328 (Magic.__init__): fix bug in global magic escapes not being
3323 correctly set.
3329 correctly set.
3324
3330
3325 2004-10-08 Fernando Perez <fperez@colorado.edu>
3331 2004-10-08 Fernando Perez <fperez@colorado.edu>
3326
3332
3327 * IPython/Magic.py (__license__): change to absolute imports of
3333 * IPython/Magic.py (__license__): change to absolute imports of
3328 ipython's own internal packages, to start adapting to the absolute
3334 ipython's own internal packages, to start adapting to the absolute
3329 import requirement of PEP-328.
3335 import requirement of PEP-328.
3330
3336
3331 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3337 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3332 files, and standardize author/license marks through the Release
3338 files, and standardize author/license marks through the Release
3333 module instead of having per/file stuff (except for files with
3339 module instead of having per/file stuff (except for files with
3334 particular licenses, like the MIT/PSF-licensed codes).
3340 particular licenses, like the MIT/PSF-licensed codes).
3335
3341
3336 * IPython/Debugger.py: remove dead code for python 2.1
3342 * IPython/Debugger.py: remove dead code for python 2.1
3337
3343
3338 2004-10-04 Fernando Perez <fperez@colorado.edu>
3344 2004-10-04 Fernando Perez <fperez@colorado.edu>
3339
3345
3340 * IPython/iplib.py (ipmagic): New function for accessing magics
3346 * IPython/iplib.py (ipmagic): New function for accessing magics
3341 via a normal python function call.
3347 via a normal python function call.
3342
3348
3343 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3349 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3344 from '@' to '%', to accomodate the new @decorator syntax of python
3350 from '@' to '%', to accomodate the new @decorator syntax of python
3345 2.4.
3351 2.4.
3346
3352
3347 2004-09-29 Fernando Perez <fperez@colorado.edu>
3353 2004-09-29 Fernando Perez <fperez@colorado.edu>
3348
3354
3349 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3355 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3350 matplotlib.use to prevent running scripts which try to switch
3356 matplotlib.use to prevent running scripts which try to switch
3351 interactive backends from within ipython. This will just crash
3357 interactive backends from within ipython. This will just crash
3352 the python interpreter, so we can't allow it (but a detailed error
3358 the python interpreter, so we can't allow it (but a detailed error
3353 is given to the user).
3359 is given to the user).
3354
3360
3355 2004-09-28 Fernando Perez <fperez@colorado.edu>
3361 2004-09-28 Fernando Perez <fperez@colorado.edu>
3356
3362
3357 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3363 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3358 matplotlib-related fixes so that using @run with non-matplotlib
3364 matplotlib-related fixes so that using @run with non-matplotlib
3359 scripts doesn't pop up spurious plot windows. This requires
3365 scripts doesn't pop up spurious plot windows. This requires
3360 matplotlib >= 0.63, where I had to make some changes as well.
3366 matplotlib >= 0.63, where I had to make some changes as well.
3361
3367
3362 * IPython/ipmaker.py (make_IPython): update version requirement to
3368 * IPython/ipmaker.py (make_IPython): update version requirement to
3363 python 2.2.
3369 python 2.2.
3364
3370
3365 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3371 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3366 banner arg for embedded customization.
3372 banner arg for embedded customization.
3367
3373
3368 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3374 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3369 explicit uses of __IP as the IPython's instance name. Now things
3375 explicit uses of __IP as the IPython's instance name. Now things
3370 are properly handled via the shell.name value. The actual code
3376 are properly handled via the shell.name value. The actual code
3371 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3377 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3372 is much better than before. I'll clean things completely when the
3378 is much better than before. I'll clean things completely when the
3373 magic stuff gets a real overhaul.
3379 magic stuff gets a real overhaul.
3374
3380
3375 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3381 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3376 minor changes to debian dir.
3382 minor changes to debian dir.
3377
3383
3378 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3384 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3379 pointer to the shell itself in the interactive namespace even when
3385 pointer to the shell itself in the interactive namespace even when
3380 a user-supplied dict is provided. This is needed for embedding
3386 a user-supplied dict is provided. This is needed for embedding
3381 purposes (found by tests with Michel Sanner).
3387 purposes (found by tests with Michel Sanner).
3382
3388
3383 2004-09-27 Fernando Perez <fperez@colorado.edu>
3389 2004-09-27 Fernando Perez <fperez@colorado.edu>
3384
3390
3385 * IPython/UserConfig/ipythonrc: remove []{} from
3391 * IPython/UserConfig/ipythonrc: remove []{} from
3386 readline_remove_delims, so that things like [modname.<TAB> do
3392 readline_remove_delims, so that things like [modname.<TAB> do
3387 proper completion. This disables [].TAB, but that's a less common
3393 proper completion. This disables [].TAB, but that's a less common
3388 case than module names in list comprehensions, for example.
3394 case than module names in list comprehensions, for example.
3389 Thanks to a report by Andrea Riciputi.
3395 Thanks to a report by Andrea Riciputi.
3390
3396
3391 2004-09-09 Fernando Perez <fperez@colorado.edu>
3397 2004-09-09 Fernando Perez <fperez@colorado.edu>
3392
3398
3393 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3399 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3394 blocking problems in win32 and osx. Fix by John.
3400 blocking problems in win32 and osx. Fix by John.
3395
3401
3396 2004-09-08 Fernando Perez <fperez@colorado.edu>
3402 2004-09-08 Fernando Perez <fperez@colorado.edu>
3397
3403
3398 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3404 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3399 for Win32 and OSX. Fix by John Hunter.
3405 for Win32 and OSX. Fix by John Hunter.
3400
3406
3401 2004-08-30 *** Released version 0.6.3
3407 2004-08-30 *** Released version 0.6.3
3402
3408
3403 2004-08-30 Fernando Perez <fperez@colorado.edu>
3409 2004-08-30 Fernando Perez <fperez@colorado.edu>
3404
3410
3405 * setup.py (isfile): Add manpages to list of dependent files to be
3411 * setup.py (isfile): Add manpages to list of dependent files to be
3406 updated.
3412 updated.
3407
3413
3408 2004-08-27 Fernando Perez <fperez@colorado.edu>
3414 2004-08-27 Fernando Perez <fperez@colorado.edu>
3409
3415
3410 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3416 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3411 for now. They don't really work with standalone WX/GTK code
3417 for now. They don't really work with standalone WX/GTK code
3412 (though matplotlib IS working fine with both of those backends).
3418 (though matplotlib IS working fine with both of those backends).
3413 This will neeed much more testing. I disabled most things with
3419 This will neeed much more testing. I disabled most things with
3414 comments, so turning it back on later should be pretty easy.
3420 comments, so turning it back on later should be pretty easy.
3415
3421
3416 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3422 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3417 autocalling of expressions like r'foo', by modifying the line
3423 autocalling of expressions like r'foo', by modifying the line
3418 split regexp. Closes
3424 split regexp. Closes
3419 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3425 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3420 Riley <ipythonbugs-AT-sabi.net>.
3426 Riley <ipythonbugs-AT-sabi.net>.
3421 (InteractiveShell.mainloop): honor --nobanner with banner
3427 (InteractiveShell.mainloop): honor --nobanner with banner
3422 extensions.
3428 extensions.
3423
3429
3424 * IPython/Shell.py: Significant refactoring of all classes, so
3430 * IPython/Shell.py: Significant refactoring of all classes, so
3425 that we can really support ALL matplotlib backends and threading
3431 that we can really support ALL matplotlib backends and threading
3426 models (John spotted a bug with Tk which required this). Now we
3432 models (John spotted a bug with Tk which required this). Now we
3427 should support single-threaded, WX-threads and GTK-threads, both
3433 should support single-threaded, WX-threads and GTK-threads, both
3428 for generic code and for matplotlib.
3434 for generic code and for matplotlib.
3429
3435
3430 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3436 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3431 -pylab, to simplify things for users. Will also remove the pylab
3437 -pylab, to simplify things for users. Will also remove the pylab
3432 profile, since now all of matplotlib configuration is directly
3438 profile, since now all of matplotlib configuration is directly
3433 handled here. This also reduces startup time.
3439 handled here. This also reduces startup time.
3434
3440
3435 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3441 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3436 shell wasn't being correctly called. Also in IPShellWX.
3442 shell wasn't being correctly called. Also in IPShellWX.
3437
3443
3438 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3444 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3439 fine-tune banner.
3445 fine-tune banner.
3440
3446
3441 * IPython/numutils.py (spike): Deprecate these spike functions,
3447 * IPython/numutils.py (spike): Deprecate these spike functions,
3442 delete (long deprecated) gnuplot_exec handler.
3448 delete (long deprecated) gnuplot_exec handler.
3443
3449
3444 2004-08-26 Fernando Perez <fperez@colorado.edu>
3450 2004-08-26 Fernando Perez <fperez@colorado.edu>
3445
3451
3446 * ipython.1: Update for threading options, plus some others which
3452 * ipython.1: Update for threading options, plus some others which
3447 were missing.
3453 were missing.
3448
3454
3449 * IPython/ipmaker.py (__call__): Added -wthread option for
3455 * IPython/ipmaker.py (__call__): Added -wthread option for
3450 wxpython thread handling. Make sure threading options are only
3456 wxpython thread handling. Make sure threading options are only
3451 valid at the command line.
3457 valid at the command line.
3452
3458
3453 * scripts/ipython: moved shell selection into a factory function
3459 * scripts/ipython: moved shell selection into a factory function
3454 in Shell.py, to keep the starter script to a minimum.
3460 in Shell.py, to keep the starter script to a minimum.
3455
3461
3456 2004-08-25 Fernando Perez <fperez@colorado.edu>
3462 2004-08-25 Fernando Perez <fperez@colorado.edu>
3457
3463
3458 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3464 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3459 John. Along with some recent changes he made to matplotlib, the
3465 John. Along with some recent changes he made to matplotlib, the
3460 next versions of both systems should work very well together.
3466 next versions of both systems should work very well together.
3461
3467
3462 2004-08-24 Fernando Perez <fperez@colorado.edu>
3468 2004-08-24 Fernando Perez <fperez@colorado.edu>
3463
3469
3464 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3470 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3465 tried to switch the profiling to using hotshot, but I'm getting
3471 tried to switch the profiling to using hotshot, but I'm getting
3466 strange errors from prof.runctx() there. I may be misreading the
3472 strange errors from prof.runctx() there. I may be misreading the
3467 docs, but it looks weird. For now the profiling code will
3473 docs, but it looks weird. For now the profiling code will
3468 continue to use the standard profiler.
3474 continue to use the standard profiler.
3469
3475
3470 2004-08-23 Fernando Perez <fperez@colorado.edu>
3476 2004-08-23 Fernando Perez <fperez@colorado.edu>
3471
3477
3472 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3478 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3473 threaded shell, by John Hunter. It's not quite ready yet, but
3479 threaded shell, by John Hunter. It's not quite ready yet, but
3474 close.
3480 close.
3475
3481
3476 2004-08-22 Fernando Perez <fperez@colorado.edu>
3482 2004-08-22 Fernando Perez <fperez@colorado.edu>
3477
3483
3478 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3484 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3479 in Magic and ultraTB.
3485 in Magic and ultraTB.
3480
3486
3481 * ipython.1: document threading options in manpage.
3487 * ipython.1: document threading options in manpage.
3482
3488
3483 * scripts/ipython: Changed name of -thread option to -gthread,
3489 * scripts/ipython: Changed name of -thread option to -gthread,
3484 since this is GTK specific. I want to leave the door open for a
3490 since this is GTK specific. I want to leave the door open for a
3485 -wthread option for WX, which will most likely be necessary. This
3491 -wthread option for WX, which will most likely be necessary. This
3486 change affects usage and ipmaker as well.
3492 change affects usage and ipmaker as well.
3487
3493
3488 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3494 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3489 handle the matplotlib shell issues. Code by John Hunter
3495 handle the matplotlib shell issues. Code by John Hunter
3490 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3496 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3491 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3497 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3492 broken (and disabled for end users) for now, but it puts the
3498 broken (and disabled for end users) for now, but it puts the
3493 infrastructure in place.
3499 infrastructure in place.
3494
3500
3495 2004-08-21 Fernando Perez <fperez@colorado.edu>
3501 2004-08-21 Fernando Perez <fperez@colorado.edu>
3496
3502
3497 * ipythonrc-pylab: Add matplotlib support.
3503 * ipythonrc-pylab: Add matplotlib support.
3498
3504
3499 * matplotlib_config.py: new files for matplotlib support, part of
3505 * matplotlib_config.py: new files for matplotlib support, part of
3500 the pylab profile.
3506 the pylab profile.
3501
3507
3502 * IPython/usage.py (__doc__): documented the threading options.
3508 * IPython/usage.py (__doc__): documented the threading options.
3503
3509
3504 2004-08-20 Fernando Perez <fperez@colorado.edu>
3510 2004-08-20 Fernando Perez <fperez@colorado.edu>
3505
3511
3506 * ipython: Modified the main calling routine to handle the -thread
3512 * ipython: Modified the main calling routine to handle the -thread
3507 and -mpthread options. This needs to be done as a top-level hack,
3513 and -mpthread options. This needs to be done as a top-level hack,
3508 because it determines which class to instantiate for IPython
3514 because it determines which class to instantiate for IPython
3509 itself.
3515 itself.
3510
3516
3511 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3517 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3512 classes to support multithreaded GTK operation without blocking,
3518 classes to support multithreaded GTK operation without blocking,
3513 and matplotlib with all backends. This is a lot of still very
3519 and matplotlib with all backends. This is a lot of still very
3514 experimental code, and threads are tricky. So it may still have a
3520 experimental code, and threads are tricky. So it may still have a
3515 few rough edges... This code owes a lot to
3521 few rough edges... This code owes a lot to
3516 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3522 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3517 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3523 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3518 to John Hunter for all the matplotlib work.
3524 to John Hunter for all the matplotlib work.
3519
3525
3520 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3526 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3521 options for gtk thread and matplotlib support.
3527 options for gtk thread and matplotlib support.
3522
3528
3523 2004-08-16 Fernando Perez <fperez@colorado.edu>
3529 2004-08-16 Fernando Perez <fperez@colorado.edu>
3524
3530
3525 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3531 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3526 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3532 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3527 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3533 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3528
3534
3529 2004-08-11 Fernando Perez <fperez@colorado.edu>
3535 2004-08-11 Fernando Perez <fperez@colorado.edu>
3530
3536
3531 * setup.py (isfile): Fix build so documentation gets updated for
3537 * setup.py (isfile): Fix build so documentation gets updated for
3532 rpms (it was only done for .tgz builds).
3538 rpms (it was only done for .tgz builds).
3533
3539
3534 2004-08-10 Fernando Perez <fperez@colorado.edu>
3540 2004-08-10 Fernando Perez <fperez@colorado.edu>
3535
3541
3536 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3542 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3537
3543
3538 * iplib.py : Silence syntax error exceptions in tab-completion.
3544 * iplib.py : Silence syntax error exceptions in tab-completion.
3539
3545
3540 2004-08-05 Fernando Perez <fperez@colorado.edu>
3546 2004-08-05 Fernando Perez <fperez@colorado.edu>
3541
3547
3542 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3548 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3543 'color off' mark for continuation prompts. This was causing long
3549 'color off' mark for continuation prompts. This was causing long
3544 continuation lines to mis-wrap.
3550 continuation lines to mis-wrap.
3545
3551
3546 2004-08-01 Fernando Perez <fperez@colorado.edu>
3552 2004-08-01 Fernando Perez <fperez@colorado.edu>
3547
3553
3548 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3554 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3549 for building ipython to be a parameter. All this is necessary
3555 for building ipython to be a parameter. All this is necessary
3550 right now to have a multithreaded version, but this insane
3556 right now to have a multithreaded version, but this insane
3551 non-design will be cleaned up soon. For now, it's a hack that
3557 non-design will be cleaned up soon. For now, it's a hack that
3552 works.
3558 works.
3553
3559
3554 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3560 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3555 args in various places. No bugs so far, but it's a dangerous
3561 args in various places. No bugs so far, but it's a dangerous
3556 practice.
3562 practice.
3557
3563
3558 2004-07-31 Fernando Perez <fperez@colorado.edu>
3564 2004-07-31 Fernando Perez <fperez@colorado.edu>
3559
3565
3560 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3566 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3561 fix completion of files with dots in their names under most
3567 fix completion of files with dots in their names under most
3562 profiles (pysh was OK because the completion order is different).
3568 profiles (pysh was OK because the completion order is different).
3563
3569
3564 2004-07-27 Fernando Perez <fperez@colorado.edu>
3570 2004-07-27 Fernando Perez <fperez@colorado.edu>
3565
3571
3566 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3572 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3567 keywords manually, b/c the one in keyword.py was removed in python
3573 keywords manually, b/c the one in keyword.py was removed in python
3568 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3574 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3569 This is NOT a bug under python 2.3 and earlier.
3575 This is NOT a bug under python 2.3 and earlier.
3570
3576
3571 2004-07-26 Fernando Perez <fperez@colorado.edu>
3577 2004-07-26 Fernando Perez <fperez@colorado.edu>
3572
3578
3573 * IPython/ultraTB.py (VerboseTB.text): Add another
3579 * IPython/ultraTB.py (VerboseTB.text): Add another
3574 linecache.checkcache() call to try to prevent inspect.py from
3580 linecache.checkcache() call to try to prevent inspect.py from
3575 crashing under python 2.3. I think this fixes
3581 crashing under python 2.3. I think this fixes
3576 http://www.scipy.net/roundup/ipython/issue17.
3582 http://www.scipy.net/roundup/ipython/issue17.
3577
3583
3578 2004-07-26 *** Released version 0.6.2
3584 2004-07-26 *** Released version 0.6.2
3579
3585
3580 2004-07-26 Fernando Perez <fperez@colorado.edu>
3586 2004-07-26 Fernando Perez <fperez@colorado.edu>
3581
3587
3582 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3588 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3583 fail for any number.
3589 fail for any number.
3584 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3590 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3585 empty bookmarks.
3591 empty bookmarks.
3586
3592
3587 2004-07-26 *** Released version 0.6.1
3593 2004-07-26 *** Released version 0.6.1
3588
3594
3589 2004-07-26 Fernando Perez <fperez@colorado.edu>
3595 2004-07-26 Fernando Perez <fperez@colorado.edu>
3590
3596
3591 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3597 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3592
3598
3593 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3599 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3594 escaping '()[]{}' in filenames.
3600 escaping '()[]{}' in filenames.
3595
3601
3596 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3602 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3597 Python 2.2 users who lack a proper shlex.split.
3603 Python 2.2 users who lack a proper shlex.split.
3598
3604
3599 2004-07-19 Fernando Perez <fperez@colorado.edu>
3605 2004-07-19 Fernando Perez <fperez@colorado.edu>
3600
3606
3601 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3607 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3602 for reading readline's init file. I follow the normal chain:
3608 for reading readline's init file. I follow the normal chain:
3603 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3609 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3604 report by Mike Heeter. This closes
3610 report by Mike Heeter. This closes
3605 http://www.scipy.net/roundup/ipython/issue16.
3611 http://www.scipy.net/roundup/ipython/issue16.
3606
3612
3607 2004-07-18 Fernando Perez <fperez@colorado.edu>
3613 2004-07-18 Fernando Perez <fperez@colorado.edu>
3608
3614
3609 * IPython/iplib.py (__init__): Add better handling of '\' under
3615 * IPython/iplib.py (__init__): Add better handling of '\' under
3610 Win32 for filenames. After a patch by Ville.
3616 Win32 for filenames. After a patch by Ville.
3611
3617
3612 2004-07-17 Fernando Perez <fperez@colorado.edu>
3618 2004-07-17 Fernando Perez <fperez@colorado.edu>
3613
3619
3614 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3620 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3615 autocalling would be triggered for 'foo is bar' if foo is
3621 autocalling would be triggered for 'foo is bar' if foo is
3616 callable. I also cleaned up the autocall detection code to use a
3622 callable. I also cleaned up the autocall detection code to use a
3617 regexp, which is faster. Bug reported by Alexander Schmolck.
3623 regexp, which is faster. Bug reported by Alexander Schmolck.
3618
3624
3619 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3625 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3620 '?' in them would confuse the help system. Reported by Alex
3626 '?' in them would confuse the help system. Reported by Alex
3621 Schmolck.
3627 Schmolck.
3622
3628
3623 2004-07-16 Fernando Perez <fperez@colorado.edu>
3629 2004-07-16 Fernando Perez <fperez@colorado.edu>
3624
3630
3625 * IPython/GnuplotInteractive.py (__all__): added plot2.
3631 * IPython/GnuplotInteractive.py (__all__): added plot2.
3626
3632
3627 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3633 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3628 plotting dictionaries, lists or tuples of 1d arrays.
3634 plotting dictionaries, lists or tuples of 1d arrays.
3629
3635
3630 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3636 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3631 optimizations.
3637 optimizations.
3632
3638
3633 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3639 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3634 the information which was there from Janko's original IPP code:
3640 the information which was there from Janko's original IPP code:
3635
3641
3636 03.05.99 20:53 porto.ifm.uni-kiel.de
3642 03.05.99 20:53 porto.ifm.uni-kiel.de
3637 --Started changelog.
3643 --Started changelog.
3638 --make clear do what it say it does
3644 --make clear do what it say it does
3639 --added pretty output of lines from inputcache
3645 --added pretty output of lines from inputcache
3640 --Made Logger a mixin class, simplifies handling of switches
3646 --Made Logger a mixin class, simplifies handling of switches
3641 --Added own completer class. .string<TAB> expands to last history
3647 --Added own completer class. .string<TAB> expands to last history
3642 line which starts with string. The new expansion is also present
3648 line which starts with string. The new expansion is also present
3643 with Ctrl-r from the readline library. But this shows, who this
3649 with Ctrl-r from the readline library. But this shows, who this
3644 can be done for other cases.
3650 can be done for other cases.
3645 --Added convention that all shell functions should accept a
3651 --Added convention that all shell functions should accept a
3646 parameter_string This opens the door for different behaviour for
3652 parameter_string This opens the door for different behaviour for
3647 each function. @cd is a good example of this.
3653 each function. @cd is a good example of this.
3648
3654
3649 04.05.99 12:12 porto.ifm.uni-kiel.de
3655 04.05.99 12:12 porto.ifm.uni-kiel.de
3650 --added logfile rotation
3656 --added logfile rotation
3651 --added new mainloop method which freezes first the namespace
3657 --added new mainloop method which freezes first the namespace
3652
3658
3653 07.05.99 21:24 porto.ifm.uni-kiel.de
3659 07.05.99 21:24 porto.ifm.uni-kiel.de
3654 --added the docreader classes. Now there is a help system.
3660 --added the docreader classes. Now there is a help system.
3655 -This is only a first try. Currently it's not easy to put new
3661 -This is only a first try. Currently it's not easy to put new
3656 stuff in the indices. But this is the way to go. Info would be
3662 stuff in the indices. But this is the way to go. Info would be
3657 better, but HTML is every where and not everybody has an info
3663 better, but HTML is every where and not everybody has an info
3658 system installed and it's not so easy to change html-docs to info.
3664 system installed and it's not so easy to change html-docs to info.
3659 --added global logfile option
3665 --added global logfile option
3660 --there is now a hook for object inspection method pinfo needs to
3666 --there is now a hook for object inspection method pinfo needs to
3661 be provided for this. Can be reached by two '??'.
3667 be provided for this. Can be reached by two '??'.
3662
3668
3663 08.05.99 20:51 porto.ifm.uni-kiel.de
3669 08.05.99 20:51 porto.ifm.uni-kiel.de
3664 --added a README
3670 --added a README
3665 --bug in rc file. Something has changed so functions in the rc
3671 --bug in rc file. Something has changed so functions in the rc
3666 file need to reference the shell and not self. Not clear if it's a
3672 file need to reference the shell and not self. Not clear if it's a
3667 bug or feature.
3673 bug or feature.
3668 --changed rc file for new behavior
3674 --changed rc file for new behavior
3669
3675
3670 2004-07-15 Fernando Perez <fperez@colorado.edu>
3676 2004-07-15 Fernando Perez <fperez@colorado.edu>
3671
3677
3672 * IPython/Logger.py (Logger.log): fixed recent bug where the input
3678 * IPython/Logger.py (Logger.log): fixed recent bug where the input
3673 cache was falling out of sync in bizarre manners when multi-line
3679 cache was falling out of sync in bizarre manners when multi-line
3674 input was present. Minor optimizations and cleanup.
3680 input was present. Minor optimizations and cleanup.
3675
3681
3676 (Logger): Remove old Changelog info for cleanup. This is the
3682 (Logger): Remove old Changelog info for cleanup. This is the
3677 information which was there from Janko's original code:
3683 information which was there from Janko's original code:
3678
3684
3679 Changes to Logger: - made the default log filename a parameter
3685 Changes to Logger: - made the default log filename a parameter
3680
3686
3681 - put a check for lines beginning with !@? in log(). Needed
3687 - put a check for lines beginning with !@? in log(). Needed
3682 (even if the handlers properly log their lines) for mid-session
3688 (even if the handlers properly log their lines) for mid-session
3683 logging activation to work properly. Without this, lines logged
3689 logging activation to work properly. Without this, lines logged
3684 in mid session, which get read from the cache, would end up
3690 in mid session, which get read from the cache, would end up
3685 'bare' (with !@? in the open) in the log. Now they are caught
3691 'bare' (with !@? in the open) in the log. Now they are caught
3686 and prepended with a #.
3692 and prepended with a #.
3687
3693
3688 * IPython/iplib.py (InteractiveShell.init_readline): added check
3694 * IPython/iplib.py (InteractiveShell.init_readline): added check
3689 in case MagicCompleter fails to be defined, so we don't crash.
3695 in case MagicCompleter fails to be defined, so we don't crash.
3690
3696
3691 2004-07-13 Fernando Perez <fperez@colorado.edu>
3697 2004-07-13 Fernando Perez <fperez@colorado.edu>
3692
3698
3693 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
3699 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
3694 of EPS if the requested filename ends in '.eps'.
3700 of EPS if the requested filename ends in '.eps'.
3695
3701
3696 2004-07-04 Fernando Perez <fperez@colorado.edu>
3702 2004-07-04 Fernando Perez <fperez@colorado.edu>
3697
3703
3698 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
3704 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
3699 escaping of quotes when calling the shell.
3705 escaping of quotes when calling the shell.
3700
3706
3701 2004-07-02 Fernando Perez <fperez@colorado.edu>
3707 2004-07-02 Fernando Perez <fperez@colorado.edu>
3702
3708
3703 * IPython/Prompts.py (CachedOutput.update): Fix problem with
3709 * IPython/Prompts.py (CachedOutput.update): Fix problem with
3704 gettext not working because we were clobbering '_'. Fixes
3710 gettext not working because we were clobbering '_'. Fixes
3705 http://www.scipy.net/roundup/ipython/issue6.
3711 http://www.scipy.net/roundup/ipython/issue6.
3706
3712
3707 2004-07-01 Fernando Perez <fperez@colorado.edu>
3713 2004-07-01 Fernando Perez <fperez@colorado.edu>
3708
3714
3709 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
3715 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
3710 into @cd. Patch by Ville.
3716 into @cd. Patch by Ville.
3711
3717
3712 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3718 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3713 new function to store things after ipmaker runs. Patch by Ville.
3719 new function to store things after ipmaker runs. Patch by Ville.
3714 Eventually this will go away once ipmaker is removed and the class
3720 Eventually this will go away once ipmaker is removed and the class
3715 gets cleaned up, but for now it's ok. Key functionality here is
3721 gets cleaned up, but for now it's ok. Key functionality here is
3716 the addition of the persistent storage mechanism, a dict for
3722 the addition of the persistent storage mechanism, a dict for
3717 keeping data across sessions (for now just bookmarks, but more can
3723 keeping data across sessions (for now just bookmarks, but more can
3718 be implemented later).
3724 be implemented later).
3719
3725
3720 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
3726 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
3721 persistent across sections. Patch by Ville, I modified it
3727 persistent across sections. Patch by Ville, I modified it
3722 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
3728 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
3723 added a '-l' option to list all bookmarks.
3729 added a '-l' option to list all bookmarks.
3724
3730
3725 * IPython/iplib.py (InteractiveShell.atexit_operations): new
3731 * IPython/iplib.py (InteractiveShell.atexit_operations): new
3726 center for cleanup. Registered with atexit.register(). I moved
3732 center for cleanup. Registered with atexit.register(). I moved
3727 here the old exit_cleanup(). After a patch by Ville.
3733 here the old exit_cleanup(). After a patch by Ville.
3728
3734
3729 * IPython/Magic.py (get_py_filename): added '~' to the accepted
3735 * IPython/Magic.py (get_py_filename): added '~' to the accepted
3730 characters in the hacked shlex_split for python 2.2.
3736 characters in the hacked shlex_split for python 2.2.
3731
3737
3732 * IPython/iplib.py (file_matches): more fixes to filenames with
3738 * IPython/iplib.py (file_matches): more fixes to filenames with
3733 whitespace in them. It's not perfect, but limitations in python's
3739 whitespace in them. It's not perfect, but limitations in python's
3734 readline make it impossible to go further.
3740 readline make it impossible to go further.
3735
3741
3736 2004-06-29 Fernando Perez <fperez@colorado.edu>
3742 2004-06-29 Fernando Perez <fperez@colorado.edu>
3737
3743
3738 * IPython/iplib.py (file_matches): escape whitespace correctly in
3744 * IPython/iplib.py (file_matches): escape whitespace correctly in
3739 filename completions. Bug reported by Ville.
3745 filename completions. Bug reported by Ville.
3740
3746
3741 2004-06-28 Fernando Perez <fperez@colorado.edu>
3747 2004-06-28 Fernando Perez <fperez@colorado.edu>
3742
3748
3743 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
3749 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
3744 the history file will be called 'history-PROFNAME' (or just
3750 the history file will be called 'history-PROFNAME' (or just
3745 'history' if no profile is loaded). I was getting annoyed at
3751 'history' if no profile is loaded). I was getting annoyed at
3746 getting my Numerical work history clobbered by pysh sessions.
3752 getting my Numerical work history clobbered by pysh sessions.
3747
3753
3748 * IPython/iplib.py (InteractiveShell.__init__): Internal
3754 * IPython/iplib.py (InteractiveShell.__init__): Internal
3749 getoutputerror() function so that we can honor the system_verbose
3755 getoutputerror() function so that we can honor the system_verbose
3750 flag for _all_ system calls. I also added escaping of #
3756 flag for _all_ system calls. I also added escaping of #
3751 characters here to avoid confusing Itpl.
3757 characters here to avoid confusing Itpl.
3752
3758
3753 * IPython/Magic.py (shlex_split): removed call to shell in
3759 * IPython/Magic.py (shlex_split): removed call to shell in
3754 parse_options and replaced it with shlex.split(). The annoying
3760 parse_options and replaced it with shlex.split(). The annoying
3755 part was that in Python 2.2, shlex.split() doesn't exist, so I had
3761 part was that in Python 2.2, shlex.split() doesn't exist, so I had
3756 to backport it from 2.3, with several frail hacks (the shlex
3762 to backport it from 2.3, with several frail hacks (the shlex
3757 module is rather limited in 2.2). Thanks to a suggestion by Ville
3763 module is rather limited in 2.2). Thanks to a suggestion by Ville
3758 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
3764 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
3759 problem.
3765 problem.
3760
3766
3761 (Magic.magic_system_verbose): new toggle to print the actual
3767 (Magic.magic_system_verbose): new toggle to print the actual
3762 system calls made by ipython. Mainly for debugging purposes.
3768 system calls made by ipython. Mainly for debugging purposes.
3763
3769
3764 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
3770 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
3765 doesn't support persistence. Reported (and fix suggested) by
3771 doesn't support persistence. Reported (and fix suggested) by
3766 Travis Caldwell <travis_caldwell2000@yahoo.com>.
3772 Travis Caldwell <travis_caldwell2000@yahoo.com>.
3767
3773
3768 2004-06-26 Fernando Perez <fperez@colorado.edu>
3774 2004-06-26 Fernando Perez <fperez@colorado.edu>
3769
3775
3770 * IPython/Logger.py (Logger.log): fix to handle correctly empty
3776 * IPython/Logger.py (Logger.log): fix to handle correctly empty
3771 continue prompts.
3777 continue prompts.
3772
3778
3773 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
3779 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
3774 function (basically a big docstring) and a few more things here to
3780 function (basically a big docstring) and a few more things here to
3775 speedup startup. pysh.py is now very lightweight. We want because
3781 speedup startup. pysh.py is now very lightweight. We want because
3776 it gets execfile'd, while InterpreterExec gets imported, so
3782 it gets execfile'd, while InterpreterExec gets imported, so
3777 byte-compilation saves time.
3783 byte-compilation saves time.
3778
3784
3779 2004-06-25 Fernando Perez <fperez@colorado.edu>
3785 2004-06-25 Fernando Perez <fperez@colorado.edu>
3780
3786
3781 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
3787 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
3782 -NUM', which was recently broken.
3788 -NUM', which was recently broken.
3783
3789
3784 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
3790 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
3785 in multi-line input (but not !!, which doesn't make sense there).
3791 in multi-line input (but not !!, which doesn't make sense there).
3786
3792
3787 * IPython/UserConfig/ipythonrc: made autoindent on by default.
3793 * IPython/UserConfig/ipythonrc: made autoindent on by default.
3788 It's just too useful, and people can turn it off in the less
3794 It's just too useful, and people can turn it off in the less
3789 common cases where it's a problem.
3795 common cases where it's a problem.
3790
3796
3791 2004-06-24 Fernando Perez <fperez@colorado.edu>
3797 2004-06-24 Fernando Perez <fperez@colorado.edu>
3792
3798
3793 * IPython/iplib.py (InteractiveShell._prefilter): big change -
3799 * IPython/iplib.py (InteractiveShell._prefilter): big change -
3794 special syntaxes (like alias calling) is now allied in multi-line
3800 special syntaxes (like alias calling) is now allied in multi-line
3795 input. This is still _very_ experimental, but it's necessary for
3801 input. This is still _very_ experimental, but it's necessary for
3796 efficient shell usage combining python looping syntax with system
3802 efficient shell usage combining python looping syntax with system
3797 calls. For now it's restricted to aliases, I don't think it
3803 calls. For now it's restricted to aliases, I don't think it
3798 really even makes sense to have this for magics.
3804 really even makes sense to have this for magics.
3799
3805
3800 2004-06-23 Fernando Perez <fperez@colorado.edu>
3806 2004-06-23 Fernando Perez <fperez@colorado.edu>
3801
3807
3802 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
3808 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
3803 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
3809 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
3804
3810
3805 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
3811 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
3806 extensions under Windows (after code sent by Gary Bishop). The
3812 extensions under Windows (after code sent by Gary Bishop). The
3807 extensions considered 'executable' are stored in IPython's rc
3813 extensions considered 'executable' are stored in IPython's rc
3808 structure as win_exec_ext.
3814 structure as win_exec_ext.
3809
3815
3810 * IPython/genutils.py (shell): new function, like system() but
3816 * IPython/genutils.py (shell): new function, like system() but
3811 without return value. Very useful for interactive shell work.
3817 without return value. Very useful for interactive shell work.
3812
3818
3813 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
3819 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
3814 delete aliases.
3820 delete aliases.
3815
3821
3816 * IPython/iplib.py (InteractiveShell.alias_table_update): make
3822 * IPython/iplib.py (InteractiveShell.alias_table_update): make
3817 sure that the alias table doesn't contain python keywords.
3823 sure that the alias table doesn't contain python keywords.
3818
3824
3819 2004-06-21 Fernando Perez <fperez@colorado.edu>
3825 2004-06-21 Fernando Perez <fperez@colorado.edu>
3820
3826
3821 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
3827 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
3822 non-existent items are found in $PATH. Reported by Thorsten.
3828 non-existent items are found in $PATH. Reported by Thorsten.
3823
3829
3824 2004-06-20 Fernando Perez <fperez@colorado.edu>
3830 2004-06-20 Fernando Perez <fperez@colorado.edu>
3825
3831
3826 * IPython/iplib.py (complete): modified the completer so that the
3832 * IPython/iplib.py (complete): modified the completer so that the
3827 order of priorities can be easily changed at runtime.
3833 order of priorities can be easily changed at runtime.
3828
3834
3829 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
3835 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
3830 Modified to auto-execute all lines beginning with '~', '/' or '.'.
3836 Modified to auto-execute all lines beginning with '~', '/' or '.'.
3831
3837
3832 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
3838 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
3833 expand Python variables prepended with $ in all system calls. The
3839 expand Python variables prepended with $ in all system calls. The
3834 same was done to InteractiveShell.handle_shell_escape. Now all
3840 same was done to InteractiveShell.handle_shell_escape. Now all
3835 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
3841 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
3836 expansion of python variables and expressions according to the
3842 expansion of python variables and expressions according to the
3837 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
3843 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
3838
3844
3839 Though PEP-215 has been rejected, a similar (but simpler) one
3845 Though PEP-215 has been rejected, a similar (but simpler) one
3840 seems like it will go into Python 2.4, PEP-292 -
3846 seems like it will go into Python 2.4, PEP-292 -
3841 http://www.python.org/peps/pep-0292.html.
3847 http://www.python.org/peps/pep-0292.html.
3842
3848
3843 I'll keep the full syntax of PEP-215, since IPython has since the
3849 I'll keep the full syntax of PEP-215, since IPython has since the
3844 start used Ka-Ping Yee's reference implementation discussed there
3850 start used Ka-Ping Yee's reference implementation discussed there
3845 (Itpl), and I actually like the powerful semantics it offers.
3851 (Itpl), and I actually like the powerful semantics it offers.
3846
3852
3847 In order to access normal shell variables, the $ has to be escaped
3853 In order to access normal shell variables, the $ has to be escaped
3848 via an extra $. For example:
3854 via an extra $. For example:
3849
3855
3850 In [7]: PATH='a python variable'
3856 In [7]: PATH='a python variable'
3851
3857
3852 In [8]: !echo $PATH
3858 In [8]: !echo $PATH
3853 a python variable
3859 a python variable
3854
3860
3855 In [9]: !echo $$PATH
3861 In [9]: !echo $$PATH
3856 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
3862 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
3857
3863
3858 (Magic.parse_options): escape $ so the shell doesn't evaluate
3864 (Magic.parse_options): escape $ so the shell doesn't evaluate
3859 things prematurely.
3865 things prematurely.
3860
3866
3861 * IPython/iplib.py (InteractiveShell.call_alias): added the
3867 * IPython/iplib.py (InteractiveShell.call_alias): added the
3862 ability for aliases to expand python variables via $.
3868 ability for aliases to expand python variables via $.
3863
3869
3864 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
3870 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
3865 system, now there's a @rehash/@rehashx pair of magics. These work
3871 system, now there's a @rehash/@rehashx pair of magics. These work
3866 like the csh rehash command, and can be invoked at any time. They
3872 like the csh rehash command, and can be invoked at any time. They
3867 build a table of aliases to everything in the user's $PATH
3873 build a table of aliases to everything in the user's $PATH
3868 (@rehash uses everything, @rehashx is slower but only adds
3874 (@rehash uses everything, @rehashx is slower but only adds
3869 executable files). With this, the pysh.py-based shell profile can
3875 executable files). With this, the pysh.py-based shell profile can
3870 now simply call rehash upon startup, and full access to all
3876 now simply call rehash upon startup, and full access to all
3871 programs in the user's path is obtained.
3877 programs in the user's path is obtained.
3872
3878
3873 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
3879 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
3874 functionality is now fully in place. I removed the old dynamic
3880 functionality is now fully in place. I removed the old dynamic
3875 code generation based approach, in favor of a much lighter one
3881 code generation based approach, in favor of a much lighter one
3876 based on a simple dict. The advantage is that this allows me to
3882 based on a simple dict. The advantage is that this allows me to
3877 now have thousands of aliases with negligible cost (unthinkable
3883 now have thousands of aliases with negligible cost (unthinkable
3878 with the old system).
3884 with the old system).
3879
3885
3880 2004-06-19 Fernando Perez <fperez@colorado.edu>
3886 2004-06-19 Fernando Perez <fperez@colorado.edu>
3881
3887
3882 * IPython/iplib.py (__init__): extended MagicCompleter class to
3888 * IPython/iplib.py (__init__): extended MagicCompleter class to
3883 also complete (last in priority) on user aliases.
3889 also complete (last in priority) on user aliases.
3884
3890
3885 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
3891 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
3886 call to eval.
3892 call to eval.
3887 (ItplNS.__init__): Added a new class which functions like Itpl,
3893 (ItplNS.__init__): Added a new class which functions like Itpl,
3888 but allows configuring the namespace for the evaluation to occur
3894 but allows configuring the namespace for the evaluation to occur
3889 in.
3895 in.
3890
3896
3891 2004-06-18 Fernando Perez <fperez@colorado.edu>
3897 2004-06-18 Fernando Perez <fperez@colorado.edu>
3892
3898
3893 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
3899 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
3894 better message when 'exit' or 'quit' are typed (a common newbie
3900 better message when 'exit' or 'quit' are typed (a common newbie
3895 confusion).
3901 confusion).
3896
3902
3897 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
3903 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
3898 check for Windows users.
3904 check for Windows users.
3899
3905
3900 * IPython/iplib.py (InteractiveShell.user_setup): removed
3906 * IPython/iplib.py (InteractiveShell.user_setup): removed
3901 disabling of colors for Windows. I'll test at runtime and issue a
3907 disabling of colors for Windows. I'll test at runtime and issue a
3902 warning if Gary's readline isn't found, as to nudge users to
3908 warning if Gary's readline isn't found, as to nudge users to
3903 download it.
3909 download it.
3904
3910
3905 2004-06-16 Fernando Perez <fperez@colorado.edu>
3911 2004-06-16 Fernando Perez <fperez@colorado.edu>
3906
3912
3907 * IPython/genutils.py (Stream.__init__): changed to print errors
3913 * IPython/genutils.py (Stream.__init__): changed to print errors
3908 to sys.stderr. I had a circular dependency here. Now it's
3914 to sys.stderr. I had a circular dependency here. Now it's
3909 possible to run ipython as IDLE's shell (consider this pre-alpha,
3915 possible to run ipython as IDLE's shell (consider this pre-alpha,
3910 since true stdout things end up in the starting terminal instead
3916 since true stdout things end up in the starting terminal instead
3911 of IDLE's out).
3917 of IDLE's out).
3912
3918
3913 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
3919 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
3914 users who haven't # updated their prompt_in2 definitions. Remove
3920 users who haven't # updated their prompt_in2 definitions. Remove
3915 eventually.
3921 eventually.
3916 (multiple_replace): added credit to original ASPN recipe.
3922 (multiple_replace): added credit to original ASPN recipe.
3917
3923
3918 2004-06-15 Fernando Perez <fperez@colorado.edu>
3924 2004-06-15 Fernando Perez <fperez@colorado.edu>
3919
3925
3920 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
3926 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
3921 list of auto-defined aliases.
3927 list of auto-defined aliases.
3922
3928
3923 2004-06-13 Fernando Perez <fperez@colorado.edu>
3929 2004-06-13 Fernando Perez <fperez@colorado.edu>
3924
3930
3925 * setup.py (scriptfiles): Don't trigger win_post_install unless an
3931 * setup.py (scriptfiles): Don't trigger win_post_install unless an
3926 install was really requested (so setup.py can be used for other
3932 install was really requested (so setup.py can be used for other
3927 things under Windows).
3933 things under Windows).
3928
3934
3929 2004-06-10 Fernando Perez <fperez@colorado.edu>
3935 2004-06-10 Fernando Perez <fperez@colorado.edu>
3930
3936
3931 * IPython/Logger.py (Logger.create_log): Manually remove any old
3937 * IPython/Logger.py (Logger.create_log): Manually remove any old
3932 backup, since os.remove may fail under Windows. Fixes bug
3938 backup, since os.remove may fail under Windows. Fixes bug
3933 reported by Thorsten.
3939 reported by Thorsten.
3934
3940
3935 2004-06-09 Fernando Perez <fperez@colorado.edu>
3941 2004-06-09 Fernando Perez <fperez@colorado.edu>
3936
3942
3937 * examples/example-embed.py: fixed all references to %n (replaced
3943 * examples/example-embed.py: fixed all references to %n (replaced
3938 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
3944 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
3939 for all examples and the manual as well.
3945 for all examples and the manual as well.
3940
3946
3941 2004-06-08 Fernando Perez <fperez@colorado.edu>
3947 2004-06-08 Fernando Perez <fperez@colorado.edu>
3942
3948
3943 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
3949 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
3944 alignment and color management. All 3 prompt subsystems now
3950 alignment and color management. All 3 prompt subsystems now
3945 inherit from BasePrompt.
3951 inherit from BasePrompt.
3946
3952
3947 * tools/release: updates for windows installer build and tag rpms
3953 * tools/release: updates for windows installer build and tag rpms
3948 with python version (since paths are fixed).
3954 with python version (since paths are fixed).
3949
3955
3950 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
3956 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
3951 which will become eventually obsolete. Also fixed the default
3957 which will become eventually obsolete. Also fixed the default
3952 prompt_in2 to use \D, so at least new users start with the correct
3958 prompt_in2 to use \D, so at least new users start with the correct
3953 defaults.
3959 defaults.
3954 WARNING: Users with existing ipythonrc files will need to apply
3960 WARNING: Users with existing ipythonrc files will need to apply
3955 this fix manually!
3961 this fix manually!
3956
3962
3957 * setup.py: make windows installer (.exe). This is finally the
3963 * setup.py: make windows installer (.exe). This is finally the
3958 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
3964 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
3959 which I hadn't included because it required Python 2.3 (or recent
3965 which I hadn't included because it required Python 2.3 (or recent
3960 distutils).
3966 distutils).
3961
3967
3962 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
3968 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
3963 usage of new '\D' escape.
3969 usage of new '\D' escape.
3964
3970
3965 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
3971 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
3966 lacks os.getuid())
3972 lacks os.getuid())
3967 (CachedOutput.set_colors): Added the ability to turn coloring
3973 (CachedOutput.set_colors): Added the ability to turn coloring
3968 on/off with @colors even for manually defined prompt colors. It
3974 on/off with @colors even for manually defined prompt colors. It
3969 uses a nasty global, but it works safely and via the generic color
3975 uses a nasty global, but it works safely and via the generic color
3970 handling mechanism.
3976 handling mechanism.
3971 (Prompt2.__init__): Introduced new escape '\D' for continuation
3977 (Prompt2.__init__): Introduced new escape '\D' for continuation
3972 prompts. It represents the counter ('\#') as dots.
3978 prompts. It represents the counter ('\#') as dots.
3973 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
3979 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
3974 need to update their ipythonrc files and replace '%n' with '\D' in
3980 need to update their ipythonrc files and replace '%n' with '\D' in
3975 their prompt_in2 settings everywhere. Sorry, but there's
3981 their prompt_in2 settings everywhere. Sorry, but there's
3976 otherwise no clean way to get all prompts to properly align. The
3982 otherwise no clean way to get all prompts to properly align. The
3977 ipythonrc shipped with IPython has been updated.
3983 ipythonrc shipped with IPython has been updated.
3978
3984
3979 2004-06-07 Fernando Perez <fperez@colorado.edu>
3985 2004-06-07 Fernando Perez <fperez@colorado.edu>
3980
3986
3981 * setup.py (isfile): Pass local_icons option to latex2html, so the
3987 * setup.py (isfile): Pass local_icons option to latex2html, so the
3982 resulting HTML file is self-contained. Thanks to
3988 resulting HTML file is self-contained. Thanks to
3983 dryice-AT-liu.com.cn for the tip.
3989 dryice-AT-liu.com.cn for the tip.
3984
3990
3985 * pysh.py: I created a new profile 'shell', which implements a
3991 * pysh.py: I created a new profile 'shell', which implements a
3986 _rudimentary_ IPython-based shell. This is in NO WAY a realy
3992 _rudimentary_ IPython-based shell. This is in NO WAY a realy
3987 system shell, nor will it become one anytime soon. It's mainly
3993 system shell, nor will it become one anytime soon. It's mainly
3988 meant to illustrate the use of the new flexible bash-like prompts.
3994 meant to illustrate the use of the new flexible bash-like prompts.
3989 I guess it could be used by hardy souls for true shell management,
3995 I guess it could be used by hardy souls for true shell management,
3990 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
3996 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
3991 profile. This uses the InterpreterExec extension provided by
3997 profile. This uses the InterpreterExec extension provided by
3992 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
3998 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
3993
3999
3994 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
4000 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
3995 auto-align itself with the length of the previous input prompt
4001 auto-align itself with the length of the previous input prompt
3996 (taking into account the invisible color escapes).
4002 (taking into account the invisible color escapes).
3997 (CachedOutput.__init__): Large restructuring of this class. Now
4003 (CachedOutput.__init__): Large restructuring of this class. Now
3998 all three prompts (primary1, primary2, output) are proper objects,
4004 all three prompts (primary1, primary2, output) are proper objects,
3999 managed by the 'parent' CachedOutput class. The code is still a
4005 managed by the 'parent' CachedOutput class. The code is still a
4000 bit hackish (all prompts share state via a pointer to the cache),
4006 bit hackish (all prompts share state via a pointer to the cache),
4001 but it's overall far cleaner than before.
4007 but it's overall far cleaner than before.
4002
4008
4003 * IPython/genutils.py (getoutputerror): modified to add verbose,
4009 * IPython/genutils.py (getoutputerror): modified to add verbose,
4004 debug and header options. This makes the interface of all getout*
4010 debug and header options. This makes the interface of all getout*
4005 functions uniform.
4011 functions uniform.
4006 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4012 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4007
4013
4008 * IPython/Magic.py (Magic.default_option): added a function to
4014 * IPython/Magic.py (Magic.default_option): added a function to
4009 allow registering default options for any magic command. This
4015 allow registering default options for any magic command. This
4010 makes it easy to have profiles which customize the magics globally
4016 makes it easy to have profiles which customize the magics globally
4011 for a certain use. The values set through this function are
4017 for a certain use. The values set through this function are
4012 picked up by the parse_options() method, which all magics should
4018 picked up by the parse_options() method, which all magics should
4013 use to parse their options.
4019 use to parse their options.
4014
4020
4015 * IPython/genutils.py (warn): modified the warnings framework to
4021 * IPython/genutils.py (warn): modified the warnings framework to
4016 use the Term I/O class. I'm trying to slowly unify all of
4022 use the Term I/O class. I'm trying to slowly unify all of
4017 IPython's I/O operations to pass through Term.
4023 IPython's I/O operations to pass through Term.
4018
4024
4019 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4025 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4020 the secondary prompt to correctly match the length of the primary
4026 the secondary prompt to correctly match the length of the primary
4021 one for any prompt. Now multi-line code will properly line up
4027 one for any prompt. Now multi-line code will properly line up
4022 even for path dependent prompts, such as the new ones available
4028 even for path dependent prompts, such as the new ones available
4023 via the prompt_specials.
4029 via the prompt_specials.
4024
4030
4025 2004-06-06 Fernando Perez <fperez@colorado.edu>
4031 2004-06-06 Fernando Perez <fperez@colorado.edu>
4026
4032
4027 * IPython/Prompts.py (prompt_specials): Added the ability to have
4033 * IPython/Prompts.py (prompt_specials): Added the ability to have
4028 bash-like special sequences in the prompts, which get
4034 bash-like special sequences in the prompts, which get
4029 automatically expanded. Things like hostname, current working
4035 automatically expanded. Things like hostname, current working
4030 directory and username are implemented already, but it's easy to
4036 directory and username are implemented already, but it's easy to
4031 add more in the future. Thanks to a patch by W.J. van der Laan
4037 add more in the future. Thanks to a patch by W.J. van der Laan
4032 <gnufnork-AT-hetdigitalegat.nl>
4038 <gnufnork-AT-hetdigitalegat.nl>
4033 (prompt_specials): Added color support for prompt strings, so
4039 (prompt_specials): Added color support for prompt strings, so
4034 users can define arbitrary color setups for their prompts.
4040 users can define arbitrary color setups for their prompts.
4035
4041
4036 2004-06-05 Fernando Perez <fperez@colorado.edu>
4042 2004-06-05 Fernando Perez <fperez@colorado.edu>
4037
4043
4038 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4044 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4039 code to load Gary Bishop's readline and configure it
4045 code to load Gary Bishop's readline and configure it
4040 automatically. Thanks to Gary for help on this.
4046 automatically. Thanks to Gary for help on this.
4041
4047
4042 2004-06-01 Fernando Perez <fperez@colorado.edu>
4048 2004-06-01 Fernando Perez <fperez@colorado.edu>
4043
4049
4044 * IPython/Logger.py (Logger.create_log): fix bug for logging
4050 * IPython/Logger.py (Logger.create_log): fix bug for logging
4045 with no filename (previous fix was incomplete).
4051 with no filename (previous fix was incomplete).
4046
4052
4047 2004-05-25 Fernando Perez <fperez@colorado.edu>
4053 2004-05-25 Fernando Perez <fperez@colorado.edu>
4048
4054
4049 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4055 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4050 parens would get passed to the shell.
4056 parens would get passed to the shell.
4051
4057
4052 2004-05-20 Fernando Perez <fperez@colorado.edu>
4058 2004-05-20 Fernando Perez <fperez@colorado.edu>
4053
4059
4054 * IPython/Magic.py (Magic.magic_prun): changed default profile
4060 * IPython/Magic.py (Magic.magic_prun): changed default profile
4055 sort order to 'time' (the more common profiling need).
4061 sort order to 'time' (the more common profiling need).
4056
4062
4057 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4063 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4058 so that source code shown is guaranteed in sync with the file on
4064 so that source code shown is guaranteed in sync with the file on
4059 disk (also changed in psource). Similar fix to the one for
4065 disk (also changed in psource). Similar fix to the one for
4060 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4066 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4061 <yann.ledu-AT-noos.fr>.
4067 <yann.ledu-AT-noos.fr>.
4062
4068
4063 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4069 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4064 with a single option would not be correctly parsed. Closes
4070 with a single option would not be correctly parsed. Closes
4065 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4071 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4066 introduced in 0.6.0 (on 2004-05-06).
4072 introduced in 0.6.0 (on 2004-05-06).
4067
4073
4068 2004-05-13 *** Released version 0.6.0
4074 2004-05-13 *** Released version 0.6.0
4069
4075
4070 2004-05-13 Fernando Perez <fperez@colorado.edu>
4076 2004-05-13 Fernando Perez <fperez@colorado.edu>
4071
4077
4072 * debian/: Added debian/ directory to CVS, so that debian support
4078 * debian/: Added debian/ directory to CVS, so that debian support
4073 is publicly accessible. The debian package is maintained by Jack
4079 is publicly accessible. The debian package is maintained by Jack
4074 Moffit <jack-AT-xiph.org>.
4080 Moffit <jack-AT-xiph.org>.
4075
4081
4076 * Documentation: included the notes about an ipython-based system
4082 * Documentation: included the notes about an ipython-based system
4077 shell (the hypothetical 'pysh') into the new_design.pdf document,
4083 shell (the hypothetical 'pysh') into the new_design.pdf document,
4078 so that these ideas get distributed to users along with the
4084 so that these ideas get distributed to users along with the
4079 official documentation.
4085 official documentation.
4080
4086
4081 2004-05-10 Fernando Perez <fperez@colorado.edu>
4087 2004-05-10 Fernando Perez <fperez@colorado.edu>
4082
4088
4083 * IPython/Logger.py (Logger.create_log): fix recently introduced
4089 * IPython/Logger.py (Logger.create_log): fix recently introduced
4084 bug (misindented line) where logstart would fail when not given an
4090 bug (misindented line) where logstart would fail when not given an
4085 explicit filename.
4091 explicit filename.
4086
4092
4087 2004-05-09 Fernando Perez <fperez@colorado.edu>
4093 2004-05-09 Fernando Perez <fperez@colorado.edu>
4088
4094
4089 * IPython/Magic.py (Magic.parse_options): skip system call when
4095 * IPython/Magic.py (Magic.parse_options): skip system call when
4090 there are no options to look for. Faster, cleaner for the common
4096 there are no options to look for. Faster, cleaner for the common
4091 case.
4097 case.
4092
4098
4093 * Documentation: many updates to the manual: describing Windows
4099 * Documentation: many updates to the manual: describing Windows
4094 support better, Gnuplot updates, credits, misc small stuff. Also
4100 support better, Gnuplot updates, credits, misc small stuff. Also
4095 updated the new_design doc a bit.
4101 updated the new_design doc a bit.
4096
4102
4097 2004-05-06 *** Released version 0.6.0.rc1
4103 2004-05-06 *** Released version 0.6.0.rc1
4098
4104
4099 2004-05-06 Fernando Perez <fperez@colorado.edu>
4105 2004-05-06 Fernando Perez <fperez@colorado.edu>
4100
4106
4101 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4107 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4102 operations to use the vastly more efficient list/''.join() method.
4108 operations to use the vastly more efficient list/''.join() method.
4103 (FormattedTB.text): Fix
4109 (FormattedTB.text): Fix
4104 http://www.scipy.net/roundup/ipython/issue12 - exception source
4110 http://www.scipy.net/roundup/ipython/issue12 - exception source
4105 extract not updated after reload. Thanks to Mike Salib
4111 extract not updated after reload. Thanks to Mike Salib
4106 <msalib-AT-mit.edu> for pinning the source of the problem.
4112 <msalib-AT-mit.edu> for pinning the source of the problem.
4107 Fortunately, the solution works inside ipython and doesn't require
4113 Fortunately, the solution works inside ipython and doesn't require
4108 any changes to python proper.
4114 any changes to python proper.
4109
4115
4110 * IPython/Magic.py (Magic.parse_options): Improved to process the
4116 * IPython/Magic.py (Magic.parse_options): Improved to process the
4111 argument list as a true shell would (by actually using the
4117 argument list as a true shell would (by actually using the
4112 underlying system shell). This way, all @magics automatically get
4118 underlying system shell). This way, all @magics automatically get
4113 shell expansion for variables. Thanks to a comment by Alex
4119 shell expansion for variables. Thanks to a comment by Alex
4114 Schmolck.
4120 Schmolck.
4115
4121
4116 2004-04-04 Fernando Perez <fperez@colorado.edu>
4122 2004-04-04 Fernando Perez <fperez@colorado.edu>
4117
4123
4118 * IPython/iplib.py (InteractiveShell.interact): Added a special
4124 * IPython/iplib.py (InteractiveShell.interact): Added a special
4119 trap for a debugger quit exception, which is basically impossible
4125 trap for a debugger quit exception, which is basically impossible
4120 to handle by normal mechanisms, given what pdb does to the stack.
4126 to handle by normal mechanisms, given what pdb does to the stack.
4121 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4127 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4122
4128
4123 2004-04-03 Fernando Perez <fperez@colorado.edu>
4129 2004-04-03 Fernando Perez <fperez@colorado.edu>
4124
4130
4125 * IPython/genutils.py (Term): Standardized the names of the Term
4131 * IPython/genutils.py (Term): Standardized the names of the Term
4126 class streams to cin/cout/cerr, following C++ naming conventions
4132 class streams to cin/cout/cerr, following C++ naming conventions
4127 (I can't use in/out/err because 'in' is not a valid attribute
4133 (I can't use in/out/err because 'in' is not a valid attribute
4128 name).
4134 name).
4129
4135
4130 * IPython/iplib.py (InteractiveShell.interact): don't increment
4136 * IPython/iplib.py (InteractiveShell.interact): don't increment
4131 the prompt if there's no user input. By Daniel 'Dang' Griffith
4137 the prompt if there's no user input. By Daniel 'Dang' Griffith
4132 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4138 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4133 Francois Pinard.
4139 Francois Pinard.
4134
4140
4135 2004-04-02 Fernando Perez <fperez@colorado.edu>
4141 2004-04-02 Fernando Perez <fperez@colorado.edu>
4136
4142
4137 * IPython/genutils.py (Stream.__init__): Modified to survive at
4143 * IPython/genutils.py (Stream.__init__): Modified to survive at
4138 least importing in contexts where stdin/out/err aren't true file
4144 least importing in contexts where stdin/out/err aren't true file
4139 objects, such as PyCrust (they lack fileno() and mode). However,
4145 objects, such as PyCrust (they lack fileno() and mode). However,
4140 the recovery facilities which rely on these things existing will
4146 the recovery facilities which rely on these things existing will
4141 not work.
4147 not work.
4142
4148
4143 2004-04-01 Fernando Perez <fperez@colorado.edu>
4149 2004-04-01 Fernando Perez <fperez@colorado.edu>
4144
4150
4145 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4151 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4146 use the new getoutputerror() function, so it properly
4152 use the new getoutputerror() function, so it properly
4147 distinguishes stdout/err.
4153 distinguishes stdout/err.
4148
4154
4149 * IPython/genutils.py (getoutputerror): added a function to
4155 * IPython/genutils.py (getoutputerror): added a function to
4150 capture separately the standard output and error of a command.
4156 capture separately the standard output and error of a command.
4151 After a comment from dang on the mailing lists. This code is
4157 After a comment from dang on the mailing lists. This code is
4152 basically a modified version of commands.getstatusoutput(), from
4158 basically a modified version of commands.getstatusoutput(), from
4153 the standard library.
4159 the standard library.
4154
4160
4155 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4161 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4156 '!!' as a special syntax (shorthand) to access @sx.
4162 '!!' as a special syntax (shorthand) to access @sx.
4157
4163
4158 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4164 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4159 command and return its output as a list split on '\n'.
4165 command and return its output as a list split on '\n'.
4160
4166
4161 2004-03-31 Fernando Perez <fperez@colorado.edu>
4167 2004-03-31 Fernando Perez <fperez@colorado.edu>
4162
4168
4163 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4169 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4164 method to dictionaries used as FakeModule instances if they lack
4170 method to dictionaries used as FakeModule instances if they lack
4165 it. At least pydoc in python2.3 breaks for runtime-defined
4171 it. At least pydoc in python2.3 breaks for runtime-defined
4166 functions without this hack. At some point I need to _really_
4172 functions without this hack. At some point I need to _really_
4167 understand what FakeModule is doing, because it's a gross hack.
4173 understand what FakeModule is doing, because it's a gross hack.
4168 But it solves Arnd's problem for now...
4174 But it solves Arnd's problem for now...
4169
4175
4170 2004-02-27 Fernando Perez <fperez@colorado.edu>
4176 2004-02-27 Fernando Perez <fperez@colorado.edu>
4171
4177
4172 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4178 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4173 mode would behave erratically. Also increased the number of
4179 mode would behave erratically. Also increased the number of
4174 possible logs in rotate mod to 999. Thanks to Rod Holland
4180 possible logs in rotate mod to 999. Thanks to Rod Holland
4175 <rhh@StructureLABS.com> for the report and fixes.
4181 <rhh@StructureLABS.com> for the report and fixes.
4176
4182
4177 2004-02-26 Fernando Perez <fperez@colorado.edu>
4183 2004-02-26 Fernando Perez <fperez@colorado.edu>
4178
4184
4179 * IPython/genutils.py (page): Check that the curses module really
4185 * IPython/genutils.py (page): Check that the curses module really
4180 has the initscr attribute before trying to use it. For some
4186 has the initscr attribute before trying to use it. For some
4181 reason, the Solaris curses module is missing this. I think this
4187 reason, the Solaris curses module is missing this. I think this
4182 should be considered a Solaris python bug, but I'm not sure.
4188 should be considered a Solaris python bug, but I'm not sure.
4183
4189
4184 2004-01-17 Fernando Perez <fperez@colorado.edu>
4190 2004-01-17 Fernando Perez <fperez@colorado.edu>
4185
4191
4186 * IPython/genutils.py (Stream.__init__): Changes to try to make
4192 * IPython/genutils.py (Stream.__init__): Changes to try to make
4187 ipython robust against stdin/out/err being closed by the user.
4193 ipython robust against stdin/out/err being closed by the user.
4188 This is 'user error' (and blocks a normal python session, at least
4194 This is 'user error' (and blocks a normal python session, at least
4189 the stdout case). However, Ipython should be able to survive such
4195 the stdout case). However, Ipython should be able to survive such
4190 instances of abuse as gracefully as possible. To simplify the
4196 instances of abuse as gracefully as possible. To simplify the
4191 coding and maintain compatibility with Gary Bishop's Term
4197 coding and maintain compatibility with Gary Bishop's Term
4192 contributions, I've made use of classmethods for this. I think
4198 contributions, I've made use of classmethods for this. I think
4193 this introduces a dependency on python 2.2.
4199 this introduces a dependency on python 2.2.
4194
4200
4195 2004-01-13 Fernando Perez <fperez@colorado.edu>
4201 2004-01-13 Fernando Perez <fperez@colorado.edu>
4196
4202
4197 * IPython/numutils.py (exp_safe): simplified the code a bit and
4203 * IPython/numutils.py (exp_safe): simplified the code a bit and
4198 removed the need for importing the kinds module altogether.
4204 removed the need for importing the kinds module altogether.
4199
4205
4200 2004-01-06 Fernando Perez <fperez@colorado.edu>
4206 2004-01-06 Fernando Perez <fperez@colorado.edu>
4201
4207
4202 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4208 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4203 a magic function instead, after some community feedback. No
4209 a magic function instead, after some community feedback. No
4204 special syntax will exist for it, but its name is deliberately
4210 special syntax will exist for it, but its name is deliberately
4205 very short.
4211 very short.
4206
4212
4207 2003-12-20 Fernando Perez <fperez@colorado.edu>
4213 2003-12-20 Fernando Perez <fperez@colorado.edu>
4208
4214
4209 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4215 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4210 new functionality, to automagically assign the result of a shell
4216 new functionality, to automagically assign the result of a shell
4211 command to a variable. I'll solicit some community feedback on
4217 command to a variable. I'll solicit some community feedback on
4212 this before making it permanent.
4218 this before making it permanent.
4213
4219
4214 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4220 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4215 requested about callables for which inspect couldn't obtain a
4221 requested about callables for which inspect couldn't obtain a
4216 proper argspec. Thanks to a crash report sent by Etienne
4222 proper argspec. Thanks to a crash report sent by Etienne
4217 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4223 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4218
4224
4219 2003-12-09 Fernando Perez <fperez@colorado.edu>
4225 2003-12-09 Fernando Perez <fperez@colorado.edu>
4220
4226
4221 * IPython/genutils.py (page): patch for the pager to work across
4227 * IPython/genutils.py (page): patch for the pager to work across
4222 various versions of Windows. By Gary Bishop.
4228 various versions of Windows. By Gary Bishop.
4223
4229
4224 2003-12-04 Fernando Perez <fperez@colorado.edu>
4230 2003-12-04 Fernando Perez <fperez@colorado.edu>
4225
4231
4226 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4232 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4227 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4233 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4228 While I tested this and it looks ok, there may still be corner
4234 While I tested this and it looks ok, there may still be corner
4229 cases I've missed.
4235 cases I've missed.
4230
4236
4231 2003-12-01 Fernando Perez <fperez@colorado.edu>
4237 2003-12-01 Fernando Perez <fperez@colorado.edu>
4232
4238
4233 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4239 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4234 where a line like 'p,q=1,2' would fail because the automagic
4240 where a line like 'p,q=1,2' would fail because the automagic
4235 system would be triggered for @p.
4241 system would be triggered for @p.
4236
4242
4237 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4243 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4238 cleanups, code unmodified.
4244 cleanups, code unmodified.
4239
4245
4240 * IPython/genutils.py (Term): added a class for IPython to handle
4246 * IPython/genutils.py (Term): added a class for IPython to handle
4241 output. In most cases it will just be a proxy for stdout/err, but
4247 output. In most cases it will just be a proxy for stdout/err, but
4242 having this allows modifications to be made for some platforms,
4248 having this allows modifications to be made for some platforms,
4243 such as handling color escapes under Windows. All of this code
4249 such as handling color escapes under Windows. All of this code
4244 was contributed by Gary Bishop, with minor modifications by me.
4250 was contributed by Gary Bishop, with minor modifications by me.
4245 The actual changes affect many files.
4251 The actual changes affect many files.
4246
4252
4247 2003-11-30 Fernando Perez <fperez@colorado.edu>
4253 2003-11-30 Fernando Perez <fperez@colorado.edu>
4248
4254
4249 * IPython/iplib.py (file_matches): new completion code, courtesy
4255 * IPython/iplib.py (file_matches): new completion code, courtesy
4250 of Jeff Collins. This enables filename completion again under
4256 of Jeff Collins. This enables filename completion again under
4251 python 2.3, which disabled it at the C level.
4257 python 2.3, which disabled it at the C level.
4252
4258
4253 2003-11-11 Fernando Perez <fperez@colorado.edu>
4259 2003-11-11 Fernando Perez <fperez@colorado.edu>
4254
4260
4255 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4261 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4256 for Numeric.array(map(...)), but often convenient.
4262 for Numeric.array(map(...)), but often convenient.
4257
4263
4258 2003-11-05 Fernando Perez <fperez@colorado.edu>
4264 2003-11-05 Fernando Perez <fperez@colorado.edu>
4259
4265
4260 * IPython/numutils.py (frange): Changed a call from int() to
4266 * IPython/numutils.py (frange): Changed a call from int() to
4261 int(round()) to prevent a problem reported with arange() in the
4267 int(round()) to prevent a problem reported with arange() in the
4262 numpy list.
4268 numpy list.
4263
4269
4264 2003-10-06 Fernando Perez <fperez@colorado.edu>
4270 2003-10-06 Fernando Perez <fperez@colorado.edu>
4265
4271
4266 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4272 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4267 prevent crashes if sys lacks an argv attribute (it happens with
4273 prevent crashes if sys lacks an argv attribute (it happens with
4268 embedded interpreters which build a bare-bones sys module).
4274 embedded interpreters which build a bare-bones sys module).
4269 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4275 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4270
4276
4271 2003-09-24 Fernando Perez <fperez@colorado.edu>
4277 2003-09-24 Fernando Perez <fperez@colorado.edu>
4272
4278
4273 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4279 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4274 to protect against poorly written user objects where __getattr__
4280 to protect against poorly written user objects where __getattr__
4275 raises exceptions other than AttributeError. Thanks to a bug
4281 raises exceptions other than AttributeError. Thanks to a bug
4276 report by Oliver Sander <osander-AT-gmx.de>.
4282 report by Oliver Sander <osander-AT-gmx.de>.
4277
4283
4278 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4284 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4279 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4285 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4280
4286
4281 2003-09-09 Fernando Perez <fperez@colorado.edu>
4287 2003-09-09 Fernando Perez <fperez@colorado.edu>
4282
4288
4283 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4289 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4284 unpacking a list whith a callable as first element would
4290 unpacking a list whith a callable as first element would
4285 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4291 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4286 Collins.
4292 Collins.
4287
4293
4288 2003-08-25 *** Released version 0.5.0
4294 2003-08-25 *** Released version 0.5.0
4289
4295
4290 2003-08-22 Fernando Perez <fperez@colorado.edu>
4296 2003-08-22 Fernando Perez <fperez@colorado.edu>
4291
4297
4292 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4298 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4293 improperly defined user exceptions. Thanks to feedback from Mark
4299 improperly defined user exceptions. Thanks to feedback from Mark
4294 Russell <mrussell-AT-verio.net>.
4300 Russell <mrussell-AT-verio.net>.
4295
4301
4296 2003-08-20 Fernando Perez <fperez@colorado.edu>
4302 2003-08-20 Fernando Perez <fperez@colorado.edu>
4297
4303
4298 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4304 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4299 printing so that it would print multi-line string forms starting
4305 printing so that it would print multi-line string forms starting
4300 with a new line. This way the formatting is better respected for
4306 with a new line. This way the formatting is better respected for
4301 objects which work hard to make nice string forms.
4307 objects which work hard to make nice string forms.
4302
4308
4303 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4309 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4304 autocall would overtake data access for objects with both
4310 autocall would overtake data access for objects with both
4305 __getitem__ and __call__.
4311 __getitem__ and __call__.
4306
4312
4307 2003-08-19 *** Released version 0.5.0-rc1
4313 2003-08-19 *** Released version 0.5.0-rc1
4308
4314
4309 2003-08-19 Fernando Perez <fperez@colorado.edu>
4315 2003-08-19 Fernando Perez <fperez@colorado.edu>
4310
4316
4311 * IPython/deep_reload.py (load_tail): single tiny change here
4317 * IPython/deep_reload.py (load_tail): single tiny change here
4312 seems to fix the long-standing bug of dreload() failing to work
4318 seems to fix the long-standing bug of dreload() failing to work
4313 for dotted names. But this module is pretty tricky, so I may have
4319 for dotted names. But this module is pretty tricky, so I may have
4314 missed some subtlety. Needs more testing!.
4320 missed some subtlety. Needs more testing!.
4315
4321
4316 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4322 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4317 exceptions which have badly implemented __str__ methods.
4323 exceptions which have badly implemented __str__ methods.
4318 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4324 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4319 which I've been getting reports about from Python 2.3 users. I
4325 which I've been getting reports about from Python 2.3 users. I
4320 wish I had a simple test case to reproduce the problem, so I could
4326 wish I had a simple test case to reproduce the problem, so I could
4321 either write a cleaner workaround or file a bug report if
4327 either write a cleaner workaround or file a bug report if
4322 necessary.
4328 necessary.
4323
4329
4324 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4330 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4325 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4331 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4326 a bug report by Tjabo Kloppenburg.
4332 a bug report by Tjabo Kloppenburg.
4327
4333
4328 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4334 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4329 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4335 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4330 seems rather unstable. Thanks to a bug report by Tjabo
4336 seems rather unstable. Thanks to a bug report by Tjabo
4331 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4337 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4332
4338
4333 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4339 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4334 this out soon because of the critical fixes in the inner loop for
4340 this out soon because of the critical fixes in the inner loop for
4335 generators.
4341 generators.
4336
4342
4337 * IPython/Magic.py (Magic.getargspec): removed. This (and
4343 * IPython/Magic.py (Magic.getargspec): removed. This (and
4338 _get_def) have been obsoleted by OInspect for a long time, I
4344 _get_def) have been obsoleted by OInspect for a long time, I
4339 hadn't noticed that they were dead code.
4345 hadn't noticed that they were dead code.
4340 (Magic._ofind): restored _ofind functionality for a few literals
4346 (Magic._ofind): restored _ofind functionality for a few literals
4341 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4347 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4342 for things like "hello".capitalize?, since that would require a
4348 for things like "hello".capitalize?, since that would require a
4343 potentially dangerous eval() again.
4349 potentially dangerous eval() again.
4344
4350
4345 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4351 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4346 logic a bit more to clean up the escapes handling and minimize the
4352 logic a bit more to clean up the escapes handling and minimize the
4347 use of _ofind to only necessary cases. The interactive 'feel' of
4353 use of _ofind to only necessary cases. The interactive 'feel' of
4348 IPython should have improved quite a bit with the changes in
4354 IPython should have improved quite a bit with the changes in
4349 _prefilter and _ofind (besides being far safer than before).
4355 _prefilter and _ofind (besides being far safer than before).
4350
4356
4351 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4357 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4352 obscure, never reported). Edit would fail to find the object to
4358 obscure, never reported). Edit would fail to find the object to
4353 edit under some circumstances.
4359 edit under some circumstances.
4354 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4360 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4355 which were causing double-calling of generators. Those eval calls
4361 which were causing double-calling of generators. Those eval calls
4356 were _very_ dangerous, since code with side effects could be
4362 were _very_ dangerous, since code with side effects could be
4357 triggered. As they say, 'eval is evil'... These were the
4363 triggered. As they say, 'eval is evil'... These were the
4358 nastiest evals in IPython. Besides, _ofind is now far simpler,
4364 nastiest evals in IPython. Besides, _ofind is now far simpler,
4359 and it should also be quite a bit faster. Its use of inspect is
4365 and it should also be quite a bit faster. Its use of inspect is
4360 also safer, so perhaps some of the inspect-related crashes I've
4366 also safer, so perhaps some of the inspect-related crashes I've
4361 seen lately with Python 2.3 might be taken care of. That will
4367 seen lately with Python 2.3 might be taken care of. That will
4362 need more testing.
4368 need more testing.
4363
4369
4364 2003-08-17 Fernando Perez <fperez@colorado.edu>
4370 2003-08-17 Fernando Perez <fperez@colorado.edu>
4365
4371
4366 * IPython/iplib.py (InteractiveShell._prefilter): significant
4372 * IPython/iplib.py (InteractiveShell._prefilter): significant
4367 simplifications to the logic for handling user escapes. Faster
4373 simplifications to the logic for handling user escapes. Faster
4368 and simpler code.
4374 and simpler code.
4369
4375
4370 2003-08-14 Fernando Perez <fperez@colorado.edu>
4376 2003-08-14 Fernando Perez <fperez@colorado.edu>
4371
4377
4372 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4378 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4373 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4379 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4374 but it should be quite a bit faster. And the recursive version
4380 but it should be quite a bit faster. And the recursive version
4375 generated O(log N) intermediate storage for all rank>1 arrays,
4381 generated O(log N) intermediate storage for all rank>1 arrays,
4376 even if they were contiguous.
4382 even if they were contiguous.
4377 (l1norm): Added this function.
4383 (l1norm): Added this function.
4378 (norm): Added this function for arbitrary norms (including
4384 (norm): Added this function for arbitrary norms (including
4379 l-infinity). l1 and l2 are still special cases for convenience
4385 l-infinity). l1 and l2 are still special cases for convenience
4380 and speed.
4386 and speed.
4381
4387
4382 2003-08-03 Fernando Perez <fperez@colorado.edu>
4388 2003-08-03 Fernando Perez <fperez@colorado.edu>
4383
4389
4384 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4390 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4385 exceptions, which now raise PendingDeprecationWarnings in Python
4391 exceptions, which now raise PendingDeprecationWarnings in Python
4386 2.3. There were some in Magic and some in Gnuplot2.
4392 2.3. There were some in Magic and some in Gnuplot2.
4387
4393
4388 2003-06-30 Fernando Perez <fperez@colorado.edu>
4394 2003-06-30 Fernando Perez <fperez@colorado.edu>
4389
4395
4390 * IPython/genutils.py (page): modified to call curses only for
4396 * IPython/genutils.py (page): modified to call curses only for
4391 terminals where TERM=='xterm'. After problems under many other
4397 terminals where TERM=='xterm'. After problems under many other
4392 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4398 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4393
4399
4394 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4400 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4395 would be triggered when readline was absent. This was just an old
4401 would be triggered when readline was absent. This was just an old
4396 debugging statement I'd forgotten to take out.
4402 debugging statement I'd forgotten to take out.
4397
4403
4398 2003-06-20 Fernando Perez <fperez@colorado.edu>
4404 2003-06-20 Fernando Perez <fperez@colorado.edu>
4399
4405
4400 * IPython/genutils.py (clock): modified to return only user time
4406 * IPython/genutils.py (clock): modified to return only user time
4401 (not counting system time), after a discussion on scipy. While
4407 (not counting system time), after a discussion on scipy. While
4402 system time may be a useful quantity occasionally, it may much
4408 system time may be a useful quantity occasionally, it may much
4403 more easily be skewed by occasional swapping or other similar
4409 more easily be skewed by occasional swapping or other similar
4404 activity.
4410 activity.
4405
4411
4406 2003-06-05 Fernando Perez <fperez@colorado.edu>
4412 2003-06-05 Fernando Perez <fperez@colorado.edu>
4407
4413
4408 * IPython/numutils.py (identity): new function, for building
4414 * IPython/numutils.py (identity): new function, for building
4409 arbitrary rank Kronecker deltas (mostly backwards compatible with
4415 arbitrary rank Kronecker deltas (mostly backwards compatible with
4410 Numeric.identity)
4416 Numeric.identity)
4411
4417
4412 2003-06-03 Fernando Perez <fperez@colorado.edu>
4418 2003-06-03 Fernando Perez <fperez@colorado.edu>
4413
4419
4414 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4420 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4415 arguments passed to magics with spaces, to allow trailing '\' to
4421 arguments passed to magics with spaces, to allow trailing '\' to
4416 work normally (mainly for Windows users).
4422 work normally (mainly for Windows users).
4417
4423
4418 2003-05-29 Fernando Perez <fperez@colorado.edu>
4424 2003-05-29 Fernando Perez <fperez@colorado.edu>
4419
4425
4420 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4426 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4421 instead of pydoc.help. This fixes a bizarre behavior where
4427 instead of pydoc.help. This fixes a bizarre behavior where
4422 printing '%s' % locals() would trigger the help system. Now
4428 printing '%s' % locals() would trigger the help system. Now
4423 ipython behaves like normal python does.
4429 ipython behaves like normal python does.
4424
4430
4425 Note that if one does 'from pydoc import help', the bizarre
4431 Note that if one does 'from pydoc import help', the bizarre
4426 behavior returns, but this will also happen in normal python, so
4432 behavior returns, but this will also happen in normal python, so
4427 it's not an ipython bug anymore (it has to do with how pydoc.help
4433 it's not an ipython bug anymore (it has to do with how pydoc.help
4428 is implemented).
4434 is implemented).
4429
4435
4430 2003-05-22 Fernando Perez <fperez@colorado.edu>
4436 2003-05-22 Fernando Perez <fperez@colorado.edu>
4431
4437
4432 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4438 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4433 return [] instead of None when nothing matches, also match to end
4439 return [] instead of None when nothing matches, also match to end
4434 of line. Patch by Gary Bishop.
4440 of line. Patch by Gary Bishop.
4435
4441
4436 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4442 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4437 protection as before, for files passed on the command line. This
4443 protection as before, for files passed on the command line. This
4438 prevents the CrashHandler from kicking in if user files call into
4444 prevents the CrashHandler from kicking in if user files call into
4439 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4445 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4440 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4446 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4441
4447
4442 2003-05-20 *** Released version 0.4.0
4448 2003-05-20 *** Released version 0.4.0
4443
4449
4444 2003-05-20 Fernando Perez <fperez@colorado.edu>
4450 2003-05-20 Fernando Perez <fperez@colorado.edu>
4445
4451
4446 * setup.py: added support for manpages. It's a bit hackish b/c of
4452 * setup.py: added support for manpages. It's a bit hackish b/c of
4447 a bug in the way the bdist_rpm distutils target handles gzipped
4453 a bug in the way the bdist_rpm distutils target handles gzipped
4448 manpages, but it works. After a patch by Jack.
4454 manpages, but it works. After a patch by Jack.
4449
4455
4450 2003-05-19 Fernando Perez <fperez@colorado.edu>
4456 2003-05-19 Fernando Perez <fperez@colorado.edu>
4451
4457
4452 * IPython/numutils.py: added a mockup of the kinds module, since
4458 * IPython/numutils.py: added a mockup of the kinds module, since
4453 it was recently removed from Numeric. This way, numutils will
4459 it was recently removed from Numeric. This way, numutils will
4454 work for all users even if they are missing kinds.
4460 work for all users even if they are missing kinds.
4455
4461
4456 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4462 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4457 failure, which can occur with SWIG-wrapped extensions. After a
4463 failure, which can occur with SWIG-wrapped extensions. After a
4458 crash report from Prabhu.
4464 crash report from Prabhu.
4459
4465
4460 2003-05-16 Fernando Perez <fperez@colorado.edu>
4466 2003-05-16 Fernando Perez <fperez@colorado.edu>
4461
4467
4462 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4468 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4463 protect ipython from user code which may call directly
4469 protect ipython from user code which may call directly
4464 sys.excepthook (this looks like an ipython crash to the user, even
4470 sys.excepthook (this looks like an ipython crash to the user, even
4465 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4471 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4466 This is especially important to help users of WxWindows, but may
4472 This is especially important to help users of WxWindows, but may
4467 also be useful in other cases.
4473 also be useful in other cases.
4468
4474
4469 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4475 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4470 an optional tb_offset to be specified, and to preserve exception
4476 an optional tb_offset to be specified, and to preserve exception
4471 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4477 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4472
4478
4473 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4479 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4474
4480
4475 2003-05-15 Fernando Perez <fperez@colorado.edu>
4481 2003-05-15 Fernando Perez <fperez@colorado.edu>
4476
4482
4477 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4483 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4478 installing for a new user under Windows.
4484 installing for a new user under Windows.
4479
4485
4480 2003-05-12 Fernando Perez <fperez@colorado.edu>
4486 2003-05-12 Fernando Perez <fperez@colorado.edu>
4481
4487
4482 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4488 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4483 handler for Emacs comint-based lines. Currently it doesn't do
4489 handler for Emacs comint-based lines. Currently it doesn't do
4484 much (but importantly, it doesn't update the history cache). In
4490 much (but importantly, it doesn't update the history cache). In
4485 the future it may be expanded if Alex needs more functionality
4491 the future it may be expanded if Alex needs more functionality
4486 there.
4492 there.
4487
4493
4488 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4494 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4489 info to crash reports.
4495 info to crash reports.
4490
4496
4491 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4497 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4492 just like Python's -c. Also fixed crash with invalid -color
4498 just like Python's -c. Also fixed crash with invalid -color
4493 option value at startup. Thanks to Will French
4499 option value at startup. Thanks to Will French
4494 <wfrench-AT-bestweb.net> for the bug report.
4500 <wfrench-AT-bestweb.net> for the bug report.
4495
4501
4496 2003-05-09 Fernando Perez <fperez@colorado.edu>
4502 2003-05-09 Fernando Perez <fperez@colorado.edu>
4497
4503
4498 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4504 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4499 to EvalDict (it's a mapping, after all) and simplified its code
4505 to EvalDict (it's a mapping, after all) and simplified its code
4500 quite a bit, after a nice discussion on c.l.py where Gustavo
4506 quite a bit, after a nice discussion on c.l.py where Gustavo
4501 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
4507 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
4502
4508
4503 2003-04-30 Fernando Perez <fperez@colorado.edu>
4509 2003-04-30 Fernando Perez <fperez@colorado.edu>
4504
4510
4505 * IPython/genutils.py (timings_out): modified it to reduce its
4511 * IPython/genutils.py (timings_out): modified it to reduce its
4506 overhead in the common reps==1 case.
4512 overhead in the common reps==1 case.
4507
4513
4508 2003-04-29 Fernando Perez <fperez@colorado.edu>
4514 2003-04-29 Fernando Perez <fperez@colorado.edu>
4509
4515
4510 * IPython/genutils.py (timings_out): Modified to use the resource
4516 * IPython/genutils.py (timings_out): Modified to use the resource
4511 module, which avoids the wraparound problems of time.clock().
4517 module, which avoids the wraparound problems of time.clock().
4512
4518
4513 2003-04-17 *** Released version 0.2.15pre4
4519 2003-04-17 *** Released version 0.2.15pre4
4514
4520
4515 2003-04-17 Fernando Perez <fperez@colorado.edu>
4521 2003-04-17 Fernando Perez <fperez@colorado.edu>
4516
4522
4517 * setup.py (scriptfiles): Split windows-specific stuff over to a
4523 * setup.py (scriptfiles): Split windows-specific stuff over to a
4518 separate file, in an attempt to have a Windows GUI installer.
4524 separate file, in an attempt to have a Windows GUI installer.
4519 That didn't work, but part of the groundwork is done.
4525 That didn't work, but part of the groundwork is done.
4520
4526
4521 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4527 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4522 indent/unindent with 4 spaces. Particularly useful in combination
4528 indent/unindent with 4 spaces. Particularly useful in combination
4523 with the new auto-indent option.
4529 with the new auto-indent option.
4524
4530
4525 2003-04-16 Fernando Perez <fperez@colorado.edu>
4531 2003-04-16 Fernando Perez <fperez@colorado.edu>
4526
4532
4527 * IPython/Magic.py: various replacements of self.rc for
4533 * IPython/Magic.py: various replacements of self.rc for
4528 self.shell.rc. A lot more remains to be done to fully disentangle
4534 self.shell.rc. A lot more remains to be done to fully disentangle
4529 this class from the main Shell class.
4535 this class from the main Shell class.
4530
4536
4531 * IPython/GnuplotRuntime.py: added checks for mouse support so
4537 * IPython/GnuplotRuntime.py: added checks for mouse support so
4532 that we don't try to enable it if the current gnuplot doesn't
4538 that we don't try to enable it if the current gnuplot doesn't
4533 really support it. Also added checks so that we don't try to
4539 really support it. Also added checks so that we don't try to
4534 enable persist under Windows (where Gnuplot doesn't recognize the
4540 enable persist under Windows (where Gnuplot doesn't recognize the
4535 option).
4541 option).
4536
4542
4537 * IPython/iplib.py (InteractiveShell.interact): Added optional
4543 * IPython/iplib.py (InteractiveShell.interact): Added optional
4538 auto-indenting code, after a patch by King C. Shu
4544 auto-indenting code, after a patch by King C. Shu
4539 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4545 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4540 get along well with pasting indented code. If I ever figure out
4546 get along well with pasting indented code. If I ever figure out
4541 how to make that part go well, it will become on by default.
4547 how to make that part go well, it will become on by default.
4542
4548
4543 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4549 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4544 crash ipython if there was an unmatched '%' in the user's prompt
4550 crash ipython if there was an unmatched '%' in the user's prompt
4545 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4551 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4546
4552
4547 * IPython/iplib.py (InteractiveShell.interact): removed the
4553 * IPython/iplib.py (InteractiveShell.interact): removed the
4548 ability to ask the user whether he wants to crash or not at the
4554 ability to ask the user whether he wants to crash or not at the
4549 'last line' exception handler. Calling functions at that point
4555 'last line' exception handler. Calling functions at that point
4550 changes the stack, and the error reports would have incorrect
4556 changes the stack, and the error reports would have incorrect
4551 tracebacks.
4557 tracebacks.
4552
4558
4553 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4559 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4554 pass through a peger a pretty-printed form of any object. After a
4560 pass through a peger a pretty-printed form of any object. After a
4555 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4561 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4556
4562
4557 2003-04-14 Fernando Perez <fperez@colorado.edu>
4563 2003-04-14 Fernando Perez <fperez@colorado.edu>
4558
4564
4559 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4565 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4560 all files in ~ would be modified at first install (instead of
4566 all files in ~ would be modified at first install (instead of
4561 ~/.ipython). This could be potentially disastrous, as the
4567 ~/.ipython). This could be potentially disastrous, as the
4562 modification (make line-endings native) could damage binary files.
4568 modification (make line-endings native) could damage binary files.
4563
4569
4564 2003-04-10 Fernando Perez <fperez@colorado.edu>
4570 2003-04-10 Fernando Perez <fperez@colorado.edu>
4565
4571
4566 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4572 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4567 handle only lines which are invalid python. This now means that
4573 handle only lines which are invalid python. This now means that
4568 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4574 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4569 for the bug report.
4575 for the bug report.
4570
4576
4571 2003-04-01 Fernando Perez <fperez@colorado.edu>
4577 2003-04-01 Fernando Perez <fperez@colorado.edu>
4572
4578
4573 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4579 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4574 where failing to set sys.last_traceback would crash pdb.pm().
4580 where failing to set sys.last_traceback would crash pdb.pm().
4575 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4581 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4576 report.
4582 report.
4577
4583
4578 2003-03-25 Fernando Perez <fperez@colorado.edu>
4584 2003-03-25 Fernando Perez <fperez@colorado.edu>
4579
4585
4580 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4586 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4581 before printing it (it had a lot of spurious blank lines at the
4587 before printing it (it had a lot of spurious blank lines at the
4582 end).
4588 end).
4583
4589
4584 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4590 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4585 output would be sent 21 times! Obviously people don't use this
4591 output would be sent 21 times! Obviously people don't use this
4586 too often, or I would have heard about it.
4592 too often, or I would have heard about it.
4587
4593
4588 2003-03-24 Fernando Perez <fperez@colorado.edu>
4594 2003-03-24 Fernando Perez <fperez@colorado.edu>
4589
4595
4590 * setup.py (scriptfiles): renamed the data_files parameter from
4596 * setup.py (scriptfiles): renamed the data_files parameter from
4591 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4597 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4592 for the patch.
4598 for the patch.
4593
4599
4594 2003-03-20 Fernando Perez <fperez@colorado.edu>
4600 2003-03-20 Fernando Perez <fperez@colorado.edu>
4595
4601
4596 * IPython/genutils.py (error): added error() and fatal()
4602 * IPython/genutils.py (error): added error() and fatal()
4597 functions.
4603 functions.
4598
4604
4599 2003-03-18 *** Released version 0.2.15pre3
4605 2003-03-18 *** Released version 0.2.15pre3
4600
4606
4601 2003-03-18 Fernando Perez <fperez@colorado.edu>
4607 2003-03-18 Fernando Perez <fperez@colorado.edu>
4602
4608
4603 * setupext/install_data_ext.py
4609 * setupext/install_data_ext.py
4604 (install_data_ext.initialize_options): Class contributed by Jack
4610 (install_data_ext.initialize_options): Class contributed by Jack
4605 Moffit for fixing the old distutils hack. He is sending this to
4611 Moffit for fixing the old distutils hack. He is sending this to
4606 the distutils folks so in the future we may not need it as a
4612 the distutils folks so in the future we may not need it as a
4607 private fix.
4613 private fix.
4608
4614
4609 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4615 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4610 changes for Debian packaging. See his patch for full details.
4616 changes for Debian packaging. See his patch for full details.
4611 The old distutils hack of making the ipythonrc* files carry a
4617 The old distutils hack of making the ipythonrc* files carry a
4612 bogus .py extension is gone, at last. Examples were moved to a
4618 bogus .py extension is gone, at last. Examples were moved to a
4613 separate subdir under doc/, and the separate executable scripts
4619 separate subdir under doc/, and the separate executable scripts
4614 now live in their own directory. Overall a great cleanup. The
4620 now live in their own directory. Overall a great cleanup. The
4615 manual was updated to use the new files, and setup.py has been
4621 manual was updated to use the new files, and setup.py has been
4616 fixed for this setup.
4622 fixed for this setup.
4617
4623
4618 * IPython/PyColorize.py (Parser.usage): made non-executable and
4624 * IPython/PyColorize.py (Parser.usage): made non-executable and
4619 created a pycolor wrapper around it to be included as a script.
4625 created a pycolor wrapper around it to be included as a script.
4620
4626
4621 2003-03-12 *** Released version 0.2.15pre2
4627 2003-03-12 *** Released version 0.2.15pre2
4622
4628
4623 2003-03-12 Fernando Perez <fperez@colorado.edu>
4629 2003-03-12 Fernando Perez <fperez@colorado.edu>
4624
4630
4625 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4631 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4626 long-standing problem with garbage characters in some terminals.
4632 long-standing problem with garbage characters in some terminals.
4627 The issue was really that the \001 and \002 escapes must _only_ be
4633 The issue was really that the \001 and \002 escapes must _only_ be
4628 passed to input prompts (which call readline), but _never_ to
4634 passed to input prompts (which call readline), but _never_ to
4629 normal text to be printed on screen. I changed ColorANSI to have
4635 normal text to be printed on screen. I changed ColorANSI to have
4630 two classes: TermColors and InputTermColors, each with the
4636 two classes: TermColors and InputTermColors, each with the
4631 appropriate escapes for input prompts or normal text. The code in
4637 appropriate escapes for input prompts or normal text. The code in
4632 Prompts.py got slightly more complicated, but this very old and
4638 Prompts.py got slightly more complicated, but this very old and
4633 annoying bug is finally fixed.
4639 annoying bug is finally fixed.
4634
4640
4635 All the credit for nailing down the real origin of this problem
4641 All the credit for nailing down the real origin of this problem
4636 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4642 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4637 *Many* thanks to him for spending quite a bit of effort on this.
4643 *Many* thanks to him for spending quite a bit of effort on this.
4638
4644
4639 2003-03-05 *** Released version 0.2.15pre1
4645 2003-03-05 *** Released version 0.2.15pre1
4640
4646
4641 2003-03-03 Fernando Perez <fperez@colorado.edu>
4647 2003-03-03 Fernando Perez <fperez@colorado.edu>
4642
4648
4643 * IPython/FakeModule.py: Moved the former _FakeModule to a
4649 * IPython/FakeModule.py: Moved the former _FakeModule to a
4644 separate file, because it's also needed by Magic (to fix a similar
4650 separate file, because it's also needed by Magic (to fix a similar
4645 pickle-related issue in @run).
4651 pickle-related issue in @run).
4646
4652
4647 2003-03-02 Fernando Perez <fperez@colorado.edu>
4653 2003-03-02 Fernando Perez <fperez@colorado.edu>
4648
4654
4649 * IPython/Magic.py (Magic.magic_autocall): new magic to control
4655 * IPython/Magic.py (Magic.magic_autocall): new magic to control
4650 the autocall option at runtime.
4656 the autocall option at runtime.
4651 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
4657 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
4652 across Magic.py to start separating Magic from InteractiveShell.
4658 across Magic.py to start separating Magic from InteractiveShell.
4653 (Magic._ofind): Fixed to return proper namespace for dotted
4659 (Magic._ofind): Fixed to return proper namespace for dotted
4654 names. Before, a dotted name would always return 'not currently
4660 names. Before, a dotted name would always return 'not currently
4655 defined', because it would find the 'parent'. s.x would be found,
4661 defined', because it would find the 'parent'. s.x would be found,
4656 but since 'x' isn't defined by itself, it would get confused.
4662 but since 'x' isn't defined by itself, it would get confused.
4657 (Magic.magic_run): Fixed pickling problems reported by Ralf
4663 (Magic.magic_run): Fixed pickling problems reported by Ralf
4658 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
4664 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
4659 that I'd used when Mike Heeter reported similar issues at the
4665 that I'd used when Mike Heeter reported similar issues at the
4660 top-level, but now for @run. It boils down to injecting the
4666 top-level, but now for @run. It boils down to injecting the
4661 namespace where code is being executed with something that looks
4667 namespace where code is being executed with something that looks
4662 enough like a module to fool pickle.dump(). Since a pickle stores
4668 enough like a module to fool pickle.dump(). Since a pickle stores
4663 a named reference to the importing module, we need this for
4669 a named reference to the importing module, we need this for
4664 pickles to save something sensible.
4670 pickles to save something sensible.
4665
4671
4666 * IPython/ipmaker.py (make_IPython): added an autocall option.
4672 * IPython/ipmaker.py (make_IPython): added an autocall option.
4667
4673
4668 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
4674 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
4669 the auto-eval code. Now autocalling is an option, and the code is
4675 the auto-eval code. Now autocalling is an option, and the code is
4670 also vastly safer. There is no more eval() involved at all.
4676 also vastly safer. There is no more eval() involved at all.
4671
4677
4672 2003-03-01 Fernando Perez <fperez@colorado.edu>
4678 2003-03-01 Fernando Perez <fperez@colorado.edu>
4673
4679
4674 * IPython/Magic.py (Magic._ofind): Changed interface to return a
4680 * IPython/Magic.py (Magic._ofind): Changed interface to return a
4675 dict with named keys instead of a tuple.
4681 dict with named keys instead of a tuple.
4676
4682
4677 * IPython: Started using CVS for IPython as of 0.2.15pre1.
4683 * IPython: Started using CVS for IPython as of 0.2.15pre1.
4678
4684
4679 * setup.py (make_shortcut): Fixed message about directories
4685 * setup.py (make_shortcut): Fixed message about directories
4680 created during Windows installation (the directories were ok, just
4686 created during Windows installation (the directories were ok, just
4681 the printed message was misleading). Thanks to Chris Liechti
4687 the printed message was misleading). Thanks to Chris Liechti
4682 <cliechti-AT-gmx.net> for the heads up.
4688 <cliechti-AT-gmx.net> for the heads up.
4683
4689
4684 2003-02-21 Fernando Perez <fperez@colorado.edu>
4690 2003-02-21 Fernando Perez <fperez@colorado.edu>
4685
4691
4686 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
4692 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
4687 of ValueError exception when checking for auto-execution. This
4693 of ValueError exception when checking for auto-execution. This
4688 one is raised by things like Numeric arrays arr.flat when the
4694 one is raised by things like Numeric arrays arr.flat when the
4689 array is non-contiguous.
4695 array is non-contiguous.
4690
4696
4691 2003-01-31 Fernando Perez <fperez@colorado.edu>
4697 2003-01-31 Fernando Perez <fperez@colorado.edu>
4692
4698
4693 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
4699 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
4694 not return any value at all (even though the command would get
4700 not return any value at all (even though the command would get
4695 executed).
4701 executed).
4696 (xsys): Flush stdout right after printing the command to ensure
4702 (xsys): Flush stdout right after printing the command to ensure
4697 proper ordering of commands and command output in the total
4703 proper ordering of commands and command output in the total
4698 output.
4704 output.
4699 (SystemExec/xsys/bq): Switched the names of xsys/bq and
4705 (SystemExec/xsys/bq): Switched the names of xsys/bq and
4700 system/getoutput as defaults. The old ones are kept for
4706 system/getoutput as defaults. The old ones are kept for
4701 compatibility reasons, so no code which uses this library needs
4707 compatibility reasons, so no code which uses this library needs
4702 changing.
4708 changing.
4703
4709
4704 2003-01-27 *** Released version 0.2.14
4710 2003-01-27 *** Released version 0.2.14
4705
4711
4706 2003-01-25 Fernando Perez <fperez@colorado.edu>
4712 2003-01-25 Fernando Perez <fperez@colorado.edu>
4707
4713
4708 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
4714 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
4709 functions defined in previous edit sessions could not be re-edited
4715 functions defined in previous edit sessions could not be re-edited
4710 (because the temp files were immediately removed). Now temp files
4716 (because the temp files were immediately removed). Now temp files
4711 are removed only at IPython's exit.
4717 are removed only at IPython's exit.
4712 (Magic.magic_run): Improved @run to perform shell-like expansions
4718 (Magic.magic_run): Improved @run to perform shell-like expansions
4713 on its arguments (~users and $VARS). With this, @run becomes more
4719 on its arguments (~users and $VARS). With this, @run becomes more
4714 like a normal command-line.
4720 like a normal command-line.
4715
4721
4716 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
4722 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
4717 bugs related to embedding and cleaned up that code. A fairly
4723 bugs related to embedding and cleaned up that code. A fairly
4718 important one was the impossibility to access the global namespace
4724 important one was the impossibility to access the global namespace
4719 through the embedded IPython (only local variables were visible).
4725 through the embedded IPython (only local variables were visible).
4720
4726
4721 2003-01-14 Fernando Perez <fperez@colorado.edu>
4727 2003-01-14 Fernando Perez <fperez@colorado.edu>
4722
4728
4723 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
4729 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
4724 auto-calling to be a bit more conservative. Now it doesn't get
4730 auto-calling to be a bit more conservative. Now it doesn't get
4725 triggered if any of '!=()<>' are in the rest of the input line, to
4731 triggered if any of '!=()<>' are in the rest of the input line, to
4726 allow comparing callables. Thanks to Alex for the heads up.
4732 allow comparing callables. Thanks to Alex for the heads up.
4727
4733
4728 2003-01-07 Fernando Perez <fperez@colorado.edu>
4734 2003-01-07 Fernando Perez <fperez@colorado.edu>
4729
4735
4730 * IPython/genutils.py (page): fixed estimation of the number of
4736 * IPython/genutils.py (page): fixed estimation of the number of
4731 lines in a string to be paged to simply count newlines. This
4737 lines in a string to be paged to simply count newlines. This
4732 prevents over-guessing due to embedded escape sequences. A better
4738 prevents over-guessing due to embedded escape sequences. A better
4733 long-term solution would involve stripping out the control chars
4739 long-term solution would involve stripping out the control chars
4734 for the count, but it's potentially so expensive I just don't
4740 for the count, but it's potentially so expensive I just don't
4735 think it's worth doing.
4741 think it's worth doing.
4736
4742
4737 2002-12-19 *** Released version 0.2.14pre50
4743 2002-12-19 *** Released version 0.2.14pre50
4738
4744
4739 2002-12-19 Fernando Perez <fperez@colorado.edu>
4745 2002-12-19 Fernando Perez <fperez@colorado.edu>
4740
4746
4741 * tools/release (version): Changed release scripts to inform
4747 * tools/release (version): Changed release scripts to inform
4742 Andrea and build a NEWS file with a list of recent changes.
4748 Andrea and build a NEWS file with a list of recent changes.
4743
4749
4744 * IPython/ColorANSI.py (__all__): changed terminal detection
4750 * IPython/ColorANSI.py (__all__): changed terminal detection
4745 code. Seems to work better for xterms without breaking
4751 code. Seems to work better for xterms without breaking
4746 konsole. Will need more testing to determine if WinXP and Mac OSX
4752 konsole. Will need more testing to determine if WinXP and Mac OSX
4747 also work ok.
4753 also work ok.
4748
4754
4749 2002-12-18 *** Released version 0.2.14pre49
4755 2002-12-18 *** Released version 0.2.14pre49
4750
4756
4751 2002-12-18 Fernando Perez <fperez@colorado.edu>
4757 2002-12-18 Fernando Perez <fperez@colorado.edu>
4752
4758
4753 * Docs: added new info about Mac OSX, from Andrea.
4759 * Docs: added new info about Mac OSX, from Andrea.
4754
4760
4755 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
4761 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
4756 allow direct plotting of python strings whose format is the same
4762 allow direct plotting of python strings whose format is the same
4757 of gnuplot data files.
4763 of gnuplot data files.
4758
4764
4759 2002-12-16 Fernando Perez <fperez@colorado.edu>
4765 2002-12-16 Fernando Perez <fperez@colorado.edu>
4760
4766
4761 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
4767 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
4762 value of exit question to be acknowledged.
4768 value of exit question to be acknowledged.
4763
4769
4764 2002-12-03 Fernando Perez <fperez@colorado.edu>
4770 2002-12-03 Fernando Perez <fperez@colorado.edu>
4765
4771
4766 * IPython/ipmaker.py: removed generators, which had been added
4772 * IPython/ipmaker.py: removed generators, which had been added
4767 by mistake in an earlier debugging run. This was causing trouble
4773 by mistake in an earlier debugging run. This was causing trouble
4768 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
4774 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
4769 for pointing this out.
4775 for pointing this out.
4770
4776
4771 2002-11-17 Fernando Perez <fperez@colorado.edu>
4777 2002-11-17 Fernando Perez <fperez@colorado.edu>
4772
4778
4773 * Manual: updated the Gnuplot section.
4779 * Manual: updated the Gnuplot section.
4774
4780
4775 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
4781 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
4776 a much better split of what goes in Runtime and what goes in
4782 a much better split of what goes in Runtime and what goes in
4777 Interactive.
4783 Interactive.
4778
4784
4779 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
4785 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
4780 being imported from iplib.
4786 being imported from iplib.
4781
4787
4782 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
4788 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
4783 for command-passing. Now the global Gnuplot instance is called
4789 for command-passing. Now the global Gnuplot instance is called
4784 'gp' instead of 'g', which was really a far too fragile and
4790 'gp' instead of 'g', which was really a far too fragile and
4785 common name.
4791 common name.
4786
4792
4787 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
4793 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
4788 bounding boxes generated by Gnuplot for square plots.
4794 bounding boxes generated by Gnuplot for square plots.
4789
4795
4790 * IPython/genutils.py (popkey): new function added. I should
4796 * IPython/genutils.py (popkey): new function added. I should
4791 suggest this on c.l.py as a dict method, it seems useful.
4797 suggest this on c.l.py as a dict method, it seems useful.
4792
4798
4793 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
4799 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
4794 to transparently handle PostScript generation. MUCH better than
4800 to transparently handle PostScript generation. MUCH better than
4795 the previous plot_eps/replot_eps (which I removed now). The code
4801 the previous plot_eps/replot_eps (which I removed now). The code
4796 is also fairly clean and well documented now (including
4802 is also fairly clean and well documented now (including
4797 docstrings).
4803 docstrings).
4798
4804
4799 2002-11-13 Fernando Perez <fperez@colorado.edu>
4805 2002-11-13 Fernando Perez <fperez@colorado.edu>
4800
4806
4801 * IPython/Magic.py (Magic.magic_edit): fixed docstring
4807 * IPython/Magic.py (Magic.magic_edit): fixed docstring
4802 (inconsistent with options).
4808 (inconsistent with options).
4803
4809
4804 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
4810 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
4805 manually disabled, I don't know why. Fixed it.
4811 manually disabled, I don't know why. Fixed it.
4806 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
4812 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
4807 eps output.
4813 eps output.
4808
4814
4809 2002-11-12 Fernando Perez <fperez@colorado.edu>
4815 2002-11-12 Fernando Perez <fperez@colorado.edu>
4810
4816
4811 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
4817 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
4812 don't propagate up to caller. Fixes crash reported by François
4818 don't propagate up to caller. Fixes crash reported by François
4813 Pinard.
4819 Pinard.
4814
4820
4815 2002-11-09 Fernando Perez <fperez@colorado.edu>
4821 2002-11-09 Fernando Perez <fperez@colorado.edu>
4816
4822
4817 * IPython/ipmaker.py (make_IPython): fixed problem with writing
4823 * IPython/ipmaker.py (make_IPython): fixed problem with writing
4818 history file for new users.
4824 history file for new users.
4819 (make_IPython): fixed bug where initial install would leave the
4825 (make_IPython): fixed bug where initial install would leave the
4820 user running in the .ipython dir.
4826 user running in the .ipython dir.
4821 (make_IPython): fixed bug where config dir .ipython would be
4827 (make_IPython): fixed bug where config dir .ipython would be
4822 created regardless of the given -ipythondir option. Thanks to Cory
4828 created regardless of the given -ipythondir option. Thanks to Cory
4823 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
4829 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
4824
4830
4825 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
4831 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
4826 type confirmations. Will need to use it in all of IPython's code
4832 type confirmations. Will need to use it in all of IPython's code
4827 consistently.
4833 consistently.
4828
4834
4829 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
4835 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
4830 context to print 31 lines instead of the default 5. This will make
4836 context to print 31 lines instead of the default 5. This will make
4831 the crash reports extremely detailed in case the problem is in
4837 the crash reports extremely detailed in case the problem is in
4832 libraries I don't have access to.
4838 libraries I don't have access to.
4833
4839
4834 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
4840 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
4835 line of defense' code to still crash, but giving users fair
4841 line of defense' code to still crash, but giving users fair
4836 warning. I don't want internal errors to go unreported: if there's
4842 warning. I don't want internal errors to go unreported: if there's
4837 an internal problem, IPython should crash and generate a full
4843 an internal problem, IPython should crash and generate a full
4838 report.
4844 report.
4839
4845
4840 2002-11-08 Fernando Perez <fperez@colorado.edu>
4846 2002-11-08 Fernando Perez <fperez@colorado.edu>
4841
4847
4842 * IPython/iplib.py (InteractiveShell.interact): added code to trap
4848 * IPython/iplib.py (InteractiveShell.interact): added code to trap
4843 otherwise uncaught exceptions which can appear if people set
4849 otherwise uncaught exceptions which can appear if people set
4844 sys.stdout to something badly broken. Thanks to a crash report
4850 sys.stdout to something badly broken. Thanks to a crash report
4845 from henni-AT-mail.brainbot.com.
4851 from henni-AT-mail.brainbot.com.
4846
4852
4847 2002-11-04 Fernando Perez <fperez@colorado.edu>
4853 2002-11-04 Fernando Perez <fperez@colorado.edu>
4848
4854
4849 * IPython/iplib.py (InteractiveShell.interact): added
4855 * IPython/iplib.py (InteractiveShell.interact): added
4850 __IPYTHON__active to the builtins. It's a flag which goes on when
4856 __IPYTHON__active to the builtins. It's a flag which goes on when
4851 the interaction starts and goes off again when it stops. This
4857 the interaction starts and goes off again when it stops. This
4852 allows embedding code to detect being inside IPython. Before this
4858 allows embedding code to detect being inside IPython. Before this
4853 was done via __IPYTHON__, but that only shows that an IPython
4859 was done via __IPYTHON__, but that only shows that an IPython
4854 instance has been created.
4860 instance has been created.
4855
4861
4856 * IPython/Magic.py (Magic.magic_env): I realized that in a
4862 * IPython/Magic.py (Magic.magic_env): I realized that in a
4857 UserDict, instance.data holds the data as a normal dict. So I
4863 UserDict, instance.data holds the data as a normal dict. So I
4858 modified @env to return os.environ.data instead of rebuilding a
4864 modified @env to return os.environ.data instead of rebuilding a
4859 dict by hand.
4865 dict by hand.
4860
4866
4861 2002-11-02 Fernando Perez <fperez@colorado.edu>
4867 2002-11-02 Fernando Perez <fperez@colorado.edu>
4862
4868
4863 * IPython/genutils.py (warn): changed so that level 1 prints no
4869 * IPython/genutils.py (warn): changed so that level 1 prints no
4864 header. Level 2 is now the default (with 'WARNING' header, as
4870 header. Level 2 is now the default (with 'WARNING' header, as
4865 before). I think I tracked all places where changes were needed in
4871 before). I think I tracked all places where changes were needed in
4866 IPython, but outside code using the old level numbering may have
4872 IPython, but outside code using the old level numbering may have
4867 broken.
4873 broken.
4868
4874
4869 * IPython/iplib.py (InteractiveShell.runcode): added this to
4875 * IPython/iplib.py (InteractiveShell.runcode): added this to
4870 handle the tracebacks in SystemExit traps correctly. The previous
4876 handle the tracebacks in SystemExit traps correctly. The previous
4871 code (through interact) was printing more of the stack than
4877 code (through interact) was printing more of the stack than
4872 necessary, showing IPython internal code to the user.
4878 necessary, showing IPython internal code to the user.
4873
4879
4874 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
4880 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
4875 default. Now that the default at the confirmation prompt is yes,
4881 default. Now that the default at the confirmation prompt is yes,
4876 it's not so intrusive. François' argument that ipython sessions
4882 it's not so intrusive. François' argument that ipython sessions
4877 tend to be complex enough not to lose them from an accidental C-d,
4883 tend to be complex enough not to lose them from an accidental C-d,
4878 is a valid one.
4884 is a valid one.
4879
4885
4880 * IPython/iplib.py (InteractiveShell.interact): added a
4886 * IPython/iplib.py (InteractiveShell.interact): added a
4881 showtraceback() call to the SystemExit trap, and modified the exit
4887 showtraceback() call to the SystemExit trap, and modified the exit
4882 confirmation to have yes as the default.
4888 confirmation to have yes as the default.
4883
4889
4884 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
4890 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
4885 this file. It's been gone from the code for a long time, this was
4891 this file. It's been gone from the code for a long time, this was
4886 simply leftover junk.
4892 simply leftover junk.
4887
4893
4888 2002-11-01 Fernando Perez <fperez@colorado.edu>
4894 2002-11-01 Fernando Perez <fperez@colorado.edu>
4889
4895
4890 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
4896 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
4891 added. If set, IPython now traps EOF and asks for
4897 added. If set, IPython now traps EOF and asks for
4892 confirmation. After a request by François Pinard.
4898 confirmation. After a request by François Pinard.
4893
4899
4894 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
4900 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
4895 of @abort, and with a new (better) mechanism for handling the
4901 of @abort, and with a new (better) mechanism for handling the
4896 exceptions.
4902 exceptions.
4897
4903
4898 2002-10-27 Fernando Perez <fperez@colorado.edu>
4904 2002-10-27 Fernando Perez <fperez@colorado.edu>
4899
4905
4900 * IPython/usage.py (__doc__): updated the --help information and
4906 * IPython/usage.py (__doc__): updated the --help information and
4901 the ipythonrc file to indicate that -log generates
4907 the ipythonrc file to indicate that -log generates
4902 ./ipython.log. Also fixed the corresponding info in @logstart.
4908 ./ipython.log. Also fixed the corresponding info in @logstart.
4903 This and several other fixes in the manuals thanks to reports by
4909 This and several other fixes in the manuals thanks to reports by
4904 François Pinard <pinard-AT-iro.umontreal.ca>.
4910 François Pinard <pinard-AT-iro.umontreal.ca>.
4905
4911
4906 * IPython/Logger.py (Logger.switch_log): Fixed error message to
4912 * IPython/Logger.py (Logger.switch_log): Fixed error message to
4907 refer to @logstart (instead of @log, which doesn't exist).
4913 refer to @logstart (instead of @log, which doesn't exist).
4908
4914
4909 * IPython/iplib.py (InteractiveShell._prefilter): fixed
4915 * IPython/iplib.py (InteractiveShell._prefilter): fixed
4910 AttributeError crash. Thanks to Christopher Armstrong
4916 AttributeError crash. Thanks to Christopher Armstrong
4911 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
4917 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
4912 introduced recently (in 0.2.14pre37) with the fix to the eval
4918 introduced recently (in 0.2.14pre37) with the fix to the eval
4913 problem mentioned below.
4919 problem mentioned below.
4914
4920
4915 2002-10-17 Fernando Perez <fperez@colorado.edu>
4921 2002-10-17 Fernando Perez <fperez@colorado.edu>
4916
4922
4917 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
4923 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
4918 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
4924 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
4919
4925
4920 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
4926 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
4921 this function to fix a problem reported by Alex Schmolck. He saw
4927 this function to fix a problem reported by Alex Schmolck. He saw
4922 it with list comprehensions and generators, which were getting
4928 it with list comprehensions and generators, which were getting
4923 called twice. The real problem was an 'eval' call in testing for
4929 called twice. The real problem was an 'eval' call in testing for
4924 automagic which was evaluating the input line silently.
4930 automagic which was evaluating the input line silently.
4925
4931
4926 This is a potentially very nasty bug, if the input has side
4932 This is a potentially very nasty bug, if the input has side
4927 effects which must not be repeated. The code is much cleaner now,
4933 effects which must not be repeated. The code is much cleaner now,
4928 without any blanket 'except' left and with a regexp test for
4934 without any blanket 'except' left and with a regexp test for
4929 actual function names.
4935 actual function names.
4930
4936
4931 But an eval remains, which I'm not fully comfortable with. I just
4937 But an eval remains, which I'm not fully comfortable with. I just
4932 don't know how to find out if an expression could be a callable in
4938 don't know how to find out if an expression could be a callable in
4933 the user's namespace without doing an eval on the string. However
4939 the user's namespace without doing an eval on the string. However
4934 that string is now much more strictly checked so that no code
4940 that string is now much more strictly checked so that no code
4935 slips by, so the eval should only happen for things that can
4941 slips by, so the eval should only happen for things that can
4936 really be only function/method names.
4942 really be only function/method names.
4937
4943
4938 2002-10-15 Fernando Perez <fperez@colorado.edu>
4944 2002-10-15 Fernando Perez <fperez@colorado.edu>
4939
4945
4940 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
4946 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
4941 OSX information to main manual, removed README_Mac_OSX file from
4947 OSX information to main manual, removed README_Mac_OSX file from
4942 distribution. Also updated credits for recent additions.
4948 distribution. Also updated credits for recent additions.
4943
4949
4944 2002-10-10 Fernando Perez <fperez@colorado.edu>
4950 2002-10-10 Fernando Perez <fperez@colorado.edu>
4945
4951
4946 * README_Mac_OSX: Added a README for Mac OSX users for fixing
4952 * README_Mac_OSX: Added a README for Mac OSX users for fixing
4947 terminal-related issues. Many thanks to Andrea Riciputi
4953 terminal-related issues. Many thanks to Andrea Riciputi
4948 <andrea.riciputi-AT-libero.it> for writing it.
4954 <andrea.riciputi-AT-libero.it> for writing it.
4949
4955
4950 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
4956 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
4951 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4957 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4952
4958
4953 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
4959 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
4954 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
4960 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
4955 <syver-en-AT-online.no> who both submitted patches for this problem.
4961 <syver-en-AT-online.no> who both submitted patches for this problem.
4956
4962
4957 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
4963 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
4958 global embedding to make sure that things don't overwrite user
4964 global embedding to make sure that things don't overwrite user
4959 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
4965 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
4960
4966
4961 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
4967 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
4962 compatibility. Thanks to Hayden Callow
4968 compatibility. Thanks to Hayden Callow
4963 <h.callow-AT-elec.canterbury.ac.nz>
4969 <h.callow-AT-elec.canterbury.ac.nz>
4964
4970
4965 2002-10-04 Fernando Perez <fperez@colorado.edu>
4971 2002-10-04 Fernando Perez <fperez@colorado.edu>
4966
4972
4967 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
4973 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
4968 Gnuplot.File objects.
4974 Gnuplot.File objects.
4969
4975
4970 2002-07-23 Fernando Perez <fperez@colorado.edu>
4976 2002-07-23 Fernando Perez <fperez@colorado.edu>
4971
4977
4972 * IPython/genutils.py (timing): Added timings() and timing() for
4978 * IPython/genutils.py (timing): Added timings() and timing() for
4973 quick access to the most commonly needed data, the execution
4979 quick access to the most commonly needed data, the execution
4974 times. Old timing() renamed to timings_out().
4980 times. Old timing() renamed to timings_out().
4975
4981
4976 2002-07-18 Fernando Perez <fperez@colorado.edu>
4982 2002-07-18 Fernando Perez <fperez@colorado.edu>
4977
4983
4978 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
4984 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
4979 bug with nested instances disrupting the parent's tab completion.
4985 bug with nested instances disrupting the parent's tab completion.
4980
4986
4981 * IPython/iplib.py (all_completions): Added Alex Schmolck's
4987 * IPython/iplib.py (all_completions): Added Alex Schmolck's
4982 all_completions code to begin the emacs integration.
4988 all_completions code to begin the emacs integration.
4983
4989
4984 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
4990 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
4985 argument to allow titling individual arrays when plotting.
4991 argument to allow titling individual arrays when plotting.
4986
4992
4987 2002-07-15 Fernando Perez <fperez@colorado.edu>
4993 2002-07-15 Fernando Perez <fperez@colorado.edu>
4988
4994
4989 * setup.py (make_shortcut): changed to retrieve the value of
4995 * setup.py (make_shortcut): changed to retrieve the value of
4990 'Program Files' directory from the registry (this value changes in
4996 'Program Files' directory from the registry (this value changes in
4991 non-english versions of Windows). Thanks to Thomas Fanslau
4997 non-english versions of Windows). Thanks to Thomas Fanslau
4992 <tfanslau-AT-gmx.de> for the report.
4998 <tfanslau-AT-gmx.de> for the report.
4993
4999
4994 2002-07-10 Fernando Perez <fperez@colorado.edu>
5000 2002-07-10 Fernando Perez <fperez@colorado.edu>
4995
5001
4996 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
5002 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
4997 a bug in pdb, which crashes if a line with only whitespace is
5003 a bug in pdb, which crashes if a line with only whitespace is
4998 entered. Bug report submitted to sourceforge.
5004 entered. Bug report submitted to sourceforge.
4999
5005
5000 2002-07-09 Fernando Perez <fperez@colorado.edu>
5006 2002-07-09 Fernando Perez <fperez@colorado.edu>
5001
5007
5002 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5008 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5003 reporting exceptions (it's a bug in inspect.py, I just set a
5009 reporting exceptions (it's a bug in inspect.py, I just set a
5004 workaround).
5010 workaround).
5005
5011
5006 2002-07-08 Fernando Perez <fperez@colorado.edu>
5012 2002-07-08 Fernando Perez <fperez@colorado.edu>
5007
5013
5008 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5014 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5009 __IPYTHON__ in __builtins__ to show up in user_ns.
5015 __IPYTHON__ in __builtins__ to show up in user_ns.
5010
5016
5011 2002-07-03 Fernando Perez <fperez@colorado.edu>
5017 2002-07-03 Fernando Perez <fperez@colorado.edu>
5012
5018
5013 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5019 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5014 name from @gp_set_instance to @gp_set_default.
5020 name from @gp_set_instance to @gp_set_default.
5015
5021
5016 * IPython/ipmaker.py (make_IPython): default editor value set to
5022 * IPython/ipmaker.py (make_IPython): default editor value set to
5017 '0' (a string), to match the rc file. Otherwise will crash when
5023 '0' (a string), to match the rc file. Otherwise will crash when
5018 .strip() is called on it.
5024 .strip() is called on it.
5019
5025
5020
5026
5021 2002-06-28 Fernando Perez <fperez@colorado.edu>
5027 2002-06-28 Fernando Perez <fperez@colorado.edu>
5022
5028
5023 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5029 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5024 of files in current directory when a file is executed via
5030 of files in current directory when a file is executed via
5025 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5031 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5026
5032
5027 * setup.py (manfiles): fix for rpm builds, submitted by RA
5033 * setup.py (manfiles): fix for rpm builds, submitted by RA
5028 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5034 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5029
5035
5030 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5036 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5031 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5037 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5032 string!). A. Schmolck caught this one.
5038 string!). A. Schmolck caught this one.
5033
5039
5034 2002-06-27 Fernando Perez <fperez@colorado.edu>
5040 2002-06-27 Fernando Perez <fperez@colorado.edu>
5035
5041
5036 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5042 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5037 defined files at the cmd line. __name__ wasn't being set to
5043 defined files at the cmd line. __name__ wasn't being set to
5038 __main__.
5044 __main__.
5039
5045
5040 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5046 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5041 regular lists and tuples besides Numeric arrays.
5047 regular lists and tuples besides Numeric arrays.
5042
5048
5043 * IPython/Prompts.py (CachedOutput.__call__): Added output
5049 * IPython/Prompts.py (CachedOutput.__call__): Added output
5044 supression for input ending with ';'. Similar to Mathematica and
5050 supression for input ending with ';'. Similar to Mathematica and
5045 Matlab. The _* vars and Out[] list are still updated, just like
5051 Matlab. The _* vars and Out[] list are still updated, just like
5046 Mathematica behaves.
5052 Mathematica behaves.
5047
5053
5048 2002-06-25 Fernando Perez <fperez@colorado.edu>
5054 2002-06-25 Fernando Perez <fperez@colorado.edu>
5049
5055
5050 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5056 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5051 .ini extensions for profiels under Windows.
5057 .ini extensions for profiels under Windows.
5052
5058
5053 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5059 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5054 string form. Fix contributed by Alexander Schmolck
5060 string form. Fix contributed by Alexander Schmolck
5055 <a.schmolck-AT-gmx.net>
5061 <a.schmolck-AT-gmx.net>
5056
5062
5057 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5063 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5058 pre-configured Gnuplot instance.
5064 pre-configured Gnuplot instance.
5059
5065
5060 2002-06-21 Fernando Perez <fperez@colorado.edu>
5066 2002-06-21 Fernando Perez <fperez@colorado.edu>
5061
5067
5062 * IPython/numutils.py (exp_safe): new function, works around the
5068 * IPython/numutils.py (exp_safe): new function, works around the
5063 underflow problems in Numeric.
5069 underflow problems in Numeric.
5064 (log2): New fn. Safe log in base 2: returns exact integer answer
5070 (log2): New fn. Safe log in base 2: returns exact integer answer
5065 for exact integer powers of 2.
5071 for exact integer powers of 2.
5066
5072
5067 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5073 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5068 properly.
5074 properly.
5069
5075
5070 2002-06-20 Fernando Perez <fperez@colorado.edu>
5076 2002-06-20 Fernando Perez <fperez@colorado.edu>
5071
5077
5072 * IPython/genutils.py (timing): new function like
5078 * IPython/genutils.py (timing): new function like
5073 Mathematica's. Similar to time_test, but returns more info.
5079 Mathematica's. Similar to time_test, but returns more info.
5074
5080
5075 2002-06-18 Fernando Perez <fperez@colorado.edu>
5081 2002-06-18 Fernando Perez <fperez@colorado.edu>
5076
5082
5077 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5083 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5078 according to Mike Heeter's suggestions.
5084 according to Mike Heeter's suggestions.
5079
5085
5080 2002-06-16 Fernando Perez <fperez@colorado.edu>
5086 2002-06-16 Fernando Perez <fperez@colorado.edu>
5081
5087
5082 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5088 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5083 system. GnuplotMagic is gone as a user-directory option. New files
5089 system. GnuplotMagic is gone as a user-directory option. New files
5084 make it easier to use all the gnuplot stuff both from external
5090 make it easier to use all the gnuplot stuff both from external
5085 programs as well as from IPython. Had to rewrite part of
5091 programs as well as from IPython. Had to rewrite part of
5086 hardcopy() b/c of a strange bug: often the ps files simply don't
5092 hardcopy() b/c of a strange bug: often the ps files simply don't
5087 get created, and require a repeat of the command (often several
5093 get created, and require a repeat of the command (often several
5088 times).
5094 times).
5089
5095
5090 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5096 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5091 resolve output channel at call time, so that if sys.stderr has
5097 resolve output channel at call time, so that if sys.stderr has
5092 been redirected by user this gets honored.
5098 been redirected by user this gets honored.
5093
5099
5094 2002-06-13 Fernando Perez <fperez@colorado.edu>
5100 2002-06-13 Fernando Perez <fperez@colorado.edu>
5095
5101
5096 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5102 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5097 IPShell. Kept a copy with the old names to avoid breaking people's
5103 IPShell. Kept a copy with the old names to avoid breaking people's
5098 embedded code.
5104 embedded code.
5099
5105
5100 * IPython/ipython: simplified it to the bare minimum after
5106 * IPython/ipython: simplified it to the bare minimum after
5101 Holger's suggestions. Added info about how to use it in
5107 Holger's suggestions. Added info about how to use it in
5102 PYTHONSTARTUP.
5108 PYTHONSTARTUP.
5103
5109
5104 * IPython/Shell.py (IPythonShell): changed the options passing
5110 * IPython/Shell.py (IPythonShell): changed the options passing
5105 from a string with funky %s replacements to a straight list. Maybe
5111 from a string with funky %s replacements to a straight list. Maybe
5106 a bit more typing, but it follows sys.argv conventions, so there's
5112 a bit more typing, but it follows sys.argv conventions, so there's
5107 less special-casing to remember.
5113 less special-casing to remember.
5108
5114
5109 2002-06-12 Fernando Perez <fperez@colorado.edu>
5115 2002-06-12 Fernando Perez <fperez@colorado.edu>
5110
5116
5111 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5117 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5112 command. Thanks to a suggestion by Mike Heeter.
5118 command. Thanks to a suggestion by Mike Heeter.
5113 (Magic.magic_pfile): added behavior to look at filenames if given
5119 (Magic.magic_pfile): added behavior to look at filenames if given
5114 arg is not a defined object.
5120 arg is not a defined object.
5115 (Magic.magic_save): New @save function to save code snippets. Also
5121 (Magic.magic_save): New @save function to save code snippets. Also
5116 a Mike Heeter idea.
5122 a Mike Heeter idea.
5117
5123
5118 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5124 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5119 plot() and replot(). Much more convenient now, especially for
5125 plot() and replot(). Much more convenient now, especially for
5120 interactive use.
5126 interactive use.
5121
5127
5122 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5128 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5123 filenames.
5129 filenames.
5124
5130
5125 2002-06-02 Fernando Perez <fperez@colorado.edu>
5131 2002-06-02 Fernando Perez <fperez@colorado.edu>
5126
5132
5127 * IPython/Struct.py (Struct.__init__): modified to admit
5133 * IPython/Struct.py (Struct.__init__): modified to admit
5128 initialization via another struct.
5134 initialization via another struct.
5129
5135
5130 * IPython/genutils.py (SystemExec.__init__): New stateful
5136 * IPython/genutils.py (SystemExec.__init__): New stateful
5131 interface to xsys and bq. Useful for writing system scripts.
5137 interface to xsys and bq. Useful for writing system scripts.
5132
5138
5133 2002-05-30 Fernando Perez <fperez@colorado.edu>
5139 2002-05-30 Fernando Perez <fperez@colorado.edu>
5134
5140
5135 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5141 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5136 documents. This will make the user download smaller (it's getting
5142 documents. This will make the user download smaller (it's getting
5137 too big).
5143 too big).
5138
5144
5139 2002-05-29 Fernando Perez <fperez@colorado.edu>
5145 2002-05-29 Fernando Perez <fperez@colorado.edu>
5140
5146
5141 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5147 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5142 fix problems with shelve and pickle. Seems to work, but I don't
5148 fix problems with shelve and pickle. Seems to work, but I don't
5143 know if corner cases break it. Thanks to Mike Heeter
5149 know if corner cases break it. Thanks to Mike Heeter
5144 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5150 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5145
5151
5146 2002-05-24 Fernando Perez <fperez@colorado.edu>
5152 2002-05-24 Fernando Perez <fperez@colorado.edu>
5147
5153
5148 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5154 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5149 macros having broken.
5155 macros having broken.
5150
5156
5151 2002-05-21 Fernando Perez <fperez@colorado.edu>
5157 2002-05-21 Fernando Perez <fperez@colorado.edu>
5152
5158
5153 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5159 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5154 introduced logging bug: all history before logging started was
5160 introduced logging bug: all history before logging started was
5155 being written one character per line! This came from the redesign
5161 being written one character per line! This came from the redesign
5156 of the input history as a special list which slices to strings,
5162 of the input history as a special list which slices to strings,
5157 not to lists.
5163 not to lists.
5158
5164
5159 2002-05-20 Fernando Perez <fperez@colorado.edu>
5165 2002-05-20 Fernando Perez <fperez@colorado.edu>
5160
5166
5161 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5167 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5162 be an attribute of all classes in this module. The design of these
5168 be an attribute of all classes in this module. The design of these
5163 classes needs some serious overhauling.
5169 classes needs some serious overhauling.
5164
5170
5165 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5171 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5166 which was ignoring '_' in option names.
5172 which was ignoring '_' in option names.
5167
5173
5168 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5174 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5169 'Verbose_novars' to 'Context' and made it the new default. It's a
5175 'Verbose_novars' to 'Context' and made it the new default. It's a
5170 bit more readable and also safer than verbose.
5176 bit more readable and also safer than verbose.
5171
5177
5172 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5178 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5173 triple-quoted strings.
5179 triple-quoted strings.
5174
5180
5175 * IPython/OInspect.py (__all__): new module exposing the object
5181 * IPython/OInspect.py (__all__): new module exposing the object
5176 introspection facilities. Now the corresponding magics are dummy
5182 introspection facilities. Now the corresponding magics are dummy
5177 wrappers around this. Having this module will make it much easier
5183 wrappers around this. Having this module will make it much easier
5178 to put these functions into our modified pdb.
5184 to put these functions into our modified pdb.
5179 This new object inspector system uses the new colorizing module,
5185 This new object inspector system uses the new colorizing module,
5180 so source code and other things are nicely syntax highlighted.
5186 so source code and other things are nicely syntax highlighted.
5181
5187
5182 2002-05-18 Fernando Perez <fperez@colorado.edu>
5188 2002-05-18 Fernando Perez <fperez@colorado.edu>
5183
5189
5184 * IPython/ColorANSI.py: Split the coloring tools into a separate
5190 * IPython/ColorANSI.py: Split the coloring tools into a separate
5185 module so I can use them in other code easier (they were part of
5191 module so I can use them in other code easier (they were part of
5186 ultraTB).
5192 ultraTB).
5187
5193
5188 2002-05-17 Fernando Perez <fperez@colorado.edu>
5194 2002-05-17 Fernando Perez <fperez@colorado.edu>
5189
5195
5190 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5196 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5191 fixed it to set the global 'g' also to the called instance, as
5197 fixed it to set the global 'g' also to the called instance, as
5192 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5198 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5193 user's 'g' variables).
5199 user's 'g' variables).
5194
5200
5195 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5201 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5196 global variables (aliases to _ih,_oh) so that users which expect
5202 global variables (aliases to _ih,_oh) so that users which expect
5197 In[5] or Out[7] to work aren't unpleasantly surprised.
5203 In[5] or Out[7] to work aren't unpleasantly surprised.
5198 (InputList.__getslice__): new class to allow executing slices of
5204 (InputList.__getslice__): new class to allow executing slices of
5199 input history directly. Very simple class, complements the use of
5205 input history directly. Very simple class, complements the use of
5200 macros.
5206 macros.
5201
5207
5202 2002-05-16 Fernando Perez <fperez@colorado.edu>
5208 2002-05-16 Fernando Perez <fperez@colorado.edu>
5203
5209
5204 * setup.py (docdirbase): make doc directory be just doc/IPython
5210 * setup.py (docdirbase): make doc directory be just doc/IPython
5205 without version numbers, it will reduce clutter for users.
5211 without version numbers, it will reduce clutter for users.
5206
5212
5207 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5213 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5208 execfile call to prevent possible memory leak. See for details:
5214 execfile call to prevent possible memory leak. See for details:
5209 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5215 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5210
5216
5211 2002-05-15 Fernando Perez <fperez@colorado.edu>
5217 2002-05-15 Fernando Perez <fperez@colorado.edu>
5212
5218
5213 * IPython/Magic.py (Magic.magic_psource): made the object
5219 * IPython/Magic.py (Magic.magic_psource): made the object
5214 introspection names be more standard: pdoc, pdef, pfile and
5220 introspection names be more standard: pdoc, pdef, pfile and
5215 psource. They all print/page their output, and it makes
5221 psource. They all print/page their output, and it makes
5216 remembering them easier. Kept old names for compatibility as
5222 remembering them easier. Kept old names for compatibility as
5217 aliases.
5223 aliases.
5218
5224
5219 2002-05-14 Fernando Perez <fperez@colorado.edu>
5225 2002-05-14 Fernando Perez <fperez@colorado.edu>
5220
5226
5221 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5227 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5222 what the mouse problem was. The trick is to use gnuplot with temp
5228 what the mouse problem was. The trick is to use gnuplot with temp
5223 files and NOT with pipes (for data communication), because having
5229 files and NOT with pipes (for data communication), because having
5224 both pipes and the mouse on is bad news.
5230 both pipes and the mouse on is bad news.
5225
5231
5226 2002-05-13 Fernando Perez <fperez@colorado.edu>
5232 2002-05-13 Fernando Perez <fperez@colorado.edu>
5227
5233
5228 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5234 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5229 bug. Information would be reported about builtins even when
5235 bug. Information would be reported about builtins even when
5230 user-defined functions overrode them.
5236 user-defined functions overrode them.
5231
5237
5232 2002-05-11 Fernando Perez <fperez@colorado.edu>
5238 2002-05-11 Fernando Perez <fperez@colorado.edu>
5233
5239
5234 * IPython/__init__.py (__all__): removed FlexCompleter from
5240 * IPython/__init__.py (__all__): removed FlexCompleter from
5235 __all__ so that things don't fail in platforms without readline.
5241 __all__ so that things don't fail in platforms without readline.
5236
5242
5237 2002-05-10 Fernando Perez <fperez@colorado.edu>
5243 2002-05-10 Fernando Perez <fperez@colorado.edu>
5238
5244
5239 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5245 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5240 it requires Numeric, effectively making Numeric a dependency for
5246 it requires Numeric, effectively making Numeric a dependency for
5241 IPython.
5247 IPython.
5242
5248
5243 * Released 0.2.13
5249 * Released 0.2.13
5244
5250
5245 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5251 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5246 profiler interface. Now all the major options from the profiler
5252 profiler interface. Now all the major options from the profiler
5247 module are directly supported in IPython, both for single
5253 module are directly supported in IPython, both for single
5248 expressions (@prun) and for full programs (@run -p).
5254 expressions (@prun) and for full programs (@run -p).
5249
5255
5250 2002-05-09 Fernando Perez <fperez@colorado.edu>
5256 2002-05-09 Fernando Perez <fperez@colorado.edu>
5251
5257
5252 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5258 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5253 magic properly formatted for screen.
5259 magic properly formatted for screen.
5254
5260
5255 * setup.py (make_shortcut): Changed things to put pdf version in
5261 * setup.py (make_shortcut): Changed things to put pdf version in
5256 doc/ instead of doc/manual (had to change lyxport a bit).
5262 doc/ instead of doc/manual (had to change lyxport a bit).
5257
5263
5258 * IPython/Magic.py (Profile.string_stats): made profile runs go
5264 * IPython/Magic.py (Profile.string_stats): made profile runs go
5259 through pager (they are long and a pager allows searching, saving,
5265 through pager (they are long and a pager allows searching, saving,
5260 etc.)
5266 etc.)
5261
5267
5262 2002-05-08 Fernando Perez <fperez@colorado.edu>
5268 2002-05-08 Fernando Perez <fperez@colorado.edu>
5263
5269
5264 * Released 0.2.12
5270 * Released 0.2.12
5265
5271
5266 2002-05-06 Fernando Perez <fperez@colorado.edu>
5272 2002-05-06 Fernando Perez <fperez@colorado.edu>
5267
5273
5268 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5274 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5269 introduced); 'hist n1 n2' was broken.
5275 introduced); 'hist n1 n2' was broken.
5270 (Magic.magic_pdb): added optional on/off arguments to @pdb
5276 (Magic.magic_pdb): added optional on/off arguments to @pdb
5271 (Magic.magic_run): added option -i to @run, which executes code in
5277 (Magic.magic_run): added option -i to @run, which executes code in
5272 the IPython namespace instead of a clean one. Also added @irun as
5278 the IPython namespace instead of a clean one. Also added @irun as
5273 an alias to @run -i.
5279 an alias to @run -i.
5274
5280
5275 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5281 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5276 fixed (it didn't really do anything, the namespaces were wrong).
5282 fixed (it didn't really do anything, the namespaces were wrong).
5277
5283
5278 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5284 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5279
5285
5280 * IPython/__init__.py (__all__): Fixed package namespace, now
5286 * IPython/__init__.py (__all__): Fixed package namespace, now
5281 'import IPython' does give access to IPython.<all> as
5287 'import IPython' does give access to IPython.<all> as
5282 expected. Also renamed __release__ to Release.
5288 expected. Also renamed __release__ to Release.
5283
5289
5284 * IPython/Debugger.py (__license__): created new Pdb class which
5290 * IPython/Debugger.py (__license__): created new Pdb class which
5285 functions like a drop-in for the normal pdb.Pdb but does NOT
5291 functions like a drop-in for the normal pdb.Pdb but does NOT
5286 import readline by default. This way it doesn't muck up IPython's
5292 import readline by default. This way it doesn't muck up IPython's
5287 readline handling, and now tab-completion finally works in the
5293 readline handling, and now tab-completion finally works in the
5288 debugger -- sort of. It completes things globally visible, but the
5294 debugger -- sort of. It completes things globally visible, but the
5289 completer doesn't track the stack as pdb walks it. That's a bit
5295 completer doesn't track the stack as pdb walks it. That's a bit
5290 tricky, and I'll have to implement it later.
5296 tricky, and I'll have to implement it later.
5291
5297
5292 2002-05-05 Fernando Perez <fperez@colorado.edu>
5298 2002-05-05 Fernando Perez <fperez@colorado.edu>
5293
5299
5294 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5300 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5295 magic docstrings when printed via ? (explicit \'s were being
5301 magic docstrings when printed via ? (explicit \'s were being
5296 printed).
5302 printed).
5297
5303
5298 * IPython/ipmaker.py (make_IPython): fixed namespace
5304 * IPython/ipmaker.py (make_IPython): fixed namespace
5299 identification bug. Now variables loaded via logs or command-line
5305 identification bug. Now variables loaded via logs or command-line
5300 files are recognized in the interactive namespace by @who.
5306 files are recognized in the interactive namespace by @who.
5301
5307
5302 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5308 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5303 log replay system stemming from the string form of Structs.
5309 log replay system stemming from the string form of Structs.
5304
5310
5305 * IPython/Magic.py (Macro.__init__): improved macros to properly
5311 * IPython/Magic.py (Macro.__init__): improved macros to properly
5306 handle magic commands in them.
5312 handle magic commands in them.
5307 (Magic.magic_logstart): usernames are now expanded so 'logstart
5313 (Magic.magic_logstart): usernames are now expanded so 'logstart
5308 ~/mylog' now works.
5314 ~/mylog' now works.
5309
5315
5310 * IPython/iplib.py (complete): fixed bug where paths starting with
5316 * IPython/iplib.py (complete): fixed bug where paths starting with
5311 '/' would be completed as magic names.
5317 '/' would be completed as magic names.
5312
5318
5313 2002-05-04 Fernando Perez <fperez@colorado.edu>
5319 2002-05-04 Fernando Perez <fperez@colorado.edu>
5314
5320
5315 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5321 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5316 allow running full programs under the profiler's control.
5322 allow running full programs under the profiler's control.
5317
5323
5318 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5324 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5319 mode to report exceptions verbosely but without formatting
5325 mode to report exceptions verbosely but without formatting
5320 variables. This addresses the issue of ipython 'freezing' (it's
5326 variables. This addresses the issue of ipython 'freezing' (it's
5321 not frozen, but caught in an expensive formatting loop) when huge
5327 not frozen, but caught in an expensive formatting loop) when huge
5322 variables are in the context of an exception.
5328 variables are in the context of an exception.
5323 (VerboseTB.text): Added '--->' markers at line where exception was
5329 (VerboseTB.text): Added '--->' markers at line where exception was
5324 triggered. Much clearer to read, especially in NoColor modes.
5330 triggered. Much clearer to read, especially in NoColor modes.
5325
5331
5326 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5332 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5327 implemented in reverse when changing to the new parse_options().
5333 implemented in reverse when changing to the new parse_options().
5328
5334
5329 2002-05-03 Fernando Perez <fperez@colorado.edu>
5335 2002-05-03 Fernando Perez <fperez@colorado.edu>
5330
5336
5331 * IPython/Magic.py (Magic.parse_options): new function so that
5337 * IPython/Magic.py (Magic.parse_options): new function so that
5332 magics can parse options easier.
5338 magics can parse options easier.
5333 (Magic.magic_prun): new function similar to profile.run(),
5339 (Magic.magic_prun): new function similar to profile.run(),
5334 suggested by Chris Hart.
5340 suggested by Chris Hart.
5335 (Magic.magic_cd): fixed behavior so that it only changes if
5341 (Magic.magic_cd): fixed behavior so that it only changes if
5336 directory actually is in history.
5342 directory actually is in history.
5337
5343
5338 * IPython/usage.py (__doc__): added information about potential
5344 * IPython/usage.py (__doc__): added information about potential
5339 slowness of Verbose exception mode when there are huge data
5345 slowness of Verbose exception mode when there are huge data
5340 structures to be formatted (thanks to Archie Paulson).
5346 structures to be formatted (thanks to Archie Paulson).
5341
5347
5342 * IPython/ipmaker.py (make_IPython): Changed default logging
5348 * IPython/ipmaker.py (make_IPython): Changed default logging
5343 (when simply called with -log) to use curr_dir/ipython.log in
5349 (when simply called with -log) to use curr_dir/ipython.log in
5344 rotate mode. Fixed crash which was occuring with -log before
5350 rotate mode. Fixed crash which was occuring with -log before
5345 (thanks to Jim Boyle).
5351 (thanks to Jim Boyle).
5346
5352
5347 2002-05-01 Fernando Perez <fperez@colorado.edu>
5353 2002-05-01 Fernando Perez <fperez@colorado.edu>
5348
5354
5349 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5355 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5350 was nasty -- though somewhat of a corner case).
5356 was nasty -- though somewhat of a corner case).
5351
5357
5352 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5358 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5353 text (was a bug).
5359 text (was a bug).
5354
5360
5355 2002-04-30 Fernando Perez <fperez@colorado.edu>
5361 2002-04-30 Fernando Perez <fperez@colorado.edu>
5356
5362
5357 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5363 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5358 a print after ^D or ^C from the user so that the In[] prompt
5364 a print after ^D or ^C from the user so that the In[] prompt
5359 doesn't over-run the gnuplot one.
5365 doesn't over-run the gnuplot one.
5360
5366
5361 2002-04-29 Fernando Perez <fperez@colorado.edu>
5367 2002-04-29 Fernando Perez <fperez@colorado.edu>
5362
5368
5363 * Released 0.2.10
5369 * Released 0.2.10
5364
5370
5365 * IPython/__release__.py (version): get date dynamically.
5371 * IPython/__release__.py (version): get date dynamically.
5366
5372
5367 * Misc. documentation updates thanks to Arnd's comments. Also ran
5373 * Misc. documentation updates thanks to Arnd's comments. Also ran
5368 a full spellcheck on the manual (hadn't been done in a while).
5374 a full spellcheck on the manual (hadn't been done in a while).
5369
5375
5370 2002-04-27 Fernando Perez <fperez@colorado.edu>
5376 2002-04-27 Fernando Perez <fperez@colorado.edu>
5371
5377
5372 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5378 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5373 starting a log in mid-session would reset the input history list.
5379 starting a log in mid-session would reset the input history list.
5374
5380
5375 2002-04-26 Fernando Perez <fperez@colorado.edu>
5381 2002-04-26 Fernando Perez <fperez@colorado.edu>
5376
5382
5377 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5383 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5378 all files were being included in an update. Now anything in
5384 all files were being included in an update. Now anything in
5379 UserConfig that matches [A-Za-z]*.py will go (this excludes
5385 UserConfig that matches [A-Za-z]*.py will go (this excludes
5380 __init__.py)
5386 __init__.py)
5381
5387
5382 2002-04-25 Fernando Perez <fperez@colorado.edu>
5388 2002-04-25 Fernando Perez <fperez@colorado.edu>
5383
5389
5384 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5390 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5385 to __builtins__ so that any form of embedded or imported code can
5391 to __builtins__ so that any form of embedded or imported code can
5386 test for being inside IPython.
5392 test for being inside IPython.
5387
5393
5388 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5394 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5389 changed to GnuplotMagic because it's now an importable module,
5395 changed to GnuplotMagic because it's now an importable module,
5390 this makes the name follow that of the standard Gnuplot module.
5396 this makes the name follow that of the standard Gnuplot module.
5391 GnuplotMagic can now be loaded at any time in mid-session.
5397 GnuplotMagic can now be loaded at any time in mid-session.
5392
5398
5393 2002-04-24 Fernando Perez <fperez@colorado.edu>
5399 2002-04-24 Fernando Perez <fperez@colorado.edu>
5394
5400
5395 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5401 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5396 the globals (IPython has its own namespace) and the
5402 the globals (IPython has its own namespace) and the
5397 PhysicalQuantity stuff is much better anyway.
5403 PhysicalQuantity stuff is much better anyway.
5398
5404
5399 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5405 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5400 embedding example to standard user directory for
5406 embedding example to standard user directory for
5401 distribution. Also put it in the manual.
5407 distribution. Also put it in the manual.
5402
5408
5403 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5409 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5404 instance as first argument (so it doesn't rely on some obscure
5410 instance as first argument (so it doesn't rely on some obscure
5405 hidden global).
5411 hidden global).
5406
5412
5407 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5413 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5408 delimiters. While it prevents ().TAB from working, it allows
5414 delimiters. While it prevents ().TAB from working, it allows
5409 completions in open (... expressions. This is by far a more common
5415 completions in open (... expressions. This is by far a more common
5410 case.
5416 case.
5411
5417
5412 2002-04-23 Fernando Perez <fperez@colorado.edu>
5418 2002-04-23 Fernando Perez <fperez@colorado.edu>
5413
5419
5414 * IPython/Extensions/InterpreterPasteInput.py: new
5420 * IPython/Extensions/InterpreterPasteInput.py: new
5415 syntax-processing module for pasting lines with >>> or ... at the
5421 syntax-processing module for pasting lines with >>> or ... at the
5416 start.
5422 start.
5417
5423
5418 * IPython/Extensions/PhysicalQ_Interactive.py
5424 * IPython/Extensions/PhysicalQ_Interactive.py
5419 (PhysicalQuantityInteractive.__int__): fixed to work with either
5425 (PhysicalQuantityInteractive.__int__): fixed to work with either
5420 Numeric or math.
5426 Numeric or math.
5421
5427
5422 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5428 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5423 provided profiles. Now we have:
5429 provided profiles. Now we have:
5424 -math -> math module as * and cmath with its own namespace.
5430 -math -> math module as * and cmath with its own namespace.
5425 -numeric -> Numeric as *, plus gnuplot & grace
5431 -numeric -> Numeric as *, plus gnuplot & grace
5426 -physics -> same as before
5432 -physics -> same as before
5427
5433
5428 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5434 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5429 user-defined magics wouldn't be found by @magic if they were
5435 user-defined magics wouldn't be found by @magic if they were
5430 defined as class methods. Also cleaned up the namespace search
5436 defined as class methods. Also cleaned up the namespace search
5431 logic and the string building (to use %s instead of many repeated
5437 logic and the string building (to use %s instead of many repeated
5432 string adds).
5438 string adds).
5433
5439
5434 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5440 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5435 of user-defined magics to operate with class methods (cleaner, in
5441 of user-defined magics to operate with class methods (cleaner, in
5436 line with the gnuplot code).
5442 line with the gnuplot code).
5437
5443
5438 2002-04-22 Fernando Perez <fperez@colorado.edu>
5444 2002-04-22 Fernando Perez <fperez@colorado.edu>
5439
5445
5440 * setup.py: updated dependency list so that manual is updated when
5446 * setup.py: updated dependency list so that manual is updated when
5441 all included files change.
5447 all included files change.
5442
5448
5443 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5449 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5444 the delimiter removal option (the fix is ugly right now).
5450 the delimiter removal option (the fix is ugly right now).
5445
5451
5446 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5452 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5447 all of the math profile (quicker loading, no conflict between
5453 all of the math profile (quicker loading, no conflict between
5448 g-9.8 and g-gnuplot).
5454 g-9.8 and g-gnuplot).
5449
5455
5450 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5456 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5451 name of post-mortem files to IPython_crash_report.txt.
5457 name of post-mortem files to IPython_crash_report.txt.
5452
5458
5453 * Cleanup/update of the docs. Added all the new readline info and
5459 * Cleanup/update of the docs. Added all the new readline info and
5454 formatted all lists as 'real lists'.
5460 formatted all lists as 'real lists'.
5455
5461
5456 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5462 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5457 tab-completion options, since the full readline parse_and_bind is
5463 tab-completion options, since the full readline parse_and_bind is
5458 now accessible.
5464 now accessible.
5459
5465
5460 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5466 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5461 handling of readline options. Now users can specify any string to
5467 handling of readline options. Now users can specify any string to
5462 be passed to parse_and_bind(), as well as the delimiters to be
5468 be passed to parse_and_bind(), as well as the delimiters to be
5463 removed.
5469 removed.
5464 (InteractiveShell.__init__): Added __name__ to the global
5470 (InteractiveShell.__init__): Added __name__ to the global
5465 namespace so that things like Itpl which rely on its existence
5471 namespace so that things like Itpl which rely on its existence
5466 don't crash.
5472 don't crash.
5467 (InteractiveShell._prefilter): Defined the default with a _ so
5473 (InteractiveShell._prefilter): Defined the default with a _ so
5468 that prefilter() is easier to override, while the default one
5474 that prefilter() is easier to override, while the default one
5469 remains available.
5475 remains available.
5470
5476
5471 2002-04-18 Fernando Perez <fperez@colorado.edu>
5477 2002-04-18 Fernando Perez <fperez@colorado.edu>
5472
5478
5473 * Added information about pdb in the docs.
5479 * Added information about pdb in the docs.
5474
5480
5475 2002-04-17 Fernando Perez <fperez@colorado.edu>
5481 2002-04-17 Fernando Perez <fperez@colorado.edu>
5476
5482
5477 * IPython/ipmaker.py (make_IPython): added rc_override option to
5483 * IPython/ipmaker.py (make_IPython): added rc_override option to
5478 allow passing config options at creation time which may override
5484 allow passing config options at creation time which may override
5479 anything set in the config files or command line. This is
5485 anything set in the config files or command line. This is
5480 particularly useful for configuring embedded instances.
5486 particularly useful for configuring embedded instances.
5481
5487
5482 2002-04-15 Fernando Perez <fperez@colorado.edu>
5488 2002-04-15 Fernando Perez <fperez@colorado.edu>
5483
5489
5484 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5490 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5485 crash embedded instances because of the input cache falling out of
5491 crash embedded instances because of the input cache falling out of
5486 sync with the output counter.
5492 sync with the output counter.
5487
5493
5488 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5494 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5489 mode which calls pdb after an uncaught exception in IPython itself.
5495 mode which calls pdb after an uncaught exception in IPython itself.
5490
5496
5491 2002-04-14 Fernando Perez <fperez@colorado.edu>
5497 2002-04-14 Fernando Perez <fperez@colorado.edu>
5492
5498
5493 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5499 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5494 readline, fix it back after each call.
5500 readline, fix it back after each call.
5495
5501
5496 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5502 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5497 method to force all access via __call__(), which guarantees that
5503 method to force all access via __call__(), which guarantees that
5498 traceback references are properly deleted.
5504 traceback references are properly deleted.
5499
5505
5500 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5506 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5501 improve printing when pprint is in use.
5507 improve printing when pprint is in use.
5502
5508
5503 2002-04-13 Fernando Perez <fperez@colorado.edu>
5509 2002-04-13 Fernando Perez <fperez@colorado.edu>
5504
5510
5505 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5511 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5506 exceptions aren't caught anymore. If the user triggers one, he
5512 exceptions aren't caught anymore. If the user triggers one, he
5507 should know why he's doing it and it should go all the way up,
5513 should know why he's doing it and it should go all the way up,
5508 just like any other exception. So now @abort will fully kill the
5514 just like any other exception. So now @abort will fully kill the
5509 embedded interpreter and the embedding code (unless that happens
5515 embedded interpreter and the embedding code (unless that happens
5510 to catch SystemExit).
5516 to catch SystemExit).
5511
5517
5512 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5518 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5513 and a debugger() method to invoke the interactive pdb debugger
5519 and a debugger() method to invoke the interactive pdb debugger
5514 after printing exception information. Also added the corresponding
5520 after printing exception information. Also added the corresponding
5515 -pdb option and @pdb magic to control this feature, and updated
5521 -pdb option and @pdb magic to control this feature, and updated
5516 the docs. After a suggestion from Christopher Hart
5522 the docs. After a suggestion from Christopher Hart
5517 (hart-AT-caltech.edu).
5523 (hart-AT-caltech.edu).
5518
5524
5519 2002-04-12 Fernando Perez <fperez@colorado.edu>
5525 2002-04-12 Fernando Perez <fperez@colorado.edu>
5520
5526
5521 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5527 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5522 the exception handlers defined by the user (not the CrashHandler)
5528 the exception handlers defined by the user (not the CrashHandler)
5523 so that user exceptions don't trigger an ipython bug report.
5529 so that user exceptions don't trigger an ipython bug report.
5524
5530
5525 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5531 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5526 configurable (it should have always been so).
5532 configurable (it should have always been so).
5527
5533
5528 2002-03-26 Fernando Perez <fperez@colorado.edu>
5534 2002-03-26 Fernando Perez <fperez@colorado.edu>
5529
5535
5530 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5536 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5531 and there to fix embedding namespace issues. This should all be
5537 and there to fix embedding namespace issues. This should all be
5532 done in a more elegant way.
5538 done in a more elegant way.
5533
5539
5534 2002-03-25 Fernando Perez <fperez@colorado.edu>
5540 2002-03-25 Fernando Perez <fperez@colorado.edu>
5535
5541
5536 * IPython/genutils.py (get_home_dir): Try to make it work under
5542 * IPython/genutils.py (get_home_dir): Try to make it work under
5537 win9x also.
5543 win9x also.
5538
5544
5539 2002-03-20 Fernando Perez <fperez@colorado.edu>
5545 2002-03-20 Fernando Perez <fperez@colorado.edu>
5540
5546
5541 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5547 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5542 sys.displayhook untouched upon __init__.
5548 sys.displayhook untouched upon __init__.
5543
5549
5544 2002-03-19 Fernando Perez <fperez@colorado.edu>
5550 2002-03-19 Fernando Perez <fperez@colorado.edu>
5545
5551
5546 * Released 0.2.9 (for embedding bug, basically).
5552 * Released 0.2.9 (for embedding bug, basically).
5547
5553
5548 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5554 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5549 exceptions so that enclosing shell's state can be restored.
5555 exceptions so that enclosing shell's state can be restored.
5550
5556
5551 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5557 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5552 naming conventions in the .ipython/ dir.
5558 naming conventions in the .ipython/ dir.
5553
5559
5554 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5560 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5555 from delimiters list so filenames with - in them get expanded.
5561 from delimiters list so filenames with - in them get expanded.
5556
5562
5557 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5563 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5558 sys.displayhook not being properly restored after an embedded call.
5564 sys.displayhook not being properly restored after an embedded call.
5559
5565
5560 2002-03-18 Fernando Perez <fperez@colorado.edu>
5566 2002-03-18 Fernando Perez <fperez@colorado.edu>
5561
5567
5562 * Released 0.2.8
5568 * Released 0.2.8
5563
5569
5564 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5570 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5565 some files weren't being included in a -upgrade.
5571 some files weren't being included in a -upgrade.
5566 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5572 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5567 on' so that the first tab completes.
5573 on' so that the first tab completes.
5568 (InteractiveShell.handle_magic): fixed bug with spaces around
5574 (InteractiveShell.handle_magic): fixed bug with spaces around
5569 quotes breaking many magic commands.
5575 quotes breaking many magic commands.
5570
5576
5571 * setup.py: added note about ignoring the syntax error messages at
5577 * setup.py: added note about ignoring the syntax error messages at
5572 installation.
5578 installation.
5573
5579
5574 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5580 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5575 streamlining the gnuplot interface, now there's only one magic @gp.
5581 streamlining the gnuplot interface, now there's only one magic @gp.
5576
5582
5577 2002-03-17 Fernando Perez <fperez@colorado.edu>
5583 2002-03-17 Fernando Perez <fperez@colorado.edu>
5578
5584
5579 * IPython/UserConfig/magic_gnuplot.py: new name for the
5585 * IPython/UserConfig/magic_gnuplot.py: new name for the
5580 example-magic_pm.py file. Much enhanced system, now with a shell
5586 example-magic_pm.py file. Much enhanced system, now with a shell
5581 for communicating directly with gnuplot, one command at a time.
5587 for communicating directly with gnuplot, one command at a time.
5582
5588
5583 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5589 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5584 setting __name__=='__main__'.
5590 setting __name__=='__main__'.
5585
5591
5586 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5592 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5587 mini-shell for accessing gnuplot from inside ipython. Should
5593 mini-shell for accessing gnuplot from inside ipython. Should
5588 extend it later for grace access too. Inspired by Arnd's
5594 extend it later for grace access too. Inspired by Arnd's
5589 suggestion.
5595 suggestion.
5590
5596
5591 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5597 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5592 calling magic functions with () in their arguments. Thanks to Arnd
5598 calling magic functions with () in their arguments. Thanks to Arnd
5593 Baecker for pointing this to me.
5599 Baecker for pointing this to me.
5594
5600
5595 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5601 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5596 infinitely for integer or complex arrays (only worked with floats).
5602 infinitely for integer or complex arrays (only worked with floats).
5597
5603
5598 2002-03-16 Fernando Perez <fperez@colorado.edu>
5604 2002-03-16 Fernando Perez <fperez@colorado.edu>
5599
5605
5600 * setup.py: Merged setup and setup_windows into a single script
5606 * setup.py: Merged setup and setup_windows into a single script
5601 which properly handles things for windows users.
5607 which properly handles things for windows users.
5602
5608
5603 2002-03-15 Fernando Perez <fperez@colorado.edu>
5609 2002-03-15 Fernando Perez <fperez@colorado.edu>
5604
5610
5605 * Big change to the manual: now the magics are all automatically
5611 * Big change to the manual: now the magics are all automatically
5606 documented. This information is generated from their docstrings
5612 documented. This information is generated from their docstrings
5607 and put in a latex file included by the manual lyx file. This way
5613 and put in a latex file included by the manual lyx file. This way
5608 we get always up to date information for the magics. The manual
5614 we get always up to date information for the magics. The manual
5609 now also has proper version information, also auto-synced.
5615 now also has proper version information, also auto-synced.
5610
5616
5611 For this to work, an undocumented --magic_docstrings option was added.
5617 For this to work, an undocumented --magic_docstrings option was added.
5612
5618
5613 2002-03-13 Fernando Perez <fperez@colorado.edu>
5619 2002-03-13 Fernando Perez <fperez@colorado.edu>
5614
5620
5615 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5621 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5616 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5622 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5617
5623
5618 2002-03-12 Fernando Perez <fperez@colorado.edu>
5624 2002-03-12 Fernando Perez <fperez@colorado.edu>
5619
5625
5620 * IPython/ultraTB.py (TermColors): changed color escapes again to
5626 * IPython/ultraTB.py (TermColors): changed color escapes again to
5621 fix the (old, reintroduced) line-wrapping bug. Basically, if
5627 fix the (old, reintroduced) line-wrapping bug. Basically, if
5622 \001..\002 aren't given in the color escapes, lines get wrapped
5628 \001..\002 aren't given in the color escapes, lines get wrapped
5623 weirdly. But giving those screws up old xterms and emacs terms. So
5629 weirdly. But giving those screws up old xterms and emacs terms. So
5624 I added some logic for emacs terms to be ok, but I can't identify old
5630 I added some logic for emacs terms to be ok, but I can't identify old
5625 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5631 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5626
5632
5627 2002-03-10 Fernando Perez <fperez@colorado.edu>
5633 2002-03-10 Fernando Perez <fperez@colorado.edu>
5628
5634
5629 * IPython/usage.py (__doc__): Various documentation cleanups and
5635 * IPython/usage.py (__doc__): Various documentation cleanups and
5630 updates, both in usage docstrings and in the manual.
5636 updates, both in usage docstrings and in the manual.
5631
5637
5632 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5638 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5633 handling of caching. Set minimum acceptabe value for having a
5639 handling of caching. Set minimum acceptabe value for having a
5634 cache at 20 values.
5640 cache at 20 values.
5635
5641
5636 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5642 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5637 install_first_time function to a method, renamed it and added an
5643 install_first_time function to a method, renamed it and added an
5638 'upgrade' mode. Now people can update their config directory with
5644 'upgrade' mode. Now people can update their config directory with
5639 a simple command line switch (-upgrade, also new).
5645 a simple command line switch (-upgrade, also new).
5640
5646
5641 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
5647 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
5642 @file (convenient for automagic users under Python >= 2.2).
5648 @file (convenient for automagic users under Python >= 2.2).
5643 Removed @files (it seemed more like a plural than an abbrev. of
5649 Removed @files (it seemed more like a plural than an abbrev. of
5644 'file show').
5650 'file show').
5645
5651
5646 * IPython/iplib.py (install_first_time): Fixed crash if there were
5652 * IPython/iplib.py (install_first_time): Fixed crash if there were
5647 backup files ('~') in .ipython/ install directory.
5653 backup files ('~') in .ipython/ install directory.
5648
5654
5649 * IPython/ipmaker.py (make_IPython): fixes for new prompt
5655 * IPython/ipmaker.py (make_IPython): fixes for new prompt
5650 system. Things look fine, but these changes are fairly
5656 system. Things look fine, but these changes are fairly
5651 intrusive. Test them for a few days.
5657 intrusive. Test them for a few days.
5652
5658
5653 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
5659 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
5654 the prompts system. Now all in/out prompt strings are user
5660 the prompts system. Now all in/out prompt strings are user
5655 controllable. This is particularly useful for embedding, as one
5661 controllable. This is particularly useful for embedding, as one
5656 can tag embedded instances with particular prompts.
5662 can tag embedded instances with particular prompts.
5657
5663
5658 Also removed global use of sys.ps1/2, which now allows nested
5664 Also removed global use of sys.ps1/2, which now allows nested
5659 embeddings without any problems. Added command-line options for
5665 embeddings without any problems. Added command-line options for
5660 the prompt strings.
5666 the prompt strings.
5661
5667
5662 2002-03-08 Fernando Perez <fperez@colorado.edu>
5668 2002-03-08 Fernando Perez <fperez@colorado.edu>
5663
5669
5664 * IPython/UserConfig/example-embed-short.py (ipshell): added
5670 * IPython/UserConfig/example-embed-short.py (ipshell): added
5665 example file with the bare minimum code for embedding.
5671 example file with the bare minimum code for embedding.
5666
5672
5667 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
5673 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
5668 functionality for the embeddable shell to be activated/deactivated
5674 functionality for the embeddable shell to be activated/deactivated
5669 either globally or at each call.
5675 either globally or at each call.
5670
5676
5671 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
5677 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
5672 rewriting the prompt with '--->' for auto-inputs with proper
5678 rewriting the prompt with '--->' for auto-inputs with proper
5673 coloring. Now the previous UGLY hack in handle_auto() is gone, and
5679 coloring. Now the previous UGLY hack in handle_auto() is gone, and
5674 this is handled by the prompts class itself, as it should.
5680 this is handled by the prompts class itself, as it should.
5675
5681
5676 2002-03-05 Fernando Perez <fperez@colorado.edu>
5682 2002-03-05 Fernando Perez <fperez@colorado.edu>
5677
5683
5678 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
5684 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
5679 @logstart to avoid name clashes with the math log function.
5685 @logstart to avoid name clashes with the math log function.
5680
5686
5681 * Big updates to X/Emacs section of the manual.
5687 * Big updates to X/Emacs section of the manual.
5682
5688
5683 * Removed ipython_emacs. Milan explained to me how to pass
5689 * Removed ipython_emacs. Milan explained to me how to pass
5684 arguments to ipython through Emacs. Some day I'm going to end up
5690 arguments to ipython through Emacs. Some day I'm going to end up
5685 learning some lisp...
5691 learning some lisp...
5686
5692
5687 2002-03-04 Fernando Perez <fperez@colorado.edu>
5693 2002-03-04 Fernando Perez <fperez@colorado.edu>
5688
5694
5689 * IPython/ipython_emacs: Created script to be used as the
5695 * IPython/ipython_emacs: Created script to be used as the
5690 py-python-command Emacs variable so we can pass IPython
5696 py-python-command Emacs variable so we can pass IPython
5691 parameters. I can't figure out how to tell Emacs directly to pass
5697 parameters. I can't figure out how to tell Emacs directly to pass
5692 parameters to IPython, so a dummy shell script will do it.
5698 parameters to IPython, so a dummy shell script will do it.
5693
5699
5694 Other enhancements made for things to work better under Emacs'
5700 Other enhancements made for things to work better under Emacs'
5695 various types of terminals. Many thanks to Milan Zamazal
5701 various types of terminals. Many thanks to Milan Zamazal
5696 <pdm-AT-zamazal.org> for all the suggestions and pointers.
5702 <pdm-AT-zamazal.org> for all the suggestions and pointers.
5697
5703
5698 2002-03-01 Fernando Perez <fperez@colorado.edu>
5704 2002-03-01 Fernando Perez <fperez@colorado.edu>
5699
5705
5700 * IPython/ipmaker.py (make_IPython): added a --readline! option so
5706 * IPython/ipmaker.py (make_IPython): added a --readline! option so
5701 that loading of readline is now optional. This gives better
5707 that loading of readline is now optional. This gives better
5702 control to emacs users.
5708 control to emacs users.
5703
5709
5704 * IPython/ultraTB.py (__date__): Modified color escape sequences
5710 * IPython/ultraTB.py (__date__): Modified color escape sequences
5705 and now things work fine under xterm and in Emacs' term buffers
5711 and now things work fine under xterm and in Emacs' term buffers
5706 (though not shell ones). Well, in emacs you get colors, but all
5712 (though not shell ones). Well, in emacs you get colors, but all
5707 seem to be 'light' colors (no difference between dark and light
5713 seem to be 'light' colors (no difference between dark and light
5708 ones). But the garbage chars are gone, and also in xterms. It
5714 ones). But the garbage chars are gone, and also in xterms. It
5709 seems that now I'm using 'cleaner' ansi sequences.
5715 seems that now I'm using 'cleaner' ansi sequences.
5710
5716
5711 2002-02-21 Fernando Perez <fperez@colorado.edu>
5717 2002-02-21 Fernando Perez <fperez@colorado.edu>
5712
5718
5713 * Released 0.2.7 (mainly to publish the scoping fix).
5719 * Released 0.2.7 (mainly to publish the scoping fix).
5714
5720
5715 * IPython/Logger.py (Logger.logstate): added. A corresponding
5721 * IPython/Logger.py (Logger.logstate): added. A corresponding
5716 @logstate magic was created.
5722 @logstate magic was created.
5717
5723
5718 * IPython/Magic.py: fixed nested scoping problem under Python
5724 * IPython/Magic.py: fixed nested scoping problem under Python
5719 2.1.x (automagic wasn't working).
5725 2.1.x (automagic wasn't working).
5720
5726
5721 2002-02-20 Fernando Perez <fperez@colorado.edu>
5727 2002-02-20 Fernando Perez <fperez@colorado.edu>
5722
5728
5723 * Released 0.2.6.
5729 * Released 0.2.6.
5724
5730
5725 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
5731 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
5726 option so that logs can come out without any headers at all.
5732 option so that logs can come out without any headers at all.
5727
5733
5728 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
5734 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
5729 SciPy.
5735 SciPy.
5730
5736
5731 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
5737 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
5732 that embedded IPython calls don't require vars() to be explicitly
5738 that embedded IPython calls don't require vars() to be explicitly
5733 passed. Now they are extracted from the caller's frame (code
5739 passed. Now they are extracted from the caller's frame (code
5734 snatched from Eric Jones' weave). Added better documentation to
5740 snatched from Eric Jones' weave). Added better documentation to
5735 the section on embedding and the example file.
5741 the section on embedding and the example file.
5736
5742
5737 * IPython/genutils.py (page): Changed so that under emacs, it just
5743 * IPython/genutils.py (page): Changed so that under emacs, it just
5738 prints the string. You can then page up and down in the emacs
5744 prints the string. You can then page up and down in the emacs
5739 buffer itself. This is how the builtin help() works.
5745 buffer itself. This is how the builtin help() works.
5740
5746
5741 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
5747 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
5742 macro scoping: macros need to be executed in the user's namespace
5748 macro scoping: macros need to be executed in the user's namespace
5743 to work as if they had been typed by the user.
5749 to work as if they had been typed by the user.
5744
5750
5745 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
5751 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
5746 execute automatically (no need to type 'exec...'). They then
5752 execute automatically (no need to type 'exec...'). They then
5747 behave like 'true macros'. The printing system was also modified
5753 behave like 'true macros'. The printing system was also modified
5748 for this to work.
5754 for this to work.
5749
5755
5750 2002-02-19 Fernando Perez <fperez@colorado.edu>
5756 2002-02-19 Fernando Perez <fperez@colorado.edu>
5751
5757
5752 * IPython/genutils.py (page_file): new function for paging files
5758 * IPython/genutils.py (page_file): new function for paging files
5753 in an OS-independent way. Also necessary for file viewing to work
5759 in an OS-independent way. Also necessary for file viewing to work
5754 well inside Emacs buffers.
5760 well inside Emacs buffers.
5755 (page): Added checks for being in an emacs buffer.
5761 (page): Added checks for being in an emacs buffer.
5756 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
5762 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
5757 same bug in iplib.
5763 same bug in iplib.
5758
5764
5759 2002-02-18 Fernando Perez <fperez@colorado.edu>
5765 2002-02-18 Fernando Perez <fperez@colorado.edu>
5760
5766
5761 * IPython/iplib.py (InteractiveShell.init_readline): modified use
5767 * IPython/iplib.py (InteractiveShell.init_readline): modified use
5762 of readline so that IPython can work inside an Emacs buffer.
5768 of readline so that IPython can work inside an Emacs buffer.
5763
5769
5764 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
5770 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
5765 method signatures (they weren't really bugs, but it looks cleaner
5771 method signatures (they weren't really bugs, but it looks cleaner
5766 and keeps PyChecker happy).
5772 and keeps PyChecker happy).
5767
5773
5768 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
5774 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
5769 for implementing various user-defined hooks. Currently only
5775 for implementing various user-defined hooks. Currently only
5770 display is done.
5776 display is done.
5771
5777
5772 * IPython/Prompts.py (CachedOutput._display): changed display
5778 * IPython/Prompts.py (CachedOutput._display): changed display
5773 functions so that they can be dynamically changed by users easily.
5779 functions so that they can be dynamically changed by users easily.
5774
5780
5775 * IPython/Extensions/numeric_formats.py (num_display): added an
5781 * IPython/Extensions/numeric_formats.py (num_display): added an
5776 extension for printing NumPy arrays in flexible manners. It
5782 extension for printing NumPy arrays in flexible manners. It
5777 doesn't do anything yet, but all the structure is in
5783 doesn't do anything yet, but all the structure is in
5778 place. Ultimately the plan is to implement output format control
5784 place. Ultimately the plan is to implement output format control
5779 like in Octave.
5785 like in Octave.
5780
5786
5781 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
5787 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
5782 methods are found at run-time by all the automatic machinery.
5788 methods are found at run-time by all the automatic machinery.
5783
5789
5784 2002-02-17 Fernando Perez <fperez@colorado.edu>
5790 2002-02-17 Fernando Perez <fperez@colorado.edu>
5785
5791
5786 * setup_Windows.py (make_shortcut): documented. Cleaned up the
5792 * setup_Windows.py (make_shortcut): documented. Cleaned up the
5787 whole file a little.
5793 whole file a little.
5788
5794
5789 * ToDo: closed this document. Now there's a new_design.lyx
5795 * ToDo: closed this document. Now there's a new_design.lyx
5790 document for all new ideas. Added making a pdf of it for the
5796 document for all new ideas. Added making a pdf of it for the
5791 end-user distro.
5797 end-user distro.
5792
5798
5793 * IPython/Logger.py (Logger.switch_log): Created this to replace
5799 * IPython/Logger.py (Logger.switch_log): Created this to replace
5794 logon() and logoff(). It also fixes a nasty crash reported by
5800 logon() and logoff(). It also fixes a nasty crash reported by
5795 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
5801 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
5796
5802
5797 * IPython/iplib.py (complete): got auto-completion to work with
5803 * IPython/iplib.py (complete): got auto-completion to work with
5798 automagic (I had wanted this for a long time).
5804 automagic (I had wanted this for a long time).
5799
5805
5800 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
5806 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
5801 to @file, since file() is now a builtin and clashes with automagic
5807 to @file, since file() is now a builtin and clashes with automagic
5802 for @file.
5808 for @file.
5803
5809
5804 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
5810 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
5805 of this was previously in iplib, which had grown to more than 2000
5811 of this was previously in iplib, which had grown to more than 2000
5806 lines, way too long. No new functionality, but it makes managing
5812 lines, way too long. No new functionality, but it makes managing
5807 the code a bit easier.
5813 the code a bit easier.
5808
5814
5809 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
5815 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
5810 information to crash reports.
5816 information to crash reports.
5811
5817
5812 2002-02-12 Fernando Perez <fperez@colorado.edu>
5818 2002-02-12 Fernando Perez <fperez@colorado.edu>
5813
5819
5814 * Released 0.2.5.
5820 * Released 0.2.5.
5815
5821
5816 2002-02-11 Fernando Perez <fperez@colorado.edu>
5822 2002-02-11 Fernando Perez <fperez@colorado.edu>
5817
5823
5818 * Wrote a relatively complete Windows installer. It puts
5824 * Wrote a relatively complete Windows installer. It puts
5819 everything in place, creates Start Menu entries and fixes the
5825 everything in place, creates Start Menu entries and fixes the
5820 color issues. Nothing fancy, but it works.
5826 color issues. Nothing fancy, but it works.
5821
5827
5822 2002-02-10 Fernando Perez <fperez@colorado.edu>
5828 2002-02-10 Fernando Perez <fperez@colorado.edu>
5823
5829
5824 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
5830 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
5825 os.path.expanduser() call so that we can type @run ~/myfile.py and
5831 os.path.expanduser() call so that we can type @run ~/myfile.py and
5826 have thigs work as expected.
5832 have thigs work as expected.
5827
5833
5828 * IPython/genutils.py (page): fixed exception handling so things
5834 * IPython/genutils.py (page): fixed exception handling so things
5829 work both in Unix and Windows correctly. Quitting a pager triggers
5835 work both in Unix and Windows correctly. Quitting a pager triggers
5830 an IOError/broken pipe in Unix, and in windows not finding a pager
5836 an IOError/broken pipe in Unix, and in windows not finding a pager
5831 is also an IOError, so I had to actually look at the return value
5837 is also an IOError, so I had to actually look at the return value
5832 of the exception, not just the exception itself. Should be ok now.
5838 of the exception, not just the exception itself. Should be ok now.
5833
5839
5834 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
5840 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
5835 modified to allow case-insensitive color scheme changes.
5841 modified to allow case-insensitive color scheme changes.
5836
5842
5837 2002-02-09 Fernando Perez <fperez@colorado.edu>
5843 2002-02-09 Fernando Perez <fperez@colorado.edu>
5838
5844
5839 * IPython/genutils.py (native_line_ends): new function to leave
5845 * IPython/genutils.py (native_line_ends): new function to leave
5840 user config files with os-native line-endings.
5846 user config files with os-native line-endings.
5841
5847
5842 * README and manual updates.
5848 * README and manual updates.
5843
5849
5844 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
5850 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
5845 instead of StringType to catch Unicode strings.
5851 instead of StringType to catch Unicode strings.
5846
5852
5847 * IPython/genutils.py (filefind): fixed bug for paths with
5853 * IPython/genutils.py (filefind): fixed bug for paths with
5848 embedded spaces (very common in Windows).
5854 embedded spaces (very common in Windows).
5849
5855
5850 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
5856 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
5851 files under Windows, so that they get automatically associated
5857 files under Windows, so that they get automatically associated
5852 with a text editor. Windows makes it a pain to handle
5858 with a text editor. Windows makes it a pain to handle
5853 extension-less files.
5859 extension-less files.
5854
5860
5855 * IPython/iplib.py (InteractiveShell.init_readline): Made the
5861 * IPython/iplib.py (InteractiveShell.init_readline): Made the
5856 warning about readline only occur for Posix. In Windows there's no
5862 warning about readline only occur for Posix. In Windows there's no
5857 way to get readline, so why bother with the warning.
5863 way to get readline, so why bother with the warning.
5858
5864
5859 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
5865 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
5860 for __str__ instead of dir(self), since dir() changed in 2.2.
5866 for __str__ instead of dir(self), since dir() changed in 2.2.
5861
5867
5862 * Ported to Windows! Tested on XP, I suspect it should work fine
5868 * Ported to Windows! Tested on XP, I suspect it should work fine
5863 on NT/2000, but I don't think it will work on 98 et al. That
5869 on NT/2000, but I don't think it will work on 98 et al. That
5864 series of Windows is such a piece of junk anyway that I won't try
5870 series of Windows is such a piece of junk anyway that I won't try
5865 porting it there. The XP port was straightforward, showed a few
5871 porting it there. The XP port was straightforward, showed a few
5866 bugs here and there (fixed all), in particular some string
5872 bugs here and there (fixed all), in particular some string
5867 handling stuff which required considering Unicode strings (which
5873 handling stuff which required considering Unicode strings (which
5868 Windows uses). This is good, but hasn't been too tested :) No
5874 Windows uses). This is good, but hasn't been too tested :) No
5869 fancy installer yet, I'll put a note in the manual so people at
5875 fancy installer yet, I'll put a note in the manual so people at
5870 least make manually a shortcut.
5876 least make manually a shortcut.
5871
5877
5872 * IPython/iplib.py (Magic.magic_colors): Unified the color options
5878 * IPython/iplib.py (Magic.magic_colors): Unified the color options
5873 into a single one, "colors". This now controls both prompt and
5879 into a single one, "colors". This now controls both prompt and
5874 exception color schemes, and can be changed both at startup
5880 exception color schemes, and can be changed both at startup
5875 (either via command-line switches or via ipythonrc files) and at
5881 (either via command-line switches or via ipythonrc files) and at
5876 runtime, with @colors.
5882 runtime, with @colors.
5877 (Magic.magic_run): renamed @prun to @run and removed the old
5883 (Magic.magic_run): renamed @prun to @run and removed the old
5878 @run. The two were too similar to warrant keeping both.
5884 @run. The two were too similar to warrant keeping both.
5879
5885
5880 2002-02-03 Fernando Perez <fperez@colorado.edu>
5886 2002-02-03 Fernando Perez <fperez@colorado.edu>
5881
5887
5882 * IPython/iplib.py (install_first_time): Added comment on how to
5888 * IPython/iplib.py (install_first_time): Added comment on how to
5883 configure the color options for first-time users. Put a <return>
5889 configure the color options for first-time users. Put a <return>
5884 request at the end so that small-terminal users get a chance to
5890 request at the end so that small-terminal users get a chance to
5885 read the startup info.
5891 read the startup info.
5886
5892
5887 2002-01-23 Fernando Perez <fperez@colorado.edu>
5893 2002-01-23 Fernando Perez <fperez@colorado.edu>
5888
5894
5889 * IPython/iplib.py (CachedOutput.update): Changed output memory
5895 * IPython/iplib.py (CachedOutput.update): Changed output memory
5890 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
5896 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
5891 input history we still use _i. Did this b/c these variable are
5897 input history we still use _i. Did this b/c these variable are
5892 very commonly used in interactive work, so the less we need to
5898 very commonly used in interactive work, so the less we need to
5893 type the better off we are.
5899 type the better off we are.
5894 (Magic.magic_prun): updated @prun to better handle the namespaces
5900 (Magic.magic_prun): updated @prun to better handle the namespaces
5895 the file will run in, including a fix for __name__ not being set
5901 the file will run in, including a fix for __name__ not being set
5896 before.
5902 before.
5897
5903
5898 2002-01-20 Fernando Perez <fperez@colorado.edu>
5904 2002-01-20 Fernando Perez <fperez@colorado.edu>
5899
5905
5900 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
5906 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
5901 extra garbage for Python 2.2. Need to look more carefully into
5907 extra garbage for Python 2.2. Need to look more carefully into
5902 this later.
5908 this later.
5903
5909
5904 2002-01-19 Fernando Perez <fperez@colorado.edu>
5910 2002-01-19 Fernando Perez <fperez@colorado.edu>
5905
5911
5906 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
5912 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
5907 display SyntaxError exceptions properly formatted when they occur
5913 display SyntaxError exceptions properly formatted when they occur
5908 (they can be triggered by imported code).
5914 (they can be triggered by imported code).
5909
5915
5910 2002-01-18 Fernando Perez <fperez@colorado.edu>
5916 2002-01-18 Fernando Perez <fperez@colorado.edu>
5911
5917
5912 * IPython/iplib.py (InteractiveShell.safe_execfile): now
5918 * IPython/iplib.py (InteractiveShell.safe_execfile): now
5913 SyntaxError exceptions are reported nicely formatted, instead of
5919 SyntaxError exceptions are reported nicely formatted, instead of
5914 spitting out only offset information as before.
5920 spitting out only offset information as before.
5915 (Magic.magic_prun): Added the @prun function for executing
5921 (Magic.magic_prun): Added the @prun function for executing
5916 programs with command line args inside IPython.
5922 programs with command line args inside IPython.
5917
5923
5918 2002-01-16 Fernando Perez <fperez@colorado.edu>
5924 2002-01-16 Fernando Perez <fperez@colorado.edu>
5919
5925
5920 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
5926 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
5921 to *not* include the last item given in a range. This brings their
5927 to *not* include the last item given in a range. This brings their
5922 behavior in line with Python's slicing:
5928 behavior in line with Python's slicing:
5923 a[n1:n2] -> a[n1]...a[n2-1]
5929 a[n1:n2] -> a[n1]...a[n2-1]
5924 It may be a bit less convenient, but I prefer to stick to Python's
5930 It may be a bit less convenient, but I prefer to stick to Python's
5925 conventions *everywhere*, so users never have to wonder.
5931 conventions *everywhere*, so users never have to wonder.
5926 (Magic.magic_macro): Added @macro function to ease the creation of
5932 (Magic.magic_macro): Added @macro function to ease the creation of
5927 macros.
5933 macros.
5928
5934
5929 2002-01-05 Fernando Perez <fperez@colorado.edu>
5935 2002-01-05 Fernando Perez <fperez@colorado.edu>
5930
5936
5931 * Released 0.2.4.
5937 * Released 0.2.4.
5932
5938
5933 * IPython/iplib.py (Magic.magic_pdef):
5939 * IPython/iplib.py (Magic.magic_pdef):
5934 (InteractiveShell.safe_execfile): report magic lines and error
5940 (InteractiveShell.safe_execfile): report magic lines and error
5935 lines without line numbers so one can easily copy/paste them for
5941 lines without line numbers so one can easily copy/paste them for
5936 re-execution.
5942 re-execution.
5937
5943
5938 * Updated manual with recent changes.
5944 * Updated manual with recent changes.
5939
5945
5940 * IPython/iplib.py (Magic.magic_oinfo): added constructor
5946 * IPython/iplib.py (Magic.magic_oinfo): added constructor
5941 docstring printing when class? is called. Very handy for knowing
5947 docstring printing when class? is called. Very handy for knowing
5942 how to create class instances (as long as __init__ is well
5948 how to create class instances (as long as __init__ is well
5943 documented, of course :)
5949 documented, of course :)
5944 (Magic.magic_doc): print both class and constructor docstrings.
5950 (Magic.magic_doc): print both class and constructor docstrings.
5945 (Magic.magic_pdef): give constructor info if passed a class and
5951 (Magic.magic_pdef): give constructor info if passed a class and
5946 __call__ info for callable object instances.
5952 __call__ info for callable object instances.
5947
5953
5948 2002-01-04 Fernando Perez <fperez@colorado.edu>
5954 2002-01-04 Fernando Perez <fperez@colorado.edu>
5949
5955
5950 * Made deep_reload() off by default. It doesn't always work
5956 * Made deep_reload() off by default. It doesn't always work
5951 exactly as intended, so it's probably safer to have it off. It's
5957 exactly as intended, so it's probably safer to have it off. It's
5952 still available as dreload() anyway, so nothing is lost.
5958 still available as dreload() anyway, so nothing is lost.
5953
5959
5954 2002-01-02 Fernando Perez <fperez@colorado.edu>
5960 2002-01-02 Fernando Perez <fperez@colorado.edu>
5955
5961
5956 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
5962 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
5957 so I wanted an updated release).
5963 so I wanted an updated release).
5958
5964
5959 2001-12-27 Fernando Perez <fperez@colorado.edu>
5965 2001-12-27 Fernando Perez <fperez@colorado.edu>
5960
5966
5961 * IPython/iplib.py (InteractiveShell.interact): Added the original
5967 * IPython/iplib.py (InteractiveShell.interact): Added the original
5962 code from 'code.py' for this module in order to change the
5968 code from 'code.py' for this module in order to change the
5963 handling of a KeyboardInterrupt. This was necessary b/c otherwise
5969 handling of a KeyboardInterrupt. This was necessary b/c otherwise
5964 the history cache would break when the user hit Ctrl-C, and
5970 the history cache would break when the user hit Ctrl-C, and
5965 interact() offers no way to add any hooks to it.
5971 interact() offers no way to add any hooks to it.
5966
5972
5967 2001-12-23 Fernando Perez <fperez@colorado.edu>
5973 2001-12-23 Fernando Perez <fperez@colorado.edu>
5968
5974
5969 * setup.py: added check for 'MANIFEST' before trying to remove
5975 * setup.py: added check for 'MANIFEST' before trying to remove
5970 it. Thanks to Sean Reifschneider.
5976 it. Thanks to Sean Reifschneider.
5971
5977
5972 2001-12-22 Fernando Perez <fperez@colorado.edu>
5978 2001-12-22 Fernando Perez <fperez@colorado.edu>
5973
5979
5974 * Released 0.2.2.
5980 * Released 0.2.2.
5975
5981
5976 * Finished (reasonably) writing the manual. Later will add the
5982 * Finished (reasonably) writing the manual. Later will add the
5977 python-standard navigation stylesheets, but for the time being
5983 python-standard navigation stylesheets, but for the time being
5978 it's fairly complete. Distribution will include html and pdf
5984 it's fairly complete. Distribution will include html and pdf
5979 versions.
5985 versions.
5980
5986
5981 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
5987 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
5982 (MayaVi author).
5988 (MayaVi author).
5983
5989
5984 2001-12-21 Fernando Perez <fperez@colorado.edu>
5990 2001-12-21 Fernando Perez <fperez@colorado.edu>
5985
5991
5986 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
5992 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
5987 good public release, I think (with the manual and the distutils
5993 good public release, I think (with the manual and the distutils
5988 installer). The manual can use some work, but that can go
5994 installer). The manual can use some work, but that can go
5989 slowly. Otherwise I think it's quite nice for end users. Next
5995 slowly. Otherwise I think it's quite nice for end users. Next
5990 summer, rewrite the guts of it...
5996 summer, rewrite the guts of it...
5991
5997
5992 * Changed format of ipythonrc files to use whitespace as the
5998 * Changed format of ipythonrc files to use whitespace as the
5993 separator instead of an explicit '='. Cleaner.
5999 separator instead of an explicit '='. Cleaner.
5994
6000
5995 2001-12-20 Fernando Perez <fperez@colorado.edu>
6001 2001-12-20 Fernando Perez <fperez@colorado.edu>
5996
6002
5997 * Started a manual in LyX. For now it's just a quick merge of the
6003 * Started a manual in LyX. For now it's just a quick merge of the
5998 various internal docstrings and READMEs. Later it may grow into a
6004 various internal docstrings and READMEs. Later it may grow into a
5999 nice, full-blown manual.
6005 nice, full-blown manual.
6000
6006
6001 * Set up a distutils based installer. Installation should now be
6007 * Set up a distutils based installer. Installation should now be
6002 trivially simple for end-users.
6008 trivially simple for end-users.
6003
6009
6004 2001-12-11 Fernando Perez <fperez@colorado.edu>
6010 2001-12-11 Fernando Perez <fperez@colorado.edu>
6005
6011
6006 * Released 0.2.0. First public release, announced it at
6012 * Released 0.2.0. First public release, announced it at
6007 comp.lang.python. From now on, just bugfixes...
6013 comp.lang.python. From now on, just bugfixes...
6008
6014
6009 * Went through all the files, set copyright/license notices and
6015 * Went through all the files, set copyright/license notices and
6010 cleaned up things. Ready for release.
6016 cleaned up things. Ready for release.
6011
6017
6012 2001-12-10 Fernando Perez <fperez@colorado.edu>
6018 2001-12-10 Fernando Perez <fperez@colorado.edu>
6013
6019
6014 * Changed the first-time installer not to use tarfiles. It's more
6020 * Changed the first-time installer not to use tarfiles. It's more
6015 robust now and less unix-dependent. Also makes it easier for
6021 robust now and less unix-dependent. Also makes it easier for
6016 people to later upgrade versions.
6022 people to later upgrade versions.
6017
6023
6018 * Changed @exit to @abort to reflect the fact that it's pretty
6024 * Changed @exit to @abort to reflect the fact that it's pretty
6019 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6025 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6020 becomes significant only when IPyhton is embedded: in that case,
6026 becomes significant only when IPyhton is embedded: in that case,
6021 C-D closes IPython only, but @abort kills the enclosing program
6027 C-D closes IPython only, but @abort kills the enclosing program
6022 too (unless it had called IPython inside a try catching
6028 too (unless it had called IPython inside a try catching
6023 SystemExit).
6029 SystemExit).
6024
6030
6025 * Created Shell module which exposes the actuall IPython Shell
6031 * Created Shell module which exposes the actuall IPython Shell
6026 classes, currently the normal and the embeddable one. This at
6032 classes, currently the normal and the embeddable one. This at
6027 least offers a stable interface we won't need to change when
6033 least offers a stable interface we won't need to change when
6028 (later) the internals are rewritten. That rewrite will be confined
6034 (later) the internals are rewritten. That rewrite will be confined
6029 to iplib and ipmaker, but the Shell interface should remain as is.
6035 to iplib and ipmaker, but the Shell interface should remain as is.
6030
6036
6031 * Added embed module which offers an embeddable IPShell object,
6037 * Added embed module which offers an embeddable IPShell object,
6032 useful to fire up IPython *inside* a running program. Great for
6038 useful to fire up IPython *inside* a running program. Great for
6033 debugging or dynamical data analysis.
6039 debugging or dynamical data analysis.
6034
6040
6035 2001-12-08 Fernando Perez <fperez@colorado.edu>
6041 2001-12-08 Fernando Perez <fperez@colorado.edu>
6036
6042
6037 * Fixed small bug preventing seeing info from methods of defined
6043 * Fixed small bug preventing seeing info from methods of defined
6038 objects (incorrect namespace in _ofind()).
6044 objects (incorrect namespace in _ofind()).
6039
6045
6040 * Documentation cleanup. Moved the main usage docstrings to a
6046 * Documentation cleanup. Moved the main usage docstrings to a
6041 separate file, usage.py (cleaner to maintain, and hopefully in the
6047 separate file, usage.py (cleaner to maintain, and hopefully in the
6042 future some perlpod-like way of producing interactive, man and
6048 future some perlpod-like way of producing interactive, man and
6043 html docs out of it will be found).
6049 html docs out of it will be found).
6044
6050
6045 * Added @profile to see your profile at any time.
6051 * Added @profile to see your profile at any time.
6046
6052
6047 * Added @p as an alias for 'print'. It's especially convenient if
6053 * Added @p as an alias for 'print'. It's especially convenient if
6048 using automagic ('p x' prints x).
6054 using automagic ('p x' prints x).
6049
6055
6050 * Small cleanups and fixes after a pychecker run.
6056 * Small cleanups and fixes after a pychecker run.
6051
6057
6052 * Changed the @cd command to handle @cd - and @cd -<n> for
6058 * Changed the @cd command to handle @cd - and @cd -<n> for
6053 visiting any directory in _dh.
6059 visiting any directory in _dh.
6054
6060
6055 * Introduced _dh, a history of visited directories. @dhist prints
6061 * Introduced _dh, a history of visited directories. @dhist prints
6056 it out with numbers.
6062 it out with numbers.
6057
6063
6058 2001-12-07 Fernando Perez <fperez@colorado.edu>
6064 2001-12-07 Fernando Perez <fperez@colorado.edu>
6059
6065
6060 * Released 0.1.22
6066 * Released 0.1.22
6061
6067
6062 * Made initialization a bit more robust against invalid color
6068 * Made initialization a bit more robust against invalid color
6063 options in user input (exit, not traceback-crash).
6069 options in user input (exit, not traceback-crash).
6064
6070
6065 * Changed the bug crash reporter to write the report only in the
6071 * Changed the bug crash reporter to write the report only in the
6066 user's .ipython directory. That way IPython won't litter people's
6072 user's .ipython directory. That way IPython won't litter people's
6067 hard disks with crash files all over the place. Also print on
6073 hard disks with crash files all over the place. Also print on
6068 screen the necessary mail command.
6074 screen the necessary mail command.
6069
6075
6070 * With the new ultraTB, implemented LightBG color scheme for light
6076 * With the new ultraTB, implemented LightBG color scheme for light
6071 background terminals. A lot of people like white backgrounds, so I
6077 background terminals. A lot of people like white backgrounds, so I
6072 guess we should at least give them something readable.
6078 guess we should at least give them something readable.
6073
6079
6074 2001-12-06 Fernando Perez <fperez@colorado.edu>
6080 2001-12-06 Fernando Perez <fperez@colorado.edu>
6075
6081
6076 * Modified the structure of ultraTB. Now there's a proper class
6082 * Modified the structure of ultraTB. Now there's a proper class
6077 for tables of color schemes which allow adding schemes easily and
6083 for tables of color schemes which allow adding schemes easily and
6078 switching the active scheme without creating a new instance every
6084 switching the active scheme without creating a new instance every
6079 time (which was ridiculous). The syntax for creating new schemes
6085 time (which was ridiculous). The syntax for creating new schemes
6080 is also cleaner. I think ultraTB is finally done, with a clean
6086 is also cleaner. I think ultraTB is finally done, with a clean
6081 class structure. Names are also much cleaner (now there's proper
6087 class structure. Names are also much cleaner (now there's proper
6082 color tables, no need for every variable to also have 'color' in
6088 color tables, no need for every variable to also have 'color' in
6083 its name).
6089 its name).
6084
6090
6085 * Broke down genutils into separate files. Now genutils only
6091 * Broke down genutils into separate files. Now genutils only
6086 contains utility functions, and classes have been moved to their
6092 contains utility functions, and classes have been moved to their
6087 own files (they had enough independent functionality to warrant
6093 own files (they had enough independent functionality to warrant
6088 it): ConfigLoader, OutputTrap, Struct.
6094 it): ConfigLoader, OutputTrap, Struct.
6089
6095
6090 2001-12-05 Fernando Perez <fperez@colorado.edu>
6096 2001-12-05 Fernando Perez <fperez@colorado.edu>
6091
6097
6092 * IPython turns 21! Released version 0.1.21, as a candidate for
6098 * IPython turns 21! Released version 0.1.21, as a candidate for
6093 public consumption. If all goes well, release in a few days.
6099 public consumption. If all goes well, release in a few days.
6094
6100
6095 * Fixed path bug (files in Extensions/ directory wouldn't be found
6101 * Fixed path bug (files in Extensions/ directory wouldn't be found
6096 unless IPython/ was explicitly in sys.path).
6102 unless IPython/ was explicitly in sys.path).
6097
6103
6098 * Extended the FlexCompleter class as MagicCompleter to allow
6104 * Extended the FlexCompleter class as MagicCompleter to allow
6099 completion of @-starting lines.
6105 completion of @-starting lines.
6100
6106
6101 * Created __release__.py file as a central repository for release
6107 * Created __release__.py file as a central repository for release
6102 info that other files can read from.
6108 info that other files can read from.
6103
6109
6104 * Fixed small bug in logging: when logging was turned on in
6110 * Fixed small bug in logging: when logging was turned on in
6105 mid-session, old lines with special meanings (!@?) were being
6111 mid-session, old lines with special meanings (!@?) were being
6106 logged without the prepended comment, which is necessary since
6112 logged without the prepended comment, which is necessary since
6107 they are not truly valid python syntax. This should make session
6113 they are not truly valid python syntax. This should make session
6108 restores produce less errors.
6114 restores produce less errors.
6109
6115
6110 * The namespace cleanup forced me to make a FlexCompleter class
6116 * The namespace cleanup forced me to make a FlexCompleter class
6111 which is nothing but a ripoff of rlcompleter, but with selectable
6117 which is nothing but a ripoff of rlcompleter, but with selectable
6112 namespace (rlcompleter only works in __main__.__dict__). I'll try
6118 namespace (rlcompleter only works in __main__.__dict__). I'll try
6113 to submit a note to the authors to see if this change can be
6119 to submit a note to the authors to see if this change can be
6114 incorporated in future rlcompleter releases (Dec.6: done)
6120 incorporated in future rlcompleter releases (Dec.6: done)
6115
6121
6116 * More fixes to namespace handling. It was a mess! Now all
6122 * More fixes to namespace handling. It was a mess! Now all
6117 explicit references to __main__.__dict__ are gone (except when
6123 explicit references to __main__.__dict__ are gone (except when
6118 really needed) and everything is handled through the namespace
6124 really needed) and everything is handled through the namespace
6119 dicts in the IPython instance. We seem to be getting somewhere
6125 dicts in the IPython instance. We seem to be getting somewhere
6120 with this, finally...
6126 with this, finally...
6121
6127
6122 * Small documentation updates.
6128 * Small documentation updates.
6123
6129
6124 * Created the Extensions directory under IPython (with an
6130 * Created the Extensions directory under IPython (with an
6125 __init__.py). Put the PhysicalQ stuff there. This directory should
6131 __init__.py). Put the PhysicalQ stuff there. This directory should
6126 be used for all special-purpose extensions.
6132 be used for all special-purpose extensions.
6127
6133
6128 * File renaming:
6134 * File renaming:
6129 ipythonlib --> ipmaker
6135 ipythonlib --> ipmaker
6130 ipplib --> iplib
6136 ipplib --> iplib
6131 This makes a bit more sense in terms of what these files actually do.
6137 This makes a bit more sense in terms of what these files actually do.
6132
6138
6133 * Moved all the classes and functions in ipythonlib to ipplib, so
6139 * Moved all the classes and functions in ipythonlib to ipplib, so
6134 now ipythonlib only has make_IPython(). This will ease up its
6140 now ipythonlib only has make_IPython(). This will ease up its
6135 splitting in smaller functional chunks later.
6141 splitting in smaller functional chunks later.
6136
6142
6137 * Cleaned up (done, I think) output of @whos. Better column
6143 * Cleaned up (done, I think) output of @whos. Better column
6138 formatting, and now shows str(var) for as much as it can, which is
6144 formatting, and now shows str(var) for as much as it can, which is
6139 typically what one gets with a 'print var'.
6145 typically what one gets with a 'print var'.
6140
6146
6141 2001-12-04 Fernando Perez <fperez@colorado.edu>
6147 2001-12-04 Fernando Perez <fperez@colorado.edu>
6142
6148
6143 * Fixed namespace problems. Now builtin/IPyhton/user names get
6149 * Fixed namespace problems. Now builtin/IPyhton/user names get
6144 properly reported in their namespace. Internal namespace handling
6150 properly reported in their namespace. Internal namespace handling
6145 is finally getting decent (not perfect yet, but much better than
6151 is finally getting decent (not perfect yet, but much better than
6146 the ad-hoc mess we had).
6152 the ad-hoc mess we had).
6147
6153
6148 * Removed -exit option. If people just want to run a python
6154 * Removed -exit option. If people just want to run a python
6149 script, that's what the normal interpreter is for. Less
6155 script, that's what the normal interpreter is for. Less
6150 unnecessary options, less chances for bugs.
6156 unnecessary options, less chances for bugs.
6151
6157
6152 * Added a crash handler which generates a complete post-mortem if
6158 * Added a crash handler which generates a complete post-mortem if
6153 IPython crashes. This will help a lot in tracking bugs down the
6159 IPython crashes. This will help a lot in tracking bugs down the
6154 road.
6160 road.
6155
6161
6156 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6162 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6157 which were boud to functions being reassigned would bypass the
6163 which were boud to functions being reassigned would bypass the
6158 logger, breaking the sync of _il with the prompt counter. This
6164 logger, breaking the sync of _il with the prompt counter. This
6159 would then crash IPython later when a new line was logged.
6165 would then crash IPython later when a new line was logged.
6160
6166
6161 2001-12-02 Fernando Perez <fperez@colorado.edu>
6167 2001-12-02 Fernando Perez <fperez@colorado.edu>
6162
6168
6163 * Made IPython a package. This means people don't have to clutter
6169 * Made IPython a package. This means people don't have to clutter
6164 their sys.path with yet another directory. Changed the INSTALL
6170 their sys.path with yet another directory. Changed the INSTALL
6165 file accordingly.
6171 file accordingly.
6166
6172
6167 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6173 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6168 sorts its output (so @who shows it sorted) and @whos formats the
6174 sorts its output (so @who shows it sorted) and @whos formats the
6169 table according to the width of the first column. Nicer, easier to
6175 table according to the width of the first column. Nicer, easier to
6170 read. Todo: write a generic table_format() which takes a list of
6176 read. Todo: write a generic table_format() which takes a list of
6171 lists and prints it nicely formatted, with optional row/column
6177 lists and prints it nicely formatted, with optional row/column
6172 separators and proper padding and justification.
6178 separators and proper padding and justification.
6173
6179
6174 * Released 0.1.20
6180 * Released 0.1.20
6175
6181
6176 * Fixed bug in @log which would reverse the inputcache list (a
6182 * Fixed bug in @log which would reverse the inputcache list (a
6177 copy operation was missing).
6183 copy operation was missing).
6178
6184
6179 * Code cleanup. @config was changed to use page(). Better, since
6185 * Code cleanup. @config was changed to use page(). Better, since
6180 its output is always quite long.
6186 its output is always quite long.
6181
6187
6182 * Itpl is back as a dependency. I was having too many problems
6188 * Itpl is back as a dependency. I was having too many problems
6183 getting the parametric aliases to work reliably, and it's just
6189 getting the parametric aliases to work reliably, and it's just
6184 easier to code weird string operations with it than playing %()s
6190 easier to code weird string operations with it than playing %()s
6185 games. It's only ~6k, so I don't think it's too big a deal.
6191 games. It's only ~6k, so I don't think it's too big a deal.
6186
6192
6187 * Found (and fixed) a very nasty bug with history. !lines weren't
6193 * Found (and fixed) a very nasty bug with history. !lines weren't
6188 getting cached, and the out of sync caches would crash
6194 getting cached, and the out of sync caches would crash
6189 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6195 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6190 division of labor a bit better. Bug fixed, cleaner structure.
6196 division of labor a bit better. Bug fixed, cleaner structure.
6191
6197
6192 2001-12-01 Fernando Perez <fperez@colorado.edu>
6198 2001-12-01 Fernando Perez <fperez@colorado.edu>
6193
6199
6194 * Released 0.1.19
6200 * Released 0.1.19
6195
6201
6196 * Added option -n to @hist to prevent line number printing. Much
6202 * Added option -n to @hist to prevent line number printing. Much
6197 easier to copy/paste code this way.
6203 easier to copy/paste code this way.
6198
6204
6199 * Created global _il to hold the input list. Allows easy
6205 * Created global _il to hold the input list. Allows easy
6200 re-execution of blocks of code by slicing it (inspired by Janko's
6206 re-execution of blocks of code by slicing it (inspired by Janko's
6201 comment on 'macros').
6207 comment on 'macros').
6202
6208
6203 * Small fixes and doc updates.
6209 * Small fixes and doc updates.
6204
6210
6205 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6211 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6206 much too fragile with automagic. Handles properly multi-line
6212 much too fragile with automagic. Handles properly multi-line
6207 statements and takes parameters.
6213 statements and takes parameters.
6208
6214
6209 2001-11-30 Fernando Perez <fperez@colorado.edu>
6215 2001-11-30 Fernando Perez <fperez@colorado.edu>
6210
6216
6211 * Version 0.1.18 released.
6217 * Version 0.1.18 released.
6212
6218
6213 * Fixed nasty namespace bug in initial module imports.
6219 * Fixed nasty namespace bug in initial module imports.
6214
6220
6215 * Added copyright/license notes to all code files (except
6221 * Added copyright/license notes to all code files (except
6216 DPyGetOpt). For the time being, LGPL. That could change.
6222 DPyGetOpt). For the time being, LGPL. That could change.
6217
6223
6218 * Rewrote a much nicer README, updated INSTALL, cleaned up
6224 * Rewrote a much nicer README, updated INSTALL, cleaned up
6219 ipythonrc-* samples.
6225 ipythonrc-* samples.
6220
6226
6221 * Overall code/documentation cleanup. Basically ready for
6227 * Overall code/documentation cleanup. Basically ready for
6222 release. Only remaining thing: licence decision (LGPL?).
6228 release. Only remaining thing: licence decision (LGPL?).
6223
6229
6224 * Converted load_config to a class, ConfigLoader. Now recursion
6230 * Converted load_config to a class, ConfigLoader. Now recursion
6225 control is better organized. Doesn't include the same file twice.
6231 control is better organized. Doesn't include the same file twice.
6226
6232
6227 2001-11-29 Fernando Perez <fperez@colorado.edu>
6233 2001-11-29 Fernando Perez <fperez@colorado.edu>
6228
6234
6229 * Got input history working. Changed output history variables from
6235 * Got input history working. Changed output history variables from
6230 _p to _o so that _i is for input and _o for output. Just cleaner
6236 _p to _o so that _i is for input and _o for output. Just cleaner
6231 convention.
6237 convention.
6232
6238
6233 * Implemented parametric aliases. This pretty much allows the
6239 * Implemented parametric aliases. This pretty much allows the
6234 alias system to offer full-blown shell convenience, I think.
6240 alias system to offer full-blown shell convenience, I think.
6235
6241
6236 * Version 0.1.17 released, 0.1.18 opened.
6242 * Version 0.1.17 released, 0.1.18 opened.
6237
6243
6238 * dot_ipython/ipythonrc (alias): added documentation.
6244 * dot_ipython/ipythonrc (alias): added documentation.
6239 (xcolor): Fixed small bug (xcolors -> xcolor)
6245 (xcolor): Fixed small bug (xcolors -> xcolor)
6240
6246
6241 * Changed the alias system. Now alias is a magic command to define
6247 * Changed the alias system. Now alias is a magic command to define
6242 aliases just like the shell. Rationale: the builtin magics should
6248 aliases just like the shell. Rationale: the builtin magics should
6243 be there for things deeply connected to IPython's
6249 be there for things deeply connected to IPython's
6244 architecture. And this is a much lighter system for what I think
6250 architecture. And this is a much lighter system for what I think
6245 is the really important feature: allowing users to define quickly
6251 is the really important feature: allowing users to define quickly
6246 magics that will do shell things for them, so they can customize
6252 magics that will do shell things for them, so they can customize
6247 IPython easily to match their work habits. If someone is really
6253 IPython easily to match their work habits. If someone is really
6248 desperate to have another name for a builtin alias, they can
6254 desperate to have another name for a builtin alias, they can
6249 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6255 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6250 works.
6256 works.
6251
6257
6252 2001-11-28 Fernando Perez <fperez@colorado.edu>
6258 2001-11-28 Fernando Perez <fperez@colorado.edu>
6253
6259
6254 * Changed @file so that it opens the source file at the proper
6260 * Changed @file so that it opens the source file at the proper
6255 line. Since it uses less, if your EDITOR environment is
6261 line. Since it uses less, if your EDITOR environment is
6256 configured, typing v will immediately open your editor of choice
6262 configured, typing v will immediately open your editor of choice
6257 right at the line where the object is defined. Not as quick as
6263 right at the line where the object is defined. Not as quick as
6258 having a direct @edit command, but for all intents and purposes it
6264 having a direct @edit command, but for all intents and purposes it
6259 works. And I don't have to worry about writing @edit to deal with
6265 works. And I don't have to worry about writing @edit to deal with
6260 all the editors, less does that.
6266 all the editors, less does that.
6261
6267
6262 * Version 0.1.16 released, 0.1.17 opened.
6268 * Version 0.1.16 released, 0.1.17 opened.
6263
6269
6264 * Fixed some nasty bugs in the page/page_dumb combo that could
6270 * Fixed some nasty bugs in the page/page_dumb combo that could
6265 crash IPython.
6271 crash IPython.
6266
6272
6267 2001-11-27 Fernando Perez <fperez@colorado.edu>
6273 2001-11-27 Fernando Perez <fperez@colorado.edu>
6268
6274
6269 * Version 0.1.15 released, 0.1.16 opened.
6275 * Version 0.1.15 released, 0.1.16 opened.
6270
6276
6271 * Finally got ? and ?? to work for undefined things: now it's
6277 * Finally got ? and ?? to work for undefined things: now it's
6272 possible to type {}.get? and get information about the get method
6278 possible to type {}.get? and get information about the get method
6273 of dicts, or os.path? even if only os is defined (so technically
6279 of dicts, or os.path? even if only os is defined (so technically
6274 os.path isn't). Works at any level. For example, after import os,
6280 os.path isn't). Works at any level. For example, after import os,
6275 os?, os.path?, os.path.abspath? all work. This is great, took some
6281 os?, os.path?, os.path.abspath? all work. This is great, took some
6276 work in _ofind.
6282 work in _ofind.
6277
6283
6278 * Fixed more bugs with logging. The sanest way to do it was to add
6284 * Fixed more bugs with logging. The sanest way to do it was to add
6279 to @log a 'mode' parameter. Killed two in one shot (this mode
6285 to @log a 'mode' parameter. Killed two in one shot (this mode
6280 option was a request of Janko's). I think it's finally clean
6286 option was a request of Janko's). I think it's finally clean
6281 (famous last words).
6287 (famous last words).
6282
6288
6283 * Added a page_dumb() pager which does a decent job of paging on
6289 * Added a page_dumb() pager which does a decent job of paging on
6284 screen, if better things (like less) aren't available. One less
6290 screen, if better things (like less) aren't available. One less
6285 unix dependency (someday maybe somebody will port this to
6291 unix dependency (someday maybe somebody will port this to
6286 windows).
6292 windows).
6287
6293
6288 * Fixed problem in magic_log: would lock of logging out if log
6294 * Fixed problem in magic_log: would lock of logging out if log
6289 creation failed (because it would still think it had succeeded).
6295 creation failed (because it would still think it had succeeded).
6290
6296
6291 * Improved the page() function using curses to auto-detect screen
6297 * Improved the page() function using curses to auto-detect screen
6292 size. Now it can make a much better decision on whether to print
6298 size. Now it can make a much better decision on whether to print
6293 or page a string. Option screen_length was modified: a value 0
6299 or page a string. Option screen_length was modified: a value 0
6294 means auto-detect, and that's the default now.
6300 means auto-detect, and that's the default now.
6295
6301
6296 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6302 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6297 go out. I'll test it for a few days, then talk to Janko about
6303 go out. I'll test it for a few days, then talk to Janko about
6298 licences and announce it.
6304 licences and announce it.
6299
6305
6300 * Fixed the length of the auto-generated ---> prompt which appears
6306 * Fixed the length of the auto-generated ---> prompt which appears
6301 for auto-parens and auto-quotes. Getting this right isn't trivial,
6307 for auto-parens and auto-quotes. Getting this right isn't trivial,
6302 with all the color escapes, different prompt types and optional
6308 with all the color escapes, different prompt types and optional
6303 separators. But it seems to be working in all the combinations.
6309 separators. But it seems to be working in all the combinations.
6304
6310
6305 2001-11-26 Fernando Perez <fperez@colorado.edu>
6311 2001-11-26 Fernando Perez <fperez@colorado.edu>
6306
6312
6307 * Wrote a regexp filter to get option types from the option names
6313 * Wrote a regexp filter to get option types from the option names
6308 string. This eliminates the need to manually keep two duplicate
6314 string. This eliminates the need to manually keep two duplicate
6309 lists.
6315 lists.
6310
6316
6311 * Removed the unneeded check_option_names. Now options are handled
6317 * Removed the unneeded check_option_names. Now options are handled
6312 in a much saner manner and it's easy to visually check that things
6318 in a much saner manner and it's easy to visually check that things
6313 are ok.
6319 are ok.
6314
6320
6315 * Updated version numbers on all files I modified to carry a
6321 * Updated version numbers on all files I modified to carry a
6316 notice so Janko and Nathan have clear version markers.
6322 notice so Janko and Nathan have clear version markers.
6317
6323
6318 * Updated docstring for ultraTB with my changes. I should send
6324 * Updated docstring for ultraTB with my changes. I should send
6319 this to Nathan.
6325 this to Nathan.
6320
6326
6321 * Lots of small fixes. Ran everything through pychecker again.
6327 * Lots of small fixes. Ran everything through pychecker again.
6322
6328
6323 * Made loading of deep_reload an cmd line option. If it's not too
6329 * Made loading of deep_reload an cmd line option. If it's not too
6324 kosher, now people can just disable it. With -nodeep_reload it's
6330 kosher, now people can just disable it. With -nodeep_reload it's
6325 still available as dreload(), it just won't overwrite reload().
6331 still available as dreload(), it just won't overwrite reload().
6326
6332
6327 * Moved many options to the no| form (-opt and -noopt
6333 * Moved many options to the no| form (-opt and -noopt
6328 accepted). Cleaner.
6334 accepted). Cleaner.
6329
6335
6330 * Changed magic_log so that if called with no parameters, it uses
6336 * Changed magic_log so that if called with no parameters, it uses
6331 'rotate' mode. That way auto-generated logs aren't automatically
6337 'rotate' mode. That way auto-generated logs aren't automatically
6332 over-written. For normal logs, now a backup is made if it exists
6338 over-written. For normal logs, now a backup is made if it exists
6333 (only 1 level of backups). A new 'backup' mode was added to the
6339 (only 1 level of backups). A new 'backup' mode was added to the
6334 Logger class to support this. This was a request by Janko.
6340 Logger class to support this. This was a request by Janko.
6335
6341
6336 * Added @logoff/@logon to stop/restart an active log.
6342 * Added @logoff/@logon to stop/restart an active log.
6337
6343
6338 * Fixed a lot of bugs in log saving/replay. It was pretty
6344 * Fixed a lot of bugs in log saving/replay. It was pretty
6339 broken. Now special lines (!@,/) appear properly in the command
6345 broken. Now special lines (!@,/) appear properly in the command
6340 history after a log replay.
6346 history after a log replay.
6341
6347
6342 * Tried and failed to implement full session saving via pickle. My
6348 * Tried and failed to implement full session saving via pickle. My
6343 idea was to pickle __main__.__dict__, but modules can't be
6349 idea was to pickle __main__.__dict__, but modules can't be
6344 pickled. This would be a better alternative to replaying logs, but
6350 pickled. This would be a better alternative to replaying logs, but
6345 seems quite tricky to get to work. Changed -session to be called
6351 seems quite tricky to get to work. Changed -session to be called
6346 -logplay, which more accurately reflects what it does. And if we
6352 -logplay, which more accurately reflects what it does. And if we
6347 ever get real session saving working, -session is now available.
6353 ever get real session saving working, -session is now available.
6348
6354
6349 * Implemented color schemes for prompts also. As for tracebacks,
6355 * Implemented color schemes for prompts also. As for tracebacks,
6350 currently only NoColor and Linux are supported. But now the
6356 currently only NoColor and Linux are supported. But now the
6351 infrastructure is in place, based on a generic ColorScheme
6357 infrastructure is in place, based on a generic ColorScheme
6352 class. So writing and activating new schemes both for the prompts
6358 class. So writing and activating new schemes both for the prompts
6353 and the tracebacks should be straightforward.
6359 and the tracebacks should be straightforward.
6354
6360
6355 * Version 0.1.13 released, 0.1.14 opened.
6361 * Version 0.1.13 released, 0.1.14 opened.
6356
6362
6357 * Changed handling of options for output cache. Now counter is
6363 * Changed handling of options for output cache. Now counter is
6358 hardwired starting at 1 and one specifies the maximum number of
6364 hardwired starting at 1 and one specifies the maximum number of
6359 entries *in the outcache* (not the max prompt counter). This is
6365 entries *in the outcache* (not the max prompt counter). This is
6360 much better, since many statements won't increase the cache
6366 much better, since many statements won't increase the cache
6361 count. It also eliminated some confusing options, now there's only
6367 count. It also eliminated some confusing options, now there's only
6362 one: cache_size.
6368 one: cache_size.
6363
6369
6364 * Added 'alias' magic function and magic_alias option in the
6370 * Added 'alias' magic function and magic_alias option in the
6365 ipythonrc file. Now the user can easily define whatever names he
6371 ipythonrc file. Now the user can easily define whatever names he
6366 wants for the magic functions without having to play weird
6372 wants for the magic functions without having to play weird
6367 namespace games. This gives IPython a real shell-like feel.
6373 namespace games. This gives IPython a real shell-like feel.
6368
6374
6369 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6375 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6370 @ or not).
6376 @ or not).
6371
6377
6372 This was one of the last remaining 'visible' bugs (that I know
6378 This was one of the last remaining 'visible' bugs (that I know
6373 of). I think if I can clean up the session loading so it works
6379 of). I think if I can clean up the session loading so it works
6374 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6380 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6375 about licensing).
6381 about licensing).
6376
6382
6377 2001-11-25 Fernando Perez <fperez@colorado.edu>
6383 2001-11-25 Fernando Perez <fperez@colorado.edu>
6378
6384
6379 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6385 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6380 there's a cleaner distinction between what ? and ?? show.
6386 there's a cleaner distinction between what ? and ?? show.
6381
6387
6382 * Added screen_length option. Now the user can define his own
6388 * Added screen_length option. Now the user can define his own
6383 screen size for page() operations.
6389 screen size for page() operations.
6384
6390
6385 * Implemented magic shell-like functions with automatic code
6391 * Implemented magic shell-like functions with automatic code
6386 generation. Now adding another function is just a matter of adding
6392 generation. Now adding another function is just a matter of adding
6387 an entry to a dict, and the function is dynamically generated at
6393 an entry to a dict, and the function is dynamically generated at
6388 run-time. Python has some really cool features!
6394 run-time. Python has some really cool features!
6389
6395
6390 * Renamed many options to cleanup conventions a little. Now all
6396 * Renamed many options to cleanup conventions a little. Now all
6391 are lowercase, and only underscores where needed. Also in the code
6397 are lowercase, and only underscores where needed. Also in the code
6392 option name tables are clearer.
6398 option name tables are clearer.
6393
6399
6394 * Changed prompts a little. Now input is 'In [n]:' instead of
6400 * Changed prompts a little. Now input is 'In [n]:' instead of
6395 'In[n]:='. This allows it the numbers to be aligned with the
6401 'In[n]:='. This allows it the numbers to be aligned with the
6396 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6402 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6397 Python (it was a Mathematica thing). The '...' continuation prompt
6403 Python (it was a Mathematica thing). The '...' continuation prompt
6398 was also changed a little to align better.
6404 was also changed a little to align better.
6399
6405
6400 * Fixed bug when flushing output cache. Not all _p<n> variables
6406 * Fixed bug when flushing output cache. Not all _p<n> variables
6401 exist, so their deletion needs to be wrapped in a try:
6407 exist, so their deletion needs to be wrapped in a try:
6402
6408
6403 * Figured out how to properly use inspect.formatargspec() (it
6409 * Figured out how to properly use inspect.formatargspec() (it
6404 requires the args preceded by *). So I removed all the code from
6410 requires the args preceded by *). So I removed all the code from
6405 _get_pdef in Magic, which was just replicating that.
6411 _get_pdef in Magic, which was just replicating that.
6406
6412
6407 * Added test to prefilter to allow redefining magic function names
6413 * Added test to prefilter to allow redefining magic function names
6408 as variables. This is ok, since the @ form is always available,
6414 as variables. This is ok, since the @ form is always available,
6409 but whe should allow the user to define a variable called 'ls' if
6415 but whe should allow the user to define a variable called 'ls' if
6410 he needs it.
6416 he needs it.
6411
6417
6412 * Moved the ToDo information from README into a separate ToDo.
6418 * Moved the ToDo information from README into a separate ToDo.
6413
6419
6414 * General code cleanup and small bugfixes. I think it's close to a
6420 * General code cleanup and small bugfixes. I think it's close to a
6415 state where it can be released, obviously with a big 'beta'
6421 state where it can be released, obviously with a big 'beta'
6416 warning on it.
6422 warning on it.
6417
6423
6418 * Got the magic function split to work. Now all magics are defined
6424 * Got the magic function split to work. Now all magics are defined
6419 in a separate class. It just organizes things a bit, and now
6425 in a separate class. It just organizes things a bit, and now
6420 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6426 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6421 was too long).
6427 was too long).
6422
6428
6423 * Changed @clear to @reset to avoid potential confusions with
6429 * Changed @clear to @reset to avoid potential confusions with
6424 the shell command clear. Also renamed @cl to @clear, which does
6430 the shell command clear. Also renamed @cl to @clear, which does
6425 exactly what people expect it to from their shell experience.
6431 exactly what people expect it to from their shell experience.
6426
6432
6427 Added a check to the @reset command (since it's so
6433 Added a check to the @reset command (since it's so
6428 destructive, it's probably a good idea to ask for confirmation).
6434 destructive, it's probably a good idea to ask for confirmation).
6429 But now reset only works for full namespace resetting. Since the
6435 But now reset only works for full namespace resetting. Since the
6430 del keyword is already there for deleting a few specific
6436 del keyword is already there for deleting a few specific
6431 variables, I don't see the point of having a redundant magic
6437 variables, I don't see the point of having a redundant magic
6432 function for the same task.
6438 function for the same task.
6433
6439
6434 2001-11-24 Fernando Perez <fperez@colorado.edu>
6440 2001-11-24 Fernando Perez <fperez@colorado.edu>
6435
6441
6436 * Updated the builtin docs (esp. the ? ones).
6442 * Updated the builtin docs (esp. the ? ones).
6437
6443
6438 * Ran all the code through pychecker. Not terribly impressed with
6444 * Ran all the code through pychecker. Not terribly impressed with
6439 it: lots of spurious warnings and didn't really find anything of
6445 it: lots of spurious warnings and didn't really find anything of
6440 substance (just a few modules being imported and not used).
6446 substance (just a few modules being imported and not used).
6441
6447
6442 * Implemented the new ultraTB functionality into IPython. New
6448 * Implemented the new ultraTB functionality into IPython. New
6443 option: xcolors. This chooses color scheme. xmode now only selects
6449 option: xcolors. This chooses color scheme. xmode now only selects
6444 between Plain and Verbose. Better orthogonality.
6450 between Plain and Verbose. Better orthogonality.
6445
6451
6446 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6452 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6447 mode and color scheme for the exception handlers. Now it's
6453 mode and color scheme for the exception handlers. Now it's
6448 possible to have the verbose traceback with no coloring.
6454 possible to have the verbose traceback with no coloring.
6449
6455
6450 2001-11-23 Fernando Perez <fperez@colorado.edu>
6456 2001-11-23 Fernando Perez <fperez@colorado.edu>
6451
6457
6452 * Version 0.1.12 released, 0.1.13 opened.
6458 * Version 0.1.12 released, 0.1.13 opened.
6453
6459
6454 * Removed option to set auto-quote and auto-paren escapes by
6460 * Removed option to set auto-quote and auto-paren escapes by
6455 user. The chances of breaking valid syntax are just too high. If
6461 user. The chances of breaking valid syntax are just too high. If
6456 someone *really* wants, they can always dig into the code.
6462 someone *really* wants, they can always dig into the code.
6457
6463
6458 * Made prompt separators configurable.
6464 * Made prompt separators configurable.
6459
6465
6460 2001-11-22 Fernando Perez <fperez@colorado.edu>
6466 2001-11-22 Fernando Perez <fperez@colorado.edu>
6461
6467
6462 * Small bugfixes in many places.
6468 * Small bugfixes in many places.
6463
6469
6464 * Removed the MyCompleter class from ipplib. It seemed redundant
6470 * Removed the MyCompleter class from ipplib. It seemed redundant
6465 with the C-p,C-n history search functionality. Less code to
6471 with the C-p,C-n history search functionality. Less code to
6466 maintain.
6472 maintain.
6467
6473
6468 * Moved all the original ipython.py code into ipythonlib.py. Right
6474 * Moved all the original ipython.py code into ipythonlib.py. Right
6469 now it's just one big dump into a function called make_IPython, so
6475 now it's just one big dump into a function called make_IPython, so
6470 no real modularity has been gained. But at least it makes the
6476 no real modularity has been gained. But at least it makes the
6471 wrapper script tiny, and since ipythonlib is a module, it gets
6477 wrapper script tiny, and since ipythonlib is a module, it gets
6472 compiled and startup is much faster.
6478 compiled and startup is much faster.
6473
6479
6474 This is a reasobably 'deep' change, so we should test it for a
6480 This is a reasobably 'deep' change, so we should test it for a
6475 while without messing too much more with the code.
6481 while without messing too much more with the code.
6476
6482
6477 2001-11-21 Fernando Perez <fperez@colorado.edu>
6483 2001-11-21 Fernando Perez <fperez@colorado.edu>
6478
6484
6479 * Version 0.1.11 released, 0.1.12 opened for further work.
6485 * Version 0.1.11 released, 0.1.12 opened for further work.
6480
6486
6481 * Removed dependency on Itpl. It was only needed in one place. It
6487 * Removed dependency on Itpl. It was only needed in one place. It
6482 would be nice if this became part of python, though. It makes life
6488 would be nice if this became part of python, though. It makes life
6483 *a lot* easier in some cases.
6489 *a lot* easier in some cases.
6484
6490
6485 * Simplified the prefilter code a bit. Now all handlers are
6491 * Simplified the prefilter code a bit. Now all handlers are
6486 expected to explicitly return a value (at least a blank string).
6492 expected to explicitly return a value (at least a blank string).
6487
6493
6488 * Heavy edits in ipplib. Removed the help system altogether. Now
6494 * Heavy edits in ipplib. Removed the help system altogether. Now
6489 obj?/?? is used for inspecting objects, a magic @doc prints
6495 obj?/?? is used for inspecting objects, a magic @doc prints
6490 docstrings, and full-blown Python help is accessed via the 'help'
6496 docstrings, and full-blown Python help is accessed via the 'help'
6491 keyword. This cleans up a lot of code (less to maintain) and does
6497 keyword. This cleans up a lot of code (less to maintain) and does
6492 the job. Since 'help' is now a standard Python component, might as
6498 the job. Since 'help' is now a standard Python component, might as
6493 well use it and remove duplicate functionality.
6499 well use it and remove duplicate functionality.
6494
6500
6495 Also removed the option to use ipplib as a standalone program. By
6501 Also removed the option to use ipplib as a standalone program. By
6496 now it's too dependent on other parts of IPython to function alone.
6502 now it's too dependent on other parts of IPython to function alone.
6497
6503
6498 * Fixed bug in genutils.pager. It would crash if the pager was
6504 * Fixed bug in genutils.pager. It would crash if the pager was
6499 exited immediately after opening (broken pipe).
6505 exited immediately after opening (broken pipe).
6500
6506
6501 * Trimmed down the VerboseTB reporting a little. The header is
6507 * Trimmed down the VerboseTB reporting a little. The header is
6502 much shorter now and the repeated exception arguments at the end
6508 much shorter now and the repeated exception arguments at the end
6503 have been removed. For interactive use the old header seemed a bit
6509 have been removed. For interactive use the old header seemed a bit
6504 excessive.
6510 excessive.
6505
6511
6506 * Fixed small bug in output of @whos for variables with multi-word
6512 * Fixed small bug in output of @whos for variables with multi-word
6507 types (only first word was displayed).
6513 types (only first word was displayed).
6508
6514
6509 2001-11-17 Fernando Perez <fperez@colorado.edu>
6515 2001-11-17 Fernando Perez <fperez@colorado.edu>
6510
6516
6511 * Version 0.1.10 released, 0.1.11 opened for further work.
6517 * Version 0.1.10 released, 0.1.11 opened for further work.
6512
6518
6513 * Modified dirs and friends. dirs now *returns* the stack (not
6519 * Modified dirs and friends. dirs now *returns* the stack (not
6514 prints), so one can manipulate it as a variable. Convenient to
6520 prints), so one can manipulate it as a variable. Convenient to
6515 travel along many directories.
6521 travel along many directories.
6516
6522
6517 * Fixed bug in magic_pdef: would only work with functions with
6523 * Fixed bug in magic_pdef: would only work with functions with
6518 arguments with default values.
6524 arguments with default values.
6519
6525
6520 2001-11-14 Fernando Perez <fperez@colorado.edu>
6526 2001-11-14 Fernando Perez <fperez@colorado.edu>
6521
6527
6522 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6528 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6523 example with IPython. Various other minor fixes and cleanups.
6529 example with IPython. Various other minor fixes and cleanups.
6524
6530
6525 * Version 0.1.9 released, 0.1.10 opened for further work.
6531 * Version 0.1.9 released, 0.1.10 opened for further work.
6526
6532
6527 * Added sys.path to the list of directories searched in the
6533 * Added sys.path to the list of directories searched in the
6528 execfile= option. It used to be the current directory and the
6534 execfile= option. It used to be the current directory and the
6529 user's IPYTHONDIR only.
6535 user's IPYTHONDIR only.
6530
6536
6531 2001-11-13 Fernando Perez <fperez@colorado.edu>
6537 2001-11-13 Fernando Perez <fperez@colorado.edu>
6532
6538
6533 * Reinstated the raw_input/prefilter separation that Janko had
6539 * Reinstated the raw_input/prefilter separation that Janko had
6534 initially. This gives a more convenient setup for extending the
6540 initially. This gives a more convenient setup for extending the
6535 pre-processor from the outside: raw_input always gets a string,
6541 pre-processor from the outside: raw_input always gets a string,
6536 and prefilter has to process it. We can then redefine prefilter
6542 and prefilter has to process it. We can then redefine prefilter
6537 from the outside and implement extensions for special
6543 from the outside and implement extensions for special
6538 purposes.
6544 purposes.
6539
6545
6540 Today I got one for inputting PhysicalQuantity objects
6546 Today I got one for inputting PhysicalQuantity objects
6541 (from Scientific) without needing any function calls at
6547 (from Scientific) without needing any function calls at
6542 all. Extremely convenient, and it's all done as a user-level
6548 all. Extremely convenient, and it's all done as a user-level
6543 extension (no IPython code was touched). Now instead of:
6549 extension (no IPython code was touched). Now instead of:
6544 a = PhysicalQuantity(4.2,'m/s**2')
6550 a = PhysicalQuantity(4.2,'m/s**2')
6545 one can simply say
6551 one can simply say
6546 a = 4.2 m/s**2
6552 a = 4.2 m/s**2
6547 or even
6553 or even
6548 a = 4.2 m/s^2
6554 a = 4.2 m/s^2
6549
6555
6550 I use this, but it's also a proof of concept: IPython really is
6556 I use this, but it's also a proof of concept: IPython really is
6551 fully user-extensible, even at the level of the parsing of the
6557 fully user-extensible, even at the level of the parsing of the
6552 command line. It's not trivial, but it's perfectly doable.
6558 command line. It's not trivial, but it's perfectly doable.
6553
6559
6554 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6560 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6555 the problem of modules being loaded in the inverse order in which
6561 the problem of modules being loaded in the inverse order in which
6556 they were defined in
6562 they were defined in
6557
6563
6558 * Version 0.1.8 released, 0.1.9 opened for further work.
6564 * Version 0.1.8 released, 0.1.9 opened for further work.
6559
6565
6560 * Added magics pdef, source and file. They respectively show the
6566 * Added magics pdef, source and file. They respectively show the
6561 definition line ('prototype' in C), source code and full python
6567 definition line ('prototype' in C), source code and full python
6562 file for any callable object. The object inspector oinfo uses
6568 file for any callable object. The object inspector oinfo uses
6563 these to show the same information.
6569 these to show the same information.
6564
6570
6565 * Version 0.1.7 released, 0.1.8 opened for further work.
6571 * Version 0.1.7 released, 0.1.8 opened for further work.
6566
6572
6567 * Separated all the magic functions into a class called Magic. The
6573 * Separated all the magic functions into a class called Magic. The
6568 InteractiveShell class was becoming too big for Xemacs to handle
6574 InteractiveShell class was becoming too big for Xemacs to handle
6569 (de-indenting a line would lock it up for 10 seconds while it
6575 (de-indenting a line would lock it up for 10 seconds while it
6570 backtracked on the whole class!)
6576 backtracked on the whole class!)
6571
6577
6572 FIXME: didn't work. It can be done, but right now namespaces are
6578 FIXME: didn't work. It can be done, but right now namespaces are
6573 all messed up. Do it later (reverted it for now, so at least
6579 all messed up. Do it later (reverted it for now, so at least
6574 everything works as before).
6580 everything works as before).
6575
6581
6576 * Got the object introspection system (magic_oinfo) working! I
6582 * Got the object introspection system (magic_oinfo) working! I
6577 think this is pretty much ready for release to Janko, so he can
6583 think this is pretty much ready for release to Janko, so he can
6578 test it for a while and then announce it. Pretty much 100% of what
6584 test it for a while and then announce it. Pretty much 100% of what
6579 I wanted for the 'phase 1' release is ready. Happy, tired.
6585 I wanted for the 'phase 1' release is ready. Happy, tired.
6580
6586
6581 2001-11-12 Fernando Perez <fperez@colorado.edu>
6587 2001-11-12 Fernando Perez <fperez@colorado.edu>
6582
6588
6583 * Version 0.1.6 released, 0.1.7 opened for further work.
6589 * Version 0.1.6 released, 0.1.7 opened for further work.
6584
6590
6585 * Fixed bug in printing: it used to test for truth before
6591 * Fixed bug in printing: it used to test for truth before
6586 printing, so 0 wouldn't print. Now checks for None.
6592 printing, so 0 wouldn't print. Now checks for None.
6587
6593
6588 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6594 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6589 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6595 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6590 reaches by hand into the outputcache. Think of a better way to do
6596 reaches by hand into the outputcache. Think of a better way to do
6591 this later.
6597 this later.
6592
6598
6593 * Various small fixes thanks to Nathan's comments.
6599 * Various small fixes thanks to Nathan's comments.
6594
6600
6595 * Changed magic_pprint to magic_Pprint. This way it doesn't
6601 * Changed magic_pprint to magic_Pprint. This way it doesn't
6596 collide with pprint() and the name is consistent with the command
6602 collide with pprint() and the name is consistent with the command
6597 line option.
6603 line option.
6598
6604
6599 * Changed prompt counter behavior to be fully like
6605 * Changed prompt counter behavior to be fully like
6600 Mathematica's. That is, even input that doesn't return a result
6606 Mathematica's. That is, even input that doesn't return a result
6601 raises the prompt counter. The old behavior was kind of confusing
6607 raises the prompt counter. The old behavior was kind of confusing
6602 (getting the same prompt number several times if the operation
6608 (getting the same prompt number several times if the operation
6603 didn't return a result).
6609 didn't return a result).
6604
6610
6605 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6611 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6606
6612
6607 * Fixed -Classic mode (wasn't working anymore).
6613 * Fixed -Classic mode (wasn't working anymore).
6608
6614
6609 * Added colored prompts using Nathan's new code. Colors are
6615 * Added colored prompts using Nathan's new code. Colors are
6610 currently hardwired, they can be user-configurable. For
6616 currently hardwired, they can be user-configurable. For
6611 developers, they can be chosen in file ipythonlib.py, at the
6617 developers, they can be chosen in file ipythonlib.py, at the
6612 beginning of the CachedOutput class def.
6618 beginning of the CachedOutput class def.
6613
6619
6614 2001-11-11 Fernando Perez <fperez@colorado.edu>
6620 2001-11-11 Fernando Perez <fperez@colorado.edu>
6615
6621
6616 * Version 0.1.5 released, 0.1.6 opened for further work.
6622 * Version 0.1.5 released, 0.1.6 opened for further work.
6617
6623
6618 * Changed magic_env to *return* the environment as a dict (not to
6624 * Changed magic_env to *return* the environment as a dict (not to
6619 print it). This way it prints, but it can also be processed.
6625 print it). This way it prints, but it can also be processed.
6620
6626
6621 * Added Verbose exception reporting to interactive
6627 * Added Verbose exception reporting to interactive
6622 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6628 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6623 traceback. Had to make some changes to the ultraTB file. This is
6629 traceback. Had to make some changes to the ultraTB file. This is
6624 probably the last 'big' thing in my mental todo list. This ties
6630 probably the last 'big' thing in my mental todo list. This ties
6625 in with the next entry:
6631 in with the next entry:
6626
6632
6627 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6633 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6628 has to specify is Plain, Color or Verbose for all exception
6634 has to specify is Plain, Color or Verbose for all exception
6629 handling.
6635 handling.
6630
6636
6631 * Removed ShellServices option. All this can really be done via
6637 * Removed ShellServices option. All this can really be done via
6632 the magic system. It's easier to extend, cleaner and has automatic
6638 the magic system. It's easier to extend, cleaner and has automatic
6633 namespace protection and documentation.
6639 namespace protection and documentation.
6634
6640
6635 2001-11-09 Fernando Perez <fperez@colorado.edu>
6641 2001-11-09 Fernando Perez <fperez@colorado.edu>
6636
6642
6637 * Fixed bug in output cache flushing (missing parameter to
6643 * Fixed bug in output cache flushing (missing parameter to
6638 __init__). Other small bugs fixed (found using pychecker).
6644 __init__). Other small bugs fixed (found using pychecker).
6639
6645
6640 * Version 0.1.4 opened for bugfixing.
6646 * Version 0.1.4 opened for bugfixing.
6641
6647
6642 2001-11-07 Fernando Perez <fperez@colorado.edu>
6648 2001-11-07 Fernando Perez <fperez@colorado.edu>
6643
6649
6644 * Version 0.1.3 released, mainly because of the raw_input bug.
6650 * Version 0.1.3 released, mainly because of the raw_input bug.
6645
6651
6646 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
6652 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
6647 and when testing for whether things were callable, a call could
6653 and when testing for whether things were callable, a call could
6648 actually be made to certain functions. They would get called again
6654 actually be made to certain functions. They would get called again
6649 once 'really' executed, with a resulting double call. A disaster
6655 once 'really' executed, with a resulting double call. A disaster
6650 in many cases (list.reverse() would never work!).
6656 in many cases (list.reverse() would never work!).
6651
6657
6652 * Removed prefilter() function, moved its code to raw_input (which
6658 * Removed prefilter() function, moved its code to raw_input (which
6653 after all was just a near-empty caller for prefilter). This saves
6659 after all was just a near-empty caller for prefilter). This saves
6654 a function call on every prompt, and simplifies the class a tiny bit.
6660 a function call on every prompt, and simplifies the class a tiny bit.
6655
6661
6656 * Fix _ip to __ip name in magic example file.
6662 * Fix _ip to __ip name in magic example file.
6657
6663
6658 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
6664 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
6659 work with non-gnu versions of tar.
6665 work with non-gnu versions of tar.
6660
6666
6661 2001-11-06 Fernando Perez <fperez@colorado.edu>
6667 2001-11-06 Fernando Perez <fperez@colorado.edu>
6662
6668
6663 * Version 0.1.2. Just to keep track of the recent changes.
6669 * Version 0.1.2. Just to keep track of the recent changes.
6664
6670
6665 * Fixed nasty bug in output prompt routine. It used to check 'if
6671 * Fixed nasty bug in output prompt routine. It used to check 'if
6666 arg != None...'. Problem is, this fails if arg implements a
6672 arg != None...'. Problem is, this fails if arg implements a
6667 special comparison (__cmp__) which disallows comparing to
6673 special comparison (__cmp__) which disallows comparing to
6668 None. Found it when trying to use the PhysicalQuantity module from
6674 None. Found it when trying to use the PhysicalQuantity module from
6669 ScientificPython.
6675 ScientificPython.
6670
6676
6671 2001-11-05 Fernando Perez <fperez@colorado.edu>
6677 2001-11-05 Fernando Perez <fperez@colorado.edu>
6672
6678
6673 * Also added dirs. Now the pushd/popd/dirs family functions
6679 * Also added dirs. Now the pushd/popd/dirs family functions
6674 basically like the shell, with the added convenience of going home
6680 basically like the shell, with the added convenience of going home
6675 when called with no args.
6681 when called with no args.
6676
6682
6677 * pushd/popd slightly modified to mimic shell behavior more
6683 * pushd/popd slightly modified to mimic shell behavior more
6678 closely.
6684 closely.
6679
6685
6680 * Added env,pushd,popd from ShellServices as magic functions. I
6686 * Added env,pushd,popd from ShellServices as magic functions. I
6681 think the cleanest will be to port all desired functions from
6687 think the cleanest will be to port all desired functions from
6682 ShellServices as magics and remove ShellServices altogether. This
6688 ShellServices as magics and remove ShellServices altogether. This
6683 will provide a single, clean way of adding functionality
6689 will provide a single, clean way of adding functionality
6684 (shell-type or otherwise) to IP.
6690 (shell-type or otherwise) to IP.
6685
6691
6686 2001-11-04 Fernando Perez <fperez@colorado.edu>
6692 2001-11-04 Fernando Perez <fperez@colorado.edu>
6687
6693
6688 * Added .ipython/ directory to sys.path. This way users can keep
6694 * Added .ipython/ directory to sys.path. This way users can keep
6689 customizations there and access them via import.
6695 customizations there and access them via import.
6690
6696
6691 2001-11-03 Fernando Perez <fperez@colorado.edu>
6697 2001-11-03 Fernando Perez <fperez@colorado.edu>
6692
6698
6693 * Opened version 0.1.1 for new changes.
6699 * Opened version 0.1.1 for new changes.
6694
6700
6695 * Changed version number to 0.1.0: first 'public' release, sent to
6701 * Changed version number to 0.1.0: first 'public' release, sent to
6696 Nathan and Janko.
6702 Nathan and Janko.
6697
6703
6698 * Lots of small fixes and tweaks.
6704 * Lots of small fixes and tweaks.
6699
6705
6700 * Minor changes to whos format. Now strings are shown, snipped if
6706 * Minor changes to whos format. Now strings are shown, snipped if
6701 too long.
6707 too long.
6702
6708
6703 * Changed ShellServices to work on __main__ so they show up in @who
6709 * Changed ShellServices to work on __main__ so they show up in @who
6704
6710
6705 * Help also works with ? at the end of a line:
6711 * Help also works with ? at the end of a line:
6706 ?sin and sin?
6712 ?sin and sin?
6707 both produce the same effect. This is nice, as often I use the
6713 both produce the same effect. This is nice, as often I use the
6708 tab-complete to find the name of a method, but I used to then have
6714 tab-complete to find the name of a method, but I used to then have
6709 to go to the beginning of the line to put a ? if I wanted more
6715 to go to the beginning of the line to put a ? if I wanted more
6710 info. Now I can just add the ? and hit return. Convenient.
6716 info. Now I can just add the ? and hit return. Convenient.
6711
6717
6712 2001-11-02 Fernando Perez <fperez@colorado.edu>
6718 2001-11-02 Fernando Perez <fperez@colorado.edu>
6713
6719
6714 * Python version check (>=2.1) added.
6720 * Python version check (>=2.1) added.
6715
6721
6716 * Added LazyPython documentation. At this point the docs are quite
6722 * Added LazyPython documentation. At this point the docs are quite
6717 a mess. A cleanup is in order.
6723 a mess. A cleanup is in order.
6718
6724
6719 * Auto-installer created. For some bizarre reason, the zipfiles
6725 * Auto-installer created. For some bizarre reason, the zipfiles
6720 module isn't working on my system. So I made a tar version
6726 module isn't working on my system. So I made a tar version
6721 (hopefully the command line options in various systems won't kill
6727 (hopefully the command line options in various systems won't kill
6722 me).
6728 me).
6723
6729
6724 * Fixes to Struct in genutils. Now all dictionary-like methods are
6730 * Fixes to Struct in genutils. Now all dictionary-like methods are
6725 protected (reasonably).
6731 protected (reasonably).
6726
6732
6727 * Added pager function to genutils and changed ? to print usage
6733 * Added pager function to genutils and changed ? to print usage
6728 note through it (it was too long).
6734 note through it (it was too long).
6729
6735
6730 * Added the LazyPython functionality. Works great! I changed the
6736 * Added the LazyPython functionality. Works great! I changed the
6731 auto-quote escape to ';', it's on home row and next to '. But
6737 auto-quote escape to ';', it's on home row and next to '. But
6732 both auto-quote and auto-paren (still /) escapes are command-line
6738 both auto-quote and auto-paren (still /) escapes are command-line
6733 parameters.
6739 parameters.
6734
6740
6735
6741
6736 2001-11-01 Fernando Perez <fperez@colorado.edu>
6742 2001-11-01 Fernando Perez <fperez@colorado.edu>
6737
6743
6738 * Version changed to 0.0.7. Fairly large change: configuration now
6744 * Version changed to 0.0.7. Fairly large change: configuration now
6739 is all stored in a directory, by default .ipython. There, all
6745 is all stored in a directory, by default .ipython. There, all
6740 config files have normal looking names (not .names)
6746 config files have normal looking names (not .names)
6741
6747
6742 * Version 0.0.6 Released first to Lucas and Archie as a test
6748 * Version 0.0.6 Released first to Lucas and Archie as a test
6743 run. Since it's the first 'semi-public' release, change version to
6749 run. Since it's the first 'semi-public' release, change version to
6744 > 0.0.6 for any changes now.
6750 > 0.0.6 for any changes now.
6745
6751
6746 * Stuff I had put in the ipplib.py changelog:
6752 * Stuff I had put in the ipplib.py changelog:
6747
6753
6748 Changes to InteractiveShell:
6754 Changes to InteractiveShell:
6749
6755
6750 - Made the usage message a parameter.
6756 - Made the usage message a parameter.
6751
6757
6752 - Require the name of the shell variable to be given. It's a bit
6758 - Require the name of the shell variable to be given. It's a bit
6753 of a hack, but allows the name 'shell' not to be hardwired in the
6759 of a hack, but allows the name 'shell' not to be hardwired in the
6754 magic (@) handler, which is problematic b/c it requires
6760 magic (@) handler, which is problematic b/c it requires
6755 polluting the global namespace with 'shell'. This in turn is
6761 polluting the global namespace with 'shell'. This in turn is
6756 fragile: if a user redefines a variable called shell, things
6762 fragile: if a user redefines a variable called shell, things
6757 break.
6763 break.
6758
6764
6759 - magic @: all functions available through @ need to be defined
6765 - magic @: all functions available through @ need to be defined
6760 as magic_<name>, even though they can be called simply as
6766 as magic_<name>, even though they can be called simply as
6761 @<name>. This allows the special command @magic to gather
6767 @<name>. This allows the special command @magic to gather
6762 information automatically about all existing magic functions,
6768 information automatically about all existing magic functions,
6763 even if they are run-time user extensions, by parsing the shell
6769 even if they are run-time user extensions, by parsing the shell
6764 instance __dict__ looking for special magic_ names.
6770 instance __dict__ looking for special magic_ names.
6765
6771
6766 - mainloop: added *two* local namespace parameters. This allows
6772 - mainloop: added *two* local namespace parameters. This allows
6767 the class to differentiate between parameters which were there
6773 the class to differentiate between parameters which were there
6768 before and after command line initialization was processed. This
6774 before and after command line initialization was processed. This
6769 way, later @who can show things loaded at startup by the
6775 way, later @who can show things loaded at startup by the
6770 user. This trick was necessary to make session saving/reloading
6776 user. This trick was necessary to make session saving/reloading
6771 really work: ideally after saving/exiting/reloading a session,
6777 really work: ideally after saving/exiting/reloading a session,
6772 *everything* should look the same, including the output of @who. I
6778 *everything* should look the same, including the output of @who. I
6773 was only able to make this work with this double namespace
6779 was only able to make this work with this double namespace
6774 trick.
6780 trick.
6775
6781
6776 - added a header to the logfile which allows (almost) full
6782 - added a header to the logfile which allows (almost) full
6777 session restoring.
6783 session restoring.
6778
6784
6779 - prepend lines beginning with @ or !, with a and log
6785 - prepend lines beginning with @ or !, with a and log
6780 them. Why? !lines: may be useful to know what you did @lines:
6786 them. Why? !lines: may be useful to know what you did @lines:
6781 they may affect session state. So when restoring a session, at
6787 they may affect session state. So when restoring a session, at
6782 least inform the user of their presence. I couldn't quite get
6788 least inform the user of their presence. I couldn't quite get
6783 them to properly re-execute, but at least the user is warned.
6789 them to properly re-execute, but at least the user is warned.
6784
6790
6785 * Started ChangeLog.
6791 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now