##// END OF EJS Templates
- Fix exception name printing for Python 2.5.
fperez -
Show More
@@ -1,927 +1,933 b''
1 1 # -*- coding: utf-8 -*-
2 2 """
3 3 ultraTB.py -- Spice up your tracebacks!
4 4
5 5 * ColorTB
6 6 I've always found it a bit hard to visually parse tracebacks in Python. The
7 7 ColorTB class is a solution to that problem. It colors the different parts of a
8 8 traceback in a manner similar to what you would expect from a syntax-highlighting
9 9 text editor.
10 10
11 11 Installation instructions for ColorTB:
12 12 import sys,ultraTB
13 13 sys.excepthook = ultraTB.ColorTB()
14 14
15 15 * VerboseTB
16 16 I've also included a port of Ka-Ping Yee's "cgitb.py" that produces all kinds
17 17 of useful info when a traceback occurs. Ping originally had it spit out HTML
18 18 and intended it for CGI programmers, but why should they have all the fun? I
19 19 altered it to spit out colored text to the terminal. It's a bit overwhelming,
20 20 but kind of neat, and maybe useful for long-running programs that you believe
21 21 are bug-free. If a crash *does* occur in that type of program you want details.
22 22 Give it a shot--you'll love it or you'll hate it.
23 23
24 24 Note:
25 25
26 26 The Verbose mode prints the variables currently visible where the exception
27 27 happened (shortening their strings if too long). This can potentially be
28 28 very slow, if you happen to have a huge data structure whose string
29 29 representation is complex to compute. Your computer may appear to freeze for
30 30 a while with cpu usage at 100%. If this occurs, you can cancel the traceback
31 31 with Ctrl-C (maybe hitting it more than once).
32 32
33 33 If you encounter this kind of situation often, you may want to use the
34 34 Verbose_novars mode instead of the regular Verbose, which avoids formatting
35 35 variables (but otherwise includes the information and context given by
36 36 Verbose).
37 37
38 38
39 39 Installation instructions for ColorTB:
40 40 import sys,ultraTB
41 41 sys.excepthook = ultraTB.VerboseTB()
42 42
43 43 Note: Much of the code in this module was lifted verbatim from the standard
44 44 library module 'traceback.py' and Ka-Ping Yee's 'cgitb.py'.
45 45
46 46 * Color schemes
47 47 The colors are defined in the class TBTools through the use of the
48 48 ColorSchemeTable class. Currently the following exist:
49 49
50 50 - NoColor: allows all of this module to be used in any terminal (the color
51 51 escapes are just dummy blank strings).
52 52
53 53 - Linux: is meant to look good in a terminal like the Linux console (black
54 54 or very dark background).
55 55
56 56 - LightBG: similar to Linux but swaps dark/light colors to be more readable
57 57 in light background terminals.
58 58
59 59 You can implement other color schemes easily, the syntax is fairly
60 60 self-explanatory. Please send back new schemes you develop to the author for
61 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 66 # Copyright (C) 2001 Nathaniel Gray <n8gray@caltech.edu>
67 67 # Copyright (C) 2001-2004 Fernando Perez <fperez@colorado.edu>
68 68 #
69 69 # Distributed under the terms of the BSD License. The full license is in
70 70 # the file COPYING, distributed as part of this software.
71 71 #*****************************************************************************
72 72
73 73 from IPython import Release
74 74 __author__ = '%s <%s>\n%s <%s>' % (Release.authors['Nathan']+
75 75 Release.authors['Fernando'])
76 76 __license__ = Release.license
77 77
78 78 # Required modules
79 79 import inspect
80 80 import keyword
81 81 import linecache
82 82 import os
83 83 import pydoc
84 84 import string
85 85 import sys
86 86 import time
87 87 import tokenize
88 88 import traceback
89 89 import types
90 90
91 91 # IPython's own modules
92 92 # Modified pdb which doesn't damage IPython's readline handling
93 93 from IPython import Debugger, PyColorize
94 94 from IPython.ipstruct import Struct
95 95 from IPython.excolors import ExceptionColors
96 96 from IPython.genutils import Term,uniq_stable,error,info
97 97
98 98 # Globals
99 99 # amount of space to put line numbers before verbose tracebacks
100 100 INDENT_SIZE = 8
101 101
102 102 # Default color scheme. This is used, for example, by the traceback
103 103 # formatter. When running in an actual IPython instance, the user's rc.colors
104 104 # value is used, but havinga module global makes this functionality available
105 105 # to users of ultraTB who are NOT running inside ipython.
106 106 DEFAULT_SCHEME = 'NoColor'
107 107
108 108 #---------------------------------------------------------------------------
109 109 # Code begins
110 110
111 111 # Utility functions
112 112 def inspect_error():
113 113 """Print a message about internal inspect errors.
114 114
115 115 These are unfortunately quite common."""
116 116
117 117 error('Internal Python error in the inspect module.\n'
118 118 'Below is the traceback from this internal error.\n')
119 119
120 120 def _fixed_getinnerframes(etb, context=1,tb_offset=0):
121 121 import linecache
122 122 LNUM_POS, LINES_POS, INDEX_POS = 2, 4, 5
123 123
124 124 records = inspect.getinnerframes(etb, context)
125 125
126 126 # If the error is at the console, don't build any context, since it would
127 127 # otherwise produce 5 blank lines printed out (there is no file at the
128 128 # console)
129 129 rec_check = records[tb_offset:]
130 130 try:
131 131 rname = rec_check[0][1]
132 132 if rname == '<ipython console>' or rname.endswith('<string>'):
133 133 return rec_check
134 134 except IndexError:
135 135 pass
136 136
137 137 aux = traceback.extract_tb(etb)
138 138 assert len(records) == len(aux)
139 139 for i, (file, lnum, _, _) in zip(range(len(records)), aux):
140 140 maybeStart = lnum-1 - context//2
141 141 start = max(maybeStart, 0)
142 142 end = start + context
143 143 lines = linecache.getlines(file)[start:end]
144 144 # pad with empty lines if necessary
145 145 if maybeStart < 0:
146 146 lines = (['\n'] * -maybeStart) + lines
147 147 if len(lines) < context:
148 148 lines += ['\n'] * (context - len(lines))
149 149 buf = list(records[i])
150 150 buf[LNUM_POS] = lnum
151 151 buf[INDEX_POS] = lnum - 1 - start
152 152 buf[LINES_POS] = lines
153 153 records[i] = tuple(buf)
154 154 return records[tb_offset:]
155 155
156 156 # Helper function -- largely belongs to VerboseTB, but we need the same
157 157 # functionality to produce a pseudo verbose TB for SyntaxErrors, so that they
158 158 # can be recognized properly by ipython.el's py-traceback-line-re
159 159 # (SyntaxErrors have to be treated specially because they have no traceback)
160 160
161 161 _parser = PyColorize.Parser()
162 162
163 163 def _formatTracebackLines(lnum, index, lines, Colors, lvals=None,scheme=None):
164 164 numbers_width = INDENT_SIZE - 1
165 165 res = []
166 166 i = lnum - index
167 167
168 168 # This lets us get fully syntax-highlighted tracebacks.
169 169 if scheme is None:
170 170 try:
171 171 scheme = __IPYTHON__.rc.colors
172 172 except:
173 173 scheme = DEFAULT_SCHEME
174 174 _line_format = _parser.format2
175 175
176 176 for line in lines:
177 177 new_line, err = _line_format(line,'str',scheme)
178 178 if not err: line = new_line
179 179
180 180 if i == lnum:
181 181 # This is the line with the error
182 182 pad = numbers_width - len(str(i))
183 183 if pad >= 3:
184 184 marker = '-'*(pad-3) + '-> '
185 185 elif pad == 2:
186 186 marker = '> '
187 187 elif pad == 1:
188 188 marker = '>'
189 189 else:
190 190 marker = ''
191 191 num = marker + str(i)
192 192 line = '%s%s%s %s%s' %(Colors.linenoEm, num,
193 193 Colors.line, line, Colors.Normal)
194 194 else:
195 195 num = '%*s' % (numbers_width,i)
196 196 line = '%s%s%s %s' %(Colors.lineno, num,
197 197 Colors.Normal, line)
198 198
199 199 res.append(line)
200 200 if lvals and i == lnum:
201 201 res.append(lvals + '\n')
202 202 i = i + 1
203 203 return res
204 204
205 205
206 206 #---------------------------------------------------------------------------
207 207 # Module classes
208 208 class TBTools:
209 209 """Basic tools used by all traceback printer classes."""
210 210
211 211 def __init__(self,color_scheme = 'NoColor',call_pdb=False):
212 212 # Whether to call the interactive pdb debugger after printing
213 213 # tracebacks or not
214 214 self.call_pdb = call_pdb
215 215
216 216 # Create color table
217 217 self.color_scheme_table = ExceptionColors
218 218
219 219 self.set_colors(color_scheme)
220 220 self.old_scheme = color_scheme # save initial value for toggles
221 221
222 222 if call_pdb:
223 223 self.pdb = Debugger.Pdb(self.color_scheme_table.active_scheme_name)
224 224 else:
225 225 self.pdb = None
226 226
227 227 def set_colors(self,*args,**kw):
228 228 """Shorthand access to the color table scheme selector method."""
229 229
230 230 # Set own color table
231 231 self.color_scheme_table.set_active_scheme(*args,**kw)
232 232 # for convenience, set Colors to the active scheme
233 233 self.Colors = self.color_scheme_table.active_colors
234 234 # Also set colors of debugger
235 235 if hasattr(self,'pdb') and self.pdb is not None:
236 236 self.pdb.set_colors(*args,**kw)
237 237
238 238 def color_toggle(self):
239 239 """Toggle between the currently active color scheme and NoColor."""
240 240
241 241 if self.color_scheme_table.active_scheme_name == 'NoColor':
242 242 self.color_scheme_table.set_active_scheme(self.old_scheme)
243 243 self.Colors = self.color_scheme_table.active_colors
244 244 else:
245 245 self.old_scheme = self.color_scheme_table.active_scheme_name
246 246 self.color_scheme_table.set_active_scheme('NoColor')
247 247 self.Colors = self.color_scheme_table.active_colors
248 248
249 249 #---------------------------------------------------------------------------
250 250 class ListTB(TBTools):
251 251 """Print traceback information from a traceback list, with optional color.
252 252
253 253 Calling: requires 3 arguments:
254 254 (etype, evalue, elist)
255 255 as would be obtained by:
256 256 etype, evalue, tb = sys.exc_info()
257 257 if tb:
258 258 elist = traceback.extract_tb(tb)
259 259 else:
260 260 elist = None
261 261
262 262 It can thus be used by programs which need to process the traceback before
263 263 printing (such as console replacements based on the code module from the
264 264 standard library).
265 265
266 266 Because they are meant to be called without a full traceback (only a
267 267 list), instances of this class can't call the interactive pdb debugger."""
268 268
269 269 def __init__(self,color_scheme = 'NoColor'):
270 270 TBTools.__init__(self,color_scheme = color_scheme,call_pdb=0)
271 271
272 272 def __call__(self, etype, value, elist):
273 273 Term.cout.flush()
274 274 Term.cerr.flush()
275 275 print >> Term.cerr, self.text(etype,value,elist)
276 276
277 277 def text(self,etype, value, elist,context=5):
278 278 """Return a color formatted string with the traceback info."""
279 279
280 280 Colors = self.Colors
281 281 out_string = ['%s%s%s\n' % (Colors.topline,'-'*60,Colors.Normal)]
282 282 if elist:
283 283 out_string.append('Traceback %s(most recent call last)%s:' % \
284 284 (Colors.normalEm, Colors.Normal) + '\n')
285 285 out_string.extend(self._format_list(elist))
286 286 lines = self._format_exception_only(etype, value)
287 287 for line in lines[:-1]:
288 288 out_string.append(" "+line)
289 289 out_string.append(lines[-1])
290 290 return ''.join(out_string)
291 291
292 292 def _format_list(self, extracted_list):
293 293 """Format a list of traceback entry tuples for printing.
294 294
295 295 Given a list of tuples as returned by extract_tb() or
296 296 extract_stack(), return a list of strings ready for printing.
297 297 Each string in the resulting list corresponds to the item with the
298 298 same index in the argument list. Each string ends in a newline;
299 299 the strings may contain internal newlines as well, for those items
300 300 whose source text line is not None.
301 301
302 302 Lifted almost verbatim from traceback.py
303 303 """
304 304
305 305 Colors = self.Colors
306 306 list = []
307 307 for filename, lineno, name, line in extracted_list[:-1]:
308 308 item = ' File %s"%s"%s, line %s%d%s, in %s%s%s\n' % \
309 309 (Colors.filename, filename, Colors.Normal,
310 310 Colors.lineno, lineno, Colors.Normal,
311 311 Colors.name, name, Colors.Normal)
312 312 if line:
313 313 item = item + ' %s\n' % line.strip()
314 314 list.append(item)
315 315 # Emphasize the last entry
316 316 filename, lineno, name, line = extracted_list[-1]
317 317 item = '%s File %s"%s"%s, line %s%d%s, in %s%s%s%s\n' % \
318 318 (Colors.normalEm,
319 319 Colors.filenameEm, filename, Colors.normalEm,
320 320 Colors.linenoEm, lineno, Colors.normalEm,
321 321 Colors.nameEm, name, Colors.normalEm,
322 322 Colors.Normal)
323 323 if line:
324 324 item = item + '%s %s%s\n' % (Colors.line, line.strip(),
325 325 Colors.Normal)
326 326 list.append(item)
327 327 return list
328 328
329 329 def _format_exception_only(self, etype, value):
330 330 """Format the exception part of a traceback.
331 331
332 332 The arguments are the exception type and value such as given by
333 333 sys.exc_info()[:2]. The return value is a list of strings, each ending
334 334 in a newline. Normally, the list contains a single string; however,
335 335 for SyntaxError exceptions, it contains several lines that (when
336 336 printed) display detailed information about where the syntax error
337 337 occurred. The message indicating which exception occurred is the
338 338 always last string in the list.
339 339
340 340 Also lifted nearly verbatim from traceback.py
341 341 """
342 342
343 343 Colors = self.Colors
344 344 list = []
345 if type(etype) == types.ClassType:
345 try:
346 346 stype = Colors.excName + etype.__name__ + Colors.Normal
347 else:
347 except AttributeError:
348 348 stype = etype # String exceptions don't get special coloring
349 349 if value is None:
350 350 list.append( str(stype) + '\n')
351 351 else:
352 352 if etype is SyntaxError:
353 353 try:
354 354 msg, (filename, lineno, offset, line) = value
355 355 except:
356 356 pass
357 357 else:
358 358 #print 'filename is',filename # dbg
359 359 if not filename: filename = "<string>"
360 360 list.append('%s File %s"%s"%s, line %s%d%s\n' % \
361 361 (Colors.normalEm,
362 362 Colors.filenameEm, filename, Colors.normalEm,
363 363 Colors.linenoEm, lineno, Colors.Normal ))
364 364 if line is not None:
365 365 i = 0
366 366 while i < len(line) and line[i].isspace():
367 367 i = i+1
368 368 list.append('%s %s%s\n' % (Colors.line,
369 369 line.strip(),
370 370 Colors.Normal))
371 371 if offset is not None:
372 372 s = ' '
373 373 for c in line[i:offset-1]:
374 374 if c.isspace():
375 375 s = s + c
376 376 else:
377 377 s = s + ' '
378 378 list.append('%s%s^%s\n' % (Colors.caret, s,
379 379 Colors.Normal) )
380 380 value = msg
381 381 s = self._some_str(value)
382 382 if s:
383 383 list.append('%s%s:%s %s\n' % (str(stype), Colors.excName,
384 384 Colors.Normal, s))
385 385 else:
386 386 list.append('%s\n' % str(stype))
387 387 return list
388 388
389 389 def _some_str(self, value):
390 390 # Lifted from traceback.py
391 391 try:
392 392 return str(value)
393 393 except:
394 394 return '<unprintable %s object>' % type(value).__name__
395 395
396 396 #----------------------------------------------------------------------------
397 397 class VerboseTB(TBTools):
398 398 """A port of Ka-Ping Yee's cgitb.py module that outputs color text instead
399 399 of HTML. Requires inspect and pydoc. Crazy, man.
400 400
401 401 Modified version which optionally strips the topmost entries from the
402 402 traceback, to be used with alternate interpreters (because their own code
403 403 would appear in the traceback)."""
404 404
405 405 def __init__(self,color_scheme = 'Linux',tb_offset=0,long_header=0,
406 406 call_pdb = 0, include_vars=1):
407 407 """Specify traceback offset, headers and color scheme.
408 408
409 409 Define how many frames to drop from the tracebacks. Calling it with
410 410 tb_offset=1 allows use of this handler in interpreters which will have
411 411 their own code at the top of the traceback (VerboseTB will first
412 412 remove that frame before printing the traceback info)."""
413 413 TBTools.__init__(self,color_scheme=color_scheme,call_pdb=call_pdb)
414 414 self.tb_offset = tb_offset
415 415 self.long_header = long_header
416 416 self.include_vars = include_vars
417 417
418 418 def text(self, etype, evalue, etb, context=5):
419 419 """Return a nice text document describing the traceback."""
420 420
421 421 # some locals
422 try:
423 etype = etype.__name__
424 except AttributeError:
425 pass
422 426 Colors = self.Colors # just a shorthand + quicker name lookup
423 427 ColorsNormal = Colors.Normal # used a lot
424 428 col_scheme = self.color_scheme_table.active_scheme_name
425 429 indent = ' '*INDENT_SIZE
426 exc = '%s%s%s' % (Colors.excName, str(etype), ColorsNormal)
427 430 em_normal = '%s\n%s%s' % (Colors.valEm, indent,ColorsNormal)
428 431 undefined = '%sundefined%s' % (Colors.em, ColorsNormal)
432 exc = '%s%s%s' % (Colors.excName,etype,ColorsNormal)
429 433
430 434 # some internal-use functions
431 435 def text_repr(value):
432 436 """Hopefully pretty robust repr equivalent."""
433 437 # this is pretty horrible but should always return *something*
434 438 try:
435 439 return pydoc.text.repr(value)
436 440 except KeyboardInterrupt:
437 441 raise
438 442 except:
439 443 try:
440 444 return repr(value)
441 445 except KeyboardInterrupt:
442 446 raise
443 447 except:
444 448 try:
445 449 # all still in an except block so we catch
446 450 # getattr raising
447 451 name = getattr(value, '__name__', None)
448 452 if name:
449 453 # ick, recursion
450 454 return text_repr(name)
451 455 klass = getattr(value, '__class__', None)
452 456 if klass:
453 457 return '%s instance' % text_repr(klass)
454 458 except KeyboardInterrupt:
455 459 raise
456 460 except:
457 461 return 'UNRECOVERABLE REPR FAILURE'
458 462 def eqrepr(value, repr=text_repr): return '=%s' % repr(value)
459 463 def nullrepr(value, repr=text_repr): return ''
460 464
461 465 # meat of the code begins
462 if type(etype) is types.ClassType:
466 try:
463 467 etype = etype.__name__
468 except AttributeError:
469 pass
464 470
465 471 if self.long_header:
466 472 # Header with the exception type, python version, and date
467 473 pyver = 'Python ' + string.split(sys.version)[0] + ': ' + sys.executable
468 474 date = time.ctime(time.time())
469 475
470 476 head = '%s%s%s\n%s%s%s\n%s' % (Colors.topline, '-'*75, ColorsNormal,
471 477 exc, ' '*(75-len(str(etype))-len(pyver)),
472 478 pyver, string.rjust(date, 75) )
473 479 head += "\nA problem occured executing Python code. Here is the sequence of function"\
474 480 "\ncalls leading up to the error, with the most recent (innermost) call last."
475 481 else:
476 482 # Simplified header
477 483 head = '%s%s%s\n%s%s' % (Colors.topline, '-'*75, ColorsNormal,exc,
478 484 string.rjust('Traceback (most recent call last)',
479 485 75 - len(str(etype)) ) )
480 486 frames = []
481 487 # Flush cache before calling inspect. This helps alleviate some of the
482 488 # problems with python 2.3's inspect.py.
483 489 linecache.checkcache()
484 490 # Drop topmost frames if requested
485 491 try:
486 492 # Try the default getinnerframes and Alex's: Alex's fixes some
487 493 # problems, but it generates empty tracebacks for console errors
488 494 # (5 blanks lines) where none should be returned.
489 495 #records = inspect.getinnerframes(etb, context)[self.tb_offset:]
490 496 #print 'python records:', records # dbg
491 497 records = _fixed_getinnerframes(etb, context,self.tb_offset)
492 498 #print 'alex records:', records # dbg
493 499 except:
494 500
495 501 # FIXME: I've been getting many crash reports from python 2.3
496 502 # users, traceable to inspect.py. If I can find a small test-case
497 503 # to reproduce this, I should either write a better workaround or
498 504 # file a bug report against inspect (if that's the real problem).
499 505 # So far, I haven't been able to find an isolated example to
500 506 # reproduce the problem.
501 507 inspect_error()
502 508 traceback.print_exc(file=Term.cerr)
503 509 info('\nUnfortunately, your original traceback can not be constructed.\n')
504 510 return ''
505 511
506 512 # build some color string templates outside these nested loops
507 513 tpl_link = '%s%%s%s' % (Colors.filenameEm,ColorsNormal)
508 514 tpl_call = 'in %s%%s%s%%s%s' % (Colors.vName, Colors.valEm,
509 515 ColorsNormal)
510 516 tpl_call_fail = 'in %s%%s%s(***failed resolving arguments***)%s' % \
511 517 (Colors.vName, Colors.valEm, ColorsNormal)
512 518 tpl_local_var = '%s%%s%s' % (Colors.vName, ColorsNormal)
513 519 tpl_global_var = '%sglobal%s %s%%s%s' % (Colors.em, ColorsNormal,
514 520 Colors.vName, ColorsNormal)
515 521 tpl_name_val = '%%s %s= %%s%s' % (Colors.valEm, ColorsNormal)
516 522 tpl_line = '%s%%s%s %%s' % (Colors.lineno, ColorsNormal)
517 523 tpl_line_em = '%s%%s%s %%s%s' % (Colors.linenoEm,Colors.line,
518 524 ColorsNormal)
519 525
520 526 # now, loop over all records printing context and info
521 527 abspath = os.path.abspath
522 528 for frame, file, lnum, func, lines, index in records:
523 529 #print '*** record:',file,lnum,func,lines,index # dbg
524 530 try:
525 531 file = file and abspath(file) or '?'
526 532 except OSError:
527 533 # if file is '<console>' or something not in the filesystem,
528 534 # the abspath call will throw an OSError. Just ignore it and
529 535 # keep the original file string.
530 536 pass
531 537 link = tpl_link % file
532 538 try:
533 539 args, varargs, varkw, locals = inspect.getargvalues(frame)
534 540 except:
535 541 # This can happen due to a bug in python2.3. We should be
536 542 # able to remove this try/except when 2.4 becomes a
537 543 # requirement. Bug details at http://python.org/sf/1005466
538 544 inspect_error()
539 545 traceback.print_exc(file=Term.cerr)
540 546 info("\nIPython's exception reporting continues...\n")
541 547
542 548 if func == '?':
543 549 call = ''
544 550 else:
545 551 # Decide whether to include variable details or not
546 552 var_repr = self.include_vars and eqrepr or nullrepr
547 553 try:
548 554 call = tpl_call % (func,inspect.formatargvalues(args,
549 555 varargs, varkw,
550 556 locals,formatvalue=var_repr))
551 557 except KeyError:
552 558 # Very odd crash from inspect.formatargvalues(). The
553 559 # scenario under which it appeared was a call to
554 560 # view(array,scale) in NumTut.view.view(), where scale had
555 561 # been defined as a scalar (it should be a tuple). Somehow
556 562 # inspect messes up resolving the argument list of view()
557 563 # and barfs out. At some point I should dig into this one
558 564 # and file a bug report about it.
559 565 inspect_error()
560 566 traceback.print_exc(file=Term.cerr)
561 567 info("\nIPython's exception reporting continues...\n")
562 568 call = tpl_call_fail % func
563 569
564 570 # Initialize a list of names on the current line, which the
565 571 # tokenizer below will populate.
566 572 names = []
567 573
568 574 def tokeneater(token_type, token, start, end, line):
569 575 """Stateful tokeneater which builds dotted names.
570 576
571 577 The list of names it appends to (from the enclosing scope) can
572 578 contain repeated composite names. This is unavoidable, since
573 579 there is no way to disambguate partial dotted structures until
574 580 the full list is known. The caller is responsible for pruning
575 581 the final list of duplicates before using it."""
576 582
577 583 # build composite names
578 584 if token == '.':
579 585 try:
580 586 names[-1] += '.'
581 587 # store state so the next token is added for x.y.z names
582 588 tokeneater.name_cont = True
583 589 return
584 590 except IndexError:
585 591 pass
586 592 if token_type == tokenize.NAME and token not in keyword.kwlist:
587 593 if tokeneater.name_cont:
588 594 # Dotted names
589 595 names[-1] += token
590 596 tokeneater.name_cont = False
591 597 else:
592 598 # Regular new names. We append everything, the caller
593 599 # will be responsible for pruning the list later. It's
594 600 # very tricky to try to prune as we go, b/c composite
595 601 # names can fool us. The pruning at the end is easy
596 602 # to do (or the caller can print a list with repeated
597 603 # names if so desired.
598 604 names.append(token)
599 605 elif token_type == tokenize.NEWLINE:
600 606 raise IndexError
601 607 # we need to store a bit of state in the tokenizer to build
602 608 # dotted names
603 609 tokeneater.name_cont = False
604 610
605 611 def linereader(file=file, lnum=[lnum], getline=linecache.getline):
606 612 line = getline(file, lnum[0])
607 613 lnum[0] += 1
608 614 return line
609 615
610 616 # Build the list of names on this line of code where the exception
611 617 # occurred.
612 618 try:
613 619 # This builds the names list in-place by capturing it from the
614 620 # enclosing scope.
615 621 tokenize.tokenize(linereader, tokeneater)
616 622 except IndexError:
617 623 # signals exit of tokenizer
618 624 pass
619 625 except tokenize.TokenError,msg:
620 626 _m = ("An unexpected error occurred while tokenizing input\n"
621 627 "The following traceback may be corrupted or invalid\n"
622 628 "The error message is: %s\n" % msg)
623 629 error(_m)
624 630
625 631 # prune names list of duplicates, but keep the right order
626 632 unique_names = uniq_stable(names)
627 633
628 634 # Start loop over vars
629 635 lvals = []
630 636 if self.include_vars:
631 637 for name_full in unique_names:
632 638 name_base = name_full.split('.',1)[0]
633 639 if name_base in frame.f_code.co_varnames:
634 640 if locals.has_key(name_base):
635 641 try:
636 642 value = repr(eval(name_full,locals))
637 643 except:
638 644 value = undefined
639 645 else:
640 646 value = undefined
641 647 name = tpl_local_var % name_full
642 648 else:
643 649 if frame.f_globals.has_key(name_base):
644 650 try:
645 651 value = repr(eval(name_full,frame.f_globals))
646 652 except:
647 653 value = undefined
648 654 else:
649 655 value = undefined
650 656 name = tpl_global_var % name_full
651 657 lvals.append(tpl_name_val % (name,value))
652 658 if lvals:
653 659 lvals = '%s%s' % (indent,em_normal.join(lvals))
654 660 else:
655 661 lvals = ''
656 662
657 663 level = '%s %s\n' % (link,call)
658 664
659 665 if index is None:
660 666 frames.append(level)
661 667 else:
662 668 frames.append('%s%s' % (level,''.join(
663 669 _formatTracebackLines(lnum,index,lines,Colors,lvals,
664 670 col_scheme))))
665 671
666 672 # Get (safely) a string form of the exception info
667 673 try:
668 674 etype_str,evalue_str = map(str,(etype,evalue))
669 675 except:
670 676 # User exception is improperly defined.
671 677 etype,evalue = str,sys.exc_info()[:2]
672 678 etype_str,evalue_str = map(str,(etype,evalue))
673 679 # ... and format it
674 680 exception = ['%s%s%s: %s' % (Colors.excName, etype_str,
675 681 ColorsNormal, evalue_str)]
676 682 if type(evalue) is types.InstanceType:
677 683 try:
678 684 names = [w for w in dir(evalue) if isinstance(w, basestring)]
679 685 except:
680 686 # Every now and then, an object with funny inernals blows up
681 687 # when dir() is called on it. We do the best we can to report
682 688 # the problem and continue
683 689 _m = '%sException reporting error (object with broken dir())%s:'
684 690 exception.append(_m % (Colors.excName,ColorsNormal))
685 691 etype_str,evalue_str = map(str,sys.exc_info()[:2])
686 692 exception.append('%s%s%s: %s' % (Colors.excName,etype_str,
687 693 ColorsNormal, evalue_str))
688 694 names = []
689 695 for name in names:
690 696 value = text_repr(getattr(evalue, name))
691 697 exception.append('\n%s%s = %s' % (indent, name, value))
692 698 # return all our info assembled as a single string
693 699 return '%s\n\n%s\n%s' % (head,'\n'.join(frames),''.join(exception[0]) )
694 700
695 701 def debugger(self,force=False):
696 702 """Call up the pdb debugger if desired, always clean up the tb
697 703 reference.
698 704
699 705 Keywords:
700 706
701 707 - force(False): by default, this routine checks the instance call_pdb
702 708 flag and does not actually invoke the debugger if the flag is false.
703 709 The 'force' option forces the debugger to activate even if the flag
704 710 is false.
705 711
706 712 If the call_pdb flag is set, the pdb interactive debugger is
707 713 invoked. In all cases, the self.tb reference to the current traceback
708 714 is deleted to prevent lingering references which hamper memory
709 715 management.
710 716
711 717 Note that each call to pdb() does an 'import readline', so if your app
712 718 requires a special setup for the readline completers, you'll have to
713 719 fix that by hand after invoking the exception handler."""
714 720
715 721 if force or self.call_pdb:
716 722 if self.pdb is None:
717 723 self.pdb = Debugger.Pdb(
718 724 self.color_scheme_table.active_scheme_name)
719 725 # the system displayhook may have changed, restore the original
720 726 # for pdb
721 727 dhook = sys.displayhook
722 728 sys.displayhook = sys.__displayhook__
723 729 self.pdb.reset()
724 730 # Find the right frame so we don't pop up inside ipython itself
725 731 if hasattr(self,'tb'):
726 732 etb = self.tb
727 733 else:
728 734 etb = self.tb = sys.last_traceback
729 735 while self.tb.tb_next is not None:
730 736 self.tb = self.tb.tb_next
731 737 try:
732 738 if etb and etb.tb_next:
733 739 etb = etb.tb_next
734 740 self.pdb.botframe = etb.tb_frame
735 741 self.pdb.interaction(self.tb.tb_frame, self.tb)
736 742 finally:
737 743 sys.displayhook = dhook
738 744
739 745 if hasattr(self,'tb'):
740 746 del self.tb
741 747
742 748 def handler(self, info=None):
743 749 (etype, evalue, etb) = info or sys.exc_info()
744 750 self.tb = etb
745 751 Term.cout.flush()
746 752 Term.cerr.flush()
747 753 print >> Term.cerr, self.text(etype, evalue, etb)
748 754
749 755 # Changed so an instance can just be called as VerboseTB_inst() and print
750 756 # out the right info on its own.
751 757 def __call__(self, etype=None, evalue=None, etb=None):
752 758 """This hook can replace sys.excepthook (for Python 2.1 or higher)."""
753 759 if etb is None:
754 760 self.handler()
755 761 else:
756 762 self.handler((etype, evalue, etb))
757 763 self.debugger()
758 764
759 765 #----------------------------------------------------------------------------
760 766 class FormattedTB(VerboseTB,ListTB):
761 767 """Subclass ListTB but allow calling with a traceback.
762 768
763 769 It can thus be used as a sys.excepthook for Python > 2.1.
764 770
765 771 Also adds 'Context' and 'Verbose' modes, not available in ListTB.
766 772
767 773 Allows a tb_offset to be specified. This is useful for situations where
768 774 one needs to remove a number of topmost frames from the traceback (such as
769 775 occurs with python programs that themselves execute other python code,
770 776 like Python shells). """
771 777
772 778 def __init__(self, mode = 'Plain', color_scheme='Linux',
773 779 tb_offset = 0,long_header=0,call_pdb=0,include_vars=0):
774 780
775 781 # NEVER change the order of this list. Put new modes at the end:
776 782 self.valid_modes = ['Plain','Context','Verbose']
777 783 self.verbose_modes = self.valid_modes[1:3]
778 784
779 785 VerboseTB.__init__(self,color_scheme,tb_offset,long_header,
780 786 call_pdb=call_pdb,include_vars=include_vars)
781 787 self.set_mode(mode)
782 788
783 789 def _extract_tb(self,tb):
784 790 if tb:
785 791 return traceback.extract_tb(tb)
786 792 else:
787 793 return None
788 794
789 795 def text(self, etype, value, tb,context=5,mode=None):
790 796 """Return formatted traceback.
791 797
792 798 If the optional mode parameter is given, it overrides the current
793 799 mode."""
794 800
795 801 if mode is None:
796 802 mode = self.mode
797 803 if mode in self.verbose_modes:
798 804 # verbose modes need a full traceback
799 805 return VerboseTB.text(self,etype, value, tb,context=5)
800 806 else:
801 807 # We must check the source cache because otherwise we can print
802 808 # out-of-date source code.
803 809 linecache.checkcache()
804 810 # Now we can extract and format the exception
805 811 elist = self._extract_tb(tb)
806 812 if len(elist) > self.tb_offset:
807 813 del elist[:self.tb_offset]
808 814 return ListTB.text(self,etype,value,elist)
809 815
810 816 def set_mode(self,mode=None):
811 817 """Switch to the desired mode.
812 818
813 819 If mode is not specified, cycles through the available modes."""
814 820
815 821 if not mode:
816 822 new_idx = ( self.valid_modes.index(self.mode) + 1 ) % \
817 823 len(self.valid_modes)
818 824 self.mode = self.valid_modes[new_idx]
819 825 elif mode not in self.valid_modes:
820 826 raise ValueError, 'Unrecognized mode in FormattedTB: <'+mode+'>\n'\
821 827 'Valid modes: '+str(self.valid_modes)
822 828 else:
823 829 self.mode = mode
824 830 # include variable details only in 'Verbose' mode
825 831 self.include_vars = (self.mode == self.valid_modes[2])
826 832
827 833 # some convenient shorcuts
828 834 def plain(self):
829 835 self.set_mode(self.valid_modes[0])
830 836
831 837 def context(self):
832 838 self.set_mode(self.valid_modes[1])
833 839
834 840 def verbose(self):
835 841 self.set_mode(self.valid_modes[2])
836 842
837 843 #----------------------------------------------------------------------------
838 844 class AutoFormattedTB(FormattedTB):
839 845 """A traceback printer which can be called on the fly.
840 846
841 847 It will find out about exceptions by itself.
842 848
843 849 A brief example:
844 850
845 851 AutoTB = AutoFormattedTB(mode = 'Verbose',color_scheme='Linux')
846 852 try:
847 853 ...
848 854 except:
849 855 AutoTB() # or AutoTB(out=logfile) where logfile is an open file object
850 856 """
851 857 def __call__(self,etype=None,evalue=None,etb=None,
852 858 out=None,tb_offset=None):
853 859 """Print out a formatted exception traceback.
854 860
855 861 Optional arguments:
856 862 - out: an open file-like object to direct output to.
857 863
858 864 - tb_offset: the number of frames to skip over in the stack, on a
859 865 per-call basis (this overrides temporarily the instance's tb_offset
860 866 given at initialization time. """
861 867
862 868 if out is None:
863 869 out = Term.cerr
864 870 Term.cout.flush()
865 871 out.flush()
866 872 if tb_offset is not None:
867 873 tb_offset, self.tb_offset = self.tb_offset, tb_offset
868 874 print >> out, self.text(etype, evalue, etb)
869 875 self.tb_offset = tb_offset
870 876 else:
871 877 print >> out, self.text(etype, evalue, etb)
872 878 self.debugger()
873 879
874 880 def text(self,etype=None,value=None,tb=None,context=5,mode=None):
875 881 if etype is None:
876 882 etype,value,tb = sys.exc_info()
877 883 self.tb = tb
878 884 return FormattedTB.text(self,etype,value,tb,context=5,mode=mode)
879 885
880 886 #---------------------------------------------------------------------------
881 887 # A simple class to preserve Nathan's original functionality.
882 888 class ColorTB(FormattedTB):
883 889 """Shorthand to initialize a FormattedTB in Linux colors mode."""
884 890 def __init__(self,color_scheme='Linux',call_pdb=0):
885 891 FormattedTB.__init__(self,color_scheme=color_scheme,
886 892 call_pdb=call_pdb)
887 893
888 894 #----------------------------------------------------------------------------
889 895 # module testing (minimal)
890 896 if __name__ == "__main__":
891 897 def spam(c, (d, e)):
892 898 x = c + d
893 899 y = c * d
894 900 foo(x, y)
895 901
896 902 def foo(a, b, bar=1):
897 903 eggs(a, b + bar)
898 904
899 905 def eggs(f, g, z=globals()):
900 906 h = f + g
901 907 i = f - g
902 908 return h / i
903 909
904 910 print ''
905 911 print '*** Before ***'
906 912 try:
907 913 print spam(1, (2, 3))
908 914 except:
909 915 traceback.print_exc()
910 916 print ''
911 917
912 918 handler = ColorTB()
913 919 print '*** ColorTB ***'
914 920 try:
915 921 print spam(1, (2, 3))
916 922 except:
917 923 apply(handler, sys.exc_info() )
918 924 print ''
919 925
920 926 handler = VerboseTB()
921 927 print '*** VerboseTB ***'
922 928 try:
923 929 print spam(1, (2, 3))
924 930 except:
925 931 apply(handler, sys.exc_info() )
926 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 7 2007-05-31 Walter Doerwald <walter@livinglogic.de>
2 8
3 9 * IPython/Extensions/igrid.py: Add new commands refresh and
4 10 refresh_timer (mapped to "R"/"F5" and to the menu) which restarts
5 11 the iterator once (refresh) or after every x seconds (refresh_timer).
6 12 Add a working implementation of "searchexpression", where the text
7 13 entered is not the text to search for, but an expression that must
8 14 be true. Added display of shortcuts to the menu. Added commands "pickinput"
9 15 and "pickinputattr" that put the object or attribute under the cursor
10 16 in the input line. Split the statusbar to be able to display the currently
11 17 active refresh interval. (Patch by Nik Tautenhahn)
12 18
13 19 2007-05-29 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
14 20
15 21 * fixing set_term_title to use ctypes as default
16 22
17 23 * fixing set_term_title fallback to work when curent dir
18 24 is on a windows network share
19 25
20 26 2007-05-28 Ville Vainio <vivainio@gmail.com>
21 27
22 28 * %cpaste: strip + with > from left (diffs).
23 29
24 30 * iplib.py: Fix crash when readline not installed
25 31
26 32 2007-05-26 Ville Vainio <vivainio@gmail.com>
27 33
28 34 * generics.py: intruduce easy to extend result_display generic
29 35 function (using simplegeneric.py).
30 36
31 37 * Fixed the append functionality of %set.
32 38
33 39 2007-05-25 Ville Vainio <vivainio@gmail.com>
34 40
35 41 * New magic: %rep (fetch / run old commands from history)
36 42
37 43 * New extension: mglob (%mglob magic), for powerful glob / find /filter
38 44 like functionality
39 45
40 46 % maghistory.py: %hist -g PATTERM greps the history for pattern
41 47
42 48 2007-05-24 Walter Doerwald <walter@livinglogic.de>
43 49
44 50 * IPython/Extensions/ipipe.py: Added a Table ihist that can be used to
45 51 browse the IPython input history
46 52
47 53 * IPython/Extensions/ibrowse.py: Added two command to ibrowse: pickinput
48 54 (mapped to "i") can be used to put the object under the curser in the input
49 55 line. pickinputattr (mapped to "I") does the same for the attribute under
50 56 the cursor.
51 57
52 58 2007-05-24 Ville Vainio <vivainio@gmail.com>
53 59
54 60 * Grand magic cleansing (changeset [2380]):
55 61
56 62 * Introduce ipy_legacy.py where the following magics were
57 63 moved:
58 64
59 65 pdef pdoc psource pfile rehash dhist Quit p r automagic autocall
60 66
61 67 If you need them, either use default profile or "import ipy_legacy"
62 68 in your ipy_user_conf.py
63 69
64 70 * Move sh and scipy profile to Extensions from UserConfig. this implies
65 71 you should not edit them, but you don't need to run %upgrade when
66 72 upgrading IPython anymore.
67 73
68 74 * %hist/%history now operates in "raw" mode by default. To get the old
69 75 behaviour, run '%hist -n' (native mode).
70 76
71 77 * split ipy_stock_completers.py to ipy_stock_completers.py and
72 78 ipy_app_completers.py. Stock completers (%cd, import, %run) are now
73 79 installed as default.
74 80
75 81 * sh profile now installs ipy_signals.py, for (hopefully) better ctrl+c
76 82 handling.
77 83
78 84 * iplib.py, ipapi.py: _ip.set_next_input(s) sets the next ("default")
79 85 input if readline is available.
80 86
81 87 2007-05-23 Ville Vainio <vivainio@gmail.com>
82 88
83 89 * macro.py: %store uses __getstate__ properly
84 90
85 91 * exesetup.py: added new setup script for creating
86 92 standalone IPython executables with py2exe (i.e.
87 93 no python installation required).
88 94
89 95 * Removed ipythonrc-scipy, ipy_profile_scipy.py takes
90 96 its place.
91 97
92 98 * rlineimpl.py, genutils.py (get_home_dir): py2exe support
93 99
94 100 2007-05-21 Ville Vainio <vivainio@gmail.com>
95 101
96 102 * platutil_win32.py (set_term_title): handle
97 103 failure of 'title' system call properly.
98 104
99 105 2007-05-17 Walter Doerwald <walter@livinglogic.de>
100 106
101 107 * IPython/Extensions/ipipe.py: Fix xrepr for ifiles.
102 108 (Bug detected by Paul Mueller).
103 109
104 110 2007-05-16 Ville Vainio <vivainio@gmail.com>
105 111
106 112 * ipy_profile_sci.py, ipython_win_post_install.py: Create
107 113 new "sci" profile, effectively a modern version of the old
108 114 "scipy" profile (which is now slated for deprecation).
109 115
110 116 2007-05-15 Ville Vainio <vivainio@gmail.com>
111 117
112 118 * pycolorize.py, pycolor.1: Paul Mueller's patches that
113 119 make pycolorize read input from stdin when run without arguments.
114 120
115 121 * Magic.py: do not require 'PATH' in %rehash/%rehashx. Closes #155
116 122
117 123 * ipy_rehashdir.py: rename ext_rehashdir to ipy_rehashdir, import
118 124 it in sh profile (instead of ipy_system_conf.py).
119 125
120 126 * Magic.py, ipy_rehashdir.py, ipy_profile_sh.py: System command
121 127 aliases are now lower case on windows (MyCommand.exe => mycommand).
122 128
123 129 * macro.py, ipapi.py, iplib.py, Prompts.py: Macro system rehaul.
124 130 Macros are now callable objects that inherit from ipapi.IPyAutocall,
125 131 i.e. get autocalled regardless of system autocall setting.
126 132
127 133 2007-05-10 Fernando Perez <Fernando.Perez@colorado.edu>
128 134
129 135 * IPython/rlineimpl.py: check for clear_history in readline and
130 136 make it a dummy no-op if not available. This function isn't
131 137 guaranteed to be in the API and appeared in Python 2.4, so we need
132 138 to check it ourselves. Also, clean up this file quite a bit.
133 139
134 140 * ipython.1: update man page and full manual with information
135 141 about threads (remove outdated warning). Closes #151.
136 142
137 143 2007-05-09 Fernando Perez <Fernando.Perez@colorado.edu>
138 144
139 145 * IPython/Extensions/ipy_constants.py: Add Gael's constants module
140 146 in trunk (note that this made it into the 0.8.1 release already,
141 147 but the changelogs didn't get coordinated). Many thanks to Gael
142 148 Varoquaux <gael.varoquaux-AT-normalesup.org>
143 149
144 150 2007-05-09 *** Released version 0.8.1
145 151
146 152 2007-05-10 Walter Doerwald <walter@livinglogic.de>
147 153
148 154 * IPython/Extensions/igrid.py: Incorporate html help into
149 155 the module, so we don't have to search for the file.
150 156
151 157 2007-05-02 Fernando Perez <Fernando.Perez@colorado.edu>
152 158
153 159 * test/test_irunner.py (RunnerTestCase._test_runner): Close #147.
154 160
155 161 2007-04-30 Ville Vainio <vivainio@gmail.com>
156 162
157 163 * iplib.py: (pre_config_initialization) Catch UnicodeDecodeError if the
158 164 user has illegal (non-ascii) home directory name
159 165
160 166 2007-04-27 Ville Vainio <vivainio@gmail.com>
161 167
162 168 * platutils_win32.py: implement set_term_title for windows
163 169
164 170 * Update version number
165 171
166 172 * ipy_profile_sh.py: more informative prompt (2 dir levels)
167 173
168 174 2007-04-26 Walter Doerwald <walter@livinglogic.de>
169 175
170 176 * IPython/Extensions/igrid.py: (igrid) Fix bug that surfaced
171 177 when the igrid input raised an exception. (Patch by Nik Tautenhahn,
172 178 bug discovered by Ville).
173 179
174 180 2007-04-26 Ville Vainio <vivainio@gmail.com>
175 181
176 182 * Extensions/ipy_completers.py: Olivier's module completer now
177 183 saves the list of root modules if it takes > 4 secs on the first run.
178 184
179 185 * Magic.py (%rehashx): %rehashx now clears the completer cache
180 186
181 187
182 188 2007-04-26 Fernando Perez <Fernando.Perez@colorado.edu>
183 189
184 190 * ipython.el: fix incorrect color scheme, reported by Stefan.
185 191 Closes #149.
186 192
187 193 * IPython/PyColorize.py (Parser.format2): fix state-handling
188 194 logic. I still don't like how that code handles state, but at
189 195 least now it should be correct, if inelegant. Closes #146.
190 196
191 197 2007-04-25 Ville Vainio <vivainio@gmail.com>
192 198
193 199 * Extensions/ipy_which.py: added extension for %which magic, works
194 200 a lot like unix 'which' but also finds and expands aliases, and
195 201 allows wildcards.
196 202
197 203 * ipapi.py (expand_alias): Now actually *return* the expanded alias,
198 204 as opposed to returning nothing.
199 205
200 206 * UserConfig/ipy_user_conf.py, ipy_profile_sh.py: do not import
201 207 ipy_stock_completers on default profile, do import on sh profile.
202 208
203 209 2007-04-22 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
204 210
205 211 * Fix bug in iplib.py/safe_execfile when launching ipython with a script
206 212 like ipython.py foo.py which raised a IndexError.
207 213
208 214 2007-04-21 Ville Vainio <vivainio@gmail.com>
209 215
210 216 * Extensions/ipy_extutil.py: added extension to manage other ipython
211 217 extensions. Now only supports 'ls' == list extensions.
212 218
213 219 2007-04-20 Fernando Perez <Fernando.Perez@colorado.edu>
214 220
215 221 * IPython/Debugger.py (BdbQuit_excepthook): fix small bug that
216 222 would prevent use of the exception system outside of a running
217 223 IPython instance.
218 224
219 225 2007-04-20 Ville Vainio <vivainio@gmail.com>
220 226
221 227 * Extensions/ipy_render.py: added extension for easy
222 228 interactive text template rendering (to clipboard). Uses Ka-Ping Yee's
223 229 'Iptl' template notation,
224 230
225 231 * Extensions/ipy_completers.py: introduced Olivier Lauzanne's
226 232 safer & faster 'import' completer.
227 233
228 234 * ipapi.py: Introduced new ipapi methods, _ip.defmacro(name, value)
229 235 and _ip.defalias(name, command).
230 236
231 237 * Extensions/ipy_exportdb.py: New extension for exporting all the
232 238 %store'd data in a portable format (normal ipapi calls like
233 239 defmacro() etc.)
234 240
235 241 2007-04-19 Ville Vainio <vivainio@gmail.com>
236 242
237 243 * upgrade_dir.py: skip junk files like *.pyc
238 244
239 245 * Release.py: version number to 0.8.1
240 246
241 247 2007-04-18 Ville Vainio <vivainio@gmail.com>
242 248
243 249 * iplib.py (safe_execfile): make "ipython foo.py" work with 2.5.1c1
244 250 and later on win32.
245 251
246 252 2007-04-16 Ville Vainio <vivainio@gmail.com>
247 253
248 254 * iplib.py (showtraceback): Do not crash when running w/o readline.
249 255
250 256 2007-04-12 Walter Doerwald <walter@livinglogic.de>
251 257
252 258 * IPython/Extensions/ipipe.py: (ils) Directoy listings are now
253 259 sorted (case sensitive with files and dirs mixed).
254 260
255 261 2007-04-10 Fernando Perez <Fernando.Perez@colorado.edu>
256 262
257 263 * IPython/Release.py (version): Open trunk for 0.8.1 development.
258 264
259 265 2007-04-10 *** Released version 0.8.0
260 266
261 267 2007-04-07 Fernando Perez <Fernando.Perez@colorado.edu>
262 268
263 269 * Tag 0.8.0 for release.
264 270
265 271 * IPython/iplib.py (reloadhist): add API function to cleanly
266 272 reload the readline history, which was growing inappropriately on
267 273 every %run call.
268 274
269 275 * win32_manual_post_install.py (run): apply last part of Nicolas
270 276 Pernetty's patch (I'd accidentally applied it in a different
271 277 directory and this particular file didn't get patched).
272 278
273 279 2007-04-05 Fernando Perez <Fernando.Perez@colorado.edu>
274 280
275 281 * IPython/Shell.py (MAIN_THREAD_ID): get rid of my stupid hack to
276 282 find the main thread id and use the proper API call. Thanks to
277 283 Stefan for the fix.
278 284
279 285 * test/test_prefilter.py (esc_handler_tests): udpate one of Dan's
280 286 unit tests to reflect fixed ticket #52, and add more tests sent by
281 287 him.
282 288
283 289 * IPython/iplib.py (raw_input): restore the readline completer
284 290 state on every input, in case third-party code messed it up.
285 291 (_prefilter): revert recent addition of early-escape checks which
286 292 prevent many valid alias calls from working.
287 293
288 294 * IPython/Shell.py (MTInteractiveShell.runcode): add a tracking
289 295 flag for sigint handler so we don't run a full signal() call on
290 296 each runcode access.
291 297
292 298 * IPython/Magic.py (magic_whos): small improvement to diagnostic
293 299 message.
294 300
295 301 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
296 302
297 303 * IPython/Shell.py (sigint_handler): I *THINK* I finally got
298 304 asynchronous exceptions working, i.e., Ctrl-C can actually
299 305 interrupt long-running code in the multithreaded shells.
300 306
301 307 This is using Tomer Filiba's great ctypes-based trick:
302 308 http://sebulba.wikispaces.com/recipe+thread2. I'd already tried
303 309 this in the past, but hadn't been able to make it work before. So
304 310 far it looks like it's actually running, but this needs more
305 311 testing. If it really works, I'll be *very* happy, and we'll owe
306 312 a huge thank you to Tomer. My current implementation is ugly,
307 313 hackish and uses nasty globals, but I don't want to try and clean
308 314 anything up until we know if it actually works.
309 315
310 316 NOTE: this feature needs ctypes to work. ctypes is included in
311 317 Python2.5, but 2.4 users will need to manually install it. This
312 318 feature makes multi-threaded shells so much more usable that it's
313 319 a minor price to pay (ctypes is very easy to install, already a
314 320 requirement for win32 and available in major linux distros).
315 321
316 322 2007-04-04 Ville Vainio <vivainio@gmail.com>
317 323
318 324 * Extensions/ipy_completers.py, ipy_stock_completers.py:
319 325 Moved implementations of 'bundled' completers to ipy_completers.py,
320 326 they are only enabled in ipy_stock_completers.py.
321 327
322 328 2007-04-04 Fernando Perez <Fernando.Perez@colorado.edu>
323 329
324 330 * IPython/PyColorize.py (Parser.format2): Fix identation of
325 331 colorzied output and return early if color scheme is NoColor, to
326 332 avoid unnecessary and expensive tokenization. Closes #131.
327 333
328 334 2007-04-03 Fernando Perez <Fernando.Perez@colorado.edu>
329 335
330 336 * IPython/Debugger.py: disable the use of pydb version 1.17. It
331 337 has a critical bug (a missing import that makes post-mortem not
332 338 work at all). Unfortunately as of this time, this is the version
333 339 shipped with Ubuntu Edgy, so quite a few people have this one. I
334 340 hope Edgy will update to a more recent package.
335 341
336 342 2007-04-02 Fernando Perez <Fernando.Perez@colorado.edu>
337 343
338 344 * IPython/iplib.py (_prefilter): close #52, second part of a patch
339 345 set by Stefan (only the first part had been applied before).
340 346
341 347 * IPython/Extensions/ipy_stock_completers.py (module_completer):
342 348 remove usage of the dangerous pkgutil.walk_packages(). See
343 349 details in comments left in the code.
344 350
345 351 * IPython/Magic.py (magic_whos): add support for numpy arrays
346 352 similar to what we had for Numeric.
347 353
348 354 * IPython/completer.py (IPCompleter.complete): extend the
349 355 complete() call API to support completions by other mechanisms
350 356 than readline. Closes #109.
351 357
352 358 * IPython/iplib.py (safe_execfile): add a safeguard under Win32 to
353 359 protect against a bug in Python's execfile(). Closes #123.
354 360
355 361 2007-04-01 Fernando Perez <Fernando.Perez@colorado.edu>
356 362
357 363 * IPython/iplib.py (split_user_input): ensure that when splitting
358 364 user input, the part that can be treated as a python name is pure
359 365 ascii (Python identifiers MUST be pure ascii). Part of the
360 366 ongoing Unicode support work.
361 367
362 368 * IPython/Prompts.py (prompt_specials_color): Add \N for the
363 369 actual prompt number, without any coloring. This allows users to
364 370 produce numbered prompts with their own colors. Added after a
365 371 report/request by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
366 372
367 373 2007-03-31 Walter Doerwald <walter@livinglogic.de>
368 374
369 375 * IPython/Extensions/igrid.py: Map the return key
370 376 to enter() and shift-return to enterattr().
371 377
372 378 2007-03-30 Fernando Perez <Fernando.Perez@colorado.edu>
373 379
374 380 * IPython/Magic.py (magic_psearch): add unicode support by
375 381 encoding to ascii the input, since this routine also only deals
376 382 with valid Python names. Fixes a bug reported by Stefan.
377 383
378 384 2007-03-29 Fernando Perez <Fernando.Perez@colorado.edu>
379 385
380 386 * IPython/Magic.py (_inspect): convert unicode input into ascii
381 387 before trying to evaluate it as a Python identifier. This fixes a
382 388 problem that the new unicode support had introduced when analyzing
383 389 long definition lines for functions.
384 390
385 391 2007-03-24 Walter Doerwald <walter@livinglogic.de>
386 392
387 393 * IPython/Extensions/igrid.py: Fix picking. Using
388 394 igrid with wxPython 2.6 and -wthread should work now.
389 395 igrid.display() simply tries to create a frame without
390 396 an application. Only if this fails an application is created.
391 397
392 398 2007-03-23 Walter Doerwald <walter@livinglogic.de>
393 399
394 400 * IPython/Extensions/path.py: Updated to version 2.2.
395 401
396 402 2007-03-23 Ville Vainio <vivainio@gmail.com>
397 403
398 404 * iplib.py: recursive alias expansion now works better, so that
399 405 cases like 'top' -> 'd:/cygwin/top' -> 'ls :/cygwin/top'
400 406 doesn't trip up the process, if 'd' has been aliased to 'ls'.
401 407
402 408 * Extensions/ipy_gnuglobal.py added, provides %global magic
403 409 for users of http://www.gnu.org/software/global
404 410
405 411 * iplib.py: '!command /?' now doesn't invoke IPython's help system.
406 412 Closes #52. Patch by Stefan van der Walt.
407 413
408 414 2007-03-23 Fernando Perez <Fernando.Perez@colorado.edu>
409 415
410 416 * IPython/FakeModule.py (FakeModule.__init__): Small fix to
411 417 respect the __file__ attribute when using %run. Thanks to a bug
412 418 report by Sebastian Rooks <sebastian.rooks-AT-free.fr>.
413 419
414 420 2007-03-22 Fernando Perez <Fernando.Perez@colorado.edu>
415 421
416 422 * IPython/iplib.py (raw_input): Fix mishandling of unicode at
417 423 input. Patch sent by Stefan.
418 424
419 425 2007-03-20 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
420 426 * IPython/Extensions/ipy_stock_completer.py
421 427 shlex_split, fix bug in shlex_split. len function
422 428 call was missing an if statement. Caused shlex_split to
423 429 sometimes return "" as last element.
424 430
425 431 2007-03-18 Fernando Perez <Fernando.Perez@colorado.edu>
426 432
427 433 * IPython/completer.py
428 434 (IPCompleter.file_matches.single_dir_expand): fix a problem
429 435 reported by Stefan, where directories containign a single subdir
430 436 would be completed too early.
431 437
432 438 * IPython/Shell.py (_load_pylab): Make the execution of 'from
433 439 pylab import *' when -pylab is given be optional. A new flag,
434 440 pylab_import_all controls this behavior, the default is True for
435 441 backwards compatibility.
436 442
437 443 * IPython/ultraTB.py (_formatTracebackLines): Added (slightly
438 444 modified) R. Bernstein's patch for fully syntax highlighted
439 445 tracebacks. The functionality is also available under ultraTB for
440 446 non-ipython users (someone using ultraTB but outside an ipython
441 447 session). They can select the color scheme by setting the
442 448 module-level global DEFAULT_SCHEME. The highlight functionality
443 449 also works when debugging.
444 450
445 451 * IPython/genutils.py (IOStream.close): small patch by
446 452 R. Bernstein for improved pydb support.
447 453
448 454 * IPython/Debugger.py (Pdb.format_stack_entry): Added patch by
449 455 DaveS <davls@telus.net> to improve support of debugging under
450 456 NTEmacs, including improved pydb behavior.
451 457
452 458 * IPython/Magic.py (magic_prun): Fix saving of profile info for
453 459 Python 2.5, where the stats object API changed a little. Thanks
454 460 to a bug report by Paul Smith <paul.smith-AT-catugmt.com>.
455 461
456 462 * IPython/ColorANSI.py (InputTermColors.Normal): applied Nicolas
457 463 Pernetty's patch to improve support for (X)Emacs under Win32.
458 464
459 465 2007-03-17 Fernando Perez <Fernando.Perez@colorado.edu>
460 466
461 467 * IPython/Shell.py (hijack_wx): ipmort WX with current semantics
462 468 to quiet a deprecation warning that fires with Wx 2.8. Thanks to
463 469 a report by Nik Tautenhahn.
464 470
465 471 2007-03-16 Walter Doerwald <walter@livinglogic.de>
466 472
467 473 * setup.py: Add the igrid help files to the list of data files
468 474 to be installed alongside igrid.
469 475 * IPython/Extensions/igrid.py: (Patch by Nik Tautenhahn)
470 476 Show the input object of the igrid browser as the window tile.
471 477 Show the object the cursor is on in the statusbar.
472 478
473 479 2007-03-15 Ville Vainio <vivainio@gmail.com>
474 480
475 481 * Extensions/ipy_stock_completers.py: Fixed exception
476 482 on mismatching quotes in %run completer. Patch by
477 483 JοΏ½rgen Stenarson. Closes #127.
478 484
479 485 2007-03-14 Ville Vainio <vivainio@gmail.com>
480 486
481 487 * Extensions/ext_rehashdir.py: Do not do auto_alias
482 488 in %rehashdir, it clobbers %store'd aliases.
483 489
484 490 * UserConfig/ipy_profile_sh.py: envpersist.py extension
485 491 (beefed up %env) imported for sh profile.
486 492
487 493 2007-03-10 Walter Doerwald <walter@livinglogic.de>
488 494
489 495 * IPython/Extensions/ipipe.py: Prefer ibrowse over igrid
490 496 as the default browser.
491 497 * IPython/Extensions/igrid.py: Make a few igrid attributes private.
492 498 As igrid displays all attributes it ever encounters, fetch() (which has
493 499 been renamed to _fetch()) doesn't have to recalculate the display attributes
494 500 every time a new item is fetched. This should speed up scrolling.
495 501
496 502 2007-03-10 Fernando Perez <Fernando.Perez@colorado.edu>
497 503
498 504 * IPython/iplib.py (InteractiveShell.__init__): fix for Alex
499 505 Schmolck's recently reported tab-completion bug (my previous one
500 506 had a problem). Patch by Dan Milstein <danmil-AT-comcast.net>.
501 507
502 508 2007-03-09 Walter Doerwald <walter@livinglogic.de>
503 509
504 510 * IPython/Extensions/igrid.py: Patch by Nik Tautenhahn:
505 511 Close help window if exiting igrid.
506 512
507 513 2007-03-02 JοΏ½rgen Stenarson <jorgen.stenarson@bostream.nu>
508 514
509 515 * IPython/Extensions/ipy_defaults.py: Check if readline is available
510 516 before calling functions from readline.
511 517
512 518 2007-03-02 Walter Doerwald <walter@livinglogic.de>
513 519
514 520 * IPython/Extensions/igrid.py: Add Nik Tautenhahns igrid extension.
515 521 igrid is a wxPython-based display object for ipipe. If your system has
516 522 wx installed igrid will be the default display. Without wx ipipe falls
517 523 back to ibrowse (which needs curses). If no curses is installed ipipe
518 524 falls back to idump.
519 525
520 526 2007-03-01 Fernando Perez <Fernando.Perez@colorado.edu>
521 527
522 528 * IPython/iplib.py (split_user_inputBROKEN): temporarily disable
523 529 my changes from yesterday, they introduced bugs. Will reactivate
524 530 once I get a correct solution, which will be much easier thanks to
525 531 Dan Milstein's new prefilter test suite.
526 532
527 533 2007-02-28 Fernando Perez <Fernando.Perez@colorado.edu>
528 534
529 535 * IPython/iplib.py (split_user_input): fix input splitting so we
530 536 don't attempt attribute accesses on things that can't possibly be
531 537 valid Python attributes. After a bug report by Alex Schmolck.
532 538 (InteractiveShell.__init__): brown-paper bag fix; regexp broke
533 539 %magic with explicit % prefix.
534 540
535 541 2007-02-27 Fernando Perez <Fernando.Perez@colorado.edu>
536 542
537 543 * IPython/Shell.py (IPShellGTK.mainloop): update threads calls to
538 544 avoid a DeprecationWarning from GTK.
539 545
540 546 2007-02-22 Fernando Perez <Fernando.Perez@colorado.edu>
541 547
542 548 * IPython/genutils.py (clock): I modified clock() to return total
543 549 time, user+system. This is a more commonly needed metric. I also
544 550 introduced the new clocku/clocks to get only user/system time if
545 551 one wants those instead.
546 552
547 553 ***WARNING: API CHANGE*** clock() used to return only user time,
548 554 so if you want exactly the same results as before, use clocku
549 555 instead.
550 556
551 557 2007-02-22 Ville Vainio <vivainio@gmail.com>
552 558
553 559 * IPython/Extensions/ipy_p4.py: Extension for improved
554 560 p4 (perforce version control system) experience.
555 561 Adds %p4 magic with p4 command completion and
556 562 automatic -G argument (marshall output as python dict)
557 563
558 564 2007-02-19 Fernando Perez <Fernando.Perez@colorado.edu>
559 565
560 566 * IPython/demo.py (Demo.re_stop): make dashes optional in demo
561 567 stop marks.
562 568 (ClearingMixin): a simple mixin to easily make a Demo class clear
563 569 the screen in between blocks and have empty marquees. The
564 570 ClearDemo and ClearIPDemo classes that use it are included.
565 571
566 572 2007-02-18 Fernando Perez <Fernando.Perez@colorado.edu>
567 573
568 574 * IPython/irunner.py (pexpect_monkeypatch): patch pexpect to
569 575 protect against exceptions at Python shutdown time. Patch
570 576 sumbmitted to upstream.
571 577
572 578 2007-02-14 Walter Doerwald <walter@livinglogic.de>
573 579
574 580 * IPython/Extensions/ibrowse.py: If entering the first object level
575 581 (i.e. the object for which the browser has been started) fails,
576 582 now the error is raised directly (aborting the browser) instead of
577 583 running into an empty levels list later.
578 584
579 585 2007-02-03 Walter Doerwald <walter@livinglogic.de>
580 586
581 587 * IPython/Extensions/ipipe.py: Add an xrepr implementation
582 588 for the noitem object.
583 589
584 590 2007-01-31 Fernando Perez <Fernando.Perez@colorado.edu>
585 591
586 592 * IPython/completer.py (Completer.attr_matches): Fix small
587 593 tab-completion bug with Enthought Traits objects with units.
588 594 Thanks to a bug report by Tom Denniston
589 595 <tom.denniston-AT-alum.dartmouth.org>.
590 596
591 597 2007-01-27 Fernando Perez <Fernando.Perez@colorado.edu>
592 598
593 599 * IPython/Extensions/ipy_stock_completers.py (runlistpy): fix a
594 600 bug where only .ipy or .py would be completed. Once the first
595 601 argument to %run has been given, all completions are valid because
596 602 they are the arguments to the script, which may well be non-python
597 603 filenames.
598 604
599 605 * IPython/irunner.py (InteractiveRunner.run_source): major updates
600 606 to irunner to allow it to correctly support real doctesting of
601 607 out-of-process ipython code.
602 608
603 609 * IPython/Magic.py (magic_cd): Make the setting of the terminal
604 610 title an option (-noterm_title) because it completely breaks
605 611 doctesting.
606 612
607 613 * IPython/demo.py: fix IPythonDemo class that was not actually working.
608 614
609 615 2007-01-24 Fernando Perez <Fernando.Perez@colorado.edu>
610 616
611 617 * IPython/irunner.py (main): fix small bug where extensions were
612 618 not being correctly recognized.
613 619
614 620 2007-01-23 Walter Doerwald <walter@livinglogic.de>
615 621
616 622 * IPython/Extensions/ipipe.py (xiter): Make sure that iterating
617 623 a string containing a single line yields the string itself as the
618 624 only item.
619 625
620 626 * IPython/Extensions/ibrowse.py (ibrowse): Avoid entering an
621 627 object if it's the same as the one on the last level (This avoids
622 628 infinite recursion for one line strings).
623 629
624 630 2007-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
625 631
626 632 * IPython/ultraTB.py (AutoFormattedTB.__call__): properly flush
627 633 all output streams before printing tracebacks. This ensures that
628 634 user output doesn't end up interleaved with traceback output.
629 635
630 636 2007-01-10 Ville Vainio <vivainio@gmail.com>
631 637
632 638 * Extensions/envpersist.py: Turbocharged %env that remembers
633 639 env vars across sessions; e.g. "%env PATH+=;/opt/scripts" or
634 640 "%env VISUAL=jed".
635 641
636 642 2007-01-05 Fernando Perez <Fernando.Perez@colorado.edu>
637 643
638 644 * IPython/iplib.py (showtraceback): ensure that we correctly call
639 645 custom handlers in all cases (some with pdb were slipping through,
640 646 but I'm not exactly sure why).
641 647
642 648 * IPython/Debugger.py (Tracer.__init__): added new class to
643 649 support set_trace-like usage of IPython's enhanced debugger.
644 650
645 651 2006-12-24 Ville Vainio <vivainio@gmail.com>
646 652
647 653 * ipmaker.py: more informative message when ipy_user_conf
648 654 import fails (suggest running %upgrade).
649 655
650 656 * tools/run_ipy_in_profiler.py: Utility to see where
651 657 the time during IPython startup is spent.
652 658
653 659 2006-12-20 Ville Vainio <vivainio@gmail.com>
654 660
655 661 * 0.7.3 is out - merge all from 0.7.3 branch to trunk
656 662
657 663 * ipapi.py: Add new ipapi method, expand_alias.
658 664
659 665 * Release.py: Bump up version to 0.7.4.svn
660 666
661 667 2006-12-17 Ville Vainio <vivainio@gmail.com>
662 668
663 669 * Extensions/jobctrl.py: Fixed &cmd arg arg...
664 670 to work properly on posix too
665 671
666 672 * Release.py: Update revnum (version is still just 0.7.3).
667 673
668 674 2006-12-15 Ville Vainio <vivainio@gmail.com>
669 675
670 676 * scripts/ipython_win_post_install: create ipython.py in
671 677 prefix + "/scripts".
672 678
673 679 * Release.py: Update version to 0.7.3.
674 680
675 681 2006-12-14 Ville Vainio <vivainio@gmail.com>
676 682
677 683 * scripts/ipython_win_post_install: Overwrite old shortcuts
678 684 if they already exist
679 685
680 686 * Release.py: release 0.7.3rc2
681 687
682 688 2006-12-13 Ville Vainio <vivainio@gmail.com>
683 689
684 690 * Branch and update Release.py for 0.7.3rc1
685 691
686 692 2006-12-13 Fernando Perez <Fernando.Perez@colorado.edu>
687 693
688 694 * IPython/Shell.py (IPShellWX): update for current WX naming
689 695 conventions, to avoid a deprecation warning with current WX
690 696 versions. Thanks to a report by Danny Shevitz.
691 697
692 698 2006-12-12 Ville Vainio <vivainio@gmail.com>
693 699
694 700 * ipmaker.py: apply david cournapeau's patch to make
695 701 import_some work properly even when ipythonrc does
696 702 import_some on empty list (it was an old bug!).
697 703
698 704 * UserConfig/ipy_user_conf.py, UserConfig/ipythonrc:
699 705 Add deprecation note to ipythonrc and a url to wiki
700 706 in ipy_user_conf.py
701 707
702 708
703 709 * Magic.py (%run): %run myscript.ipy now runs myscript.ipy
704 710 as if it was typed on IPython command prompt, i.e.
705 711 as IPython script.
706 712
707 713 * example-magic.py, magic_grepl.py: remove outdated examples
708 714
709 715 2006-12-11 Fernando Perez <Fernando.Perez@colorado.edu>
710 716
711 717 * IPython/iplib.py (debugger): prevent a nasty traceback if %debug
712 718 is called before any exception has occurred.
713 719
714 720 2006-12-08 Ville Vainio <vivainio@gmail.com>
715 721
716 722 * Extensions/ipy_stock_completers.py: fix cd completer
717 723 to translate /'s to \'s again.
718 724
719 725 * completer.py: prevent traceback on file completions w/
720 726 backslash.
721 727
722 728 * Release.py: Update release number to 0.7.3b3 for release
723 729
724 730 2006-12-07 Ville Vainio <vivainio@gmail.com>
725 731
726 732 * Extensions/ipy_signals.py: Ignore ctrl+C in IPython process
727 733 while executing external code. Provides more shell-like behaviour
728 734 and overall better response to ctrl + C / ctrl + break.
729 735
730 736 * tools/make_tarball.py: new script to create tarball straight from svn
731 737 (setup.py sdist doesn't work on win32).
732 738
733 739 * Extensions/ipy_stock_completers.py: fix cd completer to give up
734 740 on dirnames with spaces and use the default completer instead.
735 741
736 742 * Revision.py: Change version to 0.7.3b2 for release.
737 743
738 744 2006-12-05 Ville Vainio <vivainio@gmail.com>
739 745
740 746 * Magic.py, iplib.py, completer.py: Apply R. Bernstein's
741 747 pydb patch 4 (rm debug printing, py 2.5 checking)
742 748
743 749 2006-11-30 Walter Doerwald <walter@livinglogic.de>
744 750 * IPython/Extensions/ibrowse.py: Add two new commands to ibrowse:
745 751 "refresh" (mapped to "r") refreshes the screen by restarting the iterator.
746 752 "refreshfind" (mapped to "R") does the same but tries to go back to the same
747 753 object the cursor was on before the refresh. The command "markrange" is
748 754 mapped to "%" now.
749 755 * IPython/Extensions/ibrowse.py: Make igrpentry and ipwdentry comparable.
750 756
751 757 2006-11-29 Fernando Perez <Fernando.Perez@colorado.edu>
752 758
753 759 * IPython/Magic.py (magic_debug): new %debug magic to activate the
754 760 interactive debugger on the last traceback, without having to call
755 761 %pdb and rerun your code. Made minor changes in various modules,
756 762 should automatically recognize pydb if available.
757 763
758 764 2006-11-28 Ville Vainio <vivainio@gmail.com>
759 765
760 766 * completer.py: If the text start with !, show file completions
761 767 properly. This helps when trying to complete command name
762 768 for shell escapes.
763 769
764 770 2006-11-27 Ville Vainio <vivainio@gmail.com>
765 771
766 772 * ipy_stock_completers.py: bzr completer submitted by Stefan van
767 773 der Walt. Clean up svn and hg completers by using a common
768 774 vcs_completer.
769 775
770 776 2006-11-26 Ville Vainio <vivainio@gmail.com>
771 777
772 778 * Remove ipconfig and %config; you should use _ip.options structure
773 779 directly instead!
774 780
775 781 * genutils.py: add wrap_deprecated function for deprecating callables
776 782
777 783 * iplib.py: deprecate ipmagic, ipsystem, ipalias. Use _ip.magic and
778 784 _ip.system instead. ipalias is redundant.
779 785
780 786 * Magic.py: %rehashdir no longer aliases 'cmdname' to 'cmdname.exe' on
781 787 win32, but just 'cmdname'. Other extensions (non-'exe') are still made
782 788 explicit.
783 789
784 790 * ipy_stock_completers.py: 'hg' (mercurial VCS) now has a custom
785 791 completer. Try it by entering 'hg ' and pressing tab.
786 792
787 793 * macro.py: Give Macro a useful __repr__ method
788 794
789 795 * Magic.py: %whos abbreviates the typename of Macro for brevity.
790 796
791 797 2006-11-24 Walter Doerwald <walter@livinglogic.de>
792 798 * IPython/Extensions/astyle.py: Do a relative import of ipipe, so that
793 799 we don't get a duplicate ipipe module, where registration of the xrepr
794 800 implementation for Text is useless.
795 801
796 802 * IPython/Extensions/ipipe.py: Fix __xrepr__() implementation for ils.
797 803
798 804 * IPython/Extensions/ibrowse.py: Fix keymapping for the enter command.
799 805
800 806 2006-11-24 Ville Vainio <vivainio@gmail.com>
801 807
802 808 * Magic.py, manual_base.lyx: Kirill Smelkov patch:
803 809 try to use "cProfile" instead of the slower pure python
804 810 "profile"
805 811
806 812 2006-11-23 Ville Vainio <vivainio@gmail.com>
807 813
808 814 * manual_base.lyx: Kirill Smelkov patch: Fix wrong
809 815 Qt+IPython+Designer link in documentation.
810 816
811 817 * Extensions/ipy_pydb.py: R. Bernstein's patch for passing
812 818 correct Pdb object to %pydb.
813 819
814 820
815 821 2006-11-22 Walter Doerwald <walter@livinglogic.de>
816 822 * IPython/Extensions/astyle.py: Text needs it's own implemenation of the
817 823 generic xrepr(), otherwise the list implementation would kick in.
818 824
819 825 2006-11-21 Ville Vainio <vivainio@gmail.com>
820 826
821 827 * upgrade_dir.py: Now actually overwrites a nonmodified user file
822 828 with one from UserConfig.
823 829
824 830 * ipy_profile_sh.py: Add dummy "depth" to var_expand lambda,
825 831 it was missing which broke the sh profile.
826 832
827 833 * completer.py: file completer now uses explicit '/' instead
828 834 of os.path.join, expansion of 'foo' was broken on win32
829 835 if there was one directory with name 'foobar'.
830 836
831 837 * A bunch of patches from Kirill Smelkov:
832 838
833 839 * [patch 9/9] doc: point bug-tracker URL to IPythons trac-tickets.
834 840
835 841 * [patch 7/9] Implement %page -r (page in raw mode) -
836 842
837 843 * [patch 5/9] ScientificPython webpage has moved
838 844
839 845 * [patch 4/9] The manual mentions %ds, should be %dhist
840 846
841 847 * [patch 3/9] Kill old bits from %prun doc.
842 848
843 849 * [patch 1/9] Fix typos here and there.
844 850
845 851 2006-11-08 Ville Vainio <vivainio@gmail.com>
846 852
847 853 * completer.py (attr_matches): catch all exceptions raised
848 854 by eval of expr with dots.
849 855
850 856 2006-11-07 Fernando Perez <Fernando.Perez@colorado.edu>
851 857
852 858 * IPython/iplib.py (runsource): Prepend an 'if 1:' to the user
853 859 input if it starts with whitespace. This allows you to paste
854 860 indented input from any editor without manually having to type in
855 861 the 'if 1:', which is convenient when working interactively.
856 862 Slightly modifed version of a patch by Bo Peng
857 863 <bpeng-AT-rice.edu>.
858 864
859 865 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
860 866
861 867 * IPython/irunner.py (main): modified irunner so it automatically
862 868 recognizes the right runner to use based on the extension (.py for
863 869 python, .ipy for ipython and .sage for sage).
864 870
865 871 * IPython/iplib.py (InteractiveShell.ipconfig): new builtin, also
866 872 visible in ipapi as ip.config(), to programatically control the
867 873 internal rc object. There's an accompanying %config magic for
868 874 interactive use, which has been enhanced to match the
869 875 funtionality in ipconfig.
870 876
871 877 * IPython/Magic.py (magic_system_verbose): Change %system_verbose
872 878 so it's not just a toggle, it now takes an argument. Add support
873 879 for a customizable header when making system calls, as the new
874 880 system_header variable in the ipythonrc file.
875 881
876 882 2006-11-03 Walter Doerwald <walter@livinglogic.de>
877 883
878 884 * IPython/Extensions/ipipe.py: xrepr(), xiter() and xattrs() are now
879 885 generic functions (using Philip J. Eby's simplegeneric package).
880 886 This makes it possible to customize the display of third-party classes
881 887 without having to monkeypatch them. xiter() no longer supports a mode
882 888 argument and the XMode class has been removed. The same functionality can
883 889 be implemented via IterAttributeDescriptor and IterMethodDescriptor.
884 890 One consequence of the switch to generic functions is that xrepr() and
885 891 xattrs() implementation must define the default value for the mode
886 892 argument themselves and xattrs() implementations must return real
887 893 descriptors.
888 894
889 895 * IPython/external: This new subpackage will contain all third-party
890 896 packages that are bundled with IPython. (The first one is simplegeneric).
891 897
892 898 * IPython/Extensions/ipipe.py (ifile/ils): Readd output of the parent
893 899 directory which as been dropped in r1703.
894 900
895 901 * IPython/Extensions/ipipe.py (iless): Fixed.
896 902
897 903 * IPython/Extensions/ibrowse: Fixed sorting under Python 2.3.
898 904
899 905 2006-11-03 Fernando Perez <Fernando.Perez@colorado.edu>
900 906
901 907 * IPython/iplib.py (InteractiveShell.var_expand): fix stack
902 908 handling in variable expansion so that shells and magics recognize
903 909 function local scopes correctly. Bug reported by Brian.
904 910
905 911 * scripts/ipython: remove the very first entry in sys.path which
906 912 Python auto-inserts for scripts, so that sys.path under IPython is
907 913 as similar as possible to that under plain Python.
908 914
909 915 * IPython/completer.py (IPCompleter.file_matches): Fix
910 916 tab-completion so that quotes are not closed unless the completion
911 917 is unambiguous. After a request by Stefan. Minor cleanups in
912 918 ipy_stock_completers.
913 919
914 920 2006-11-02 Ville Vainio <vivainio@gmail.com>
915 921
916 922 * ipy_stock_completers.py: Add %run and %cd completers.
917 923
918 924 * completer.py: Try running custom completer for both
919 925 "foo" and "%foo" if the command is just "foo". Ignore case
920 926 when filtering possible completions.
921 927
922 928 * UserConfig/ipy_user_conf.py: install stock completers as default
923 929
924 930 * iplib.py (history_saving_wrapper), debugger(), ipy_pydb.py:
925 931 simplified readline history save / restore through a wrapper
926 932 function
927 933
928 934
929 935 2006-10-31 Ville Vainio <vivainio@gmail.com>
930 936
931 937 * strdispatch.py, completer.py, ipy_stock_completers.py:
932 938 Allow str_key ("command") in completer hooks. Implement
933 939 trivial completer for 'import' (stdlib modules only). Rename
934 940 ipy_linux_package_managers.py to ipy_stock_completers.py.
935 941 SVN completer.
936 942
937 943 * Extensions/ledit.py: %magic line editor for easily and
938 944 incrementally manipulating lists of strings. The magic command
939 945 name is %led.
940 946
941 947 2006-10-30 Ville Vainio <vivainio@gmail.com>
942 948
943 949 * Debugger.py, iplib.py (debugger()): Add last set of Rocky
944 950 Bernsteins's patches for pydb integration.
945 951 http://bashdb.sourceforge.net/pydb/
946 952
947 953 * strdispatch.py, iplib.py, completer.py, IPython/__init__.py,
948 954 Extensions/ipy_linux_package_managers.py, hooks.py: Implement
949 955 custom completer hook to allow the users to implement their own
950 956 completers. See ipy_linux_package_managers.py for example. The
951 957 hook name is 'complete_command'.
952 958
953 959 2006-10-28 Fernando Perez <Fernando.Perez@colorado.edu>
954 960
955 961 * IPython/UserConfig/ipythonrc-scipy: minor cleanups to remove old
956 962 Numeric leftovers.
957 963
958 964 * ipython.el (py-execute-region): apply Stefan's patch to fix
959 965 garbled results if the python shell hasn't been previously started.
960 966
961 967 * IPython/genutils.py (arg_split): moved to genutils, since it's a
962 968 pretty generic function and useful for other things.
963 969
964 970 * IPython/OInspect.py (getsource): Add customizable source
965 971 extractor. After a request/patch form W. Stein (SAGE).
966 972
967 973 * IPython/irunner.py (InteractiveRunner.run_source): reset tty
968 974 window size to a more reasonable value from what pexpect does,
969 975 since their choice causes wrapping bugs with long input lines.
970 976
971 977 2006-10-28 Ville Vainio <vivainio@gmail.com>
972 978
973 979 * Magic.py (%run): Save and restore the readline history from
974 980 file around %run commands to prevent side effects from
975 981 %runned programs that might use readline (e.g. pydb).
976 982
977 983 * extensions/ipy_pydb.py: Adds %pydb magic when imported, for
978 984 invoking the pydb enhanced debugger.
979 985
980 986 2006-10-23 Walter Doerwald <walter@livinglogic.de>
981 987
982 988 * IPython/Extensions/ipipe.py (ifile): Remove all methods that
983 989 call the base class method and propagate the return value to
984 990 ifile. This is now done by path itself.
985 991
986 992 2006-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
987 993
988 994 * IPython/ipapi.py (IPApi.__init__): Added new entry to public
989 995 api: set_crash_handler(), to expose the ability to change the
990 996 internal crash handler.
991 997
992 998 * IPython/CrashHandler.py (CrashHandler.__init__): abstract out
993 999 the various parameters of the crash handler so that apps using
994 1000 IPython as their engine can customize crash handling. Ipmlemented
995 1001 at the request of SAGE.
996 1002
997 1003 2006-10-14 Ville Vainio <vivainio@gmail.com>
998 1004
999 1005 * Magic.py, ipython.el: applied first "safe" part of Rocky
1000 1006 Bernstein's patch set for pydb integration.
1001 1007
1002 1008 * Magic.py (%unalias, %alias): %store'd aliases can now be
1003 1009 removed with '%unalias'. %alias w/o args now shows most
1004 1010 interesting (stored / manually defined) aliases last
1005 1011 where they catch the eye w/o scrolling.
1006 1012
1007 1013 * Magic.py (%rehashx), ext_rehashdir.py: files with
1008 1014 'py' extension are always considered executable, even
1009 1015 when not in PATHEXT environment variable.
1010 1016
1011 1017 2006-10-12 Ville Vainio <vivainio@gmail.com>
1012 1018
1013 1019 * jobctrl.py: Add new "jobctrl" extension for spawning background
1014 1020 processes with "&find /". 'import jobctrl' to try it out. Requires
1015 1021 'subprocess' module, standard in python 2.4+.
1016 1022
1017 1023 * iplib.py (expand_aliases, handle_alias): Aliases expand transitively,
1018 1024 so if foo -> bar and bar -> baz, then foo -> baz.
1019 1025
1020 1026 2006-10-09 Fernando Perez <Fernando.Perez@colorado.edu>
1021 1027
1022 1028 * IPython/Magic.py (Magic.parse_options): add a new posix option
1023 1029 to allow parsing of input args in magics that doesn't strip quotes
1024 1030 (if posix=False). This also closes %timeit bug reported by
1025 1031 Stefan.
1026 1032
1027 1033 2006-10-03 Ville Vainio <vivainio@gmail.com>
1028 1034
1029 1035 * iplib.py (raw_input, interact): Return ValueError catching for
1030 1036 raw_input. Fixes infinite loop for sys.stdin.close() or
1031 1037 sys.stdout.close().
1032 1038
1033 1039 2006-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
1034 1040
1035 1041 * IPython/irunner.py (InteractiveRunner.run_source): small fixes
1036 1042 to help in handling doctests. irunner is now pretty useful for
1037 1043 running standalone scripts and simulate a full interactive session
1038 1044 in a format that can be then pasted as a doctest.
1039 1045
1040 1046 * IPython/iplib.py (InteractiveShell.__init__): Install exit/quit
1041 1047 on top of the default (useless) ones. This also fixes the nasty
1042 1048 way in which 2.5's Quitter() exits (reverted [1785]).
1043 1049
1044 1050 * IPython/Debugger.py (Pdb.__init__): Fix ipdb to work with python
1045 1051 2.5.
1046 1052
1047 1053 * IPython/ultraTB.py (TBTools.set_colors): Make sure that ipdb
1048 1054 color scheme is updated as well when color scheme is changed
1049 1055 interactively.
1050 1056
1051 1057 2006-09-27 Ville Vainio <vivainio@gmail.com>
1052 1058
1053 1059 * iplib.py (raw_input): python 2.5 closes stdin on quit -> avoid
1054 1060 infinite loop and just exit. It's a hack, but will do for a while.
1055 1061
1056 1062 2006-08-25 Walter Doerwald <walter@livinglogic.de>
1057 1063
1058 1064 * IPython/Extensions/ipipe.py (ils): Add arguments dirs and files to
1059 1065 the constructor, this makes it possible to get a list of only directories
1060 1066 or only files.
1061 1067
1062 1068 2006-08-12 Ville Vainio <vivainio@gmail.com>
1063 1069
1064 1070 * Fakemodule.py, OInspect.py: Reverted 2006-08-11 mods,
1065 1071 they broke unittest
1066 1072
1067 1073 2006-08-11 Ville Vainio <vivainio@gmail.com>
1068 1074
1069 1075 * Fakemodule.py, OInspect.py: remove 2006-08-09 monkepatch
1070 1076 by resolving issue properly, i.e. by inheriting FakeModule
1071 1077 from types.ModuleType. Pickling ipython interactive data
1072 1078 should still work as usual (testing appreciated).
1073 1079
1074 1080 2006-08-09 Fernando Perez <Fernando.Perez@colorado.edu>
1075 1081
1076 1082 * IPython/OInspect.py: monkeypatch inspect from the stdlib if
1077 1083 running under python 2.3 with code from 2.4 to fix a bug with
1078 1084 help(). Reported by the Debian maintainers, Norbert Tretkowski
1079 1085 <norbert-AT-tretkowski.de> and Alexandre Fayolle
1080 1086 <afayolle-AT-debian.org>.
1081 1087
1082 1088 2006-08-04 Walter Doerwald <walter@livinglogic.de>
1083 1089
1084 1090 * IPython/Extensions/ibrowse.py: Fixed the help message in the footer
1085 1091 (which was displaying "quit" twice).
1086 1092
1087 1093 2006-07-28 Walter Doerwald <walter@livinglogic.de>
1088 1094
1089 1095 * IPython/Extensions/ipipe.py: Fix isort.__iter__() (was still using
1090 1096 the mode argument).
1091 1097
1092 1098 2006-07-27 Walter Doerwald <walter@livinglogic.de>
1093 1099
1094 1100 * IPython/Extensions/ipipe.py: Fix getglobals() if we're
1095 1101 not running under IPython.
1096 1102
1097 1103 * IPython/Extensions/ipipe.py: Rename XAttr to AttributeDetail
1098 1104 and make it iterable (iterating over the attribute itself). Add two new
1099 1105 magic strings for __xattrs__(): If the string starts with "-", the attribute
1100 1106 will not be displayed in ibrowse's detail view (but it can still be
1101 1107 iterated over). This makes it possible to add attributes that are large
1102 1108 lists or generator methods to the detail view. Replace magic attribute names
1103 1109 and _attrname() and _getattr() with "descriptors": For each type of magic
1104 1110 attribute name there's a subclass of Descriptor: None -> SelfDescriptor();
1105 1111 "foo" -> AttributeDescriptor("foo"); "foo()" -> MethodDescriptor("foo");
1106 1112 "-foo" -> IterAttributeDescriptor("foo"); "-foo()" -> IterMethodDescriptor("foo");
1107 1113 foo() -> FunctionDescriptor(foo). Magic strings returned from __xattrs__()
1108 1114 are still supported.
1109 1115
1110 1116 * IPython/Extensions/ibrowse.py: If fetching the next row from the input
1111 1117 fails in ibrowse.fetch(), the exception object is added as the last item
1112 1118 and item fetching is canceled. This prevents ibrowse from aborting if e.g.
1113 1119 a generator throws an exception midway through execution.
1114 1120
1115 1121 * IPython/Extensions/ipipe.py: Turn ifile's properties mimetype and
1116 1122 encoding into methods.
1117 1123
1118 1124 2006-07-26 Ville Vainio <vivainio@gmail.com>
1119 1125
1120 1126 * iplib.py: history now stores multiline input as single
1121 1127 history entries. Patch by Jorgen Cederlof.
1122 1128
1123 1129 2006-07-18 Walter Doerwald <walter@livinglogic.de>
1124 1130
1125 1131 * IPython/Extensions/ibrowse.py: Make cursor visible over
1126 1132 non existing attributes.
1127 1133
1128 1134 2006-07-14 Walter Doerwald <walter@livinglogic.de>
1129 1135
1130 1136 * IPython/Extensions/ipipe.py (ix): Use os.popen4() so that the
1131 1137 error output of the running command doesn't mess up the screen.
1132 1138
1133 1139 2006-07-13 Walter Doerwald <walter@livinglogic.de>
1134 1140
1135 1141 * IPython/Extensions/ipipe.py (isort): Make isort usable without
1136 1142 argument. This sorts the items themselves.
1137 1143
1138 1144 2006-07-12 Walter Doerwald <walter@livinglogic.de>
1139 1145
1140 1146 * IPython/Extensions/ipipe.py (eval, ifilter, isort, ieval):
1141 1147 Compile expression strings into code objects. This should speed
1142 1148 up ifilter and friends somewhat.
1143 1149
1144 1150 2006-07-08 Ville Vainio <vivainio@gmail.com>
1145 1151
1146 1152 * Magic.py: %cpaste now strips > from the beginning of lines
1147 1153 to ease pasting quoted code from emails. Contributed by
1148 1154 Stefan van der Walt.
1149 1155
1150 1156 2006-06-29 Ville Vainio <vivainio@gmail.com>
1151 1157
1152 1158 * ipmaker.py, Shell.py: qt4agg matplotlib backend support for pylab
1153 1159 mode, patch contributed by Darren Dale. NEEDS TESTING!
1154 1160
1155 1161 2006-06-28 Walter Doerwald <walter@livinglogic.de>
1156 1162
1157 1163 * IPython/Extensions/ibrowse.py: Give the ibrowse cursor row
1158 1164 a blue background. Fix fetching new display rows when the browser
1159 1165 scrolls more than a screenful (e.g. by using the goto command).
1160 1166
1161 1167 2006-06-27 Ville Vainio <vivainio@gmail.com>
1162 1168
1163 1169 * Magic.py (_inspect, _ofind) Apply David Huard's
1164 1170 patch for displaying the correct docstring for 'property'
1165 1171 attributes.
1166 1172
1167 1173 2006-06-23 Walter Doerwald <walter@livinglogic.de>
1168 1174
1169 1175 * IPython/Extensions/ibrowse.py: Put the documentation of the keyboard
1170 1176 commands into the methods implementing them.
1171 1177
1172 1178 2006-06-22 Fernando Perez <Fernando.Perez@colorado.edu>
1173 1179
1174 1180 * ipython.el (ipython-indentation-hook): cleanup patch, submitted
1175 1181 by Kov Chai <tchaikov-AT-gmail.com>. He notes that the original
1176 1182 autoindent support was authored by Jin Liu.
1177 1183
1178 1184 2006-06-22 Walter Doerwald <walter@livinglogic.de>
1179 1185
1180 1186 * IPython/Extensions/ibrowse.py: Replace the plain dictionaries used
1181 1187 for keymaps with a custom class that simplifies handling.
1182 1188
1183 1189 2006-06-19 Walter Doerwald <walter@livinglogic.de>
1184 1190
1185 1191 * IPython/Extensions/ibrowse.py: ibrowse now properly handles terminal
1186 1192 resizing. This requires Python 2.5 to work.
1187 1193
1188 1194 2006-06-16 Walter Doerwald <walter@livinglogic.de>
1189 1195
1190 1196 * IPython/Extensions/ibrowse.py: Add two new commands to
1191 1197 ibrowse: "hideattr" (mapped to "h") hides the attribute under
1192 1198 the cursor. "unhiderattrs" (mapped to "H") reveals all hidden
1193 1199 attributes again. Remapped the help command to "?". Display
1194 1200 keycodes in the range 0x01-0x1F as CTRL-xx. Add CTRL-a and CTRL-e
1195 1201 as keys for the "home" and "end" commands. Add three new commands
1196 1202 to the input mode for "find" and friends: "delend" (CTRL-K)
1197 1203 deletes to the end of line. "incsearchup" searches upwards in the
1198 1204 command history for an input that starts with the text before the cursor.
1199 1205 "incsearchdown" does the same downwards. Removed a bogus mapping of
1200 1206 the x key to "delete".
1201 1207
1202 1208 2006-06-15 Ville Vainio <vivainio@gmail.com>
1203 1209
1204 1210 * iplib.py, hooks.py: Added new generate_prompt hook that can be
1205 1211 used to create prompts dynamically, instead of the "old" way of
1206 1212 assigning "magic" strings to prompt_in1 and prompt_in2. The old
1207 1213 way still works (it's invoked by the default hook), of course.
1208 1214
1209 1215 * Prompts.py: added generate_output_prompt hook for altering output
1210 1216 prompt
1211 1217
1212 1218 * Release.py: Changed version string to 0.7.3.svn.
1213 1219
1214 1220 2006-06-15 Walter Doerwald <walter@livinglogic.de>
1215 1221
1216 1222 * IPython/Extensions/ibrowse.py: Change _BrowserLevel.moveto() so that
1217 1223 the call to fetch() always tries to fetch enough data for at least one
1218 1224 full screen. This makes it possible to simply call moveto(0,0,True) in
1219 1225 the constructor. Fix typos and removed the obsolete goto attribute.
1220 1226
1221 1227 2006-06-12 Ville Vainio <vivainio@gmail.com>
1222 1228
1223 1229 * ipy_profile_sh.py: applied Krisha Mohan Gundu's patch for
1224 1230 allowing $variable interpolation within multiline statements,
1225 1231 though so far only with "sh" profile for a testing period.
1226 1232 The patch also enables splitting long commands with \ but it
1227 1233 doesn't work properly yet.
1228 1234
1229 1235 2006-06-12 Walter Doerwald <walter@livinglogic.de>
1230 1236
1231 1237 * IPython/Extensions/ibrowse.py (_dodisplay): Display the length of the
1232 1238 input history and the position of the cursor in the input history for
1233 1239 the find, findbackwards and goto command.
1234 1240
1235 1241 2006-06-10 Walter Doerwald <walter@livinglogic.de>
1236 1242
1237 1243 * IPython/Extensions/ibrowse.py: Add a class _CommandInput that
1238 1244 implements the basic functionality of browser commands that require
1239 1245 input. Reimplement the goto, find and findbackwards commands as
1240 1246 subclasses of _CommandInput. Add an input history and keymaps to those
1241 1247 commands. Add "\r" as a keyboard shortcut for the enterdefault and
1242 1248 execute commands.
1243 1249
1244 1250 2006-06-07 Ville Vainio <vivainio@gmail.com>
1245 1251
1246 1252 * iplib.py: ipython mybatch.ipy exits ipython immediately after
1247 1253 running the batch files instead of leaving the session open.
1248 1254
1249 1255 2006-06-07 Fernando Perez <Fernando.Perez@colorado.edu>
1250 1256
1251 1257 * IPython/iplib.py (InteractiveShell.__init__): update BSD fix, as
1252 1258 the original fix was incomplete. Patch submitted by W. Maier.
1253 1259
1254 1260 2006-06-07 Ville Vainio <vivainio@gmail.com>
1255 1261
1256 1262 * iplib.py,Magic.py, ipmaker.py (magic_rehashx):
1257 1263 Confirmation prompts can be supressed by 'quiet' option.
1258 1264 _ip.options.quiet = 1 means "assume yes for all yes/no queries".
1259 1265
1260 1266 2006-06-06 *** Released version 0.7.2
1261 1267
1262 1268 2006-06-06 Fernando Perez <Fernando.Perez@colorado.edu>
1263 1269
1264 1270 * IPython/Release.py (version): Made 0.7.2 final for release.
1265 1271 Repo tagged and release cut.
1266 1272
1267 1273 2006-06-05 Ville Vainio <vivainio@gmail.com>
1268 1274
1269 1275 * Magic.py (magic_rehashx): Honor no_alias list earlier in
1270 1276 %rehashx, to avoid clobbering builtins in ipy_profile_sh.py
1271 1277
1272 1278 * upgrade_dir.py: try import 'path' module a bit harder
1273 1279 (for %upgrade)
1274 1280
1275 1281 2006-06-03 Fernando Perez <Fernando.Perez@colorado.edu>
1276 1282
1277 1283 * IPython/genutils.py (ask_yes_no): treat EOF as a default answer
1278 1284 instead of looping 20 times.
1279 1285
1280 1286 * IPython/ipmaker.py (make_IPython): honor -ipythondir flag
1281 1287 correctly at initialization time. Bug reported by Krishna Mohan
1282 1288 Gundu <gkmohan-AT-gmail.com> on the user list.
1283 1289
1284 1290 * IPython/Release.py (version): Mark 0.7.2 version to start
1285 1291 testing for release on 06/06.
1286 1292
1287 1293 2006-05-31 Fernando Perez <Fernando.Perez@colorado.edu>
1288 1294
1289 1295 * scripts/irunner: thin script interface so users don't have to
1290 1296 find the module and call it as an executable, since modules rarely
1291 1297 live in people's PATH.
1292 1298
1293 1299 * IPython/irunner.py (InteractiveRunner.__init__): added
1294 1300 delaybeforesend attribute to control delays with newer versions of
1295 1301 pexpect. Thanks to detailed help from pexpect's author, Noah
1296 1302 Spurrier <noah-AT-noah.org>. Noted how to use the SAGE runner
1297 1303 correctly (it works in NoColor mode).
1298 1304
1299 1305 * IPython/iplib.py (handle_normal): fix nasty crash reported on
1300 1306 SAGE list, from improper log() calls.
1301 1307
1302 1308 2006-05-31 Ville Vainio <vivainio@gmail.com>
1303 1309
1304 1310 * upgrade_dir.py, Magic.py (magic_upgrade): call upgrade_dir
1305 1311 with args in parens to work correctly with dirs that have spaces.
1306 1312
1307 1313 2006-05-30 Fernando Perez <Fernando.Perez@colorado.edu>
1308 1314
1309 1315 * IPython/Logger.py (Logger.logstart): add option to log raw input
1310 1316 instead of the processed one. A -r flag was added to the
1311 1317 %logstart magic used for controlling logging.
1312 1318
1313 1319 2006-05-29 Fernando Perez <Fernando.Perez@colorado.edu>
1314 1320
1315 1321 * IPython/iplib.py (InteractiveShell.__init__): add check for the
1316 1322 *BSDs to omit --color from all 'ls' aliases, since *BSD ls doesn't
1317 1323 recognize the option. After a bug report by Will Maier. This
1318 1324 closes #64 (will do it after confirmation from W. Maier).
1319 1325
1320 1326 * IPython/irunner.py: New module to run scripts as if manually
1321 1327 typed into an interactive environment, based on pexpect. After a
1322 1328 submission by Ken Schutte <kschutte-AT-csail.mit.edu> on the
1323 1329 ipython-user list. Simple unittests in the tests/ directory.
1324 1330
1325 1331 * tools/release: add Will Maier, OpenBSD port maintainer, to
1326 1332 recepients list. We are now officially part of the OpenBSD ports:
1327 1333 http://www.openbsd.org/ports.html ! Many thanks to Will for the
1328 1334 work.
1329 1335
1330 1336 2006-05-26 Fernando Perez <Fernando.Perez@colorado.edu>
1331 1337
1332 1338 * IPython/ipmaker.py (make_IPython): modify sys.argv fix (below)
1333 1339 so that it doesn't break tkinter apps.
1334 1340
1335 1341 * IPython/iplib.py (_prefilter): fix bug where aliases would
1336 1342 shadow variables when autocall was fully off. Reported by SAGE
1337 1343 author William Stein.
1338 1344
1339 1345 * IPython/OInspect.py (Inspector.__init__): add a flag to control
1340 1346 at what detail level strings are computed when foo? is requested.
1341 1347 This allows users to ask for example that the string form of an
1342 1348 object is only computed when foo?? is called, or even never, by
1343 1349 setting the object_info_string_level >= 2 in the configuration
1344 1350 file. This new option has been added and documented. After a
1345 1351 request by SAGE to be able to control the printing of very large
1346 1352 objects more easily.
1347 1353
1348 1354 2006-05-25 Fernando Perez <Fernando.Perez@colorado.edu>
1349 1355
1350 1356 * IPython/ipmaker.py (make_IPython): remove the ipython call path
1351 1357 from sys.argv, to be 100% consistent with how Python itself works
1352 1358 (as seen for example with python -i file.py). After a bug report
1353 1359 by Jeffrey Collins.
1354 1360
1355 1361 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix
1356 1362 nasty bug which was preventing custom namespaces with -pylab,
1357 1363 reported by M. Foord. Minor cleanup, remove old matplotlib.matlab
1358 1364 compatibility (long gone from mpl).
1359 1365
1360 1366 * IPython/ipapi.py (make_session): name change: create->make. We
1361 1367 use make in other places (ipmaker,...), it's shorter and easier to
1362 1368 type and say, etc. I'm trying to clean things before 0.7.2 so
1363 1369 that I can keep things stable wrt to ipapi in the chainsaw branch.
1364 1370
1365 1371 * ipython.el: fix the py-pdbtrack-input-prompt variable so that
1366 1372 python-mode recognizes our debugger mode. Add support for
1367 1373 autoindent inside (X)emacs. After a patch sent in by Jin Liu
1368 1374 <m.liu.jin-AT-gmail.com> originally written by
1369 1375 doxgen-AT-newsmth.net (with minor modifications for xemacs
1370 1376 compatibility)
1371 1377
1372 1378 * IPython/Debugger.py (Pdb.format_stack_entry): fix formatting of
1373 1379 tracebacks when walking the stack so that the stack tracking system
1374 1380 in emacs' python-mode can identify the frames correctly.
1375 1381
1376 1382 * IPython/ipmaker.py (make_IPython): make the internal (and
1377 1383 default config) autoedit_syntax value false by default. Too many
1378 1384 users have complained to me (both on and off-list) about problems
1379 1385 with this option being on by default, so I'm making it default to
1380 1386 off. It can still be enabled by anyone via the usual mechanisms.
1381 1387
1382 1388 * IPython/completer.py (Completer.attr_matches): add support for
1383 1389 PyCrust-style _getAttributeNames magic method. Patch contributed
1384 1390 by <mscott-AT-goldenspud.com>. Closes #50.
1385 1391
1386 1392 * IPython/iplib.py (InteractiveShell.__init__): remove the
1387 1393 deletion of exit/quit from __builtin__, which can break
1388 1394 third-party tools like the Zope debugging console. The
1389 1395 %exit/%quit magics remain. In general, it's probably a good idea
1390 1396 not to delete anything from __builtin__, since we never know what
1391 1397 that will break. In any case, python now (for 2.5) will support
1392 1398 'real' exit/quit, so this issue is moot. Closes #55.
1393 1399
1394 1400 * IPython/genutils.py (with_obj): rename the 'with' function to
1395 1401 'withobj' to avoid incompatibilities with Python 2.5, where 'with'
1396 1402 becomes a language keyword. Closes #53.
1397 1403
1398 1404 * IPython/FakeModule.py (FakeModule.__init__): add a proper
1399 1405 __file__ attribute to this so it fools more things into thinking
1400 1406 it is a real module. Closes #59.
1401 1407
1402 1408 * IPython/Magic.py (magic_edit): add -n option to open the editor
1403 1409 at a specific line number. After a patch by Stefan van der Walt.
1404 1410
1405 1411 2006-05-23 Fernando Perez <Fernando.Perez@colorado.edu>
1406 1412
1407 1413 * IPython/iplib.py (edit_syntax_error): fix crash when for some
1408 1414 reason the file could not be opened. After automatic crash
1409 1415 reports sent by James Graham <jgraham-AT-ast.cam.ac.uk> and
1410 1416 Charles Dolan <charlespatrickdolan-AT-yahoo.com>.
1411 1417 (_should_recompile): Don't fire editor if using %bg, since there
1412 1418 is no file in the first place. From the same report as above.
1413 1419 (raw_input): protect against faulty third-party prefilters. After
1414 1420 an automatic crash report sent by Dirk Laurie <dirk-AT-sun.ac.za>
1415 1421 while running under SAGE.
1416 1422
1417 1423 2006-05-23 Ville Vainio <vivainio@gmail.com>
1418 1424
1419 1425 * ipapi.py: Stripped down ip.to_user_ns() to work only as
1420 1426 ip.to_user_ns("x1 y1"), which exposes vars x1 and y1. ipapi.get()
1421 1427 now returns None (again), unless dummy is specifically allowed by
1422 1428 ipapi.get(allow_dummy=True).
1423 1429
1424 1430 2006-05-18 Fernando Perez <Fernando.Perez@colorado.edu>
1425 1431
1426 1432 * IPython: remove all 2.2-compatibility objects and hacks from
1427 1433 everywhere, since we only support 2.3 at this point. Docs
1428 1434 updated.
1429 1435
1430 1436 * IPython/ipapi.py (IPApi.__init__): Cleanup of all getters.
1431 1437 Anything requiring extra validation can be turned into a Python
1432 1438 property in the future. I used a property for the db one b/c
1433 1439 there was a nasty circularity problem with the initialization
1434 1440 order, which right now I don't have time to clean up.
1435 1441
1436 1442 * IPython/Shell.py (MTInteractiveShell.runcode): Fix, I think,
1437 1443 another locking bug reported by Jorgen. I'm not 100% sure though,
1438 1444 so more testing is needed...
1439 1445
1440 1446 2006-05-17 Fernando Perez <Fernando.Perez@colorado.edu>
1441 1447
1442 1448 * IPython/ipapi.py (IPApi.to_user_ns): New function to inject
1443 1449 local variables from any routine in user code (typically executed
1444 1450 with %run) directly into the interactive namespace. Very useful
1445 1451 when doing complex debugging.
1446 1452 (IPythonNotRunning): Changed the default None object to a dummy
1447 1453 whose attributes can be queried as well as called without
1448 1454 exploding, to ease writing code which works transparently both in
1449 1455 and out of ipython and uses some of this API.
1450 1456
1451 1457 2006-05-16 Fernando Perez <Fernando.Perez@colorado.edu>
1452 1458
1453 1459 * IPython/hooks.py (result_display): Fix the fact that our display
1454 1460 hook was using str() instead of repr(), as the default python
1455 1461 console does. This had gone unnoticed b/c it only happened if
1456 1462 %Pprint was off, but the inconsistency was there.
1457 1463
1458 1464 2006-05-15 Ville Vainio <vivainio@gmail.com>
1459 1465
1460 1466 * Oinspect.py: Only show docstring for nonexisting/binary files
1461 1467 when doing object??, closing ticket #62
1462 1468
1463 1469 2006-05-13 Fernando Perez <Fernando.Perez@colorado.edu>
1464 1470
1465 1471 * IPython/Shell.py (MTInteractiveShell.runsource): Fix threading
1466 1472 bug, closes http://www.scipy.net/roundup/ipython/issue55. A lock
1467 1473 was being released in a routine which hadn't checked if it had
1468 1474 been the one to acquire it.
1469 1475
1470 1476 2006-05-07 Fernando Perez <Fernando.Perez@colorado.edu>
1471 1477
1472 1478 * IPython/Release.py (version): put out 0.7.2.rc1 for testing.
1473 1479
1474 1480 2006-04-11 Ville Vainio <vivainio@gmail.com>
1475 1481
1476 1482 * iplib.py, ipmaker.py: .ipy extension now means "ipython batch file"
1477 1483 in command line. E.g. "ipython test.ipy" runs test.ipy with ipython
1478 1484 prefilters, allowing stuff like magics and aliases in the file.
1479 1485
1480 1486 * Prompts.py, Extensions/clearcmd.py, ipy_system_conf.py: %clear magic
1481 1487 added. Supported now are "%clear in" and "%clear out" (clear input and
1482 1488 output history, respectively). Also fixed CachedOutput.flush to
1483 1489 properly flush the output cache.
1484 1490
1485 1491 * Extensions/pspersistence.py: Fix %store to avoid "%store obj.attr"
1486 1492 half-success (and fail explicitly).
1487 1493
1488 1494 2006-03-28 Ville Vainio <vivainio@gmail.com>
1489 1495
1490 1496 * iplib.py: Fix quoting of aliases so that only argless ones
1491 1497 are quoted
1492 1498
1493 1499 2006-03-28 Ville Vainio <vivainio@gmail.com>
1494 1500
1495 1501 * iplib.py: Quote aliases with spaces in the name.
1496 1502 "c:\program files\blah\bin" is now legal alias target.
1497 1503
1498 1504 * ext_rehashdir.py: Space no longer allowed as arg
1499 1505 separator, since space is legal in path names.
1500 1506
1501 1507 2006-03-16 Ville Vainio <vivainio@gmail.com>
1502 1508
1503 1509 * upgrade_dir.py: Take path.py from Extensions, correcting
1504 1510 %upgrade magic
1505 1511
1506 1512 * ipmaker.py: Suggest using %upgrade if ipy_user_conf.py isn't found.
1507 1513
1508 1514 * hooks.py: Only enclose editor binary in quotes if legal and
1509 1515 necessary (space in the name, and is an existing file). Fixes a bug
1510 1516 reported by Zachary Pincus.
1511 1517
1512 1518 2006-03-13 Fernando Perez <Fernando.Perez@colorado.edu>
1513 1519
1514 1520 * Manual: thanks to a tip on proper color handling for Emacs, by
1515 1521 Eric J Haywiser <ejh1-AT-MIT.EDU>.
1516 1522
1517 1523 * ipython.el: close http://www.scipy.net/roundup/ipython/issue57
1518 1524 by applying the provided patch. Thanks to Liu Jin
1519 1525 <m.liu.jin-AT-gmail.com> for the contribution. No problems under
1520 1526 XEmacs/Linux, I'm trusting the submitter that it actually helps
1521 1527 under win32/GNU Emacs. Will revisit if any problems are reported.
1522 1528
1523 1529 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1524 1530
1525 1531 * IPython/Gnuplot2.py (_FileClass): update for current Gnuplot.py
1526 1532 from SVN, thanks to a patch by Ryan Woodard <rywo@bas.ac.uk>.
1527 1533
1528 1534 2006-03-12 Ville Vainio <vivainio@gmail.com>
1529 1535
1530 1536 * Magic.py (magic_timeit): Added %timeit magic, contributed by
1531 1537 Torsten Marek.
1532 1538
1533 1539 2006-03-12 Fernando Perez <Fernando.Perez@colorado.edu>
1534 1540
1535 1541 * IPython/Magic.py (magic_macro): fix so that the n1-n2 syntax for
1536 1542 line ranges works again.
1537 1543
1538 1544 2006-03-11 Fernando Perez <Fernando.Perez@colorado.edu>
1539 1545
1540 1546 * IPython/iplib.py (showtraceback): add back sys.last_traceback
1541 1547 and friends, after a discussion with Zach Pincus on ipython-user.
1542 1548 I'm not 100% sure, but after thinking about it quite a bit, it may
1543 1549 be OK. Testing with the multithreaded shells didn't reveal any
1544 1550 problems, but let's keep an eye out.
1545 1551
1546 1552 In the process, I fixed a few things which were calling
1547 1553 self.InteractiveTB() directly (like safe_execfile), which is a
1548 1554 mistake: ALL exception reporting should be done by calling
1549 1555 self.showtraceback(), which handles state and tab-completion and
1550 1556 more.
1551 1557
1552 1558 2006-03-01 Ville Vainio <vivainio@gmail.com>
1553 1559
1554 1560 * Extensions/ipipe.py: Added Walter Doerwald's "ipipe" module.
1555 1561 To use, do "from ipipe import *".
1556 1562
1557 1563 2006-02-24 Ville Vainio <vivainio@gmail.com>
1558 1564
1559 1565 * Magic.py, upgrade_dir.py: %upgrade magic added. Does things more
1560 1566 "cleanly" and safely than the older upgrade mechanism.
1561 1567
1562 1568 2006-02-21 Ville Vainio <vivainio@gmail.com>
1563 1569
1564 1570 * Magic.py: %save works again.
1565 1571
1566 1572 2006-02-15 Ville Vainio <vivainio@gmail.com>
1567 1573
1568 1574 * Magic.py: %Pprint works again
1569 1575
1570 1576 * Extensions/ipy_sane_defaults.py: Provide everything provided
1571 1577 in default ipythonrc, to make it possible to have a completely empty
1572 1578 ipythonrc (and thus completely rc-file free configuration)
1573 1579
1574 1580 2006-02-11 Fernando Perez <Fernando.Perez@colorado.edu>
1575 1581
1576 1582 * IPython/hooks.py (editor): quote the call to the editor command,
1577 1583 to allow commands with spaces in them. Problem noted by watching
1578 1584 Ian Oswald's video about textpad under win32 at
1579 1585 http://showmedo.com/videoListPage?listKey=PythonIPythonSeries
1580 1586
1581 1587 * IPython/UserConfig/ipythonrc: Replace @ signs with % when
1582 1588 describing magics (we haven't used @ for a loong time).
1583 1589
1584 1590 * IPython/ultraTB.py (VerboseTB.text.text_repr): Added patch
1585 1591 contributed by marienz to close
1586 1592 http://www.scipy.net/roundup/ipython/issue53.
1587 1593
1588 1594 2006-02-10 Ville Vainio <vivainio@gmail.com>
1589 1595
1590 1596 * genutils.py: getoutput now works in win32 too
1591 1597
1592 1598 * completer.py: alias and magic completion only invoked
1593 1599 at the first "item" in the line, to avoid "cd %store"
1594 1600 nonsense.
1595 1601
1596 1602 2006-02-09 Ville Vainio <vivainio@gmail.com>
1597 1603
1598 1604 * test/*: Added a unit testing framework (finally).
1599 1605 '%run runtests.py' to run test_*.
1600 1606
1601 1607 * ipapi.py: Exposed runlines and set_custom_exc
1602 1608
1603 1609 2006-02-07 Ville Vainio <vivainio@gmail.com>
1604 1610
1605 1611 * iplib.py: don't split "f 1 2" to "f(1,2)" in autocall,
1606 1612 instead use "f(1 2)" as before.
1607 1613
1608 1614 2006-02-05 Fernando Perez <Fernando.Perez@colorado.edu>
1609 1615
1610 1616 * IPython/demo.py (IPythonDemo): Add new classes to the demo
1611 1617 facilities, for demos processed by the IPython input filter
1612 1618 (IPythonDemo), and for running a script one-line-at-a-time as a
1613 1619 demo, both for pure Python (LineDemo) and for IPython-processed
1614 1620 input (IPythonLineDemo). After a request by Dave Kohel, from the
1615 1621 SAGE team.
1616 1622 (Demo.edit): added an edit() method to the demo objects, to edit
1617 1623 the in-memory copy of the last executed block.
1618 1624
1619 1625 * IPython/Magic.py (magic_edit): add '-r' option for 'raw'
1620 1626 processing to %edit, %macro and %save. These commands can now be
1621 1627 invoked on the unprocessed input as it was typed by the user
1622 1628 (without any prefilters applied). After requests by the SAGE team
1623 1629 at SAGE days 2006: http://modular.ucsd.edu/sage/days1/schedule.html.
1624 1630
1625 1631 2006-02-01 Ville Vainio <vivainio@gmail.com>
1626 1632
1627 1633 * setup.py, eggsetup.py: easy_install ipython==dev works
1628 1634 correctly now (on Linux)
1629 1635
1630 1636 * ipy_user_conf,ipmaker: user config changes, removed spurious
1631 1637 warnings
1632 1638
1633 1639 * iplib: if rc.banner is string, use it as is.
1634 1640
1635 1641 * Magic: %pycat accepts a string argument and pages it's contents.
1636 1642
1637 1643
1638 1644 2006-01-30 Ville Vainio <vivainio@gmail.com>
1639 1645
1640 1646 * pickleshare,pspersistence,ipapi,Magic: persistence overhaul.
1641 1647 Now %store and bookmarks work through PickleShare, meaning that
1642 1648 concurrent access is possible and all ipython sessions see the
1643 1649 same database situation all the time, instead of snapshot of
1644 1650 the situation when the session was started. Hence, %bookmark
1645 1651 results are immediately accessible from othes sessions. The database
1646 1652 is also available for use by user extensions. See:
1647 1653 http://www.python.org/pypi/pickleshare
1648 1654
1649 1655 * hooks.py: Two new hooks, 'shutdown_hook' and 'late_startup_hook'.
1650 1656
1651 1657 * aliases can now be %store'd
1652 1658
1653 1659 * path.py moved to Extensions so that pickleshare does not need
1654 1660 IPython-specific import. Extensions added to pythonpath right
1655 1661 at __init__.
1656 1662
1657 1663 * iplib.py: ipalias deprecated/redundant; aliases are converted and
1658 1664 called with _ip.system and the pre-transformed command string.
1659 1665
1660 1666 2006-01-29 Fernando Perez <Fernando.Perez@colorado.edu>
1661 1667
1662 1668 * IPython/iplib.py (interact): Fix that we were not catching
1663 1669 KeyboardInterrupt exceptions properly. I'm not quite sure why the
1664 1670 logic here had to change, but it's fixed now.
1665 1671
1666 1672 2006-01-29 Ville Vainio <vivainio@gmail.com>
1667 1673
1668 1674 * iplib.py: Try to import pyreadline on Windows.
1669 1675
1670 1676 2006-01-27 Ville Vainio <vivainio@gmail.com>
1671 1677
1672 1678 * iplib.py: Expose ipapi as _ip in builtin namespace.
1673 1679 Makes ipmagic (-> _ip.magic), ipsystem (-> _ip.system)
1674 1680 and ip_set_hook (-> _ip.set_hook) redundant. % and !
1675 1681 syntax now produce _ip.* variant of the commands.
1676 1682
1677 1683 * "_ip.options().autoedit_syntax = 2" automatically throws
1678 1684 user to editor for syntax error correction without prompting.
1679 1685
1680 1686 2006-01-27 Ville Vainio <vivainio@gmail.com>
1681 1687
1682 1688 * ipmaker.py: Give "realistic" sys.argv for scripts (without
1683 1689 'ipython' at argv[0]) executed through command line.
1684 1690 NOTE: this DEPRECATES calling ipython with multiple scripts
1685 1691 ("ipython a.py b.py c.py")
1686 1692
1687 1693 * iplib.py, hooks.py: Added configurable input prefilter,
1688 1694 named 'input_prefilter'. See ext_rescapture.py for example
1689 1695 usage.
1690 1696
1691 1697 * ext_rescapture.py, Magic.py: Better system command output capture
1692 1698 through 'var = !ls' (deprecates user-visible %sc). Same notation
1693 1699 applies for magics, 'var = %alias' assigns alias list to var.
1694 1700
1695 1701 * ipapi.py: added meta() for accessing extension-usable data store.
1696 1702
1697 1703 * iplib.py: added InteractiveShell.getapi(). New magics should be
1698 1704 written doing self.getapi() instead of using the shell directly.
1699 1705
1700 1706 * Magic.py: %store now allows doing %store foo > ~/myfoo.txt and
1701 1707 %store foo >> ~/myfoo.txt to store variables to files (in clean
1702 1708 textual form, not a restorable pickle).
1703 1709
1704 1710 * ipmaker.py: now import ipy_profile_PROFILENAME automatically
1705 1711
1706 1712 * usage.py, Magic.py: added %quickref
1707 1713
1708 1714 * iplib.py: ESC_PAREN fixes: /f 1 2 -> f(1,2), not f(1 2).
1709 1715
1710 1716 * GetoptErrors when invoking magics etc. with wrong args
1711 1717 are now more helpful:
1712 1718 GetoptError: option -l not recognized (allowed: "qb" )
1713 1719
1714 1720 2006-01-25 Fernando Perez <Fernando.Perez@colorado.edu>
1715 1721
1716 1722 * IPython/demo.py (Demo.show): Flush stdout after each block, so
1717 1723 computationally intensive blocks don't appear to stall the demo.
1718 1724
1719 1725 2006-01-24 Ville Vainio <vivainio@gmail.com>
1720 1726
1721 1727 * iplib.py, hooks.py: 'result_display' hook can return a non-None
1722 1728 value to manipulate resulting history entry.
1723 1729
1724 1730 * ipapi.py: Moved TryNext here from hooks.py. Moved functions
1725 1731 to instance methods of IPApi class, to make extending an embedded
1726 1732 IPython feasible. See ext_rehashdir.py for example usage.
1727 1733
1728 1734 * Merged 1071-1076 from branches/0.7.1
1729 1735
1730 1736
1731 1737 2006-01-23 Fernando Perez <Fernando.Perez@colorado.edu>
1732 1738
1733 1739 * tools/release (daystamp): Fix build tools to use the new
1734 1740 eggsetup.py script to build lightweight eggs.
1735 1741
1736 1742 * Applied changesets 1062 and 1064 before 0.7.1 release.
1737 1743
1738 1744 * IPython/Magic.py (magic_history): Add '-r' option to %hist, to
1739 1745 see the raw input history (without conversions like %ls ->
1740 1746 ipmagic("ls")). After a request from W. Stein, SAGE
1741 1747 (http://modular.ucsd.edu/sage) developer. This information is
1742 1748 stored in the input_hist_raw attribute of the IPython instance, so
1743 1749 developers can access it if needed (it's an InputList instance).
1744 1750
1745 1751 * Versionstring = 0.7.2.svn
1746 1752
1747 1753 * eggsetup.py: A separate script for constructing eggs, creates
1748 1754 proper launch scripts even on Windows (an .exe file in
1749 1755 \python24\scripts).
1750 1756
1751 1757 * ipapi.py: launch_new_instance, launch entry point needed for the
1752 1758 egg.
1753 1759
1754 1760 2006-01-23 Ville Vainio <vivainio@gmail.com>
1755 1761
1756 1762 * Added %cpaste magic for pasting python code
1757 1763
1758 1764 2006-01-22 Ville Vainio <vivainio@gmail.com>
1759 1765
1760 1766 * Merge from branches/0.7.1 into trunk, revs 1052-1057
1761 1767
1762 1768 * Versionstring = 0.7.2.svn
1763 1769
1764 1770 * eggsetup.py: A separate script for constructing eggs, creates
1765 1771 proper launch scripts even on Windows (an .exe file in
1766 1772 \python24\scripts).
1767 1773
1768 1774 * ipapi.py: launch_new_instance, launch entry point needed for the
1769 1775 egg.
1770 1776
1771 1777 2006-01-22 Fernando Perez <Fernando.Perez@colorado.edu>
1772 1778
1773 1779 * IPython/OInspect.py (Inspector.pinfo): fix bug where foo?? or
1774 1780 %pfile foo would print the file for foo even if it was a binary.
1775 1781 Now, extensions '.so' and '.dll' are skipped.
1776 1782
1777 1783 * IPython/Shell.py (MTInteractiveShell.__init__): Fix threading
1778 1784 bug, where macros would fail in all threaded modes. I'm not 100%
1779 1785 sure, so I'm going to put out an rc instead of making a release
1780 1786 today, and wait for feedback for at least a few days.
1781 1787
1782 1788 * IPython/iplib.py (handle_normal): fix (finally? somehow I doubt
1783 1789 it...) the handling of pasting external code with autoindent on.
1784 1790 To get out of a multiline input, the rule will appear for most
1785 1791 users unchanged: two blank lines or change the indent level
1786 1792 proposed by IPython. But there is a twist now: you can
1787 1793 add/subtract only *one or two spaces*. If you add/subtract three
1788 1794 or more (unless you completely delete the line), IPython will
1789 1795 accept that line, and you'll need to enter a second one of pure
1790 1796 whitespace. I know it sounds complicated, but I can't find a
1791 1797 different solution that covers all the cases, with the right
1792 1798 heuristics. Hopefully in actual use, nobody will really notice
1793 1799 all these strange rules and things will 'just work'.
1794 1800
1795 1801 2006-01-21 Fernando Perez <Fernando.Perez@colorado.edu>
1796 1802
1797 1803 * IPython/iplib.py (interact): catch exceptions which can be
1798 1804 triggered asynchronously by signal handlers. Thanks to an
1799 1805 automatic crash report, submitted by Colin Kingsley
1800 1806 <tercel-AT-gentoo.org>.
1801 1807
1802 1808 2006-01-20 Ville Vainio <vivainio@gmail.com>
1803 1809
1804 1810 * Ipython/Extensions/ext_rehashdir.py: Created a usable example
1805 1811 (%rehashdir, very useful, try it out) of how to extend ipython
1806 1812 with new magics. Also added Extensions dir to pythonpath to make
1807 1813 importing extensions easy.
1808 1814
1809 1815 * %store now complains when trying to store interactively declared
1810 1816 classes / instances of those classes.
1811 1817
1812 1818 * Extensions/ipy_system_conf.py, UserConfig/ipy_user_conf.py,
1813 1819 ipmaker.py: Config rehaul. Now ipy_..._conf.py are always imported
1814 1820 if they exist, and ipy_user_conf.py with some defaults is created for
1815 1821 the user.
1816 1822
1817 1823 * Startup rehashing done by the config file, not InterpreterExec.
1818 1824 This means system commands are available even without selecting the
1819 1825 pysh profile. It's the sensible default after all.
1820 1826
1821 1827 2006-01-20 Fernando Perez <Fernando.Perez@colorado.edu>
1822 1828
1823 1829 * IPython/iplib.py (raw_input): I _think_ I got the pasting of
1824 1830 multiline code with autoindent on working. But I am really not
1825 1831 sure, so this needs more testing. Will commit a debug-enabled
1826 1832 version for now, while I test it some more, so that Ville and
1827 1833 others may also catch any problems. Also made
1828 1834 self.indent_current_str() a method, to ensure that there's no
1829 1835 chance of the indent space count and the corresponding string
1830 1836 falling out of sync. All code needing the string should just call
1831 1837 the method.
1832 1838
1833 1839 2006-01-18 Fernando Perez <Fernando.Perez@colorado.edu>
1834 1840
1835 1841 * IPython/Magic.py (magic_edit): fix check for when users don't
1836 1842 save their output files, the try/except was in the wrong section.
1837 1843
1838 1844 2006-01-17 Fernando Perez <Fernando.Perez@colorado.edu>
1839 1845
1840 1846 * IPython/Magic.py (magic_run): fix __file__ global missing from
1841 1847 script's namespace when executed via %run. After a report by
1842 1848 Vivian.
1843 1849
1844 1850 * IPython/Debugger.py (Pdb.__init__): Fix breakage with '%run -d'
1845 1851 when using python 2.4. The parent constructor changed in 2.4, and
1846 1852 we need to track it directly (we can't call it, as it messes up
1847 1853 readline and tab-completion inside our pdb would stop working).
1848 1854 After a bug report by R. Bernstein <rocky-AT-panix.com>.
1849 1855
1850 1856 2006-01-16 Ville Vainio <vivainio@gmail.com>
1851 1857
1852 1858 * Ipython/magic.py: Reverted back to old %edit functionality
1853 1859 that returns file contents on exit.
1854 1860
1855 1861 * IPython/path.py: Added Jason Orendorff's "path" module to
1856 1862 IPython tree, http://www.jorendorff.com/articles/python/path/.
1857 1863 You can get path objects conveniently through %sc, and !!, e.g.:
1858 1864 sc files=ls
1859 1865 for p in files.paths: # or files.p
1860 1866 print p,p.mtime
1861 1867
1862 1868 * Ipython/iplib.py:"," and ";" autoquoting-upon-autocall
1863 1869 now work again without considering the exclusion regexp -
1864 1870 hence, things like ',foo my/path' turn to 'foo("my/path")'
1865 1871 instead of syntax error.
1866 1872
1867 1873
1868 1874 2006-01-14 Ville Vainio <vivainio@gmail.com>
1869 1875
1870 1876 * IPython/ipapi.py (ashook, asmagic, options): Added convenience
1871 1877 ipapi decorators for python 2.4 users, options() provides access to rc
1872 1878 data.
1873 1879
1874 1880 * IPython/Magic.py (magic_cd): %cd now accepts backslashes
1875 1881 as path separators (even on Linux ;-). Space character after
1876 1882 backslash (as yielded by tab completer) is still space;
1877 1883 "%cd long\ name" works as expected.
1878 1884
1879 1885 * IPython/ipapi.py,hooks.py,iplib.py: Hooks now implemented
1880 1886 as "chain of command", with priority. API stays the same,
1881 1887 TryNext exception raised by a hook function signals that
1882 1888 current hook failed and next hook should try handling it, as
1883 1889 suggested by Walter DΓΆrwald <walter@livinglogic.de>. Walter also
1884 1890 requested configurable display hook, which is now implemented.
1885 1891
1886 1892 2006-01-13 Ville Vainio <vivainio@gmail.com>
1887 1893
1888 1894 * IPython/platutils*.py: platform specific utility functions,
1889 1895 so far only set_term_title is implemented (change terminal
1890 1896 label in windowing systems). %cd now changes the title to
1891 1897 current dir.
1892 1898
1893 1899 * IPython/Release.py: Added myself to "authors" list,
1894 1900 had to create new files.
1895 1901
1896 1902 * IPython/iplib.py (handle_shell_escape): fixed logical flaw in
1897 1903 shell escape; not a known bug but had potential to be one in the
1898 1904 future.
1899 1905
1900 1906 * IPython/ipapi.py (added),OInspect.py,iplib.py: "Public"
1901 1907 extension API for IPython! See the module for usage example. Fix
1902 1908 OInspect for docstring-less magic functions.
1903 1909
1904 1910
1905 1911 2006-01-13 Fernando Perez <Fernando.Perez@colorado.edu>
1906 1912
1907 1913 * IPython/iplib.py (raw_input): temporarily deactivate all
1908 1914 attempts at allowing pasting of code with autoindent on. It
1909 1915 introduced bugs (reported by Prabhu) and I can't seem to find a
1910 1916 robust combination which works in all cases. Will have to revisit
1911 1917 later.
1912 1918
1913 1919 * IPython/genutils.py: remove isspace() function. We've dropped
1914 1920 2.2 compatibility, so it's OK to use the string method.
1915 1921
1916 1922 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1917 1923
1918 1924 * IPython/iplib.py (InteractiveShell.__init__): fix regexp
1919 1925 matching what NOT to autocall on, to include all python binary
1920 1926 operators (including things like 'and', 'or', 'is' and 'in').
1921 1927 Prompted by a bug report on 'foo & bar', but I realized we had
1922 1928 many more potential bug cases with other operators. The regexp is
1923 1929 self.re_exclude_auto, it's fairly commented.
1924 1930
1925 1931 2006-01-12 Ville Vainio <vivainio@gmail.com>
1926 1932
1927 1933 * IPython/iplib.py (make_quoted_expr,handle_shell_escape):
1928 1934 Prettified and hardened string/backslash quoting with ipsystem(),
1929 1935 ipalias() and ipmagic(). Now even \ characters are passed to
1930 1936 %magics, !shell escapes and aliases exactly as they are in the
1931 1937 ipython command line. Should improve backslash experience,
1932 1938 particularly in Windows (path delimiter for some commands that
1933 1939 won't understand '/'), but Unix benefits as well (regexps). %cd
1934 1940 magic still doesn't support backslash path delimiters, though. Also
1935 1941 deleted all pretense of supporting multiline command strings in
1936 1942 !system or %magic commands. Thanks to Jerry McRae for suggestions.
1937 1943
1938 1944 * doc/build_doc_instructions.txt added. Documentation on how to
1939 1945 use doc/update_manual.py, added yesterday. Both files contributed
1940 1946 by JΓΆrgen Stenarson <jorgen.stenarson-AT-bostream.nu>. This slates
1941 1947 doc/*.sh for deprecation at a later date.
1942 1948
1943 1949 * /ipython.py Added ipython.py to root directory for
1944 1950 zero-installation (tar xzvf ipython.tgz; cd ipython; python
1945 1951 ipython.py) and development convenience (no need to keep doing
1946 1952 "setup.py install" between changes).
1947 1953
1948 1954 * Made ! and !! shell escapes work (again) in multiline expressions:
1949 1955 if 1:
1950 1956 !ls
1951 1957 !!ls
1952 1958
1953 1959 2006-01-12 Fernando Perez <Fernando.Perez@colorado.edu>
1954 1960
1955 1961 * IPython/ipstruct.py (Struct): Rename IPython.Struct to
1956 1962 IPython.ipstruct, to avoid local shadowing of the stdlib 'struct'
1957 1963 module in case-insensitive installation. Was causing crashes
1958 1964 under win32. Closes http://www.scipy.net/roundup/ipython/issue49.
1959 1965
1960 1966 * IPython/Magic.py (magic_pycat): Fix pycat, patch by Marien Zwart
1961 1967 <marienz-AT-gentoo.org>, closes
1962 1968 http://www.scipy.net/roundup/ipython/issue51.
1963 1969
1964 1970 2006-01-11 Fernando Perez <Fernando.Perez@colorado.edu>
1965 1971
1966 1972 * IPython/Shell.py (IPShellGTK.on_timer): Finally fix the
1967 1973 problem of excessive CPU usage under *nix and keyboard lag under
1968 1974 win32.
1969 1975
1970 1976 2006-01-10 *** Released version 0.7.0
1971 1977
1972 1978 2006-01-10 Fernando Perez <Fernando.Perez@colorado.edu>
1973 1979
1974 1980 * IPython/Release.py (revision): tag version number to 0.7.0,
1975 1981 ready for release.
1976 1982
1977 1983 * IPython/Magic.py (magic_edit): Add print statement to %edit so
1978 1984 it informs the user of the name of the temp. file used. This can
1979 1985 help if you decide later to reuse that same file, so you know
1980 1986 where to copy the info from.
1981 1987
1982 1988 2006-01-09 Fernando Perez <Fernando.Perez@colorado.edu>
1983 1989
1984 1990 * setup_bdist_egg.py: little script to build an egg. Added
1985 1991 support in the release tools as well.
1986 1992
1987 1993 2006-01-08 Fernando Perez <Fernando.Perez@colorado.edu>
1988 1994
1989 1995 * IPython/Shell.py (IPShellWX.__init__): add support for WXPython
1990 1996 version selection (new -wxversion command line and ipythonrc
1991 1997 parameter). Patch contributed by Arnd Baecker
1992 1998 <arnd.baecker-AT-web.de>.
1993 1999
1994 2000 * IPython/iplib.py (embed_mainloop): fix tab-completion in
1995 2001 embedded instances, for variables defined at the interactive
1996 2002 prompt of the embedded ipython. Reported by Arnd.
1997 2003
1998 2004 * IPython/Magic.py (magic_autocall): Fix %autocall magic. Now
1999 2005 it can be used as a (stateful) toggle, or with a direct parameter.
2000 2006
2001 2007 * IPython/ultraTB.py (_fixed_getinnerframes): remove debug assert which
2002 2008 could be triggered in certain cases and cause the traceback
2003 2009 printer not to work.
2004 2010
2005 2011 2006-01-07 Fernando Perez <Fernando.Perez@colorado.edu>
2006 2012
2007 2013 * IPython/iplib.py (_should_recompile): Small fix, closes
2008 2014 http://www.scipy.net/roundup/ipython/issue48. Patch by Scott.
2009 2015
2010 2016 2006-01-04 Fernando Perez <Fernando.Perez@colorado.edu>
2011 2017
2012 2018 * IPython/Shell.py (IPShellGTK.mainloop): fix bug in the GTK
2013 2019 backend for matplotlib (100% cpu utiliziation). Thanks to Charlie
2014 2020 Moad for help with tracking it down.
2015 2021
2016 2022 * IPython/iplib.py (handle_auto): fix autocall handling for
2017 2023 objects which support BOTH __getitem__ and __call__ (so that f [x]
2018 2024 is left alone, instead of becoming f([x]) automatically).
2019 2025
2020 2026 * IPython/Magic.py (magic_cd): fix crash when cd -b was used.
2021 2027 Ville's patch.
2022 2028
2023 2029 2006-01-03 Fernando Perez <Fernando.Perez@colorado.edu>
2024 2030
2025 2031 * IPython/iplib.py (handle_auto): changed autocall semantics to
2026 2032 include 'smart' mode, where the autocall transformation is NOT
2027 2033 applied if there are no arguments on the line. This allows you to
2028 2034 just type 'foo' if foo is a callable to see its internal form,
2029 2035 instead of having it called with no arguments (typically a
2030 2036 mistake). The old 'full' autocall still exists: for that, you
2031 2037 need to set the 'autocall' parameter to 2 in your ipythonrc file.
2032 2038
2033 2039 * IPython/completer.py (Completer.attr_matches): add
2034 2040 tab-completion support for Enthoughts' traits. After a report by
2035 2041 Arnd and a patch by Prabhu.
2036 2042
2037 2043 2006-01-02 Fernando Perez <Fernando.Perez@colorado.edu>
2038 2044
2039 2045 * IPython/ultraTB.py (_fixed_getinnerframes): added Alex
2040 2046 Schmolck's patch to fix inspect.getinnerframes().
2041 2047
2042 2048 * IPython/iplib.py (InteractiveShell.__init__): significant fixes
2043 2049 for embedded instances, regarding handling of namespaces and items
2044 2050 added to the __builtin__ one. Multiple embedded instances and
2045 2051 recursive embeddings should work better now (though I'm not sure
2046 2052 I've got all the corner cases fixed, that code is a bit of a brain
2047 2053 twister).
2048 2054
2049 2055 * IPython/Magic.py (magic_edit): added support to edit in-memory
2050 2056 macros (automatically creates the necessary temp files). %edit
2051 2057 also doesn't return the file contents anymore, it's just noise.
2052 2058
2053 2059 * IPython/completer.py (Completer.attr_matches): revert change to
2054 2060 complete only on attributes listed in __all__. I realized it
2055 2061 cripples the tab-completion system as a tool for exploring the
2056 2062 internals of unknown libraries (it renders any non-__all__
2057 2063 attribute off-limits). I got bit by this when trying to see
2058 2064 something inside the dis module.
2059 2065
2060 2066 2005-12-31 Fernando Perez <Fernando.Perez@colorado.edu>
2061 2067
2062 2068 * IPython/iplib.py (InteractiveShell.__init__): add .meta
2063 2069 namespace for users and extension writers to hold data in. This
2064 2070 follows the discussion in
2065 2071 http://projects.scipy.org/ipython/ipython/wiki/RefactoringIPython.
2066 2072
2067 2073 * IPython/completer.py (IPCompleter.complete): small patch to help
2068 2074 tab-completion under Emacs, after a suggestion by John Barnard
2069 2075 <barnarj-AT-ccf.org>.
2070 2076
2071 2077 * IPython/Magic.py (Magic.extract_input_slices): added support for
2072 2078 the slice notation in magics to use N-M to represent numbers N...M
2073 2079 (closed endpoints). This is used by %macro and %save.
2074 2080
2075 2081 * IPython/completer.py (Completer.attr_matches): for modules which
2076 2082 define __all__, complete only on those. After a patch by Jeffrey
2077 2083 Collins <jcollins_boulder-AT-earthlink.net>. Also, clean up and
2078 2084 speed up this routine.
2079 2085
2080 2086 * IPython/Logger.py (Logger.log): fix a history handling bug. I
2081 2087 don't know if this is the end of it, but the behavior now is
2082 2088 certainly much more correct. Note that coupled with macros,
2083 2089 slightly surprising (at first) behavior may occur: a macro will in
2084 2090 general expand to multiple lines of input, so upon exiting, the
2085 2091 in/out counters will both be bumped by the corresponding amount
2086 2092 (as if the macro's contents had been typed interactively). Typing
2087 2093 %hist will reveal the intermediate (silently processed) lines.
2088 2094
2089 2095 * IPython/Magic.py (magic_run): fix a subtle bug which could cause
2090 2096 pickle to fail (%run was overwriting __main__ and not restoring
2091 2097 it, but pickle relies on __main__ to operate).
2092 2098
2093 2099 * IPython/iplib.py (InteractiveShell): fix pdb calling: I'm now
2094 2100 using properties, but forgot to make the main InteractiveShell
2095 2101 class a new-style class. Properties fail silently, and
2096 2102 mysteriously, with old-style class (getters work, but
2097 2103 setters don't do anything).
2098 2104
2099 2105 2005-12-30 Fernando Perez <Fernando.Perez@colorado.edu>
2100 2106
2101 2107 * IPython/Magic.py (magic_history): fix history reporting bug (I
2102 2108 know some nasties are still there, I just can't seem to find a
2103 2109 reproducible test case to track them down; the input history is
2104 2110 falling out of sync...)
2105 2111
2106 2112 * IPython/iplib.py (handle_shell_escape): fix bug where both
2107 2113 aliases and system accesses where broken for indented code (such
2108 2114 as loops).
2109 2115
2110 2116 * IPython/genutils.py (shell): fix small but critical bug for
2111 2117 win32 system access.
2112 2118
2113 2119 2005-12-29 Fernando Perez <Fernando.Perez@colorado.edu>
2114 2120
2115 2121 * IPython/iplib.py (showtraceback): remove use of the
2116 2122 sys.last_{type/value/traceback} structures, which are non
2117 2123 thread-safe.
2118 2124 (_prefilter): change control flow to ensure that we NEVER
2119 2125 introspect objects when autocall is off. This will guarantee that
2120 2126 having an input line of the form 'x.y', where access to attribute
2121 2127 'y' has side effects, doesn't trigger the side effect TWICE. It
2122 2128 is important to note that, with autocall on, these side effects
2123 2129 can still happen.
2124 2130 (ipsystem): new builtin, to complete the ip{magic/alias/system}
2125 2131 trio. IPython offers these three kinds of special calls which are
2126 2132 not python code, and it's a good thing to have their call method
2127 2133 be accessible as pure python functions (not just special syntax at
2128 2134 the command line). It gives us a better internal implementation
2129 2135 structure, as well as exposing these for user scripting more
2130 2136 cleanly.
2131 2137
2132 2138 * IPython/macro.py (Macro.__init__): moved macros to a standalone
2133 2139 file. Now that they'll be more likely to be used with the
2134 2140 persistance system (%store), I want to make sure their module path
2135 2141 doesn't change in the future, so that we don't break things for
2136 2142 users' persisted data.
2137 2143
2138 2144 * IPython/iplib.py (autoindent_update): move indentation
2139 2145 management into the _text_ processing loop, not the keyboard
2140 2146 interactive one. This is necessary to correctly process non-typed
2141 2147 multiline input (such as macros).
2142 2148
2143 2149 * IPython/Magic.py (Magic.format_latex): patch by Stefan van der
2144 2150 Walt <stefan-AT-sun.ac.za> to fix latex formatting of docstrings,
2145 2151 which was producing problems in the resulting manual.
2146 2152 (magic_whos): improve reporting of instances (show their class,
2147 2153 instead of simply printing 'instance' which isn't terribly
2148 2154 informative).
2149 2155
2150 2156 * IPython/genutils.py (shell): commit Jorgen Stenarson's patch
2151 2157 (minor mods) to support network shares under win32.
2152 2158
2153 2159 * IPython/winconsole.py (get_console_size): add new winconsole
2154 2160 module and fixes to page_dumb() to improve its behavior under
2155 2161 win32. Contributed by Alexander Belchenko <bialix-AT-ukr.net>.
2156 2162
2157 2163 * IPython/Magic.py (Macro): simplified Macro class to just
2158 2164 subclass list. We've had only 2.2 compatibility for a very long
2159 2165 time, yet I was still avoiding subclassing the builtin types. No
2160 2166 more (I'm also starting to use properties, though I won't shift to
2161 2167 2.3-specific features quite yet).
2162 2168 (magic_store): added Ville's patch for lightweight variable
2163 2169 persistence, after a request on the user list by Matt Wilkie
2164 2170 <maphew-AT-gmail.com>. The new %store magic's docstring has full
2165 2171 details.
2166 2172
2167 2173 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2168 2174 changed the default logfile name from 'ipython.log' to
2169 2175 'ipython_log.py'. These logs are real python files, and now that
2170 2176 we have much better multiline support, people are more likely to
2171 2177 want to use them as such. Might as well name them correctly.
2172 2178
2173 2179 * IPython/Magic.py: substantial cleanup. While we can't stop
2174 2180 using magics as mixins, due to the existing customizations 'out
2175 2181 there' which rely on the mixin naming conventions, at least I
2176 2182 cleaned out all cross-class name usage. So once we are OK with
2177 2183 breaking compatibility, the two systems can be separated.
2178 2184
2179 2185 * IPython/Logger.py: major cleanup. This one is NOT a mixin
2180 2186 anymore, and the class is a fair bit less hideous as well. New
2181 2187 features were also introduced: timestamping of input, and logging
2182 2188 of output results. These are user-visible with the -t and -o
2183 2189 options to %logstart. Closes
2184 2190 http://www.scipy.net/roundup/ipython/issue11 and a request by
2185 2191 William Stein (SAGE developer - http://modular.ucsd.edu/sage).
2186 2192
2187 2193 2005-12-28 Fernando Perez <Fernando.Perez@colorado.edu>
2188 2194
2189 2195 * IPython/iplib.py (handle_shell_escape): add Ville's patch to
2190 2196 better handle backslashes in paths. See the thread 'More Windows
2191 2197 questions part 2 - \/ characters revisited' on the iypthon user
2192 2198 list:
2193 2199 http://scipy.net/pipermail/ipython-user/2005-June/000907.html
2194 2200
2195 2201 (InteractiveShell.__init__): fix tab-completion bug in threaded shells.
2196 2202
2197 2203 (InteractiveShell.__init__): change threaded shells to not use the
2198 2204 ipython crash handler. This was causing more problems than not,
2199 2205 as exceptions in the main thread (GUI code, typically) would
2200 2206 always show up as a 'crash', when they really weren't.
2201 2207
2202 2208 The colors and exception mode commands (%colors/%xmode) have been
2203 2209 synchronized to also take this into account, so users can get
2204 2210 verbose exceptions for their threaded code as well. I also added
2205 2211 support for activating pdb inside this exception handler as well,
2206 2212 so now GUI authors can use IPython's enhanced pdb at runtime.
2207 2213
2208 2214 * IPython/ipmaker.py (make_IPython): make the autoedit_syntax flag
2209 2215 true by default, and add it to the shipped ipythonrc file. Since
2210 2216 this asks the user before proceeding, I think it's OK to make it
2211 2217 true by default.
2212 2218
2213 2219 * IPython/Magic.py (magic_exit): make new exit/quit magics instead
2214 2220 of the previous special-casing of input in the eval loop. I think
2215 2221 this is cleaner, as they really are commands and shouldn't have
2216 2222 a special role in the middle of the core code.
2217 2223
2218 2224 2005-12-27 Fernando Perez <Fernando.Perez@colorado.edu>
2219 2225
2220 2226 * IPython/iplib.py (edit_syntax_error): added support for
2221 2227 automatically reopening the editor if the file had a syntax error
2222 2228 in it. Thanks to scottt who provided the patch at:
2223 2229 http://www.scipy.net/roundup/ipython/issue36 (slightly modified
2224 2230 version committed).
2225 2231
2226 2232 * IPython/iplib.py (handle_normal): add suport for multi-line
2227 2233 input with emtpy lines. This fixes
2228 2234 http://www.scipy.net/roundup/ipython/issue43 and a similar
2229 2235 discussion on the user list.
2230 2236
2231 2237 WARNING: a behavior change is necessarily introduced to support
2232 2238 blank lines: now a single blank line with whitespace does NOT
2233 2239 break the input loop, which means that when autoindent is on, by
2234 2240 default hitting return on the next (indented) line does NOT exit.
2235 2241
2236 2242 Instead, to exit a multiline input you can either have:
2237 2243
2238 2244 - TWO whitespace lines (just hit return again), or
2239 2245 - a single whitespace line of a different length than provided
2240 2246 by the autoindent (add or remove a space).
2241 2247
2242 2248 * IPython/completer.py (MagicCompleter.__init__): new 'completer'
2243 2249 module to better organize all readline-related functionality.
2244 2250 I've deleted FlexCompleter and put all completion clases here.
2245 2251
2246 2252 * IPython/iplib.py (raw_input): improve indentation management.
2247 2253 It is now possible to paste indented code with autoindent on, and
2248 2254 the code is interpreted correctly (though it still looks bad on
2249 2255 screen, due to the line-oriented nature of ipython).
2250 2256 (MagicCompleter.complete): change behavior so that a TAB key on an
2251 2257 otherwise empty line actually inserts a tab, instead of completing
2252 2258 on the entire global namespace. This makes it easier to use the
2253 2259 TAB key for indentation. After a request by Hans Meine
2254 2260 <hans_meine-AT-gmx.net>
2255 2261 (_prefilter): add support so that typing plain 'exit' or 'quit'
2256 2262 does a sensible thing. Originally I tried to deviate as little as
2257 2263 possible from the default python behavior, but even that one may
2258 2264 change in this direction (thread on python-dev to that effect).
2259 2265 Regardless, ipython should do the right thing even if CPython's
2260 2266 '>>>' prompt doesn't.
2261 2267 (InteractiveShell): removed subclassing code.InteractiveConsole
2262 2268 class. By now we'd overridden just about all of its methods: I've
2263 2269 copied the remaining two over, and now ipython is a standalone
2264 2270 class. This will provide a clearer picture for the chainsaw
2265 2271 branch refactoring.
2266 2272
2267 2273 2005-12-26 Fernando Perez <Fernando.Perez@colorado.edu>
2268 2274
2269 2275 * IPython/ultraTB.py (VerboseTB.text): harden reporting against
2270 2276 failures for objects which break when dir() is called on them.
2271 2277
2272 2278 * IPython/FlexCompleter.py (Completer.__init__): Added support for
2273 2279 distinct local and global namespaces in the completer API. This
2274 2280 change allows us to properly handle completion with distinct
2275 2281 scopes, including in embedded instances (this had never really
2276 2282 worked correctly).
2277 2283
2278 2284 Note: this introduces a change in the constructor for
2279 2285 MagicCompleter, as a new global_namespace parameter is now the
2280 2286 second argument (the others were bumped one position).
2281 2287
2282 2288 2005-12-25 Fernando Perez <Fernando.Perez@colorado.edu>
2283 2289
2284 2290 * IPython/iplib.py (embed_mainloop): fix tab-completion in
2285 2291 embedded instances (which can be done now thanks to Vivian's
2286 2292 frame-handling fixes for pdb).
2287 2293 (InteractiveShell.__init__): Fix namespace handling problem in
2288 2294 embedded instances. We were overwriting __main__ unconditionally,
2289 2295 and this should only be done for 'full' (non-embedded) IPython;
2290 2296 embedded instances must respect the caller's __main__. Thanks to
2291 2297 a bug report by Yaroslav Bulatov <yaroslavvb-AT-gmail.com>
2292 2298
2293 2299 2005-12-24 Fernando Perez <Fernando.Perez@colorado.edu>
2294 2300
2295 2301 * setup.py: added download_url to setup(). This registers the
2296 2302 download address at PyPI, which is not only useful to humans
2297 2303 browsing the site, but is also picked up by setuptools (the Eggs
2298 2304 machinery). Thanks to Ville and R. Kern for the info/discussion
2299 2305 on this.
2300 2306
2301 2307 2005-12-23 Fernando Perez <Fernando.Perez@colorado.edu>
2302 2308
2303 2309 * IPython/Debugger.py (Pdb.__init__): Major pdb mode enhancements.
2304 2310 This brings a lot of nice functionality to the pdb mode, which now
2305 2311 has tab-completion, syntax highlighting, and better stack handling
2306 2312 than before. Many thanks to Vivian De Smedt
2307 2313 <vivian-AT-vdesmedt.com> for the original patches.
2308 2314
2309 2315 2005-12-08 Fernando Perez <Fernando.Perez@colorado.edu>
2310 2316
2311 2317 * IPython/Shell.py (IPShellGTK.mainloop): fix mainloop() calling
2312 2318 sequence to consistently accept the banner argument. The
2313 2319 inconsistency was tripping SAGE, thanks to Gary Zablackis
2314 2320 <gzabl-AT-yahoo.com> for the report.
2315 2321
2316 2322 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2317 2323
2318 2324 * IPython/iplib.py (InteractiveShell.post_config_initialization):
2319 2325 Fix bug where a naked 'alias' call in the ipythonrc file would
2320 2326 cause a crash. Bug reported by Jorgen Stenarson.
2321 2327
2322 2328 2005-11-15 Fernando Perez <Fernando.Perez@colorado.edu>
2323 2329
2324 2330 * IPython/ipmaker.py (make_IPython): cleanups which should improve
2325 2331 startup time.
2326 2332
2327 2333 * IPython/iplib.py (runcode): my globals 'fix' for embedded
2328 2334 instances had introduced a bug with globals in normal code. Now
2329 2335 it's working in all cases.
2330 2336
2331 2337 * IPython/Magic.py (magic_psearch): Finish wildcard cleanup and
2332 2338 API changes. A new ipytonrc option, 'wildcards_case_sensitive'
2333 2339 has been introduced to set the default case sensitivity of the
2334 2340 searches. Users can still select either mode at runtime on a
2335 2341 per-search basis.
2336 2342
2337 2343 2005-11-13 Fernando Perez <Fernando.Perez@colorado.edu>
2338 2344
2339 2345 * IPython/wildcard.py (NameSpace.__init__): fix resolution of
2340 2346 attributes in wildcard searches for subclasses. Modified version
2341 2347 of a patch by Jorgen.
2342 2348
2343 2349 2005-11-12 Fernando Perez <Fernando.Perez@colorado.edu>
2344 2350
2345 2351 * IPython/iplib.py (embed_mainloop): Fix handling of globals for
2346 2352 embedded instances. I added a user_global_ns attribute to the
2347 2353 InteractiveShell class to handle this.
2348 2354
2349 2355 2005-10-31 Fernando Perez <Fernando.Perez@colorado.edu>
2350 2356
2351 2357 * IPython/Shell.py (IPShellGTK.mainloop): Change timeout_add to
2352 2358 idle_add, which fixes horrible keyboard lag problems under gtk 2.6
2353 2359 (reported under win32, but may happen also in other platforms).
2354 2360 Bug report and fix courtesy of Sean Moore <smm-AT-logic.bm>
2355 2361
2356 2362 2005-10-15 Fernando Perez <Fernando.Perez@colorado.edu>
2357 2363
2358 2364 * IPython/Magic.py (magic_psearch): new support for wildcard
2359 2365 patterns. Now, typing ?a*b will list all names which begin with a
2360 2366 and end in b, for example. The %psearch magic has full
2361 2367 docstrings. Many thanks to JΓΆrgen Stenarson
2362 2368 <jorgen.stenarson-AT-bostream.nu>, author of the patches
2363 2369 implementing this functionality.
2364 2370
2365 2371 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2366 2372
2367 2373 * Manual: fixed long-standing annoyance of double-dashes (as in
2368 2374 --prefix=~, for example) being stripped in the HTML version. This
2369 2375 is a latex2html bug, but a workaround was provided. Many thanks
2370 2376 to George K. Thiruvathukal <gthiruv-AT-luc.edu> for the detailed
2371 2377 help, and Michael Tobis <mtobis-AT-gmail.com> for getting the ball
2372 2378 rolling. This seemingly small issue had tripped a number of users
2373 2379 when first installing, so I'm glad to see it gone.
2374 2380
2375 2381 2005-09-27 Fernando Perez <Fernando.Perez@colorado.edu>
2376 2382
2377 2383 * IPython/Extensions/numeric_formats.py: fix missing import,
2378 2384 reported by Stephen Walton.
2379 2385
2380 2386 2005-09-24 Fernando Perez <Fernando.Perez@colorado.edu>
2381 2387
2382 2388 * IPython/demo.py: finish demo module, fully documented now.
2383 2389
2384 2390 * IPython/genutils.py (file_read): simple little utility to read a
2385 2391 file and ensure it's closed afterwards.
2386 2392
2387 2393 2005-09-23 Fernando Perez <Fernando.Perez@colorado.edu>
2388 2394
2389 2395 * IPython/demo.py (Demo.__init__): added support for individually
2390 2396 tagging blocks for automatic execution.
2391 2397
2392 2398 * IPython/Magic.py (magic_pycat): new %pycat magic for showing
2393 2399 syntax-highlighted python sources, requested by John.
2394 2400
2395 2401 2005-09-22 Fernando Perez <Fernando.Perez@colorado.edu>
2396 2402
2397 2403 * IPython/demo.py (Demo.again): fix bug where again() blocks after
2398 2404 finishing.
2399 2405
2400 2406 * IPython/genutils.py (shlex_split): moved from Magic to here,
2401 2407 where all 2.2 compatibility stuff lives. I needed it for demo.py.
2402 2408
2403 2409 * IPython/demo.py (Demo.__init__): added support for silent
2404 2410 blocks, improved marks as regexps, docstrings written.
2405 2411 (Demo.__init__): better docstring, added support for sys.argv.
2406 2412
2407 2413 * IPython/genutils.py (marquee): little utility used by the demo
2408 2414 code, handy in general.
2409 2415
2410 2416 * IPython/demo.py (Demo.__init__): new class for interactive
2411 2417 demos. Not documented yet, I just wrote it in a hurry for
2412 2418 scipy'05. Will docstring later.
2413 2419
2414 2420 2005-09-20 Fernando Perez <Fernando.Perez@colorado.edu>
2415 2421
2416 2422 * IPython/Shell.py (sigint_handler): Drastic simplification which
2417 2423 also seems to make Ctrl-C work correctly across threads! This is
2418 2424 so simple, that I can't beleive I'd missed it before. Needs more
2419 2425 testing, though.
2420 2426 (KBINT): Never mind, revert changes. I'm sure I'd tried something
2421 2427 like this before...
2422 2428
2423 2429 * IPython/genutils.py (get_home_dir): add protection against
2424 2430 non-dirs in win32 registry.
2425 2431
2426 2432 * IPython/iplib.py (InteractiveShell.alias_table_validate): fix
2427 2433 bug where dict was mutated while iterating (pysh crash).
2428 2434
2429 2435 2005-09-06 Fernando Perez <Fernando.Perez@colorado.edu>
2430 2436
2431 2437 * IPython/iplib.py (handle_auto): Fix inconsistency arising from
2432 2438 spurious newlines added by this routine. After a report by
2433 2439 F. Mantegazza.
2434 2440
2435 2441 2005-09-05 Fernando Perez <Fernando.Perez@colorado.edu>
2436 2442
2437 2443 * IPython/Shell.py (hijack_gtk): remove pygtk.require("2.0")
2438 2444 calls. These were a leftover from the GTK 1.x days, and can cause
2439 2445 problems in certain cases (after a report by John Hunter).
2440 2446
2441 2447 * IPython/iplib.py (InteractiveShell.__init__): Trap exception if
2442 2448 os.getcwd() fails at init time. Thanks to patch from David Remahl
2443 2449 <chmod007-AT-mac.com>.
2444 2450 (InteractiveShell.__init__): prevent certain special magics from
2445 2451 being shadowed by aliases. Closes
2446 2452 http://www.scipy.net/roundup/ipython/issue41.
2447 2453
2448 2454 2005-08-31 Fernando Perez <Fernando.Perez@colorado.edu>
2449 2455
2450 2456 * IPython/iplib.py (InteractiveShell.complete): Added new
2451 2457 top-level completion method to expose the completion mechanism
2452 2458 beyond readline-based environments.
2453 2459
2454 2460 2005-08-19 Fernando Perez <Fernando.Perez@colorado.edu>
2455 2461
2456 2462 * tools/ipsvnc (svnversion): fix svnversion capture.
2457 2463
2458 2464 * IPython/iplib.py (InteractiveShell.__init__): Add has_readline
2459 2465 attribute to self, which was missing. Before, it was set by a
2460 2466 routine which in certain cases wasn't being called, so the
2461 2467 instance could end up missing the attribute. This caused a crash.
2462 2468 Closes http://www.scipy.net/roundup/ipython/issue40.
2463 2469
2464 2470 2005-08-16 Fernando Perez <fperez@colorado.edu>
2465 2471
2466 2472 * IPython/ultraTB.py (VerboseTB.text): don't crash if object
2467 2473 contains non-string attribute. Closes
2468 2474 http://www.scipy.net/roundup/ipython/issue38.
2469 2475
2470 2476 2005-08-14 Fernando Perez <fperez@colorado.edu>
2471 2477
2472 2478 * tools/ipsvnc: Minor improvements, to add changeset info.
2473 2479
2474 2480 2005-08-12 Fernando Perez <fperez@colorado.edu>
2475 2481
2476 2482 * IPython/iplib.py (runsource): remove self.code_to_run_src
2477 2483 attribute. I realized this is nothing more than
2478 2484 '\n'.join(self.buffer), and having the same data in two different
2479 2485 places is just asking for synchronization bugs. This may impact
2480 2486 people who have custom exception handlers, so I need to warn
2481 2487 ipython-dev about it (F. Mantegazza may use them).
2482 2488
2483 2489 2005-07-29 Fernando Perez <Fernando.Perez@colorado.edu>
2484 2490
2485 2491 * IPython/genutils.py: fix 2.2 compatibility (generators)
2486 2492
2487 2493 2005-07-18 Fernando Perez <fperez@colorado.edu>
2488 2494
2489 2495 * IPython/genutils.py (get_home_dir): fix to help users with
2490 2496 invalid $HOME under win32.
2491 2497
2492 2498 2005-07-17 Fernando Perez <fperez@colorado.edu>
2493 2499
2494 2500 * IPython/Prompts.py (str_safe): Make unicode-safe. Also remove
2495 2501 some old hacks and clean up a bit other routines; code should be
2496 2502 simpler and a bit faster.
2497 2503
2498 2504 * IPython/iplib.py (interact): removed some last-resort attempts
2499 2505 to survive broken stdout/stderr. That code was only making it
2500 2506 harder to abstract out the i/o (necessary for gui integration),
2501 2507 and the crashes it could prevent were extremely rare in practice
2502 2508 (besides being fully user-induced in a pretty violent manner).
2503 2509
2504 2510 * IPython/genutils.py (IOStream.__init__): Simplify the i/o stuff.
2505 2511 Nothing major yet, but the code is simpler to read; this should
2506 2512 make it easier to do more serious modifications in the future.
2507 2513
2508 2514 * IPython/Extensions/InterpreterExec.py: Fix auto-quoting in pysh,
2509 2515 which broke in .15 (thanks to a report by Ville).
2510 2516
2511 2517 * IPython/Itpl.py (Itpl.__init__): add unicode support (it may not
2512 2518 be quite correct, I know next to nothing about unicode). This
2513 2519 will allow unicode strings to be used in prompts, amongst other
2514 2520 cases. It also will prevent ipython from crashing when unicode
2515 2521 shows up unexpectedly in many places. If ascii encoding fails, we
2516 2522 assume utf_8. Currently the encoding is not a user-visible
2517 2523 setting, though it could be made so if there is demand for it.
2518 2524
2519 2525 * IPython/ipmaker.py (make_IPython): remove old 2.1-specific hack.
2520 2526
2521 2527 * IPython/Struct.py (Struct.merge): switch keys() to iterator.
2522 2528
2523 2529 * IPython/background_jobs.py: moved 2.2 compatibility to genutils.
2524 2530
2525 2531 * IPython/genutils.py: Add 2.2 compatibility here, so all other
2526 2532 code can work transparently for 2.2/2.3.
2527 2533
2528 2534 2005-07-16 Fernando Perez <fperez@colorado.edu>
2529 2535
2530 2536 * IPython/ultraTB.py (ExceptionColors): Make a global variable
2531 2537 out of the color scheme table used for coloring exception
2532 2538 tracebacks. This allows user code to add new schemes at runtime.
2533 2539 This is a minimally modified version of the patch at
2534 2540 http://www.scipy.net/roundup/ipython/issue35, many thanks to pabw
2535 2541 for the contribution.
2536 2542
2537 2543 * IPython/FlexCompleter.py (Completer.attr_matches): Add a
2538 2544 slightly modified version of the patch in
2539 2545 http://www.scipy.net/roundup/ipython/issue34, which also allows me
2540 2546 to remove the previous try/except solution (which was costlier).
2541 2547 Thanks to Gaetan Lehmann <gaetan.lehmann-AT-jouy.inra.fr> for the fix.
2542 2548
2543 2549 2005-06-08 Fernando Perez <fperez@colorado.edu>
2544 2550
2545 2551 * IPython/iplib.py (write/write_err): Add methods to abstract all
2546 2552 I/O a bit more.
2547 2553
2548 2554 * IPython/Shell.py (IPShellGTK.mainloop): Fix GTK deprecation
2549 2555 warning, reported by Aric Hagberg, fix by JD Hunter.
2550 2556
2551 2557 2005-06-02 *** Released version 0.6.15
2552 2558
2553 2559 2005-06-01 Fernando Perez <fperez@colorado.edu>
2554 2560
2555 2561 * IPython/iplib.py (MagicCompleter.file_matches): Fix
2556 2562 tab-completion of filenames within open-quoted strings. Note that
2557 2563 this requires that in ~/.ipython/ipythonrc, users change the
2558 2564 readline delimiters configuration to read:
2559 2565
2560 2566 readline_remove_delims -/~
2561 2567
2562 2568
2563 2569 2005-05-31 *** Released version 0.6.14
2564 2570
2565 2571 2005-05-29 Fernando Perez <fperez@colorado.edu>
2566 2572
2567 2573 * IPython/ultraTB.py (VerboseTB.text): Fix crash for tracebacks
2568 2574 with files not on the filesystem. Reported by Eliyahu Sandler
2569 2575 <eli@gondolin.net>
2570 2576
2571 2577 2005-05-22 Fernando Perez <fperez@colorado.edu>
2572 2578
2573 2579 * IPython/iplib.py: Fix a few crashes in the --upgrade option.
2574 2580 After an initial report by LUK ShunTim <shuntim.luk@polyu.edu.hk>.
2575 2581
2576 2582 2005-05-19 Fernando Perez <fperez@colorado.edu>
2577 2583
2578 2584 * IPython/iplib.py (safe_execfile): close a file which could be
2579 2585 left open (causing problems in win32, which locks open files).
2580 2586 Thanks to a bug report by D Brown <dbrown2@yahoo.com>.
2581 2587
2582 2588 2005-05-18 Fernando Perez <fperez@colorado.edu>
2583 2589
2584 2590 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): pass all
2585 2591 keyword arguments correctly to safe_execfile().
2586 2592
2587 2593 2005-05-13 Fernando Perez <fperez@colorado.edu>
2588 2594
2589 2595 * ipython.1: Added info about Qt to manpage, and threads warning
2590 2596 to usage page (invoked with --help).
2591 2597
2592 2598 * IPython/iplib.py (MagicCompleter.python_func_kw_matches): Added
2593 2599 new matcher (it goes at the end of the priority list) to do
2594 2600 tab-completion on named function arguments. Submitted by George
2595 2601 Sakkis <gsakkis-AT-eden.rutgers.edu>. See the thread at
2596 2602 http://www.scipy.net/pipermail/ipython-dev/2005-April/000436.html
2597 2603 for more details.
2598 2604
2599 2605 * IPython/Magic.py (magic_run): Added new -e flag to ignore
2600 2606 SystemExit exceptions in the script being run. Thanks to a report
2601 2607 by danny shevitz <danny_shevitz-AT-yahoo.com>, about this
2602 2608 producing very annoying behavior when running unit tests.
2603 2609
2604 2610 2005-05-12 Fernando Perez <fperez@colorado.edu>
2605 2611
2606 2612 * IPython/iplib.py (handle_auto): fixed auto-quoting and parens,
2607 2613 which I'd broken (again) due to a changed regexp. In the process,
2608 2614 added ';' as an escape to auto-quote the whole line without
2609 2615 splitting its arguments. Thanks to a report by Jerry McRae
2610 2616 <qrs0xyc02-AT-sneakemail.com>.
2611 2617
2612 2618 * IPython/ultraTB.py (VerboseTB.text): protect against rare but
2613 2619 possible crashes caused by a TokenError. Reported by Ed Schofield
2614 2620 <schofield-AT-ftw.at>.
2615 2621
2616 2622 2005-05-06 Fernando Perez <fperez@colorado.edu>
2617 2623
2618 2624 * IPython/Shell.py (hijack_wx): Fix to work with WX v.2.6.
2619 2625
2620 2626 2005-04-29 Fernando Perez <fperez@colorado.edu>
2621 2627
2622 2628 * IPython/Shell.py (IPShellQt): Thanks to Denis Rivière
2623 2629 <nudz-AT-free.fr>, Yann Cointepas <yann-AT-sapetnioc.org> and Benjamin
2624 2630 Thyreau <Benji2-AT-decideur.info>, we now have a -qthread option
2625 2631 which provides support for Qt interactive usage (similar to the
2626 2632 existing one for WX and GTK). This had been often requested.
2627 2633
2628 2634 2005-04-14 *** Released version 0.6.13
2629 2635
2630 2636 2005-04-08 Fernando Perez <fperez@colorado.edu>
2631 2637
2632 2638 * IPython/Magic.py (Magic._ofind): remove docstring evaluation
2633 2639 from _ofind, which gets called on almost every input line. Now,
2634 2640 we only try to get docstrings if they are actually going to be
2635 2641 used (the overhead of fetching unnecessary docstrings can be
2636 2642 noticeable for certain objects, such as Pyro proxies).
2637 2643
2638 2644 * IPython/iplib.py (MagicCompleter.python_matches): Change the API
2639 2645 for completers. For some reason I had been passing them the state
2640 2646 variable, which completers never actually need, and was in
2641 2647 conflict with the rlcompleter API. Custom completers ONLY need to
2642 2648 take the text parameter.
2643 2649
2644 2650 * IPython/Extensions/InterpreterExec.py: Fix regexp so that magics
2645 2651 work correctly in pysh. I've also moved all the logic which used
2646 2652 to be in pysh.py here, which will prevent problems with future
2647 2653 upgrades. However, this time I must warn users to update their
2648 2654 pysh profile to include the line
2649 2655
2650 2656 import_all IPython.Extensions.InterpreterExec
2651 2657
2652 2658 because otherwise things won't work for them. They MUST also
2653 2659 delete pysh.py and the line
2654 2660
2655 2661 execfile pysh.py
2656 2662
2657 2663 from their ipythonrc-pysh.
2658 2664
2659 2665 * IPython/FlexCompleter.py (Completer.attr_matches): Make more
2660 2666 robust in the face of objects whose dir() returns non-strings
2661 2667 (which it shouldn't, but some broken libs like ITK do). Thanks to
2662 2668 a patch by John Hunter (implemented differently, though). Also
2663 2669 minor improvements by using .extend instead of + on lists.
2664 2670
2665 2671 * pysh.py:
2666 2672
2667 2673 2005-04-06 Fernando Perez <fperez@colorado.edu>
2668 2674
2669 2675 * IPython/ipmaker.py (make_IPython): Make multi_line_specials on
2670 2676 by default, so that all users benefit from it. Those who don't
2671 2677 want it can still turn it off.
2672 2678
2673 2679 * IPython/UserConfig/ipythonrc: Add multi_line_specials to the
2674 2680 config file, I'd forgotten about this, so users were getting it
2675 2681 off by default.
2676 2682
2677 2683 * IPython/iplib.py (ipmagic): big overhaul of the magic system for
2678 2684 consistency. Now magics can be called in multiline statements,
2679 2685 and python variables can be expanded in magic calls via $var.
2680 2686 This makes the magic system behave just like aliases or !system
2681 2687 calls.
2682 2688
2683 2689 2005-03-28 Fernando Perez <fperez@colorado.edu>
2684 2690
2685 2691 * IPython/iplib.py (handle_auto): cleanup to use %s instead of
2686 2692 expensive string additions for building command. Add support for
2687 2693 trailing ';' when autocall is used.
2688 2694
2689 2695 2005-03-26 Fernando Perez <fperez@colorado.edu>
2690 2696
2691 2697 * ipython.el: Fix http://www.scipy.net/roundup/ipython/issue31.
2692 2698 Bugfix by A. Schmolck, the ipython.el maintainer. Also make
2693 2699 ipython.el robust against prompts with any number of spaces
2694 2700 (including 0) after the ':' character.
2695 2701
2696 2702 * IPython/Prompts.py (Prompt2.set_p_str): Fix spurious space in
2697 2703 continuation prompt, which misled users to think the line was
2698 2704 already indented. Closes debian Bug#300847, reported to me by
2699 2705 Norbert Tretkowski <tretkowski-AT-inittab.de>.
2700 2706
2701 2707 2005-03-23 Fernando Perez <fperez@colorado.edu>
2702 2708
2703 2709 * IPython/Prompts.py (Prompt1.__str__): Make sure that prompts are
2704 2710 properly aligned if they have embedded newlines.
2705 2711
2706 2712 * IPython/iplib.py (runlines): Add a public method to expose
2707 2713 IPython's code execution machinery, so that users can run strings
2708 2714 as if they had been typed at the prompt interactively.
2709 2715 (InteractiveShell.__init__): Added getoutput() to the __IPYTHON__
2710 2716 methods which can call the system shell, but with python variable
2711 2717 expansion. The three such methods are: __IPYTHON__.system,
2712 2718 .getoutput and .getoutputerror. These need to be documented in a
2713 2719 'public API' section (to be written) of the manual.
2714 2720
2715 2721 2005-03-20 Fernando Perez <fperez@colorado.edu>
2716 2722
2717 2723 * IPython/iplib.py (InteractiveShell.set_custom_exc): new system
2718 2724 for custom exception handling. This is quite powerful, and it
2719 2725 allows for user-installable exception handlers which can trap
2720 2726 custom exceptions at runtime and treat them separately from
2721 2727 IPython's default mechanisms. At the request of FrΓ©dΓ©ric
2722 2728 Mantegazza <mantegazza-AT-ill.fr>.
2723 2729 (InteractiveShell.set_custom_completer): public API function to
2724 2730 add new completers at runtime.
2725 2731
2726 2732 2005-03-19 Fernando Perez <fperez@colorado.edu>
2727 2733
2728 2734 * IPython/OInspect.py (getdoc): Add a call to obj.getdoc(), to
2729 2735 allow objects which provide their docstrings via non-standard
2730 2736 mechanisms (like Pyro proxies) to still be inspected by ipython's
2731 2737 ? system.
2732 2738
2733 2739 * IPython/iplib.py (InteractiveShell.__init__): back off the _o/_e
2734 2740 automatic capture system. I tried quite hard to make it work
2735 2741 reliably, and simply failed. I tried many combinations with the
2736 2742 subprocess module, but eventually nothing worked in all needed
2737 2743 cases (not blocking stdin for the child, duplicating stdout
2738 2744 without blocking, etc). The new %sc/%sx still do capture to these
2739 2745 magical list/string objects which make shell use much more
2740 2746 conveninent, so not all is lost.
2741 2747
2742 2748 XXX - FIX MANUAL for the change above!
2743 2749
2744 2750 (runsource): I copied code.py's runsource() into ipython to modify
2745 2751 it a bit. Now the code object and source to be executed are
2746 2752 stored in ipython. This makes this info accessible to third-party
2747 2753 tools, like custom exception handlers. After a request by FrΓ©dΓ©ric
2748 2754 Mantegazza <mantegazza-AT-ill.fr>.
2749 2755
2750 2756 * IPython/UserConfig/ipythonrc: Add up/down arrow keys to
2751 2757 history-search via readline (like C-p/C-n). I'd wanted this for a
2752 2758 long time, but only recently found out how to do it. For users
2753 2759 who already have their ipythonrc files made and want this, just
2754 2760 add:
2755 2761
2756 2762 readline_parse_and_bind "\e[A": history-search-backward
2757 2763 readline_parse_and_bind "\e[B": history-search-forward
2758 2764
2759 2765 2005-03-18 Fernando Perez <fperez@colorado.edu>
2760 2766
2761 2767 * IPython/Magic.py (magic_sc): %sc and %sx now use the fancy
2762 2768 LSString and SList classes which allow transparent conversions
2763 2769 between list mode and whitespace-separated string.
2764 2770 (magic_r): Fix recursion problem in %r.
2765 2771
2766 2772 * IPython/genutils.py (LSString): New class to be used for
2767 2773 automatic storage of the results of all alias/system calls in _o
2768 2774 and _e (stdout/err). These provide a .l/.list attribute which
2769 2775 does automatic splitting on newlines. This means that for most
2770 2776 uses, you'll never need to do capturing of output with %sc/%sx
2771 2777 anymore, since ipython keeps this always done for you. Note that
2772 2778 only the LAST results are stored, the _o/e variables are
2773 2779 overwritten on each call. If you need to save their contents
2774 2780 further, simply bind them to any other name.
2775 2781
2776 2782 2005-03-17 Fernando Perez <fperez@colorado.edu>
2777 2783
2778 2784 * IPython/Prompts.py (BasePrompt.cwd_filt): a few more fixes for
2779 2785 prompt namespace handling.
2780 2786
2781 2787 2005-03-16 Fernando Perez <fperez@colorado.edu>
2782 2788
2783 2789 * IPython/Prompts.py (CachedOutput.__init__): Fix default and
2784 2790 classic prompts to be '>>> ' (final space was missing, and it
2785 2791 trips the emacs python mode).
2786 2792 (BasePrompt.__str__): Added safe support for dynamic prompt
2787 2793 strings. Now you can set your prompt string to be '$x', and the
2788 2794 value of x will be printed from your interactive namespace. The
2789 2795 interpolation syntax includes the full Itpl support, so
2790 2796 ${foo()+x+bar()} is a valid prompt string now, and the function
2791 2797 calls will be made at runtime.
2792 2798
2793 2799 2005-03-15 Fernando Perez <fperez@colorado.edu>
2794 2800
2795 2801 * IPython/Magic.py (magic_history): renamed %hist to %history, to
2796 2802 avoid name clashes in pylab. %hist still works, it just forwards
2797 2803 the call to %history.
2798 2804
2799 2805 2005-03-02 *** Released version 0.6.12
2800 2806
2801 2807 2005-03-02 Fernando Perez <fperez@colorado.edu>
2802 2808
2803 2809 * IPython/iplib.py (handle_magic): log magic calls properly as
2804 2810 ipmagic() function calls.
2805 2811
2806 2812 * IPython/Magic.py (magic_time): Improved %time to support
2807 2813 statements and provide wall-clock as well as CPU time.
2808 2814
2809 2815 2005-02-27 Fernando Perez <fperez@colorado.edu>
2810 2816
2811 2817 * IPython/hooks.py: New hooks module, to expose user-modifiable
2812 2818 IPython functionality in a clean manner. For now only the editor
2813 2819 hook is actually written, and other thigns which I intend to turn
2814 2820 into proper hooks aren't yet there. The display and prefilter
2815 2821 stuff, for example, should be hooks. But at least now the
2816 2822 framework is in place, and the rest can be moved here with more
2817 2823 time later. IPython had had a .hooks variable for a long time for
2818 2824 this purpose, but I'd never actually used it for anything.
2819 2825
2820 2826 2005-02-26 Fernando Perez <fperez@colorado.edu>
2821 2827
2822 2828 * IPython/ipmaker.py (make_IPython): make the default ipython
2823 2829 directory be called _ipython under win32, to follow more the
2824 2830 naming peculiarities of that platform (where buggy software like
2825 2831 Visual Sourcesafe breaks with .named directories). Reported by
2826 2832 Ville Vainio.
2827 2833
2828 2834 2005-02-23 Fernando Perez <fperez@colorado.edu>
2829 2835
2830 2836 * IPython/iplib.py (InteractiveShell.__init__): removed a few
2831 2837 auto_aliases for win32 which were causing problems. Users can
2832 2838 define the ones they personally like.
2833 2839
2834 2840 2005-02-21 Fernando Perez <fperez@colorado.edu>
2835 2841
2836 2842 * IPython/Magic.py (magic_time): new magic to time execution of
2837 2843 expressions. After a request by Charles Moad <cmoad-AT-indiana.edu>.
2838 2844
2839 2845 2005-02-19 Fernando Perez <fperez@colorado.edu>
2840 2846
2841 2847 * IPython/ConfigLoader.py (ConfigLoader.load): Allow empty strings
2842 2848 into keys (for prompts, for example).
2843 2849
2844 2850 * IPython/Prompts.py (BasePrompt.set_p_str): Fix to allow empty
2845 2851 prompts in case users want them. This introduces a small behavior
2846 2852 change: ipython does not automatically add a space to all prompts
2847 2853 anymore. To get the old prompts with a space, users should add it
2848 2854 manually to their ipythonrc file, so for example prompt_in1 should
2849 2855 now read 'In [\#]: ' instead of 'In [\#]:'.
2850 2856 (BasePrompt.__init__): New option prompts_pad_left (only in rc
2851 2857 file) to control left-padding of secondary prompts.
2852 2858
2853 2859 * IPython/Magic.py (Magic.profile_missing_notice): Don't crash if
2854 2860 the profiler can't be imported. Fix for Debian, which removed
2855 2861 profile.py because of License issues. I applied a slightly
2856 2862 modified version of the original Debian patch at
2857 2863 http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=294500.
2858 2864
2859 2865 2005-02-17 Fernando Perez <fperez@colorado.edu>
2860 2866
2861 2867 * IPython/genutils.py (native_line_ends): Fix bug which would
2862 2868 cause improper line-ends under win32 b/c I was not opening files
2863 2869 in binary mode. Bug report and fix thanks to Ville.
2864 2870
2865 2871 * IPython/iplib.py (handle_auto): Fix bug which I introduced when
2866 2872 trying to catch spurious foo[1] autocalls. My fix actually broke
2867 2873 ',/' autoquote/call with explicit escape (bad regexp).
2868 2874
2869 2875 2005-02-15 *** Released version 0.6.11
2870 2876
2871 2877 2005-02-14 Fernando Perez <fperez@colorado.edu>
2872 2878
2873 2879 * IPython/background_jobs.py: New background job management
2874 2880 subsystem. This is implemented via a new set of classes, and
2875 2881 IPython now provides a builtin 'jobs' object for background job
2876 2882 execution. A convenience %bg magic serves as a lightweight
2877 2883 frontend for starting the more common type of calls. This was
2878 2884 inspired by discussions with B. Granger and the BackgroundCommand
2879 2885 class described in the book Python Scripting for Computational
2880 2886 Science, by H. P. Langtangen: http://folk.uio.no/hpl/scripting
2881 2887 (although ultimately no code from this text was used, as IPython's
2882 2888 system is a separate implementation).
2883 2889
2884 2890 * IPython/iplib.py (MagicCompleter.python_matches): add new option
2885 2891 to control the completion of single/double underscore names
2886 2892 separately. As documented in the example ipytonrc file, the
2887 2893 readline_omit__names variable can now be set to 2, to omit even
2888 2894 single underscore names. Thanks to a patch by Brian Wong
2889 2895 <BrianWong-AT-AirgoNetworks.Com>.
2890 2896 (InteractiveShell.__init__): Fix bug which would cause foo[1] to
2891 2897 be autocalled as foo([1]) if foo were callable. A problem for
2892 2898 things which are both callable and implement __getitem__.
2893 2899 (init_readline): Fix autoindentation for win32. Thanks to a patch
2894 2900 by Vivian De Smedt <vivian-AT-vdesmedt.com>.
2895 2901
2896 2902 2005-02-12 Fernando Perez <fperez@colorado.edu>
2897 2903
2898 2904 * IPython/ipmaker.py (make_IPython): Disabled the stout traps
2899 2905 which I had written long ago to sort out user error messages which
2900 2906 may occur during startup. This seemed like a good idea initially,
2901 2907 but it has proven a disaster in retrospect. I don't want to
2902 2908 change much code for now, so my fix is to set the internal 'debug'
2903 2909 flag to true everywhere, whose only job was precisely to control
2904 2910 this subsystem. This closes issue 28 (as well as avoiding all
2905 2911 sorts of strange hangups which occur from time to time).
2906 2912
2907 2913 2005-02-07 Fernando Perez <fperez@colorado.edu>
2908 2914
2909 2915 * IPython/Magic.py (magic_edit): Fix 'ed -p' not working when the
2910 2916 previous call produced a syntax error.
2911 2917
2912 2918 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
2913 2919 classes without constructor.
2914 2920
2915 2921 2005-02-06 Fernando Perez <fperez@colorado.edu>
2916 2922
2917 2923 * IPython/iplib.py (MagicCompleter.complete): Extend the list of
2918 2924 completions with the results of each matcher, so we return results
2919 2925 to the user from all namespaces. This breaks with ipython
2920 2926 tradition, but I think it's a nicer behavior. Now you get all
2921 2927 possible completions listed, from all possible namespaces (python,
2922 2928 filesystem, magics...) After a request by John Hunter
2923 2929 <jdhunter-AT-nitace.bsd.uchicago.edu>.
2924 2930
2925 2931 2005-02-05 Fernando Perez <fperez@colorado.edu>
2926 2932
2927 2933 * IPython/Magic.py (magic_prun): Fix bug where prun would fail if
2928 2934 the call had quote characters in it (the quotes were stripped).
2929 2935
2930 2936 2005-01-31 Fernando Perez <fperez@colorado.edu>
2931 2937
2932 2938 * IPython/iplib.py (InteractiveShell.__init__): reduce reliance on
2933 2939 Itpl.itpl() to make the code more robust against psyco
2934 2940 optimizations.
2935 2941
2936 2942 * IPython/Itpl.py (Itpl.__str__): Use a _getframe() call instead
2937 2943 of causing an exception. Quicker, cleaner.
2938 2944
2939 2945 2005-01-28 Fernando Perez <fperez@colorado.edu>
2940 2946
2941 2947 * scripts/ipython_win_post_install.py (install): hardcode
2942 2948 sys.prefix+'python.exe' as the executable path. It turns out that
2943 2949 during the post-installation run, sys.executable resolves to the
2944 2950 name of the binary installer! I should report this as a distutils
2945 2951 bug, I think. I updated the .10 release with this tiny fix, to
2946 2952 avoid annoying the lists further.
2947 2953
2948 2954 2005-01-27 *** Released version 0.6.10
2949 2955
2950 2956 2005-01-27 Fernando Perez <fperez@colorado.edu>
2951 2957
2952 2958 * IPython/numutils.py (norm): Added 'inf' as optional name for
2953 2959 L-infinity norm, included references to mathworld.com for vector
2954 2960 norm definitions.
2955 2961 (amin/amax): added amin/amax for array min/max. Similar to what
2956 2962 pylab ships with after the recent reorganization of names.
2957 2963 (spike/spike_odd): removed deprecated spike/spike_odd functions.
2958 2964
2959 2965 * ipython.el: committed Alex's recent fixes and improvements.
2960 2966 Tested with python-mode from CVS, and it looks excellent. Since
2961 2967 python-mode hasn't released anything in a while, I'm temporarily
2962 2968 putting a copy of today's CVS (v 4.70) of python-mode in:
2963 2969 http://ipython.scipy.org/tmp/python-mode.el
2964 2970
2965 2971 * scripts/ipython_win_post_install.py (install): Win32 fix to use
2966 2972 sys.executable for the executable name, instead of assuming it's
2967 2973 called 'python.exe' (the post-installer would have produced broken
2968 2974 setups on systems with a differently named python binary).
2969 2975
2970 2976 * IPython/PyColorize.py (Parser.__call__): change explicit '\n'
2971 2977 references to os.linesep, to make the code more
2972 2978 platform-independent. This is also part of the win32 coloring
2973 2979 fixes.
2974 2980
2975 2981 * IPython/genutils.py (page_dumb): Remove attempts to chop long
2976 2982 lines, which actually cause coloring bugs because the length of
2977 2983 the line is very difficult to correctly compute with embedded
2978 2984 escapes. This was the source of all the coloring problems under
2979 2985 Win32. I think that _finally_, Win32 users have a properly
2980 2986 working ipython in all respects. This would never have happened
2981 2987 if not for Gary Bishop and Viktor Ransmayr's great help and work.
2982 2988
2983 2989 2005-01-26 *** Released version 0.6.9
2984 2990
2985 2991 2005-01-25 Fernando Perez <fperez@colorado.edu>
2986 2992
2987 2993 * setup.py: finally, we have a true Windows installer, thanks to
2988 2994 the excellent work of Viktor Ransmayr
2989 2995 <viktor.ransmayr-AT-t-online.de>. The docs have been updated for
2990 2996 Windows users. The setup routine is quite a bit cleaner thanks to
2991 2997 this, and the post-install script uses the proper functions to
2992 2998 allow a clean de-installation using the standard Windows Control
2993 2999 Panel.
2994 3000
2995 3001 * IPython/genutils.py (get_home_dir): changed to use the $HOME
2996 3002 environment variable under all OSes (including win32) if
2997 3003 available. This will give consistency to win32 users who have set
2998 3004 this variable for any reason. If os.environ['HOME'] fails, the
2999 3005 previous policy of using HOMEDRIVE\HOMEPATH kicks in.
3000 3006
3001 3007 2005-01-24 Fernando Perez <fperez@colorado.edu>
3002 3008
3003 3009 * IPython/numutils.py (empty_like): add empty_like(), similar to
3004 3010 zeros_like() but taking advantage of the new empty() Numeric routine.
3005 3011
3006 3012 2005-01-23 *** Released version 0.6.8
3007 3013
3008 3014 2005-01-22 Fernando Perez <fperez@colorado.edu>
3009 3015
3010 3016 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): I removed the
3011 3017 automatic show() calls. After discussing things with JDH, it
3012 3018 turns out there are too many corner cases where this can go wrong.
3013 3019 It's best not to try to be 'too smart', and simply have ipython
3014 3020 reproduce as much as possible the default behavior of a normal
3015 3021 python shell.
3016 3022
3017 3023 * IPython/iplib.py (InteractiveShell.__init__): Modified the
3018 3024 line-splitting regexp and _prefilter() to avoid calling getattr()
3019 3025 on assignments. This closes
3020 3026 http://www.scipy.net/roundup/ipython/issue24. Note that Python's
3021 3027 readline uses getattr(), so a simple <TAB> keypress is still
3022 3028 enough to trigger getattr() calls on an object.
3023 3029
3024 3030 2005-01-21 Fernando Perez <fperez@colorado.edu>
3025 3031
3026 3032 * IPython/Shell.py (MatplotlibShellBase.magic_run): Fix the %run
3027 3033 docstring under pylab so it doesn't mask the original.
3028 3034
3029 3035 2005-01-21 *** Released version 0.6.7
3030 3036
3031 3037 2005-01-21 Fernando Perez <fperez@colorado.edu>
3032 3038
3033 3039 * IPython/Shell.py (MTInteractiveShell.runcode): Trap a crash with
3034 3040 signal handling for win32 users in multithreaded mode.
3035 3041
3036 3042 2005-01-17 Fernando Perez <fperez@colorado.edu>
3037 3043
3038 3044 * IPython/OInspect.py (Inspector.pinfo): Fix crash when inspecting
3039 3045 instances with no __init__. After a crash report by Norbert Nemec
3040 3046 <Norbert-AT-nemec-online.de>.
3041 3047
3042 3048 2005-01-14 Fernando Perez <fperez@colorado.edu>
3043 3049
3044 3050 * IPython/ultraTB.py (VerboseTB.text): Fix bug in reporting of
3045 3051 names for verbose exceptions, when multiple dotted names and the
3046 3052 'parent' object were present on the same line.
3047 3053
3048 3054 2005-01-11 Fernando Perez <fperez@colorado.edu>
3049 3055
3050 3056 * IPython/genutils.py (flag_calls): new utility to trap and flag
3051 3057 calls in functions. I need it to clean up matplotlib support.
3052 3058 Also removed some deprecated code in genutils.
3053 3059
3054 3060 * IPython/Shell.py (MatplotlibShellBase.mplot_exec): small fix so
3055 3061 that matplotlib scripts called with %run, which don't call show()
3056 3062 themselves, still have their plotting windows open.
3057 3063
3058 3064 2005-01-05 Fernando Perez <fperez@colorado.edu>
3059 3065
3060 3066 * IPython/Shell.py (IPShellGTK.__init__): Patch by Andrew Straw
3061 3067 <astraw-AT-caltech.edu>, to fix gtk deprecation warnings.
3062 3068
3063 3069 2004-12-19 Fernando Perez <fperez@colorado.edu>
3064 3070
3065 3071 * IPython/Shell.py (MTInteractiveShell.runcode): Get rid of
3066 3072 parent_runcode, which was an eyesore. The same result can be
3067 3073 obtained with Python's regular superclass mechanisms.
3068 3074
3069 3075 2004-12-17 Fernando Perez <fperez@colorado.edu>
3070 3076
3071 3077 * IPython/Magic.py (Magic.magic_sc): Fix quote stripping problem
3072 3078 reported by Prabhu.
3073 3079 (Magic.magic_sx): direct all errors to Term.cerr (defaults to
3074 3080 sys.stderr) instead of explicitly calling sys.stderr. This helps
3075 3081 maintain our I/O abstractions clean, for future GUI embeddings.
3076 3082
3077 3083 * IPython/genutils.py (info): added new utility for sys.stderr
3078 3084 unified info message handling (thin wrapper around warn()).
3079 3085
3080 3086 * IPython/ultraTB.py (VerboseTB.text): Fix misreported global
3081 3087 composite (dotted) names on verbose exceptions.
3082 3088 (VerboseTB.nullrepr): harden against another kind of errors which
3083 3089 Python's inspect module can trigger, and which were crashing
3084 3090 IPython. Thanks to a report by Marco Lombardi
3085 3091 <mlombard-AT-ma010192.hq.eso.org>.
3086 3092
3087 3093 2004-12-13 *** Released version 0.6.6
3088 3094
3089 3095 2004-12-12 Fernando Perez <fperez@colorado.edu>
3090 3096
3091 3097 * IPython/Shell.py (IPShellGTK.mainloop): catch RuntimeErrors
3092 3098 generated by pygtk upon initialization if it was built without
3093 3099 threads (for matplotlib users). After a crash reported by
3094 3100 Leguijt, Jaap J SIEP-EPT-RES <Jaap.Leguijt-AT-shell.com>.
3095 3101
3096 3102 * IPython/ipmaker.py (make_IPython): fix small bug in the
3097 3103 import_some parameter for multiple imports.
3098 3104
3099 3105 * IPython/iplib.py (ipmagic): simplified the interface of
3100 3106 ipmagic() to take a single string argument, just as it would be
3101 3107 typed at the IPython cmd line.
3102 3108 (ipalias): Added new ipalias() with an interface identical to
3103 3109 ipmagic(). This completes exposing a pure python interface to the
3104 3110 alias and magic system, which can be used in loops or more complex
3105 3111 code where IPython's automatic line mangling is not active.
3106 3112
3107 3113 * IPython/genutils.py (timing): changed interface of timing to
3108 3114 simply run code once, which is the most common case. timings()
3109 3115 remains unchanged, for the cases where you want multiple runs.
3110 3116
3111 3117 * IPython/Shell.py (MatplotlibShellBase._matplotlib_config): Fix a
3112 3118 bug where Python2.2 crashes with exec'ing code which does not end
3113 3119 in a single newline. Python 2.3 is OK, so I hadn't noticed this
3114 3120 before.
3115 3121
3116 3122 2004-12-10 Fernando Perez <fperez@colorado.edu>
3117 3123
3118 3124 * IPython/Magic.py (Magic.magic_prun): changed name of option from
3119 3125 -t to -T, to accomodate the new -t flag in %run (the %run and
3120 3126 %prun options are kind of intermixed, and it's not easy to change
3121 3127 this with the limitations of python's getopt).
3122 3128
3123 3129 * IPython/Magic.py (Magic.magic_run): Added new -t option to time
3124 3130 the execution of scripts. It's not as fine-tuned as timeit.py,
3125 3131 but it works from inside ipython (and under 2.2, which lacks
3126 3132 timeit.py). Optionally a number of runs > 1 can be given for
3127 3133 timing very short-running code.
3128 3134
3129 3135 * IPython/genutils.py (uniq_stable): new routine which returns a
3130 3136 list of unique elements in any iterable, but in stable order of
3131 3137 appearance. I needed this for the ultraTB fixes, and it's a handy
3132 3138 utility.
3133 3139
3134 3140 * IPython/ultraTB.py (VerboseTB.text): Fix proper reporting of
3135 3141 dotted names in Verbose exceptions. This had been broken since
3136 3142 the very start, now x.y will properly be printed in a Verbose
3137 3143 traceback, instead of x being shown and y appearing always as an
3138 3144 'undefined global'. Getting this to work was a bit tricky,
3139 3145 because by default python tokenizers are stateless. Saved by
3140 3146 python's ability to easily add a bit of state to an arbitrary
3141 3147 function (without needing to build a full-blown callable object).
3142 3148
3143 3149 Also big cleanup of this code, which had horrendous runtime
3144 3150 lookups of zillions of attributes for colorization. Moved all
3145 3151 this code into a few templates, which make it cleaner and quicker.
3146 3152
3147 3153 Printout quality was also improved for Verbose exceptions: one
3148 3154 variable per line, and memory addresses are printed (this can be
3149 3155 quite handy in nasty debugging situations, which is what Verbose
3150 3156 is for).
3151 3157
3152 3158 * IPython/ipmaker.py (make_IPython): Do NOT execute files named in
3153 3159 the command line as scripts to be loaded by embedded instances.
3154 3160 Doing so has the potential for an infinite recursion if there are
3155 3161 exceptions thrown in the process. This fixes a strange crash
3156 3162 reported by Philippe MULLER <muller-AT-irit.fr>.
3157 3163
3158 3164 2004-12-09 Fernando Perez <fperez@colorado.edu>
3159 3165
3160 3166 * IPython/Shell.py (MatplotlibShellBase.use): Change pylab support
3161 3167 to reflect new names in matplotlib, which now expose the
3162 3168 matlab-compatible interface via a pylab module instead of the
3163 3169 'matlab' name. The new code is backwards compatible, so users of
3164 3170 all matplotlib versions are OK. Patch by J. Hunter.
3165 3171
3166 3172 * IPython/OInspect.py (Inspector.pinfo): Add to object? printing
3167 3173 of __init__ docstrings for instances (class docstrings are already
3168 3174 automatically printed). Instances with customized docstrings
3169 3175 (indep. of the class) are also recognized and all 3 separate
3170 3176 docstrings are printed (instance, class, constructor). After some
3171 3177 comments/suggestions by J. Hunter.
3172 3178
3173 3179 2004-12-05 Fernando Perez <fperez@colorado.edu>
3174 3180
3175 3181 * IPython/iplib.py (MagicCompleter.complete): Remove annoying
3176 3182 warnings when tab-completion fails and triggers an exception.
3177 3183
3178 3184 2004-12-03 Fernando Perez <fperez@colorado.edu>
3179 3185
3180 3186 * IPython/Magic.py (magic_prun): Fix bug where an exception would
3181 3187 be triggered when using 'run -p'. An incorrect option flag was
3182 3188 being set ('d' instead of 'D').
3183 3189 (manpage): fix missing escaped \- sign.
3184 3190
3185 3191 2004-11-30 *** Released version 0.6.5
3186 3192
3187 3193 2004-11-30 Fernando Perez <fperez@colorado.edu>
3188 3194
3189 3195 * IPython/Magic.py (Magic.magic_run): Fix bug in breakpoint
3190 3196 setting with -d option.
3191 3197
3192 3198 * setup.py (docfiles): Fix problem where the doc glob I was using
3193 3199 was COMPLETELY BROKEN. It was giving the right files by pure
3194 3200 accident, but failed once I tried to include ipython.el. Note:
3195 3201 glob() does NOT allow you to do exclusion on multiple endings!
3196 3202
3197 3203 2004-11-29 Fernando Perez <fperez@colorado.edu>
3198 3204
3199 3205 * IPython/usage.py (__doc__): cleaned up usage docstring, by using
3200 3206 the manpage as the source. Better formatting & consistency.
3201 3207
3202 3208 * IPython/Magic.py (magic_run): Added new -d option, to run
3203 3209 scripts under the control of the python pdb debugger. Note that
3204 3210 this required changing the %prun option -d to -D, to avoid a clash
3205 3211 (since %run must pass options to %prun, and getopt is too dumb to
3206 3212 handle options with string values with embedded spaces). Thanks
3207 3213 to a suggestion by Matthew Arnison <maffew-AT-cat.org.au>.
3208 3214 (magic_who_ls): added type matching to %who and %whos, so that one
3209 3215 can filter their output to only include variables of certain
3210 3216 types. Another suggestion by Matthew.
3211 3217 (magic_whos): Added memory summaries in kb and Mb for arrays.
3212 3218 (magic_who): Improve formatting (break lines every 9 vars).
3213 3219
3214 3220 2004-11-28 Fernando Perez <fperez@colorado.edu>
3215 3221
3216 3222 * IPython/Logger.py (Logger.log): Fix bug in syncing the input
3217 3223 cache when empty lines were present.
3218 3224
3219 3225 2004-11-24 Fernando Perez <fperez@colorado.edu>
3220 3226
3221 3227 * IPython/usage.py (__doc__): document the re-activated threading
3222 3228 options for WX and GTK.
3223 3229
3224 3230 2004-11-23 Fernando Perez <fperez@colorado.edu>
3225 3231
3226 3232 * IPython/Shell.py (start): Added Prabhu's big patch to reactivate
3227 3233 the -wthread and -gthread options, along with a new -tk one to try
3228 3234 and coordinate Tk threading with wx/gtk. The tk support is very
3229 3235 platform dependent, since it seems to require Tcl and Tk to be
3230 3236 built with threads (Fedora1/2 appears NOT to have it, but in
3231 3237 Prabhu's Debian boxes it works OK). But even with some Tk
3232 3238 limitations, this is a great improvement.
3233 3239
3234 3240 * IPython/Prompts.py (prompt_specials_color): Added \t for time
3235 3241 info in user prompts. Patch by Prabhu.
3236 3242
3237 3243 2004-11-18 Fernando Perez <fperez@colorado.edu>
3238 3244
3239 3245 * IPython/genutils.py (ask_yes_no): Add check for a max of 20
3240 3246 EOFErrors and bail, to avoid infinite loops if a non-terminating
3241 3247 file is fed into ipython. Patch submitted in issue 19 by user,
3242 3248 many thanks.
3243 3249
3244 3250 * IPython/iplib.py (InteractiveShell.handle_auto): do NOT trigger
3245 3251 autoquote/parens in continuation prompts, which can cause lots of
3246 3252 problems. Closes roundup issue 20.
3247 3253
3248 3254 2004-11-17 Fernando Perez <fperez@colorado.edu>
3249 3255
3250 3256 * debian/control (Build-Depends-Indep): Fix dpatch dependency,
3251 3257 reported as debian bug #280505. I'm not sure my local changelog
3252 3258 entry has the proper debian format (Jack?).
3253 3259
3254 3260 2004-11-08 *** Released version 0.6.4
3255 3261
3256 3262 2004-11-08 Fernando Perez <fperez@colorado.edu>
3257 3263
3258 3264 * IPython/iplib.py (init_readline): Fix exit message for Windows
3259 3265 when readline is active. Thanks to a report by Eric Jones
3260 3266 <eric-AT-enthought.com>.
3261 3267
3262 3268 2004-11-07 Fernando Perez <fperez@colorado.edu>
3263 3269
3264 3270 * IPython/genutils.py (page): Add a trap for OSError exceptions,
3265 3271 sometimes seen by win2k/cygwin users.
3266 3272
3267 3273 2004-11-06 Fernando Perez <fperez@colorado.edu>
3268 3274
3269 3275 * IPython/iplib.py (interact): Change the handling of %Exit from
3270 3276 trying to propagate a SystemExit to an internal ipython flag.
3271 3277 This is less elegant than using Python's exception mechanism, but
3272 3278 I can't get that to work reliably with threads, so under -pylab
3273 3279 %Exit was hanging IPython. Cross-thread exception handling is
3274 3280 really a bitch. Thaks to a bug report by Stephen Walton
3275 3281 <stephen.walton-AT-csun.edu>.
3276 3282
3277 3283 2004-11-04 Fernando Perez <fperez@colorado.edu>
3278 3284
3279 3285 * IPython/iplib.py (raw_input_original): store a pointer to the
3280 3286 true raw_input to harden against code which can modify it
3281 3287 (wx.py.PyShell does this and would otherwise crash ipython).
3282 3288 Thanks to a bug report by Jim Flowers <james.flowers-AT-lgx.com>.
3283 3289
3284 3290 * IPython/Shell.py (MTInteractiveShell.runsource): Cleaner fix for
3285 3291 Ctrl-C problem, which does not mess up the input line.
3286 3292
3287 3293 2004-11-03 Fernando Perez <fperez@colorado.edu>
3288 3294
3289 3295 * IPython/Release.py: Changed licensing to BSD, in all files.
3290 3296 (name): lowercase name for tarball/RPM release.
3291 3297
3292 3298 * IPython/OInspect.py (getdoc): wrap inspect.getdoc() safely for
3293 3299 use throughout ipython.
3294 3300
3295 3301 * IPython/Magic.py (Magic._ofind): Switch to using the new
3296 3302 OInspect.getdoc() function.
3297 3303
3298 3304 * IPython/Shell.py (sigint_handler): Hack to ignore the execution
3299 3305 of the line currently being canceled via Ctrl-C. It's extremely
3300 3306 ugly, but I don't know how to do it better (the problem is one of
3301 3307 handling cross-thread exceptions).
3302 3308
3303 3309 2004-10-28 Fernando Perez <fperez@colorado.edu>
3304 3310
3305 3311 * IPython/Shell.py (signal_handler): add signal handlers to trap
3306 3312 SIGINT and SIGSEGV in threaded code properly. Thanks to a bug
3307 3313 report by Francesc Alted.
3308 3314
3309 3315 2004-10-21 Fernando Perez <fperez@colorado.edu>
3310 3316
3311 3317 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Fix @
3312 3318 to % for pysh syntax extensions.
3313 3319
3314 3320 2004-10-09 Fernando Perez <fperez@colorado.edu>
3315 3321
3316 3322 * IPython/Magic.py (Magic.magic_whos): modify output of Numeric
3317 3323 arrays to print a more useful summary, without calling str(arr).
3318 3324 This avoids the problem of extremely lengthy computations which
3319 3325 occur if arr is large, and appear to the user as a system lockup
3320 3326 with 100% cpu activity. After a suggestion by Kristian Sandberg
3321 3327 <Kristian.Sandberg@colorado.edu>.
3322 3328 (Magic.__init__): fix bug in global magic escapes not being
3323 3329 correctly set.
3324 3330
3325 3331 2004-10-08 Fernando Perez <fperez@colorado.edu>
3326 3332
3327 3333 * IPython/Magic.py (__license__): change to absolute imports of
3328 3334 ipython's own internal packages, to start adapting to the absolute
3329 3335 import requirement of PEP-328.
3330 3336
3331 3337 * IPython/genutils.py (__author__): Fix coding to utf-8 on all
3332 3338 files, and standardize author/license marks through the Release
3333 3339 module instead of having per/file stuff (except for files with
3334 3340 particular licenses, like the MIT/PSF-licensed codes).
3335 3341
3336 3342 * IPython/Debugger.py: remove dead code for python 2.1
3337 3343
3338 3344 2004-10-04 Fernando Perez <fperez@colorado.edu>
3339 3345
3340 3346 * IPython/iplib.py (ipmagic): New function for accessing magics
3341 3347 via a normal python function call.
3342 3348
3343 3349 * IPython/Magic.py (Magic.magic_magic): Change the magic escape
3344 3350 from '@' to '%', to accomodate the new @decorator syntax of python
3345 3351 2.4.
3346 3352
3347 3353 2004-09-29 Fernando Perez <fperez@colorado.edu>
3348 3354
3349 3355 * IPython/Shell.py (MatplotlibShellBase.use): Added a wrapper to
3350 3356 matplotlib.use to prevent running scripts which try to switch
3351 3357 interactive backends from within ipython. This will just crash
3352 3358 the python interpreter, so we can't allow it (but a detailed error
3353 3359 is given to the user).
3354 3360
3355 3361 2004-09-28 Fernando Perez <fperez@colorado.edu>
3356 3362
3357 3363 * IPython/Shell.py (MatplotlibShellBase.mplot_exec):
3358 3364 matplotlib-related fixes so that using @run with non-matplotlib
3359 3365 scripts doesn't pop up spurious plot windows. This requires
3360 3366 matplotlib >= 0.63, where I had to make some changes as well.
3361 3367
3362 3368 * IPython/ipmaker.py (make_IPython): update version requirement to
3363 3369 python 2.2.
3364 3370
3365 3371 * IPython/iplib.py (InteractiveShell.mainloop): Add an optional
3366 3372 banner arg for embedded customization.
3367 3373
3368 3374 * IPython/Magic.py (Magic.__init__): big cleanup to remove all
3369 3375 explicit uses of __IP as the IPython's instance name. Now things
3370 3376 are properly handled via the shell.name value. The actual code
3371 3377 is a bit ugly b/c I'm doing it via a global in Magic.py, but this
3372 3378 is much better than before. I'll clean things completely when the
3373 3379 magic stuff gets a real overhaul.
3374 3380
3375 3381 * ipython.1: small fixes, sent in by Jack Moffit. He also sent in
3376 3382 minor changes to debian dir.
3377 3383
3378 3384 * IPython/iplib.py (InteractiveShell.__init__): Fix adding a
3379 3385 pointer to the shell itself in the interactive namespace even when
3380 3386 a user-supplied dict is provided. This is needed for embedding
3381 3387 purposes (found by tests with Michel Sanner).
3382 3388
3383 3389 2004-09-27 Fernando Perez <fperez@colorado.edu>
3384 3390
3385 3391 * IPython/UserConfig/ipythonrc: remove []{} from
3386 3392 readline_remove_delims, so that things like [modname.<TAB> do
3387 3393 proper completion. This disables [].TAB, but that's a less common
3388 3394 case than module names in list comprehensions, for example.
3389 3395 Thanks to a report by Andrea Riciputi.
3390 3396
3391 3397 2004-09-09 Fernando Perez <fperez@colorado.edu>
3392 3398
3393 3399 * IPython/Shell.py (IPShellGTK.mainloop): reorder to avoid
3394 3400 blocking problems in win32 and osx. Fix by John.
3395 3401
3396 3402 2004-09-08 Fernando Perez <fperez@colorado.edu>
3397 3403
3398 3404 * IPython/Shell.py (IPShellWX.OnInit): Fix output redirection bug
3399 3405 for Win32 and OSX. Fix by John Hunter.
3400 3406
3401 3407 2004-08-30 *** Released version 0.6.3
3402 3408
3403 3409 2004-08-30 Fernando Perez <fperez@colorado.edu>
3404 3410
3405 3411 * setup.py (isfile): Add manpages to list of dependent files to be
3406 3412 updated.
3407 3413
3408 3414 2004-08-27 Fernando Perez <fperez@colorado.edu>
3409 3415
3410 3416 * IPython/Shell.py (start): I've disabled -wthread and -gthread
3411 3417 for now. They don't really work with standalone WX/GTK code
3412 3418 (though matplotlib IS working fine with both of those backends).
3413 3419 This will neeed much more testing. I disabled most things with
3414 3420 comments, so turning it back on later should be pretty easy.
3415 3421
3416 3422 * IPython/iplib.py (InteractiveShell.__init__): Fix accidental
3417 3423 autocalling of expressions like r'foo', by modifying the line
3418 3424 split regexp. Closes
3419 3425 http://www.scipy.net/roundup/ipython/issue18, reported by Nicholas
3420 3426 Riley <ipythonbugs-AT-sabi.net>.
3421 3427 (InteractiveShell.mainloop): honor --nobanner with banner
3422 3428 extensions.
3423 3429
3424 3430 * IPython/Shell.py: Significant refactoring of all classes, so
3425 3431 that we can really support ALL matplotlib backends and threading
3426 3432 models (John spotted a bug with Tk which required this). Now we
3427 3433 should support single-threaded, WX-threads and GTK-threads, both
3428 3434 for generic code and for matplotlib.
3429 3435
3430 3436 * IPython/ipmaker.py (__call__): Changed -mpthread option to
3431 3437 -pylab, to simplify things for users. Will also remove the pylab
3432 3438 profile, since now all of matplotlib configuration is directly
3433 3439 handled here. This also reduces startup time.
3434 3440
3435 3441 * IPython/Shell.py (IPShellGTK.run): Fixed bug where mainloop() of
3436 3442 shell wasn't being correctly called. Also in IPShellWX.
3437 3443
3438 3444 * IPython/iplib.py (InteractiveShell.__init__): Added option to
3439 3445 fine-tune banner.
3440 3446
3441 3447 * IPython/numutils.py (spike): Deprecate these spike functions,
3442 3448 delete (long deprecated) gnuplot_exec handler.
3443 3449
3444 3450 2004-08-26 Fernando Perez <fperez@colorado.edu>
3445 3451
3446 3452 * ipython.1: Update for threading options, plus some others which
3447 3453 were missing.
3448 3454
3449 3455 * IPython/ipmaker.py (__call__): Added -wthread option for
3450 3456 wxpython thread handling. Make sure threading options are only
3451 3457 valid at the command line.
3452 3458
3453 3459 * scripts/ipython: moved shell selection into a factory function
3454 3460 in Shell.py, to keep the starter script to a minimum.
3455 3461
3456 3462 2004-08-25 Fernando Perez <fperez@colorado.edu>
3457 3463
3458 3464 * IPython/Shell.py (IPShellWX.wxexit): fixes to WX threading, by
3459 3465 John. Along with some recent changes he made to matplotlib, the
3460 3466 next versions of both systems should work very well together.
3461 3467
3462 3468 2004-08-24 Fernando Perez <fperez@colorado.edu>
3463 3469
3464 3470 * IPython/Magic.py (Magic.magic_prun): cleanup some dead code. I
3465 3471 tried to switch the profiling to using hotshot, but I'm getting
3466 3472 strange errors from prof.runctx() there. I may be misreading the
3467 3473 docs, but it looks weird. For now the profiling code will
3468 3474 continue to use the standard profiler.
3469 3475
3470 3476 2004-08-23 Fernando Perez <fperez@colorado.edu>
3471 3477
3472 3478 * IPython/Shell.py (IPShellWX.__init__): Improvements to the WX
3473 3479 threaded shell, by John Hunter. It's not quite ready yet, but
3474 3480 close.
3475 3481
3476 3482 2004-08-22 Fernando Perez <fperez@colorado.edu>
3477 3483
3478 3484 * IPython/iplib.py (InteractiveShell.interact): tab cleanups, also
3479 3485 in Magic and ultraTB.
3480 3486
3481 3487 * ipython.1: document threading options in manpage.
3482 3488
3483 3489 * scripts/ipython: Changed name of -thread option to -gthread,
3484 3490 since this is GTK specific. I want to leave the door open for a
3485 3491 -wthread option for WX, which will most likely be necessary. This
3486 3492 change affects usage and ipmaker as well.
3487 3493
3488 3494 * IPython/Shell.py (matplotlib_shell): Add a factory function to
3489 3495 handle the matplotlib shell issues. Code by John Hunter
3490 3496 <jdhunter-AT-nitace.bsd.uchicago.edu>.
3491 3497 (IPShellMatplotlibWX.__init__): Rudimentary WX support. It's
3492 3498 broken (and disabled for end users) for now, but it puts the
3493 3499 infrastructure in place.
3494 3500
3495 3501 2004-08-21 Fernando Perez <fperez@colorado.edu>
3496 3502
3497 3503 * ipythonrc-pylab: Add matplotlib support.
3498 3504
3499 3505 * matplotlib_config.py: new files for matplotlib support, part of
3500 3506 the pylab profile.
3501 3507
3502 3508 * IPython/usage.py (__doc__): documented the threading options.
3503 3509
3504 3510 2004-08-20 Fernando Perez <fperez@colorado.edu>
3505 3511
3506 3512 * ipython: Modified the main calling routine to handle the -thread
3507 3513 and -mpthread options. This needs to be done as a top-level hack,
3508 3514 because it determines which class to instantiate for IPython
3509 3515 itself.
3510 3516
3511 3517 * IPython/Shell.py (MTInteractiveShell.__init__): New set of
3512 3518 classes to support multithreaded GTK operation without blocking,
3513 3519 and matplotlib with all backends. This is a lot of still very
3514 3520 experimental code, and threads are tricky. So it may still have a
3515 3521 few rough edges... This code owes a lot to
3516 3522 http://aspn.activestate.com/ASPN/Cookbook/Python/Recipe/65109, by
3517 3523 Brian # McErlean and John Finlay, to Antoon Pardon for fixes, and
3518 3524 to John Hunter for all the matplotlib work.
3519 3525
3520 3526 * IPython/ipmaker.py (__call__): Added -thread and -mpthread
3521 3527 options for gtk thread and matplotlib support.
3522 3528
3523 3529 2004-08-16 Fernando Perez <fperez@colorado.edu>
3524 3530
3525 3531 * IPython/iplib.py (InteractiveShell.__init__): don't trigger
3526 3532 autocall for things like p*q,p/q,p+q,p-q, when p is callable. Bug
3527 3533 reported by Stephen Walton <stephen.walton-AT-csun.edu>.
3528 3534
3529 3535 2004-08-11 Fernando Perez <fperez@colorado.edu>
3530 3536
3531 3537 * setup.py (isfile): Fix build so documentation gets updated for
3532 3538 rpms (it was only done for .tgz builds).
3533 3539
3534 3540 2004-08-10 Fernando Perez <fperez@colorado.edu>
3535 3541
3536 3542 * genutils.py (Term): Fix misspell of stdin stream (sin->cin).
3537 3543
3538 3544 * iplib.py : Silence syntax error exceptions in tab-completion.
3539 3545
3540 3546 2004-08-05 Fernando Perez <fperez@colorado.edu>
3541 3547
3542 3548 * IPython/Prompts.py (Prompt2.set_colors): Fix incorrectly set
3543 3549 'color off' mark for continuation prompts. This was causing long
3544 3550 continuation lines to mis-wrap.
3545 3551
3546 3552 2004-08-01 Fernando Perez <fperez@colorado.edu>
3547 3553
3548 3554 * IPython/ipmaker.py (make_IPython): Allow the shell class used
3549 3555 for building ipython to be a parameter. All this is necessary
3550 3556 right now to have a multithreaded version, but this insane
3551 3557 non-design will be cleaned up soon. For now, it's a hack that
3552 3558 works.
3553 3559
3554 3560 * IPython/Shell.py (IPShell.__init__): Stop using mutable default
3555 3561 args in various places. No bugs so far, but it's a dangerous
3556 3562 practice.
3557 3563
3558 3564 2004-07-31 Fernando Perez <fperez@colorado.edu>
3559 3565
3560 3566 * IPython/iplib.py (complete): ignore SyntaxError exceptions to
3561 3567 fix completion of files with dots in their names under most
3562 3568 profiles (pysh was OK because the completion order is different).
3563 3569
3564 3570 2004-07-27 Fernando Perez <fperez@colorado.edu>
3565 3571
3566 3572 * IPython/iplib.py (InteractiveShell.__init__): build dict of
3567 3573 keywords manually, b/c the one in keyword.py was removed in python
3568 3574 2.4. Patch by Anakim Border <aborder-AT-users.sourceforge.net>.
3569 3575 This is NOT a bug under python 2.3 and earlier.
3570 3576
3571 3577 2004-07-26 Fernando Perez <fperez@colorado.edu>
3572 3578
3573 3579 * IPython/ultraTB.py (VerboseTB.text): Add another
3574 3580 linecache.checkcache() call to try to prevent inspect.py from
3575 3581 crashing under python 2.3. I think this fixes
3576 3582 http://www.scipy.net/roundup/ipython/issue17.
3577 3583
3578 3584 2004-07-26 *** Released version 0.6.2
3579 3585
3580 3586 2004-07-26 Fernando Perez <fperez@colorado.edu>
3581 3587
3582 3588 * IPython/Magic.py (Magic.magic_cd): Fix bug where 'cd -N' would
3583 3589 fail for any number.
3584 3590 (Magic.magic_bookmark): Fix bug where 'bookmark -l' would fail for
3585 3591 empty bookmarks.
3586 3592
3587 3593 2004-07-26 *** Released version 0.6.1
3588 3594
3589 3595 2004-07-26 Fernando Perez <fperez@colorado.edu>
3590 3596
3591 3597 * ipython_win_post_install.py (run): Added pysh shortcut for Windows.
3592 3598
3593 3599 * IPython/iplib.py (protect_filename): Applied Ville's patch for
3594 3600 escaping '()[]{}' in filenames.
3595 3601
3596 3602 * IPython/Magic.py (shlex_split): Fix handling of '*' and '?' for
3597 3603 Python 2.2 users who lack a proper shlex.split.
3598 3604
3599 3605 2004-07-19 Fernando Perez <fperez@colorado.edu>
3600 3606
3601 3607 * IPython/iplib.py (InteractiveShell.init_readline): Add support
3602 3608 for reading readline's init file. I follow the normal chain:
3603 3609 $INPUTRC is honored, otherwise ~/.inputrc is used. Thanks to a
3604 3610 report by Mike Heeter. This closes
3605 3611 http://www.scipy.net/roundup/ipython/issue16.
3606 3612
3607 3613 2004-07-18 Fernando Perez <fperez@colorado.edu>
3608 3614
3609 3615 * IPython/iplib.py (__init__): Add better handling of '\' under
3610 3616 Win32 for filenames. After a patch by Ville.
3611 3617
3612 3618 2004-07-17 Fernando Perez <fperez@colorado.edu>
3613 3619
3614 3620 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
3615 3621 autocalling would be triggered for 'foo is bar' if foo is
3616 3622 callable. I also cleaned up the autocall detection code to use a
3617 3623 regexp, which is faster. Bug reported by Alexander Schmolck.
3618 3624
3619 3625 * IPython/Magic.py (Magic.magic_pinfo): Fix bug where strings with
3620 3626 '?' in them would confuse the help system. Reported by Alex
3621 3627 Schmolck.
3622 3628
3623 3629 2004-07-16 Fernando Perez <fperez@colorado.edu>
3624 3630
3625 3631 * IPython/GnuplotInteractive.py (__all__): added plot2.
3626 3632
3627 3633 * IPython/Gnuplot2.py (Gnuplot.plot2): added new function for
3628 3634 plotting dictionaries, lists or tuples of 1d arrays.
3629 3635
3630 3636 * IPython/Magic.py (Magic.magic_hist): small clenaups and
3631 3637 optimizations.
3632 3638
3633 3639 * IPython/iplib.py:Remove old Changelog info for cleanup. This is
3634 3640 the information which was there from Janko's original IPP code:
3635 3641
3636 3642 03.05.99 20:53 porto.ifm.uni-kiel.de
3637 3643 --Started changelog.
3638 3644 --make clear do what it say it does
3639 3645 --added pretty output of lines from inputcache
3640 3646 --Made Logger a mixin class, simplifies handling of switches
3641 3647 --Added own completer class. .string<TAB> expands to last history
3642 3648 line which starts with string. The new expansion is also present
3643 3649 with Ctrl-r from the readline library. But this shows, who this
3644 3650 can be done for other cases.
3645 3651 --Added convention that all shell functions should accept a
3646 3652 parameter_string This opens the door for different behaviour for
3647 3653 each function. @cd is a good example of this.
3648 3654
3649 3655 04.05.99 12:12 porto.ifm.uni-kiel.de
3650 3656 --added logfile rotation
3651 3657 --added new mainloop method which freezes first the namespace
3652 3658
3653 3659 07.05.99 21:24 porto.ifm.uni-kiel.de
3654 3660 --added the docreader classes. Now there is a help system.
3655 3661 -This is only a first try. Currently it's not easy to put new
3656 3662 stuff in the indices. But this is the way to go. Info would be
3657 3663 better, but HTML is every where and not everybody has an info
3658 3664 system installed and it's not so easy to change html-docs to info.
3659 3665 --added global logfile option
3660 3666 --there is now a hook for object inspection method pinfo needs to
3661 3667 be provided for this. Can be reached by two '??'.
3662 3668
3663 3669 08.05.99 20:51 porto.ifm.uni-kiel.de
3664 3670 --added a README
3665 3671 --bug in rc file. Something has changed so functions in the rc
3666 3672 file need to reference the shell and not self. Not clear if it's a
3667 3673 bug or feature.
3668 3674 --changed rc file for new behavior
3669 3675
3670 3676 2004-07-15 Fernando Perez <fperez@colorado.edu>
3671 3677
3672 3678 * IPython/Logger.py (Logger.log): fixed recent bug where the input
3673 3679 cache was falling out of sync in bizarre manners when multi-line
3674 3680 input was present. Minor optimizations and cleanup.
3675 3681
3676 3682 (Logger): Remove old Changelog info for cleanup. This is the
3677 3683 information which was there from Janko's original code:
3678 3684
3679 3685 Changes to Logger: - made the default log filename a parameter
3680 3686
3681 3687 - put a check for lines beginning with !@? in log(). Needed
3682 3688 (even if the handlers properly log their lines) for mid-session
3683 3689 logging activation to work properly. Without this, lines logged
3684 3690 in mid session, which get read from the cache, would end up
3685 3691 'bare' (with !@? in the open) in the log. Now they are caught
3686 3692 and prepended with a #.
3687 3693
3688 3694 * IPython/iplib.py (InteractiveShell.init_readline): added check
3689 3695 in case MagicCompleter fails to be defined, so we don't crash.
3690 3696
3691 3697 2004-07-13 Fernando Perez <fperez@colorado.edu>
3692 3698
3693 3699 * IPython/Gnuplot2.py (Gnuplot.hardcopy): add automatic generation
3694 3700 of EPS if the requested filename ends in '.eps'.
3695 3701
3696 3702 2004-07-04 Fernando Perez <fperez@colorado.edu>
3697 3703
3698 3704 * IPython/iplib.py (InteractiveShell.handle_shell_escape): Fix
3699 3705 escaping of quotes when calling the shell.
3700 3706
3701 3707 2004-07-02 Fernando Perez <fperez@colorado.edu>
3702 3708
3703 3709 * IPython/Prompts.py (CachedOutput.update): Fix problem with
3704 3710 gettext not working because we were clobbering '_'. Fixes
3705 3711 http://www.scipy.net/roundup/ipython/issue6.
3706 3712
3707 3713 2004-07-01 Fernando Perez <fperez@colorado.edu>
3708 3714
3709 3715 * IPython/Magic.py (Magic.magic_cd): integrated bookmark handling
3710 3716 into @cd. Patch by Ville.
3711 3717
3712 3718 * IPython/iplib.py (InteractiveShell.post_config_initialization):
3713 3719 new function to store things after ipmaker runs. Patch by Ville.
3714 3720 Eventually this will go away once ipmaker is removed and the class
3715 3721 gets cleaned up, but for now it's ok. Key functionality here is
3716 3722 the addition of the persistent storage mechanism, a dict for
3717 3723 keeping data across sessions (for now just bookmarks, but more can
3718 3724 be implemented later).
3719 3725
3720 3726 * IPython/Magic.py (Magic.magic_bookmark): New bookmark system,
3721 3727 persistent across sections. Patch by Ville, I modified it
3722 3728 soemwhat to allow bookmarking arbitrary dirs other than CWD. Also
3723 3729 added a '-l' option to list all bookmarks.
3724 3730
3725 3731 * IPython/iplib.py (InteractiveShell.atexit_operations): new
3726 3732 center for cleanup. Registered with atexit.register(). I moved
3727 3733 here the old exit_cleanup(). After a patch by Ville.
3728 3734
3729 3735 * IPython/Magic.py (get_py_filename): added '~' to the accepted
3730 3736 characters in the hacked shlex_split for python 2.2.
3731 3737
3732 3738 * IPython/iplib.py (file_matches): more fixes to filenames with
3733 3739 whitespace in them. It's not perfect, but limitations in python's
3734 3740 readline make it impossible to go further.
3735 3741
3736 3742 2004-06-29 Fernando Perez <fperez@colorado.edu>
3737 3743
3738 3744 * IPython/iplib.py (file_matches): escape whitespace correctly in
3739 3745 filename completions. Bug reported by Ville.
3740 3746
3741 3747 2004-06-28 Fernando Perez <fperez@colorado.edu>
3742 3748
3743 3749 * IPython/ipmaker.py (__call__): Added per-profile histories. Now
3744 3750 the history file will be called 'history-PROFNAME' (or just
3745 3751 'history' if no profile is loaded). I was getting annoyed at
3746 3752 getting my Numerical work history clobbered by pysh sessions.
3747 3753
3748 3754 * IPython/iplib.py (InteractiveShell.__init__): Internal
3749 3755 getoutputerror() function so that we can honor the system_verbose
3750 3756 flag for _all_ system calls. I also added escaping of #
3751 3757 characters here to avoid confusing Itpl.
3752 3758
3753 3759 * IPython/Magic.py (shlex_split): removed call to shell in
3754 3760 parse_options and replaced it with shlex.split(). The annoying
3755 3761 part was that in Python 2.2, shlex.split() doesn't exist, so I had
3756 3762 to backport it from 2.3, with several frail hacks (the shlex
3757 3763 module is rather limited in 2.2). Thanks to a suggestion by Ville
3758 3764 Vainio <vivainio@kolumbus.fi>. For Python 2.3 there should be no
3759 3765 problem.
3760 3766
3761 3767 (Magic.magic_system_verbose): new toggle to print the actual
3762 3768 system calls made by ipython. Mainly for debugging purposes.
3763 3769
3764 3770 * IPython/GnuplotRuntime.py (gnu_out): fix bug for cygwin, which
3765 3771 doesn't support persistence. Reported (and fix suggested) by
3766 3772 Travis Caldwell <travis_caldwell2000@yahoo.com>.
3767 3773
3768 3774 2004-06-26 Fernando Perez <fperez@colorado.edu>
3769 3775
3770 3776 * IPython/Logger.py (Logger.log): fix to handle correctly empty
3771 3777 continue prompts.
3772 3778
3773 3779 * IPython/Extensions/InterpreterExec.py (pysh): moved the pysh()
3774 3780 function (basically a big docstring) and a few more things here to
3775 3781 speedup startup. pysh.py is now very lightweight. We want because
3776 3782 it gets execfile'd, while InterpreterExec gets imported, so
3777 3783 byte-compilation saves time.
3778 3784
3779 3785 2004-06-25 Fernando Perez <fperez@colorado.edu>
3780 3786
3781 3787 * IPython/Magic.py (Magic.magic_cd): Fixed to restore usage of 'cd
3782 3788 -NUM', which was recently broken.
3783 3789
3784 3790 * IPython/iplib.py (InteractiveShell.handle_shell_escape): allow !
3785 3791 in multi-line input (but not !!, which doesn't make sense there).
3786 3792
3787 3793 * IPython/UserConfig/ipythonrc: made autoindent on by default.
3788 3794 It's just too useful, and people can turn it off in the less
3789 3795 common cases where it's a problem.
3790 3796
3791 3797 2004-06-24 Fernando Perez <fperez@colorado.edu>
3792 3798
3793 3799 * IPython/iplib.py (InteractiveShell._prefilter): big change -
3794 3800 special syntaxes (like alias calling) is now allied in multi-line
3795 3801 input. This is still _very_ experimental, but it's necessary for
3796 3802 efficient shell usage combining python looping syntax with system
3797 3803 calls. For now it's restricted to aliases, I don't think it
3798 3804 really even makes sense to have this for magics.
3799 3805
3800 3806 2004-06-23 Fernando Perez <fperez@colorado.edu>
3801 3807
3802 3808 * IPython/Extensions/InterpreterExec.py (prefilter_shell): Added
3803 3809 $var=cmd <=> @sc var=cmd and $$var=cmd <=> @sc -l var=cmd.
3804 3810
3805 3811 * IPython/Magic.py (Magic.magic_rehashx): modified to handle
3806 3812 extensions under Windows (after code sent by Gary Bishop). The
3807 3813 extensions considered 'executable' are stored in IPython's rc
3808 3814 structure as win_exec_ext.
3809 3815
3810 3816 * IPython/genutils.py (shell): new function, like system() but
3811 3817 without return value. Very useful for interactive shell work.
3812 3818
3813 3819 * IPython/Magic.py (Magic.magic_unalias): New @unalias function to
3814 3820 delete aliases.
3815 3821
3816 3822 * IPython/iplib.py (InteractiveShell.alias_table_update): make
3817 3823 sure that the alias table doesn't contain python keywords.
3818 3824
3819 3825 2004-06-21 Fernando Perez <fperez@colorado.edu>
3820 3826
3821 3827 * IPython/Magic.py (Magic.magic_rehash): Fix crash when
3822 3828 non-existent items are found in $PATH. Reported by Thorsten.
3823 3829
3824 3830 2004-06-20 Fernando Perez <fperez@colorado.edu>
3825 3831
3826 3832 * IPython/iplib.py (complete): modified the completer so that the
3827 3833 order of priorities can be easily changed at runtime.
3828 3834
3829 3835 * IPython/Extensions/InterpreterExec.py (prefilter_shell):
3830 3836 Modified to auto-execute all lines beginning with '~', '/' or '.'.
3831 3837
3832 3838 * IPython/Magic.py (Magic.magic_sx): modified @sc and @sx to
3833 3839 expand Python variables prepended with $ in all system calls. The
3834 3840 same was done to InteractiveShell.handle_shell_escape. Now all
3835 3841 system access mechanisms (!, !!, @sc, @sx and aliases) allow the
3836 3842 expansion of python variables and expressions according to the
3837 3843 syntax of PEP-215 - http://www.python.org/peps/pep-0215.html.
3838 3844
3839 3845 Though PEP-215 has been rejected, a similar (but simpler) one
3840 3846 seems like it will go into Python 2.4, PEP-292 -
3841 3847 http://www.python.org/peps/pep-0292.html.
3842 3848
3843 3849 I'll keep the full syntax of PEP-215, since IPython has since the
3844 3850 start used Ka-Ping Yee's reference implementation discussed there
3845 3851 (Itpl), and I actually like the powerful semantics it offers.
3846 3852
3847 3853 In order to access normal shell variables, the $ has to be escaped
3848 3854 via an extra $. For example:
3849 3855
3850 3856 In [7]: PATH='a python variable'
3851 3857
3852 3858 In [8]: !echo $PATH
3853 3859 a python variable
3854 3860
3855 3861 In [9]: !echo $$PATH
3856 3862 /usr/local/lf9560/bin:/usr/local/intel/compiler70/ia32/bin:...
3857 3863
3858 3864 (Magic.parse_options): escape $ so the shell doesn't evaluate
3859 3865 things prematurely.
3860 3866
3861 3867 * IPython/iplib.py (InteractiveShell.call_alias): added the
3862 3868 ability for aliases to expand python variables via $.
3863 3869
3864 3870 * IPython/Magic.py (Magic.magic_rehash): based on the new alias
3865 3871 system, now there's a @rehash/@rehashx pair of magics. These work
3866 3872 like the csh rehash command, and can be invoked at any time. They
3867 3873 build a table of aliases to everything in the user's $PATH
3868 3874 (@rehash uses everything, @rehashx is slower but only adds
3869 3875 executable files). With this, the pysh.py-based shell profile can
3870 3876 now simply call rehash upon startup, and full access to all
3871 3877 programs in the user's path is obtained.
3872 3878
3873 3879 * IPython/iplib.py (InteractiveShell.call_alias): The new alias
3874 3880 functionality is now fully in place. I removed the old dynamic
3875 3881 code generation based approach, in favor of a much lighter one
3876 3882 based on a simple dict. The advantage is that this allows me to
3877 3883 now have thousands of aliases with negligible cost (unthinkable
3878 3884 with the old system).
3879 3885
3880 3886 2004-06-19 Fernando Perez <fperez@colorado.edu>
3881 3887
3882 3888 * IPython/iplib.py (__init__): extended MagicCompleter class to
3883 3889 also complete (last in priority) on user aliases.
3884 3890
3885 3891 * IPython/Itpl.py (Itpl.__str__): fixed order of globals/locals in
3886 3892 call to eval.
3887 3893 (ItplNS.__init__): Added a new class which functions like Itpl,
3888 3894 but allows configuring the namespace for the evaluation to occur
3889 3895 in.
3890 3896
3891 3897 2004-06-18 Fernando Perez <fperez@colorado.edu>
3892 3898
3893 3899 * IPython/iplib.py (InteractiveShell.runcode): modify to print a
3894 3900 better message when 'exit' or 'quit' are typed (a common newbie
3895 3901 confusion).
3896 3902
3897 3903 * IPython/Magic.py (Magic.magic_colors): Added the runtime color
3898 3904 check for Windows users.
3899 3905
3900 3906 * IPython/iplib.py (InteractiveShell.user_setup): removed
3901 3907 disabling of colors for Windows. I'll test at runtime and issue a
3902 3908 warning if Gary's readline isn't found, as to nudge users to
3903 3909 download it.
3904 3910
3905 3911 2004-06-16 Fernando Perez <fperez@colorado.edu>
3906 3912
3907 3913 * IPython/genutils.py (Stream.__init__): changed to print errors
3908 3914 to sys.stderr. I had a circular dependency here. Now it's
3909 3915 possible to run ipython as IDLE's shell (consider this pre-alpha,
3910 3916 since true stdout things end up in the starting terminal instead
3911 3917 of IDLE's out).
3912 3918
3913 3919 * IPython/Prompts.py (Prompt2.set_colors): prevent crashes for
3914 3920 users who haven't # updated their prompt_in2 definitions. Remove
3915 3921 eventually.
3916 3922 (multiple_replace): added credit to original ASPN recipe.
3917 3923
3918 3924 2004-06-15 Fernando Perez <fperez@colorado.edu>
3919 3925
3920 3926 * IPython/iplib.py (InteractiveShell.__init__): add 'cp' to the
3921 3927 list of auto-defined aliases.
3922 3928
3923 3929 2004-06-13 Fernando Perez <fperez@colorado.edu>
3924 3930
3925 3931 * setup.py (scriptfiles): Don't trigger win_post_install unless an
3926 3932 install was really requested (so setup.py can be used for other
3927 3933 things under Windows).
3928 3934
3929 3935 2004-06-10 Fernando Perez <fperez@colorado.edu>
3930 3936
3931 3937 * IPython/Logger.py (Logger.create_log): Manually remove any old
3932 3938 backup, since os.remove may fail under Windows. Fixes bug
3933 3939 reported by Thorsten.
3934 3940
3935 3941 2004-06-09 Fernando Perez <fperez@colorado.edu>
3936 3942
3937 3943 * examples/example-embed.py: fixed all references to %n (replaced
3938 3944 with \\# for ps1/out prompts and with \\D for ps2 prompts). Done
3939 3945 for all examples and the manual as well.
3940 3946
3941 3947 2004-06-08 Fernando Perez <fperez@colorado.edu>
3942 3948
3943 3949 * IPython/Prompts.py (Prompt2.set_p_str): fixed all prompt
3944 3950 alignment and color management. All 3 prompt subsystems now
3945 3951 inherit from BasePrompt.
3946 3952
3947 3953 * tools/release: updates for windows installer build and tag rpms
3948 3954 with python version (since paths are fixed).
3949 3955
3950 3956 * IPython/UserConfig/ipythonrc: modified to use \# instead of %n,
3951 3957 which will become eventually obsolete. Also fixed the default
3952 3958 prompt_in2 to use \D, so at least new users start with the correct
3953 3959 defaults.
3954 3960 WARNING: Users with existing ipythonrc files will need to apply
3955 3961 this fix manually!
3956 3962
3957 3963 * setup.py: make windows installer (.exe). This is finally the
3958 3964 integration of an old patch by Cory Dodt <dodt-AT-fcoe.k12.ca.us>,
3959 3965 which I hadn't included because it required Python 2.3 (or recent
3960 3966 distutils).
3961 3967
3962 3968 * IPython/usage.py (__doc__): update docs (and manpage) to reflect
3963 3969 usage of new '\D' escape.
3964 3970
3965 3971 * IPython/Prompts.py (ROOT_SYMBOL): Small fix for Windows (which
3966 3972 lacks os.getuid())
3967 3973 (CachedOutput.set_colors): Added the ability to turn coloring
3968 3974 on/off with @colors even for manually defined prompt colors. It
3969 3975 uses a nasty global, but it works safely and via the generic color
3970 3976 handling mechanism.
3971 3977 (Prompt2.__init__): Introduced new escape '\D' for continuation
3972 3978 prompts. It represents the counter ('\#') as dots.
3973 3979 *** NOTE *** THIS IS A BACKWARDS-INCOMPATIBLE CHANGE. Users will
3974 3980 need to update their ipythonrc files and replace '%n' with '\D' in
3975 3981 their prompt_in2 settings everywhere. Sorry, but there's
3976 3982 otherwise no clean way to get all prompts to properly align. The
3977 3983 ipythonrc shipped with IPython has been updated.
3978 3984
3979 3985 2004-06-07 Fernando Perez <fperez@colorado.edu>
3980 3986
3981 3987 * setup.py (isfile): Pass local_icons option to latex2html, so the
3982 3988 resulting HTML file is self-contained. Thanks to
3983 3989 dryice-AT-liu.com.cn for the tip.
3984 3990
3985 3991 * pysh.py: I created a new profile 'shell', which implements a
3986 3992 _rudimentary_ IPython-based shell. This is in NO WAY a realy
3987 3993 system shell, nor will it become one anytime soon. It's mainly
3988 3994 meant to illustrate the use of the new flexible bash-like prompts.
3989 3995 I guess it could be used by hardy souls for true shell management,
3990 3996 but it's no tcsh/bash... pysh.py is loaded by the 'shell'
3991 3997 profile. This uses the InterpreterExec extension provided by
3992 3998 W.J. van der Laan <gnufnork-AT-hetdigitalegat.nl>
3993 3999
3994 4000 * IPython/Prompts.py (PromptOut.__str__): now it will correctly
3995 4001 auto-align itself with the length of the previous input prompt
3996 4002 (taking into account the invisible color escapes).
3997 4003 (CachedOutput.__init__): Large restructuring of this class. Now
3998 4004 all three prompts (primary1, primary2, output) are proper objects,
3999 4005 managed by the 'parent' CachedOutput class. The code is still a
4000 4006 bit hackish (all prompts share state via a pointer to the cache),
4001 4007 but it's overall far cleaner than before.
4002 4008
4003 4009 * IPython/genutils.py (getoutputerror): modified to add verbose,
4004 4010 debug and header options. This makes the interface of all getout*
4005 4011 functions uniform.
4006 4012 (SystemExec.getoutputerror): added getoutputerror to SystemExec.
4007 4013
4008 4014 * IPython/Magic.py (Magic.default_option): added a function to
4009 4015 allow registering default options for any magic command. This
4010 4016 makes it easy to have profiles which customize the magics globally
4011 4017 for a certain use. The values set through this function are
4012 4018 picked up by the parse_options() method, which all magics should
4013 4019 use to parse their options.
4014 4020
4015 4021 * IPython/genutils.py (warn): modified the warnings framework to
4016 4022 use the Term I/O class. I'm trying to slowly unify all of
4017 4023 IPython's I/O operations to pass through Term.
4018 4024
4019 4025 * IPython/Prompts.py (Prompt2._str_other): Added functionality in
4020 4026 the secondary prompt to correctly match the length of the primary
4021 4027 one for any prompt. Now multi-line code will properly line up
4022 4028 even for path dependent prompts, such as the new ones available
4023 4029 via the prompt_specials.
4024 4030
4025 4031 2004-06-06 Fernando Perez <fperez@colorado.edu>
4026 4032
4027 4033 * IPython/Prompts.py (prompt_specials): Added the ability to have
4028 4034 bash-like special sequences in the prompts, which get
4029 4035 automatically expanded. Things like hostname, current working
4030 4036 directory and username are implemented already, but it's easy to
4031 4037 add more in the future. Thanks to a patch by W.J. van der Laan
4032 4038 <gnufnork-AT-hetdigitalegat.nl>
4033 4039 (prompt_specials): Added color support for prompt strings, so
4034 4040 users can define arbitrary color setups for their prompts.
4035 4041
4036 4042 2004-06-05 Fernando Perez <fperez@colorado.edu>
4037 4043
4038 4044 * IPython/genutils.py (Term.reopen_all): Added Windows-specific
4039 4045 code to load Gary Bishop's readline and configure it
4040 4046 automatically. Thanks to Gary for help on this.
4041 4047
4042 4048 2004-06-01 Fernando Perez <fperez@colorado.edu>
4043 4049
4044 4050 * IPython/Logger.py (Logger.create_log): fix bug for logging
4045 4051 with no filename (previous fix was incomplete).
4046 4052
4047 4053 2004-05-25 Fernando Perez <fperez@colorado.edu>
4048 4054
4049 4055 * IPython/Magic.py (Magic.parse_options): fix bug where naked
4050 4056 parens would get passed to the shell.
4051 4057
4052 4058 2004-05-20 Fernando Perez <fperez@colorado.edu>
4053 4059
4054 4060 * IPython/Magic.py (Magic.magic_prun): changed default profile
4055 4061 sort order to 'time' (the more common profiling need).
4056 4062
4057 4063 * IPython/OInspect.py (Inspector.pinfo): flush the inspect cache
4058 4064 so that source code shown is guaranteed in sync with the file on
4059 4065 disk (also changed in psource). Similar fix to the one for
4060 4066 ultraTB on 2004-05-06. Thanks to a bug report by Yann Le Du
4061 4067 <yann.ledu-AT-noos.fr>.
4062 4068
4063 4069 * IPython/Magic.py (Magic.parse_options): Fixed bug where commands
4064 4070 with a single option would not be correctly parsed. Closes
4065 4071 http://www.scipy.net/roundup/ipython/issue14. This bug had been
4066 4072 introduced in 0.6.0 (on 2004-05-06).
4067 4073
4068 4074 2004-05-13 *** Released version 0.6.0
4069 4075
4070 4076 2004-05-13 Fernando Perez <fperez@colorado.edu>
4071 4077
4072 4078 * debian/: Added debian/ directory to CVS, so that debian support
4073 4079 is publicly accessible. The debian package is maintained by Jack
4074 4080 Moffit <jack-AT-xiph.org>.
4075 4081
4076 4082 * Documentation: included the notes about an ipython-based system
4077 4083 shell (the hypothetical 'pysh') into the new_design.pdf document,
4078 4084 so that these ideas get distributed to users along with the
4079 4085 official documentation.
4080 4086
4081 4087 2004-05-10 Fernando Perez <fperez@colorado.edu>
4082 4088
4083 4089 * IPython/Logger.py (Logger.create_log): fix recently introduced
4084 4090 bug (misindented line) where logstart would fail when not given an
4085 4091 explicit filename.
4086 4092
4087 4093 2004-05-09 Fernando Perez <fperez@colorado.edu>
4088 4094
4089 4095 * IPython/Magic.py (Magic.parse_options): skip system call when
4090 4096 there are no options to look for. Faster, cleaner for the common
4091 4097 case.
4092 4098
4093 4099 * Documentation: many updates to the manual: describing Windows
4094 4100 support better, Gnuplot updates, credits, misc small stuff. Also
4095 4101 updated the new_design doc a bit.
4096 4102
4097 4103 2004-05-06 *** Released version 0.6.0.rc1
4098 4104
4099 4105 2004-05-06 Fernando Perez <fperez@colorado.edu>
4100 4106
4101 4107 * IPython/ultraTB.py (ListTB.text): modified a ton of string +=
4102 4108 operations to use the vastly more efficient list/''.join() method.
4103 4109 (FormattedTB.text): Fix
4104 4110 http://www.scipy.net/roundup/ipython/issue12 - exception source
4105 4111 extract not updated after reload. Thanks to Mike Salib
4106 4112 <msalib-AT-mit.edu> for pinning the source of the problem.
4107 4113 Fortunately, the solution works inside ipython and doesn't require
4108 4114 any changes to python proper.
4109 4115
4110 4116 * IPython/Magic.py (Magic.parse_options): Improved to process the
4111 4117 argument list as a true shell would (by actually using the
4112 4118 underlying system shell). This way, all @magics automatically get
4113 4119 shell expansion for variables. Thanks to a comment by Alex
4114 4120 Schmolck.
4115 4121
4116 4122 2004-04-04 Fernando Perez <fperez@colorado.edu>
4117 4123
4118 4124 * IPython/iplib.py (InteractiveShell.interact): Added a special
4119 4125 trap for a debugger quit exception, which is basically impossible
4120 4126 to handle by normal mechanisms, given what pdb does to the stack.
4121 4127 This fixes a crash reported by <fgibbons-AT-llama.med.harvard.edu>.
4122 4128
4123 4129 2004-04-03 Fernando Perez <fperez@colorado.edu>
4124 4130
4125 4131 * IPython/genutils.py (Term): Standardized the names of the Term
4126 4132 class streams to cin/cout/cerr, following C++ naming conventions
4127 4133 (I can't use in/out/err because 'in' is not a valid attribute
4128 4134 name).
4129 4135
4130 4136 * IPython/iplib.py (InteractiveShell.interact): don't increment
4131 4137 the prompt if there's no user input. By Daniel 'Dang' Griffith
4132 4138 <pythondev-dang-AT-lazytwinacres.net>, after a suggestion from
4133 4139 Francois Pinard.
4134 4140
4135 4141 2004-04-02 Fernando Perez <fperez@colorado.edu>
4136 4142
4137 4143 * IPython/genutils.py (Stream.__init__): Modified to survive at
4138 4144 least importing in contexts where stdin/out/err aren't true file
4139 4145 objects, such as PyCrust (they lack fileno() and mode). However,
4140 4146 the recovery facilities which rely on these things existing will
4141 4147 not work.
4142 4148
4143 4149 2004-04-01 Fernando Perez <fperez@colorado.edu>
4144 4150
4145 4151 * IPython/Magic.py (Magic.magic_sx): modified (as well as @sc) to
4146 4152 use the new getoutputerror() function, so it properly
4147 4153 distinguishes stdout/err.
4148 4154
4149 4155 * IPython/genutils.py (getoutputerror): added a function to
4150 4156 capture separately the standard output and error of a command.
4151 4157 After a comment from dang on the mailing lists. This code is
4152 4158 basically a modified version of commands.getstatusoutput(), from
4153 4159 the standard library.
4154 4160
4155 4161 * IPython/iplib.py (InteractiveShell.handle_shell_escape): added
4156 4162 '!!' as a special syntax (shorthand) to access @sx.
4157 4163
4158 4164 * IPython/Magic.py (Magic.magic_sx): new magic, to execute a shell
4159 4165 command and return its output as a list split on '\n'.
4160 4166
4161 4167 2004-03-31 Fernando Perez <fperez@colorado.edu>
4162 4168
4163 4169 * IPython/FakeModule.py (FakeModule.__init__): added __nonzero__
4164 4170 method to dictionaries used as FakeModule instances if they lack
4165 4171 it. At least pydoc in python2.3 breaks for runtime-defined
4166 4172 functions without this hack. At some point I need to _really_
4167 4173 understand what FakeModule is doing, because it's a gross hack.
4168 4174 But it solves Arnd's problem for now...
4169 4175
4170 4176 2004-02-27 Fernando Perez <fperez@colorado.edu>
4171 4177
4172 4178 * IPython/Logger.py (Logger.create_log): Fix bug where 'rotate'
4173 4179 mode would behave erratically. Also increased the number of
4174 4180 possible logs in rotate mod to 999. Thanks to Rod Holland
4175 4181 <rhh@StructureLABS.com> for the report and fixes.
4176 4182
4177 4183 2004-02-26 Fernando Perez <fperez@colorado.edu>
4178 4184
4179 4185 * IPython/genutils.py (page): Check that the curses module really
4180 4186 has the initscr attribute before trying to use it. For some
4181 4187 reason, the Solaris curses module is missing this. I think this
4182 4188 should be considered a Solaris python bug, but I'm not sure.
4183 4189
4184 4190 2004-01-17 Fernando Perez <fperez@colorado.edu>
4185 4191
4186 4192 * IPython/genutils.py (Stream.__init__): Changes to try to make
4187 4193 ipython robust against stdin/out/err being closed by the user.
4188 4194 This is 'user error' (and blocks a normal python session, at least
4189 4195 the stdout case). However, Ipython should be able to survive such
4190 4196 instances of abuse as gracefully as possible. To simplify the
4191 4197 coding and maintain compatibility with Gary Bishop's Term
4192 4198 contributions, I've made use of classmethods for this. I think
4193 4199 this introduces a dependency on python 2.2.
4194 4200
4195 4201 2004-01-13 Fernando Perez <fperez@colorado.edu>
4196 4202
4197 4203 * IPython/numutils.py (exp_safe): simplified the code a bit and
4198 4204 removed the need for importing the kinds module altogether.
4199 4205
4200 4206 2004-01-06 Fernando Perez <fperez@colorado.edu>
4201 4207
4202 4208 * IPython/Magic.py (Magic.magic_sc): Made the shell capture system
4203 4209 a magic function instead, after some community feedback. No
4204 4210 special syntax will exist for it, but its name is deliberately
4205 4211 very short.
4206 4212
4207 4213 2003-12-20 Fernando Perez <fperez@colorado.edu>
4208 4214
4209 4215 * IPython/iplib.py (InteractiveShell.handle_shell_assign): Added
4210 4216 new functionality, to automagically assign the result of a shell
4211 4217 command to a variable. I'll solicit some community feedback on
4212 4218 this before making it permanent.
4213 4219
4214 4220 * IPython/OInspect.py (Inspector.pinfo): Fix crash when info was
4215 4221 requested about callables for which inspect couldn't obtain a
4216 4222 proper argspec. Thanks to a crash report sent by Etienne
4217 4223 Posthumus <etienne-AT-apple01.cs.vu.nl>.
4218 4224
4219 4225 2003-12-09 Fernando Perez <fperez@colorado.edu>
4220 4226
4221 4227 * IPython/genutils.py (page): patch for the pager to work across
4222 4228 various versions of Windows. By Gary Bishop.
4223 4229
4224 4230 2003-12-04 Fernando Perez <fperez@colorado.edu>
4225 4231
4226 4232 * IPython/Gnuplot2.py (PlotItems): Fixes for working with
4227 4233 Gnuplot.py version 1.7, whose internal names changed quite a bit.
4228 4234 While I tested this and it looks ok, there may still be corner
4229 4235 cases I've missed.
4230 4236
4231 4237 2003-12-01 Fernando Perez <fperez@colorado.edu>
4232 4238
4233 4239 * IPython/iplib.py (InteractiveShell._prefilter): Fixed a bug
4234 4240 where a line like 'p,q=1,2' would fail because the automagic
4235 4241 system would be triggered for @p.
4236 4242
4237 4243 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): Tab-related
4238 4244 cleanups, code unmodified.
4239 4245
4240 4246 * IPython/genutils.py (Term): added a class for IPython to handle
4241 4247 output. In most cases it will just be a proxy for stdout/err, but
4242 4248 having this allows modifications to be made for some platforms,
4243 4249 such as handling color escapes under Windows. All of this code
4244 4250 was contributed by Gary Bishop, with minor modifications by me.
4245 4251 The actual changes affect many files.
4246 4252
4247 4253 2003-11-30 Fernando Perez <fperez@colorado.edu>
4248 4254
4249 4255 * IPython/iplib.py (file_matches): new completion code, courtesy
4250 4256 of Jeff Collins. This enables filename completion again under
4251 4257 python 2.3, which disabled it at the C level.
4252 4258
4253 4259 2003-11-11 Fernando Perez <fperez@colorado.edu>
4254 4260
4255 4261 * IPython/numutils.py (amap): Added amap() fn. Simple shorthand
4256 4262 for Numeric.array(map(...)), but often convenient.
4257 4263
4258 4264 2003-11-05 Fernando Perez <fperez@colorado.edu>
4259 4265
4260 4266 * IPython/numutils.py (frange): Changed a call from int() to
4261 4267 int(round()) to prevent a problem reported with arange() in the
4262 4268 numpy list.
4263 4269
4264 4270 2003-10-06 Fernando Perez <fperez@colorado.edu>
4265 4271
4266 4272 * IPython/DPyGetOpt.py (DPyGetOpt.processArguments): changed to
4267 4273 prevent crashes if sys lacks an argv attribute (it happens with
4268 4274 embedded interpreters which build a bare-bones sys module).
4269 4275 Thanks to a report/bugfix by Adam Hupp <hupp-AT-cs.wisc.edu>.
4270 4276
4271 4277 2003-09-24 Fernando Perez <fperez@colorado.edu>
4272 4278
4273 4279 * IPython/Magic.py (Magic._ofind): blanket except around getattr()
4274 4280 to protect against poorly written user objects where __getattr__
4275 4281 raises exceptions other than AttributeError. Thanks to a bug
4276 4282 report by Oliver Sander <osander-AT-gmx.de>.
4277 4283
4278 4284 * IPython/FakeModule.py (FakeModule.__repr__): this method was
4279 4285 missing. Thanks to bug report by Ralf Schmitt <ralf-AT-brainbot.com>.
4280 4286
4281 4287 2003-09-09 Fernando Perez <fperez@colorado.edu>
4282 4288
4283 4289 * IPython/iplib.py (InteractiveShell._prefilter): fix bug where
4284 4290 unpacking a list whith a callable as first element would
4285 4291 mistakenly trigger autocalling. Thanks to a bug report by Jeffery
4286 4292 Collins.
4287 4293
4288 4294 2003-08-25 *** Released version 0.5.0
4289 4295
4290 4296 2003-08-22 Fernando Perez <fperez@colorado.edu>
4291 4297
4292 4298 * IPython/ultraTB.py (VerboseTB.linereader): Improved handling of
4293 4299 improperly defined user exceptions. Thanks to feedback from Mark
4294 4300 Russell <mrussell-AT-verio.net>.
4295 4301
4296 4302 2003-08-20 Fernando Perez <fperez@colorado.edu>
4297 4303
4298 4304 * IPython/OInspect.py (Inspector.pinfo): changed String Form
4299 4305 printing so that it would print multi-line string forms starting
4300 4306 with a new line. This way the formatting is better respected for
4301 4307 objects which work hard to make nice string forms.
4302 4308
4303 4309 * IPython/iplib.py (InteractiveShell.handle_auto): Fix bug where
4304 4310 autocall would overtake data access for objects with both
4305 4311 __getitem__ and __call__.
4306 4312
4307 4313 2003-08-19 *** Released version 0.5.0-rc1
4308 4314
4309 4315 2003-08-19 Fernando Perez <fperez@colorado.edu>
4310 4316
4311 4317 * IPython/deep_reload.py (load_tail): single tiny change here
4312 4318 seems to fix the long-standing bug of dreload() failing to work
4313 4319 for dotted names. But this module is pretty tricky, so I may have
4314 4320 missed some subtlety. Needs more testing!.
4315 4321
4316 4322 * IPython/ultraTB.py (VerboseTB.linereader): harden against user
4317 4323 exceptions which have badly implemented __str__ methods.
4318 4324 (VerboseTB.text): harden against inspect.getinnerframes crashing,
4319 4325 which I've been getting reports about from Python 2.3 users. I
4320 4326 wish I had a simple test case to reproduce the problem, so I could
4321 4327 either write a cleaner workaround or file a bug report if
4322 4328 necessary.
4323 4329
4324 4330 * IPython/Magic.py (Magic.magic_edit): fixed bug where after
4325 4331 making a class 'foo', file 'foo.py' couldn't be edited. Thanks to
4326 4332 a bug report by Tjabo Kloppenburg.
4327 4333
4328 4334 * IPython/ultraTB.py (VerboseTB.debugger): hardened against pdb
4329 4335 crashes. Wrapped the pdb call in a blanket try/except, since pdb
4330 4336 seems rather unstable. Thanks to a bug report by Tjabo
4331 4337 Kloppenburg <tjabo.kloppenburg-AT-unix-ag.uni-siegen.de>.
4332 4338
4333 4339 * IPython/Release.py (version): release 0.5.0-rc1. I want to put
4334 4340 this out soon because of the critical fixes in the inner loop for
4335 4341 generators.
4336 4342
4337 4343 * IPython/Magic.py (Magic.getargspec): removed. This (and
4338 4344 _get_def) have been obsoleted by OInspect for a long time, I
4339 4345 hadn't noticed that they were dead code.
4340 4346 (Magic._ofind): restored _ofind functionality for a few literals
4341 4347 (those in ["''",'""','[]','{}','()']). But it won't work anymore
4342 4348 for things like "hello".capitalize?, since that would require a
4343 4349 potentially dangerous eval() again.
4344 4350
4345 4351 * IPython/iplib.py (InteractiveShell._prefilter): reorganized the
4346 4352 logic a bit more to clean up the escapes handling and minimize the
4347 4353 use of _ofind to only necessary cases. The interactive 'feel' of
4348 4354 IPython should have improved quite a bit with the changes in
4349 4355 _prefilter and _ofind (besides being far safer than before).
4350 4356
4351 4357 * IPython/Magic.py (Magic.magic_edit): Fixed old bug (but rather
4352 4358 obscure, never reported). Edit would fail to find the object to
4353 4359 edit under some circumstances.
4354 4360 (Magic._ofind): CRITICAL FIX. Finally removed the eval() calls
4355 4361 which were causing double-calling of generators. Those eval calls
4356 4362 were _very_ dangerous, since code with side effects could be
4357 4363 triggered. As they say, 'eval is evil'... These were the
4358 4364 nastiest evals in IPython. Besides, _ofind is now far simpler,
4359 4365 and it should also be quite a bit faster. Its use of inspect is
4360 4366 also safer, so perhaps some of the inspect-related crashes I've
4361 4367 seen lately with Python 2.3 might be taken care of. That will
4362 4368 need more testing.
4363 4369
4364 4370 2003-08-17 Fernando Perez <fperez@colorado.edu>
4365 4371
4366 4372 * IPython/iplib.py (InteractiveShell._prefilter): significant
4367 4373 simplifications to the logic for handling user escapes. Faster
4368 4374 and simpler code.
4369 4375
4370 4376 2003-08-14 Fernando Perez <fperez@colorado.edu>
4371 4377
4372 4378 * IPython/numutils.py (sum_flat): rewrote to be non-recursive.
4373 4379 Now it requires O(N) storage (N=size(a)) for non-contiguous input,
4374 4380 but it should be quite a bit faster. And the recursive version
4375 4381 generated O(log N) intermediate storage for all rank>1 arrays,
4376 4382 even if they were contiguous.
4377 4383 (l1norm): Added this function.
4378 4384 (norm): Added this function for arbitrary norms (including
4379 4385 l-infinity). l1 and l2 are still special cases for convenience
4380 4386 and speed.
4381 4387
4382 4388 2003-08-03 Fernando Perez <fperez@colorado.edu>
4383 4389
4384 4390 * IPython/Magic.py (Magic.magic_edit): Removed all remaining string
4385 4391 exceptions, which now raise PendingDeprecationWarnings in Python
4386 4392 2.3. There were some in Magic and some in Gnuplot2.
4387 4393
4388 4394 2003-06-30 Fernando Perez <fperez@colorado.edu>
4389 4395
4390 4396 * IPython/genutils.py (page): modified to call curses only for
4391 4397 terminals where TERM=='xterm'. After problems under many other
4392 4398 terminals were reported by Keith Beattie <KSBeattie-AT-lbl.gov>.
4393 4399
4394 4400 * IPython/iplib.py (complete): removed spurious 'print "IE"' which
4395 4401 would be triggered when readline was absent. This was just an old
4396 4402 debugging statement I'd forgotten to take out.
4397 4403
4398 4404 2003-06-20 Fernando Perez <fperez@colorado.edu>
4399 4405
4400 4406 * IPython/genutils.py (clock): modified to return only user time
4401 4407 (not counting system time), after a discussion on scipy. While
4402 4408 system time may be a useful quantity occasionally, it may much
4403 4409 more easily be skewed by occasional swapping or other similar
4404 4410 activity.
4405 4411
4406 4412 2003-06-05 Fernando Perez <fperez@colorado.edu>
4407 4413
4408 4414 * IPython/numutils.py (identity): new function, for building
4409 4415 arbitrary rank Kronecker deltas (mostly backwards compatible with
4410 4416 Numeric.identity)
4411 4417
4412 4418 2003-06-03 Fernando Perez <fperez@colorado.edu>
4413 4419
4414 4420 * IPython/iplib.py (InteractiveShell.handle_magic): protect
4415 4421 arguments passed to magics with spaces, to allow trailing '\' to
4416 4422 work normally (mainly for Windows users).
4417 4423
4418 4424 2003-05-29 Fernando Perez <fperez@colorado.edu>
4419 4425
4420 4426 * IPython/ipmaker.py (make_IPython): Load site._Helper() as help
4421 4427 instead of pydoc.help. This fixes a bizarre behavior where
4422 4428 printing '%s' % locals() would trigger the help system. Now
4423 4429 ipython behaves like normal python does.
4424 4430
4425 4431 Note that if one does 'from pydoc import help', the bizarre
4426 4432 behavior returns, but this will also happen in normal python, so
4427 4433 it's not an ipython bug anymore (it has to do with how pydoc.help
4428 4434 is implemented).
4429 4435
4430 4436 2003-05-22 Fernando Perez <fperez@colorado.edu>
4431 4437
4432 4438 * IPython/FlexCompleter.py (Completer.attr_matches): fixed to
4433 4439 return [] instead of None when nothing matches, also match to end
4434 4440 of line. Patch by Gary Bishop.
4435 4441
4436 4442 * IPython/ipmaker.py (make_IPython): Added same sys.excepthook
4437 4443 protection as before, for files passed on the command line. This
4438 4444 prevents the CrashHandler from kicking in if user files call into
4439 4445 sys.excepthook (such as PyQt and WxWindows have a nasty habit of
4440 4446 doing). After a report by Kasper Souren <Kasper.Souren-AT-ircam.fr>
4441 4447
4442 4448 2003-05-20 *** Released version 0.4.0
4443 4449
4444 4450 2003-05-20 Fernando Perez <fperez@colorado.edu>
4445 4451
4446 4452 * setup.py: added support for manpages. It's a bit hackish b/c of
4447 4453 a bug in the way the bdist_rpm distutils target handles gzipped
4448 4454 manpages, but it works. After a patch by Jack.
4449 4455
4450 4456 2003-05-19 Fernando Perez <fperez@colorado.edu>
4451 4457
4452 4458 * IPython/numutils.py: added a mockup of the kinds module, since
4453 4459 it was recently removed from Numeric. This way, numutils will
4454 4460 work for all users even if they are missing kinds.
4455 4461
4456 4462 * IPython/Magic.py (Magic._ofind): Harden against an inspect
4457 4463 failure, which can occur with SWIG-wrapped extensions. After a
4458 4464 crash report from Prabhu.
4459 4465
4460 4466 2003-05-16 Fernando Perez <fperez@colorado.edu>
4461 4467
4462 4468 * IPython/iplib.py (InteractiveShell.excepthook): New method to
4463 4469 protect ipython from user code which may call directly
4464 4470 sys.excepthook (this looks like an ipython crash to the user, even
4465 4471 when it isn't). After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4466 4472 This is especially important to help users of WxWindows, but may
4467 4473 also be useful in other cases.
4468 4474
4469 4475 * IPython/ultraTB.py (AutoFormattedTB.__call__): Changed to allow
4470 4476 an optional tb_offset to be specified, and to preserve exception
4471 4477 info if given. After a patch by Gary Bishop <gb-AT-cs.unc.edu>.
4472 4478
4473 4479 * ipython.1 (Default): Thanks to Jack's work, we now have manpages!
4474 4480
4475 4481 2003-05-15 Fernando Perez <fperez@colorado.edu>
4476 4482
4477 4483 * IPython/iplib.py (InteractiveShell.user_setup): Fix crash when
4478 4484 installing for a new user under Windows.
4479 4485
4480 4486 2003-05-12 Fernando Perez <fperez@colorado.edu>
4481 4487
4482 4488 * IPython/iplib.py (InteractiveShell.handle_emacs): New line
4483 4489 handler for Emacs comint-based lines. Currently it doesn't do
4484 4490 much (but importantly, it doesn't update the history cache). In
4485 4491 the future it may be expanded if Alex needs more functionality
4486 4492 there.
4487 4493
4488 4494 * IPython/CrashHandler.py (CrashHandler.__call__): Added platform
4489 4495 info to crash reports.
4490 4496
4491 4497 * IPython/iplib.py (InteractiveShell.mainloop): Added -c option,
4492 4498 just like Python's -c. Also fixed crash with invalid -color
4493 4499 option value at startup. Thanks to Will French
4494 4500 <wfrench-AT-bestweb.net> for the bug report.
4495 4501
4496 4502 2003-05-09 Fernando Perez <fperez@colorado.edu>
4497 4503
4498 4504 * IPython/genutils.py (EvalDict.__getitem__): Renamed EvalString
4499 4505 to EvalDict (it's a mapping, after all) and simplified its code
4500 4506 quite a bit, after a nice discussion on c.l.py where Gustavo
4501 4507 CΓ³rdova <gcordova-AT-sismex.com> suggested the new version.
4502 4508
4503 4509 2003-04-30 Fernando Perez <fperez@colorado.edu>
4504 4510
4505 4511 * IPython/genutils.py (timings_out): modified it to reduce its
4506 4512 overhead in the common reps==1 case.
4507 4513
4508 4514 2003-04-29 Fernando Perez <fperez@colorado.edu>
4509 4515
4510 4516 * IPython/genutils.py (timings_out): Modified to use the resource
4511 4517 module, which avoids the wraparound problems of time.clock().
4512 4518
4513 4519 2003-04-17 *** Released version 0.2.15pre4
4514 4520
4515 4521 2003-04-17 Fernando Perez <fperez@colorado.edu>
4516 4522
4517 4523 * setup.py (scriptfiles): Split windows-specific stuff over to a
4518 4524 separate file, in an attempt to have a Windows GUI installer.
4519 4525 That didn't work, but part of the groundwork is done.
4520 4526
4521 4527 * IPython/UserConfig/ipythonrc: Added M-i, M-o and M-I for
4522 4528 indent/unindent with 4 spaces. Particularly useful in combination
4523 4529 with the new auto-indent option.
4524 4530
4525 4531 2003-04-16 Fernando Perez <fperez@colorado.edu>
4526 4532
4527 4533 * IPython/Magic.py: various replacements of self.rc for
4528 4534 self.shell.rc. A lot more remains to be done to fully disentangle
4529 4535 this class from the main Shell class.
4530 4536
4531 4537 * IPython/GnuplotRuntime.py: added checks for mouse support so
4532 4538 that we don't try to enable it if the current gnuplot doesn't
4533 4539 really support it. Also added checks so that we don't try to
4534 4540 enable persist under Windows (where Gnuplot doesn't recognize the
4535 4541 option).
4536 4542
4537 4543 * IPython/iplib.py (InteractiveShell.interact): Added optional
4538 4544 auto-indenting code, after a patch by King C. Shu
4539 4545 <kingshu-AT-myrealbox.com>. It's off by default because it doesn't
4540 4546 get along well with pasting indented code. If I ever figure out
4541 4547 how to make that part go well, it will become on by default.
4542 4548
4543 4549 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixed bug which would
4544 4550 crash ipython if there was an unmatched '%' in the user's prompt
4545 4551 string. Reported by Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4546 4552
4547 4553 * IPython/iplib.py (InteractiveShell.interact): removed the
4548 4554 ability to ask the user whether he wants to crash or not at the
4549 4555 'last line' exception handler. Calling functions at that point
4550 4556 changes the stack, and the error reports would have incorrect
4551 4557 tracebacks.
4552 4558
4553 4559 * IPython/Magic.py (Magic.magic_page): Added new @page magic, to
4554 4560 pass through a peger a pretty-printed form of any object. After a
4555 4561 contribution by Olivier Aubert <oaubert-AT-bat710.univ-lyon1.fr>
4556 4562
4557 4563 2003-04-14 Fernando Perez <fperez@colorado.edu>
4558 4564
4559 4565 * IPython/iplib.py (InteractiveShell.user_setup): Fixed bug where
4560 4566 all files in ~ would be modified at first install (instead of
4561 4567 ~/.ipython). This could be potentially disastrous, as the
4562 4568 modification (make line-endings native) could damage binary files.
4563 4569
4564 4570 2003-04-10 Fernando Perez <fperez@colorado.edu>
4565 4571
4566 4572 * IPython/iplib.py (InteractiveShell.handle_help): Modified to
4567 4573 handle only lines which are invalid python. This now means that
4568 4574 lines like 'x=1 #?' execute properly. Thanks to Jeffery Collins
4569 4575 for the bug report.
4570 4576
4571 4577 2003-04-01 Fernando Perez <fperez@colorado.edu>
4572 4578
4573 4579 * IPython/iplib.py (InteractiveShell.showtraceback): Fixed bug
4574 4580 where failing to set sys.last_traceback would crash pdb.pm().
4575 4581 Thanks to Jeffery D. Collins <Jeff.Collins-AT-vexcel.com> for the bug
4576 4582 report.
4577 4583
4578 4584 2003-03-25 Fernando Perez <fperez@colorado.edu>
4579 4585
4580 4586 * IPython/Magic.py (Magic.magic_prun): rstrip() output of profiler
4581 4587 before printing it (it had a lot of spurious blank lines at the
4582 4588 end).
4583 4589
4584 4590 * IPython/Gnuplot2.py (Gnuplot.hardcopy): fixed bug where lpr
4585 4591 output would be sent 21 times! Obviously people don't use this
4586 4592 too often, or I would have heard about it.
4587 4593
4588 4594 2003-03-24 Fernando Perez <fperez@colorado.edu>
4589 4595
4590 4596 * setup.py (scriptfiles): renamed the data_files parameter from
4591 4597 'base' to 'data' to fix rpm build issues. Thanks to Ralf Ahlbrink
4592 4598 for the patch.
4593 4599
4594 4600 2003-03-20 Fernando Perez <fperez@colorado.edu>
4595 4601
4596 4602 * IPython/genutils.py (error): added error() and fatal()
4597 4603 functions.
4598 4604
4599 4605 2003-03-18 *** Released version 0.2.15pre3
4600 4606
4601 4607 2003-03-18 Fernando Perez <fperez@colorado.edu>
4602 4608
4603 4609 * setupext/install_data_ext.py
4604 4610 (install_data_ext.initialize_options): Class contributed by Jack
4605 4611 Moffit for fixing the old distutils hack. He is sending this to
4606 4612 the distutils folks so in the future we may not need it as a
4607 4613 private fix.
4608 4614
4609 4615 * MANIFEST.in: Extensive reorganization, based on Jack Moffit's
4610 4616 changes for Debian packaging. See his patch for full details.
4611 4617 The old distutils hack of making the ipythonrc* files carry a
4612 4618 bogus .py extension is gone, at last. Examples were moved to a
4613 4619 separate subdir under doc/, and the separate executable scripts
4614 4620 now live in their own directory. Overall a great cleanup. The
4615 4621 manual was updated to use the new files, and setup.py has been
4616 4622 fixed for this setup.
4617 4623
4618 4624 * IPython/PyColorize.py (Parser.usage): made non-executable and
4619 4625 created a pycolor wrapper around it to be included as a script.
4620 4626
4621 4627 2003-03-12 *** Released version 0.2.15pre2
4622 4628
4623 4629 2003-03-12 Fernando Perez <fperez@colorado.edu>
4624 4630
4625 4631 * IPython/ColorANSI.py (make_color_table): Finally fixed the
4626 4632 long-standing problem with garbage characters in some terminals.
4627 4633 The issue was really that the \001 and \002 escapes must _only_ be
4628 4634 passed to input prompts (which call readline), but _never_ to
4629 4635 normal text to be printed on screen. I changed ColorANSI to have
4630 4636 two classes: TermColors and InputTermColors, each with the
4631 4637 appropriate escapes for input prompts or normal text. The code in
4632 4638 Prompts.py got slightly more complicated, but this very old and
4633 4639 annoying bug is finally fixed.
4634 4640
4635 4641 All the credit for nailing down the real origin of this problem
4636 4642 and the correct solution goes to Jack Moffit <jack-AT-xiph.org>.
4637 4643 *Many* thanks to him for spending quite a bit of effort on this.
4638 4644
4639 4645 2003-03-05 *** Released version 0.2.15pre1
4640 4646
4641 4647 2003-03-03 Fernando Perez <fperez@colorado.edu>
4642 4648
4643 4649 * IPython/FakeModule.py: Moved the former _FakeModule to a
4644 4650 separate file, because it's also needed by Magic (to fix a similar
4645 4651 pickle-related issue in @run).
4646 4652
4647 4653 2003-03-02 Fernando Perez <fperez@colorado.edu>
4648 4654
4649 4655 * IPython/Magic.py (Magic.magic_autocall): new magic to control
4650 4656 the autocall option at runtime.
4651 4657 (Magic.magic_dhist): changed self.user_ns to self.shell.user_ns
4652 4658 across Magic.py to start separating Magic from InteractiveShell.
4653 4659 (Magic._ofind): Fixed to return proper namespace for dotted
4654 4660 names. Before, a dotted name would always return 'not currently
4655 4661 defined', because it would find the 'parent'. s.x would be found,
4656 4662 but since 'x' isn't defined by itself, it would get confused.
4657 4663 (Magic.magic_run): Fixed pickling problems reported by Ralf
4658 4664 Ahlbrink <RAhlbrink-AT-RosenInspection.net>. The fix was similar to
4659 4665 that I'd used when Mike Heeter reported similar issues at the
4660 4666 top-level, but now for @run. It boils down to injecting the
4661 4667 namespace where code is being executed with something that looks
4662 4668 enough like a module to fool pickle.dump(). Since a pickle stores
4663 4669 a named reference to the importing module, we need this for
4664 4670 pickles to save something sensible.
4665 4671
4666 4672 * IPython/ipmaker.py (make_IPython): added an autocall option.
4667 4673
4668 4674 * IPython/iplib.py (InteractiveShell._prefilter): reordered all of
4669 4675 the auto-eval code. Now autocalling is an option, and the code is
4670 4676 also vastly safer. There is no more eval() involved at all.
4671 4677
4672 4678 2003-03-01 Fernando Perez <fperez@colorado.edu>
4673 4679
4674 4680 * IPython/Magic.py (Magic._ofind): Changed interface to return a
4675 4681 dict with named keys instead of a tuple.
4676 4682
4677 4683 * IPython: Started using CVS for IPython as of 0.2.15pre1.
4678 4684
4679 4685 * setup.py (make_shortcut): Fixed message about directories
4680 4686 created during Windows installation (the directories were ok, just
4681 4687 the printed message was misleading). Thanks to Chris Liechti
4682 4688 <cliechti-AT-gmx.net> for the heads up.
4683 4689
4684 4690 2003-02-21 Fernando Perez <fperez@colorado.edu>
4685 4691
4686 4692 * IPython/iplib.py (InteractiveShell._prefilter): Fixed catching
4687 4693 of ValueError exception when checking for auto-execution. This
4688 4694 one is raised by things like Numeric arrays arr.flat when the
4689 4695 array is non-contiguous.
4690 4696
4691 4697 2003-01-31 Fernando Perez <fperez@colorado.edu>
4692 4698
4693 4699 * IPython/genutils.py (SystemExec.bq): Fixed bug where bq would
4694 4700 not return any value at all (even though the command would get
4695 4701 executed).
4696 4702 (xsys): Flush stdout right after printing the command to ensure
4697 4703 proper ordering of commands and command output in the total
4698 4704 output.
4699 4705 (SystemExec/xsys/bq): Switched the names of xsys/bq and
4700 4706 system/getoutput as defaults. The old ones are kept for
4701 4707 compatibility reasons, so no code which uses this library needs
4702 4708 changing.
4703 4709
4704 4710 2003-01-27 *** Released version 0.2.14
4705 4711
4706 4712 2003-01-25 Fernando Perez <fperez@colorado.edu>
4707 4713
4708 4714 * IPython/Magic.py (Magic.magic_edit): Fixed problem where
4709 4715 functions defined in previous edit sessions could not be re-edited
4710 4716 (because the temp files were immediately removed). Now temp files
4711 4717 are removed only at IPython's exit.
4712 4718 (Magic.magic_run): Improved @run to perform shell-like expansions
4713 4719 on its arguments (~users and $VARS). With this, @run becomes more
4714 4720 like a normal command-line.
4715 4721
4716 4722 * IPython/Shell.py (IPShellEmbed.__call__): Fixed a bunch of small
4717 4723 bugs related to embedding and cleaned up that code. A fairly
4718 4724 important one was the impossibility to access the global namespace
4719 4725 through the embedded IPython (only local variables were visible).
4720 4726
4721 4727 2003-01-14 Fernando Perez <fperez@colorado.edu>
4722 4728
4723 4729 * IPython/iplib.py (InteractiveShell._prefilter): Fixed
4724 4730 auto-calling to be a bit more conservative. Now it doesn't get
4725 4731 triggered if any of '!=()<>' are in the rest of the input line, to
4726 4732 allow comparing callables. Thanks to Alex for the heads up.
4727 4733
4728 4734 2003-01-07 Fernando Perez <fperez@colorado.edu>
4729 4735
4730 4736 * IPython/genutils.py (page): fixed estimation of the number of
4731 4737 lines in a string to be paged to simply count newlines. This
4732 4738 prevents over-guessing due to embedded escape sequences. A better
4733 4739 long-term solution would involve stripping out the control chars
4734 4740 for the count, but it's potentially so expensive I just don't
4735 4741 think it's worth doing.
4736 4742
4737 4743 2002-12-19 *** Released version 0.2.14pre50
4738 4744
4739 4745 2002-12-19 Fernando Perez <fperez@colorado.edu>
4740 4746
4741 4747 * tools/release (version): Changed release scripts to inform
4742 4748 Andrea and build a NEWS file with a list of recent changes.
4743 4749
4744 4750 * IPython/ColorANSI.py (__all__): changed terminal detection
4745 4751 code. Seems to work better for xterms without breaking
4746 4752 konsole. Will need more testing to determine if WinXP and Mac OSX
4747 4753 also work ok.
4748 4754
4749 4755 2002-12-18 *** Released version 0.2.14pre49
4750 4756
4751 4757 2002-12-18 Fernando Perez <fperez@colorado.edu>
4752 4758
4753 4759 * Docs: added new info about Mac OSX, from Andrea.
4754 4760
4755 4761 * IPython/Gnuplot2.py (String): Added a String PlotItem class to
4756 4762 allow direct plotting of python strings whose format is the same
4757 4763 of gnuplot data files.
4758 4764
4759 4765 2002-12-16 Fernando Perez <fperez@colorado.edu>
4760 4766
4761 4767 * IPython/iplib.py (InteractiveShell.interact): fixed default (y)
4762 4768 value of exit question to be acknowledged.
4763 4769
4764 4770 2002-12-03 Fernando Perez <fperez@colorado.edu>
4765 4771
4766 4772 * IPython/ipmaker.py: removed generators, which had been added
4767 4773 by mistake in an earlier debugging run. This was causing trouble
4768 4774 to users of python 2.1.x. Thanks to Abel Daniel <abli-AT-freemail.hu>
4769 4775 for pointing this out.
4770 4776
4771 4777 2002-11-17 Fernando Perez <fperez@colorado.edu>
4772 4778
4773 4779 * Manual: updated the Gnuplot section.
4774 4780
4775 4781 * IPython/GnuplotRuntime.py: refactored a lot all this code, with
4776 4782 a much better split of what goes in Runtime and what goes in
4777 4783 Interactive.
4778 4784
4779 4785 * IPython/ipmaker.py: fixed bug where import_fail_info wasn't
4780 4786 being imported from iplib.
4781 4787
4782 4788 * IPython/GnuplotInteractive.py (magic_gpc): renamed @gp to @gpc
4783 4789 for command-passing. Now the global Gnuplot instance is called
4784 4790 'gp' instead of 'g', which was really a far too fragile and
4785 4791 common name.
4786 4792
4787 4793 * IPython/Gnuplot2.py (eps_fix_bbox): added this to fix broken
4788 4794 bounding boxes generated by Gnuplot for square plots.
4789 4795
4790 4796 * IPython/genutils.py (popkey): new function added. I should
4791 4797 suggest this on c.l.py as a dict method, it seems useful.
4792 4798
4793 4799 * IPython/Gnuplot2.py (Gnuplot.plot): Overhauled plot and replot
4794 4800 to transparently handle PostScript generation. MUCH better than
4795 4801 the previous plot_eps/replot_eps (which I removed now). The code
4796 4802 is also fairly clean and well documented now (including
4797 4803 docstrings).
4798 4804
4799 4805 2002-11-13 Fernando Perez <fperez@colorado.edu>
4800 4806
4801 4807 * IPython/Magic.py (Magic.magic_edit): fixed docstring
4802 4808 (inconsistent with options).
4803 4809
4804 4810 * IPython/Gnuplot2.py (Gnuplot.hardcopy): hardcopy had been
4805 4811 manually disabled, I don't know why. Fixed it.
4806 4812 (Gnuplot._plot_eps): added new plot_eps/replot_eps to get directly
4807 4813 eps output.
4808 4814
4809 4815 2002-11-12 Fernando Perez <fperez@colorado.edu>
4810 4816
4811 4817 * IPython/genutils.py (ask_yes_no): trap EOF and ^C so that they
4812 4818 don't propagate up to caller. Fixes crash reported by François
4813 4819 Pinard.
4814 4820
4815 4821 2002-11-09 Fernando Perez <fperez@colorado.edu>
4816 4822
4817 4823 * IPython/ipmaker.py (make_IPython): fixed problem with writing
4818 4824 history file for new users.
4819 4825 (make_IPython): fixed bug where initial install would leave the
4820 4826 user running in the .ipython dir.
4821 4827 (make_IPython): fixed bug where config dir .ipython would be
4822 4828 created regardless of the given -ipythondir option. Thanks to Cory
4823 4829 Dodt <cdodt-AT-fcoe.k12.ca.us> for the bug report.
4824 4830
4825 4831 * IPython/genutils.py (ask_yes_no): new function for asking yes/no
4826 4832 type confirmations. Will need to use it in all of IPython's code
4827 4833 consistently.
4828 4834
4829 4835 * IPython/CrashHandler.py (CrashHandler.__call__): changed the
4830 4836 context to print 31 lines instead of the default 5. This will make
4831 4837 the crash reports extremely detailed in case the problem is in
4832 4838 libraries I don't have access to.
4833 4839
4834 4840 * IPython/iplib.py (InteractiveShell.interact): changed the 'last
4835 4841 line of defense' code to still crash, but giving users fair
4836 4842 warning. I don't want internal errors to go unreported: if there's
4837 4843 an internal problem, IPython should crash and generate a full
4838 4844 report.
4839 4845
4840 4846 2002-11-08 Fernando Perez <fperez@colorado.edu>
4841 4847
4842 4848 * IPython/iplib.py (InteractiveShell.interact): added code to trap
4843 4849 otherwise uncaught exceptions which can appear if people set
4844 4850 sys.stdout to something badly broken. Thanks to a crash report
4845 4851 from henni-AT-mail.brainbot.com.
4846 4852
4847 4853 2002-11-04 Fernando Perez <fperez@colorado.edu>
4848 4854
4849 4855 * IPython/iplib.py (InteractiveShell.interact): added
4850 4856 __IPYTHON__active to the builtins. It's a flag which goes on when
4851 4857 the interaction starts and goes off again when it stops. This
4852 4858 allows embedding code to detect being inside IPython. Before this
4853 4859 was done via __IPYTHON__, but that only shows that an IPython
4854 4860 instance has been created.
4855 4861
4856 4862 * IPython/Magic.py (Magic.magic_env): I realized that in a
4857 4863 UserDict, instance.data holds the data as a normal dict. So I
4858 4864 modified @env to return os.environ.data instead of rebuilding a
4859 4865 dict by hand.
4860 4866
4861 4867 2002-11-02 Fernando Perez <fperez@colorado.edu>
4862 4868
4863 4869 * IPython/genutils.py (warn): changed so that level 1 prints no
4864 4870 header. Level 2 is now the default (with 'WARNING' header, as
4865 4871 before). I think I tracked all places where changes were needed in
4866 4872 IPython, but outside code using the old level numbering may have
4867 4873 broken.
4868 4874
4869 4875 * IPython/iplib.py (InteractiveShell.runcode): added this to
4870 4876 handle the tracebacks in SystemExit traps correctly. The previous
4871 4877 code (through interact) was printing more of the stack than
4872 4878 necessary, showing IPython internal code to the user.
4873 4879
4874 4880 * IPython/UserConfig/ipythonrc.py: Made confirm_exit 1 by
4875 4881 default. Now that the default at the confirmation prompt is yes,
4876 4882 it's not so intrusive. François' argument that ipython sessions
4877 4883 tend to be complex enough not to lose them from an accidental C-d,
4878 4884 is a valid one.
4879 4885
4880 4886 * IPython/iplib.py (InteractiveShell.interact): added a
4881 4887 showtraceback() call to the SystemExit trap, and modified the exit
4882 4888 confirmation to have yes as the default.
4883 4889
4884 4890 * IPython/UserConfig/ipythonrc.py: removed 'session' option from
4885 4891 this file. It's been gone from the code for a long time, this was
4886 4892 simply leftover junk.
4887 4893
4888 4894 2002-11-01 Fernando Perez <fperez@colorado.edu>
4889 4895
4890 4896 * IPython/UserConfig/ipythonrc.py: new confirm_exit option
4891 4897 added. If set, IPython now traps EOF and asks for
4892 4898 confirmation. After a request by François Pinard.
4893 4899
4894 4900 * IPython/Magic.py (Magic.magic_Exit): New @Exit and @Quit instead
4895 4901 of @abort, and with a new (better) mechanism for handling the
4896 4902 exceptions.
4897 4903
4898 4904 2002-10-27 Fernando Perez <fperez@colorado.edu>
4899 4905
4900 4906 * IPython/usage.py (__doc__): updated the --help information and
4901 4907 the ipythonrc file to indicate that -log generates
4902 4908 ./ipython.log. Also fixed the corresponding info in @logstart.
4903 4909 This and several other fixes in the manuals thanks to reports by
4904 4910 François Pinard <pinard-AT-iro.umontreal.ca>.
4905 4911
4906 4912 * IPython/Logger.py (Logger.switch_log): Fixed error message to
4907 4913 refer to @logstart (instead of @log, which doesn't exist).
4908 4914
4909 4915 * IPython/iplib.py (InteractiveShell._prefilter): fixed
4910 4916 AttributeError crash. Thanks to Christopher Armstrong
4911 4917 <radix-AT-twistedmatrix.com> for the report/fix. This bug had been
4912 4918 introduced recently (in 0.2.14pre37) with the fix to the eval
4913 4919 problem mentioned below.
4914 4920
4915 4921 2002-10-17 Fernando Perez <fperez@colorado.edu>
4916 4922
4917 4923 * IPython/ConfigLoader.py (ConfigLoader.load): Fixes for Windows
4918 4924 installation. Thanks to Leonardo Santagada <retype-AT-terra.com.br>.
4919 4925
4920 4926 * IPython/iplib.py (InteractiveShell._prefilter): Many changes to
4921 4927 this function to fix a problem reported by Alex Schmolck. He saw
4922 4928 it with list comprehensions and generators, which were getting
4923 4929 called twice. The real problem was an 'eval' call in testing for
4924 4930 automagic which was evaluating the input line silently.
4925 4931
4926 4932 This is a potentially very nasty bug, if the input has side
4927 4933 effects which must not be repeated. The code is much cleaner now,
4928 4934 without any blanket 'except' left and with a regexp test for
4929 4935 actual function names.
4930 4936
4931 4937 But an eval remains, which I'm not fully comfortable with. I just
4932 4938 don't know how to find out if an expression could be a callable in
4933 4939 the user's namespace without doing an eval on the string. However
4934 4940 that string is now much more strictly checked so that no code
4935 4941 slips by, so the eval should only happen for things that can
4936 4942 really be only function/method names.
4937 4943
4938 4944 2002-10-15 Fernando Perez <fperez@colorado.edu>
4939 4945
4940 4946 * Updated LyX to 1.2.1 so I can work on the docs again. Added Mac
4941 4947 OSX information to main manual, removed README_Mac_OSX file from
4942 4948 distribution. Also updated credits for recent additions.
4943 4949
4944 4950 2002-10-10 Fernando Perez <fperez@colorado.edu>
4945 4951
4946 4952 * README_Mac_OSX: Added a README for Mac OSX users for fixing
4947 4953 terminal-related issues. Many thanks to Andrea Riciputi
4948 4954 <andrea.riciputi-AT-libero.it> for writing it.
4949 4955
4950 4956 * IPython/UserConfig/ipythonrc.py: Fixes to various small issues,
4951 4957 thanks to Thorsten Kampe <thorsten-AT-thorstenkampe.de>.
4952 4958
4953 4959 * setup.py (make_shortcut): Fixes for Windows installation. Thanks
4954 4960 to Fredrik Kant <fredrik.kant-AT-front.com> and Syver Enstad
4955 4961 <syver-en-AT-online.no> who both submitted patches for this problem.
4956 4962
4957 4963 * IPython/iplib.py (InteractiveShell.embed_mainloop): Patch for
4958 4964 global embedding to make sure that things don't overwrite user
4959 4965 globals accidentally. Thanks to Richard <rxe-AT-renre-europe.com>
4960 4966
4961 4967 * IPython/Gnuplot2.py (gp): Patch for Gnuplot.py 1.6
4962 4968 compatibility. Thanks to Hayden Callow
4963 4969 <h.callow-AT-elec.canterbury.ac.nz>
4964 4970
4965 4971 2002-10-04 Fernando Perez <fperez@colorado.edu>
4966 4972
4967 4973 * IPython/Gnuplot2.py (PlotItem): Added 'index' option for
4968 4974 Gnuplot.File objects.
4969 4975
4970 4976 2002-07-23 Fernando Perez <fperez@colorado.edu>
4971 4977
4972 4978 * IPython/genutils.py (timing): Added timings() and timing() for
4973 4979 quick access to the most commonly needed data, the execution
4974 4980 times. Old timing() renamed to timings_out().
4975 4981
4976 4982 2002-07-18 Fernando Perez <fperez@colorado.edu>
4977 4983
4978 4984 * IPython/Shell.py (IPShellEmbed.restore_system_completer): fixed
4979 4985 bug with nested instances disrupting the parent's tab completion.
4980 4986
4981 4987 * IPython/iplib.py (all_completions): Added Alex Schmolck's
4982 4988 all_completions code to begin the emacs integration.
4983 4989
4984 4990 * IPython/Gnuplot2.py (zip_items): Added optional 'titles'
4985 4991 argument to allow titling individual arrays when plotting.
4986 4992
4987 4993 2002-07-15 Fernando Perez <fperez@colorado.edu>
4988 4994
4989 4995 * setup.py (make_shortcut): changed to retrieve the value of
4990 4996 'Program Files' directory from the registry (this value changes in
4991 4997 non-english versions of Windows). Thanks to Thomas Fanslau
4992 4998 <tfanslau-AT-gmx.de> for the report.
4993 4999
4994 5000 2002-07-10 Fernando Perez <fperez@colorado.edu>
4995 5001
4996 5002 * IPython/ultraTB.py (VerboseTB.debugger): enabled workaround for
4997 5003 a bug in pdb, which crashes if a line with only whitespace is
4998 5004 entered. Bug report submitted to sourceforge.
4999 5005
5000 5006 2002-07-09 Fernando Perez <fperez@colorado.edu>
5001 5007
5002 5008 * IPython/ultraTB.py (VerboseTB.nullrepr): fixed rare crash when
5003 5009 reporting exceptions (it's a bug in inspect.py, I just set a
5004 5010 workaround).
5005 5011
5006 5012 2002-07-08 Fernando Perez <fperez@colorado.edu>
5007 5013
5008 5014 * IPython/iplib.py (InteractiveShell.__init__): fixed reference to
5009 5015 __IPYTHON__ in __builtins__ to show up in user_ns.
5010 5016
5011 5017 2002-07-03 Fernando Perez <fperez@colorado.edu>
5012 5018
5013 5019 * IPython/GnuplotInteractive.py (magic_gp_set_default): changed
5014 5020 name from @gp_set_instance to @gp_set_default.
5015 5021
5016 5022 * IPython/ipmaker.py (make_IPython): default editor value set to
5017 5023 '0' (a string), to match the rc file. Otherwise will crash when
5018 5024 .strip() is called on it.
5019 5025
5020 5026
5021 5027 2002-06-28 Fernando Perez <fperez@colorado.edu>
5022 5028
5023 5029 * IPython/iplib.py (InteractiveShell.safe_execfile): fix importing
5024 5030 of files in current directory when a file is executed via
5025 5031 @run. Patch also by RA <ralf_ahlbrink-AT-web.de>.
5026 5032
5027 5033 * setup.py (manfiles): fix for rpm builds, submitted by RA
5028 5034 <ralf_ahlbrink-AT-web.de>. Now we have RPMs!
5029 5035
5030 5036 * IPython/ipmaker.py (make_IPython): fixed lookup of default
5031 5037 editor when set to '0'. Problem was, '0' evaluates to True (it's a
5032 5038 string!). A. Schmolck caught this one.
5033 5039
5034 5040 2002-06-27 Fernando Perez <fperez@colorado.edu>
5035 5041
5036 5042 * IPython/ipmaker.py (make_IPython): fixed bug when running user
5037 5043 defined files at the cmd line. __name__ wasn't being set to
5038 5044 __main__.
5039 5045
5040 5046 * IPython/Gnuplot2.py (zip_items): improved it so it can plot also
5041 5047 regular lists and tuples besides Numeric arrays.
5042 5048
5043 5049 * IPython/Prompts.py (CachedOutput.__call__): Added output
5044 5050 supression for input ending with ';'. Similar to Mathematica and
5045 5051 Matlab. The _* vars and Out[] list are still updated, just like
5046 5052 Mathematica behaves.
5047 5053
5048 5054 2002-06-25 Fernando Perez <fperez@colorado.edu>
5049 5055
5050 5056 * IPython/ConfigLoader.py (ConfigLoader.load): fixed checking of
5051 5057 .ini extensions for profiels under Windows.
5052 5058
5053 5059 * IPython/OInspect.py (Inspector.pinfo): improved alignment of
5054 5060 string form. Fix contributed by Alexander Schmolck
5055 5061 <a.schmolck-AT-gmx.net>
5056 5062
5057 5063 * IPython/GnuplotRuntime.py (gp_new): new function. Returns a
5058 5064 pre-configured Gnuplot instance.
5059 5065
5060 5066 2002-06-21 Fernando Perez <fperez@colorado.edu>
5061 5067
5062 5068 * IPython/numutils.py (exp_safe): new function, works around the
5063 5069 underflow problems in Numeric.
5064 5070 (log2): New fn. Safe log in base 2: returns exact integer answer
5065 5071 for exact integer powers of 2.
5066 5072
5067 5073 * IPython/Magic.py (get_py_filename): fixed it not expanding '~'
5068 5074 properly.
5069 5075
5070 5076 2002-06-20 Fernando Perez <fperez@colorado.edu>
5071 5077
5072 5078 * IPython/genutils.py (timing): new function like
5073 5079 Mathematica's. Similar to time_test, but returns more info.
5074 5080
5075 5081 2002-06-18 Fernando Perez <fperez@colorado.edu>
5076 5082
5077 5083 * IPython/Magic.py (Magic.magic_save): modified @save and @r
5078 5084 according to Mike Heeter's suggestions.
5079 5085
5080 5086 2002-06-16 Fernando Perez <fperez@colorado.edu>
5081 5087
5082 5088 * IPython/GnuplotRuntime.py: Massive overhaul to the Gnuplot
5083 5089 system. GnuplotMagic is gone as a user-directory option. New files
5084 5090 make it easier to use all the gnuplot stuff both from external
5085 5091 programs as well as from IPython. Had to rewrite part of
5086 5092 hardcopy() b/c of a strange bug: often the ps files simply don't
5087 5093 get created, and require a repeat of the command (often several
5088 5094 times).
5089 5095
5090 5096 * IPython/ultraTB.py (AutoFormattedTB.__call__): changed to
5091 5097 resolve output channel at call time, so that if sys.stderr has
5092 5098 been redirected by user this gets honored.
5093 5099
5094 5100 2002-06-13 Fernando Perez <fperez@colorado.edu>
5095 5101
5096 5102 * IPython/Shell.py (IPShell.__init__): Changed IPythonShell to
5097 5103 IPShell. Kept a copy with the old names to avoid breaking people's
5098 5104 embedded code.
5099 5105
5100 5106 * IPython/ipython: simplified it to the bare minimum after
5101 5107 Holger's suggestions. Added info about how to use it in
5102 5108 PYTHONSTARTUP.
5103 5109
5104 5110 * IPython/Shell.py (IPythonShell): changed the options passing
5105 5111 from a string with funky %s replacements to a straight list. Maybe
5106 5112 a bit more typing, but it follows sys.argv conventions, so there's
5107 5113 less special-casing to remember.
5108 5114
5109 5115 2002-06-12 Fernando Perez <fperez@colorado.edu>
5110 5116
5111 5117 * IPython/Magic.py (Magic.magic_r): new magic auto-repeat
5112 5118 command. Thanks to a suggestion by Mike Heeter.
5113 5119 (Magic.magic_pfile): added behavior to look at filenames if given
5114 5120 arg is not a defined object.
5115 5121 (Magic.magic_save): New @save function to save code snippets. Also
5116 5122 a Mike Heeter idea.
5117 5123
5118 5124 * IPython/UserConfig/GnuplotMagic.py (plot): Improvements to
5119 5125 plot() and replot(). Much more convenient now, especially for
5120 5126 interactive use.
5121 5127
5122 5128 * IPython/Magic.py (Magic.magic_run): Added .py automatically to
5123 5129 filenames.
5124 5130
5125 5131 2002-06-02 Fernando Perez <fperez@colorado.edu>
5126 5132
5127 5133 * IPython/Struct.py (Struct.__init__): modified to admit
5128 5134 initialization via another struct.
5129 5135
5130 5136 * IPython/genutils.py (SystemExec.__init__): New stateful
5131 5137 interface to xsys and bq. Useful for writing system scripts.
5132 5138
5133 5139 2002-05-30 Fernando Perez <fperez@colorado.edu>
5134 5140
5135 5141 * MANIFEST.in: Changed docfile selection to exclude all the lyx
5136 5142 documents. This will make the user download smaller (it's getting
5137 5143 too big).
5138 5144
5139 5145 2002-05-29 Fernando Perez <fperez@colorado.edu>
5140 5146
5141 5147 * IPython/iplib.py (_FakeModule.__init__): New class introduced to
5142 5148 fix problems with shelve and pickle. Seems to work, but I don't
5143 5149 know if corner cases break it. Thanks to Mike Heeter
5144 5150 <korora-AT-SDF.LONESTAR.ORG> for the bug reports and test cases.
5145 5151
5146 5152 2002-05-24 Fernando Perez <fperez@colorado.edu>
5147 5153
5148 5154 * IPython/Magic.py (Macro.__init__): fixed magics embedded in
5149 5155 macros having broken.
5150 5156
5151 5157 2002-05-21 Fernando Perez <fperez@colorado.edu>
5152 5158
5153 5159 * IPython/Magic.py (Magic.magic_logstart): fixed recently
5154 5160 introduced logging bug: all history before logging started was
5155 5161 being written one character per line! This came from the redesign
5156 5162 of the input history as a special list which slices to strings,
5157 5163 not to lists.
5158 5164
5159 5165 2002-05-20 Fernando Perez <fperez@colorado.edu>
5160 5166
5161 5167 * IPython/Prompts.py (CachedOutput.__init__): made the color table
5162 5168 be an attribute of all classes in this module. The design of these
5163 5169 classes needs some serious overhauling.
5164 5170
5165 5171 * IPython/DPyGetOpt.py (DPyGetOpt.setPosixCompliance): fixed bug
5166 5172 which was ignoring '_' in option names.
5167 5173
5168 5174 * IPython/ultraTB.py (FormattedTB.__init__): Changed
5169 5175 'Verbose_novars' to 'Context' and made it the new default. It's a
5170 5176 bit more readable and also safer than verbose.
5171 5177
5172 5178 * IPython/PyColorize.py (Parser.__call__): Fixed coloring of
5173 5179 triple-quoted strings.
5174 5180
5175 5181 * IPython/OInspect.py (__all__): new module exposing the object
5176 5182 introspection facilities. Now the corresponding magics are dummy
5177 5183 wrappers around this. Having this module will make it much easier
5178 5184 to put these functions into our modified pdb.
5179 5185 This new object inspector system uses the new colorizing module,
5180 5186 so source code and other things are nicely syntax highlighted.
5181 5187
5182 5188 2002-05-18 Fernando Perez <fperez@colorado.edu>
5183 5189
5184 5190 * IPython/ColorANSI.py: Split the coloring tools into a separate
5185 5191 module so I can use them in other code easier (they were part of
5186 5192 ultraTB).
5187 5193
5188 5194 2002-05-17 Fernando Perez <fperez@colorado.edu>
5189 5195
5190 5196 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5191 5197 fixed it to set the global 'g' also to the called instance, as
5192 5198 long as 'g' was still a gnuplot instance (so it doesn't overwrite
5193 5199 user's 'g' variables).
5194 5200
5195 5201 * IPython/iplib.py (InteractiveShell.__init__): Added In/Out
5196 5202 global variables (aliases to _ih,_oh) so that users which expect
5197 5203 In[5] or Out[7] to work aren't unpleasantly surprised.
5198 5204 (InputList.__getslice__): new class to allow executing slices of
5199 5205 input history directly. Very simple class, complements the use of
5200 5206 macros.
5201 5207
5202 5208 2002-05-16 Fernando Perez <fperez@colorado.edu>
5203 5209
5204 5210 * setup.py (docdirbase): make doc directory be just doc/IPython
5205 5211 without version numbers, it will reduce clutter for users.
5206 5212
5207 5213 * IPython/Magic.py (Magic.magic_run): Add explicit local dict to
5208 5214 execfile call to prevent possible memory leak. See for details:
5209 5215 http://mail.python.org/pipermail/python-list/2002-February/088476.html
5210 5216
5211 5217 2002-05-15 Fernando Perez <fperez@colorado.edu>
5212 5218
5213 5219 * IPython/Magic.py (Magic.magic_psource): made the object
5214 5220 introspection names be more standard: pdoc, pdef, pfile and
5215 5221 psource. They all print/page their output, and it makes
5216 5222 remembering them easier. Kept old names for compatibility as
5217 5223 aliases.
5218 5224
5219 5225 2002-05-14 Fernando Perez <fperez@colorado.edu>
5220 5226
5221 5227 * IPython/UserConfig/GnuplotMagic.py: I think I finally understood
5222 5228 what the mouse problem was. The trick is to use gnuplot with temp
5223 5229 files and NOT with pipes (for data communication), because having
5224 5230 both pipes and the mouse on is bad news.
5225 5231
5226 5232 2002-05-13 Fernando Perez <fperez@colorado.edu>
5227 5233
5228 5234 * IPython/Magic.py (Magic._ofind): fixed namespace order search
5229 5235 bug. Information would be reported about builtins even when
5230 5236 user-defined functions overrode them.
5231 5237
5232 5238 2002-05-11 Fernando Perez <fperez@colorado.edu>
5233 5239
5234 5240 * IPython/__init__.py (__all__): removed FlexCompleter from
5235 5241 __all__ so that things don't fail in platforms without readline.
5236 5242
5237 5243 2002-05-10 Fernando Perez <fperez@colorado.edu>
5238 5244
5239 5245 * IPython/__init__.py (__all__): removed numutils from __all__ b/c
5240 5246 it requires Numeric, effectively making Numeric a dependency for
5241 5247 IPython.
5242 5248
5243 5249 * Released 0.2.13
5244 5250
5245 5251 * IPython/Magic.py (Magic.magic_prun): big overhaul to the
5246 5252 profiler interface. Now all the major options from the profiler
5247 5253 module are directly supported in IPython, both for single
5248 5254 expressions (@prun) and for full programs (@run -p).
5249 5255
5250 5256 2002-05-09 Fernando Perez <fperez@colorado.edu>
5251 5257
5252 5258 * IPython/Magic.py (Magic.magic_doc): fixed to show docstrings of
5253 5259 magic properly formatted for screen.
5254 5260
5255 5261 * setup.py (make_shortcut): Changed things to put pdf version in
5256 5262 doc/ instead of doc/manual (had to change lyxport a bit).
5257 5263
5258 5264 * IPython/Magic.py (Profile.string_stats): made profile runs go
5259 5265 through pager (they are long and a pager allows searching, saving,
5260 5266 etc.)
5261 5267
5262 5268 2002-05-08 Fernando Perez <fperez@colorado.edu>
5263 5269
5264 5270 * Released 0.2.12
5265 5271
5266 5272 2002-05-06 Fernando Perez <fperez@colorado.edu>
5267 5273
5268 5274 * IPython/Magic.py (Magic.magic_hist): small bug fixed (recently
5269 5275 introduced); 'hist n1 n2' was broken.
5270 5276 (Magic.magic_pdb): added optional on/off arguments to @pdb
5271 5277 (Magic.magic_run): added option -i to @run, which executes code in
5272 5278 the IPython namespace instead of a clean one. Also added @irun as
5273 5279 an alias to @run -i.
5274 5280
5275 5281 * IPython/UserConfig/GnuplotMagic.py (magic_gp_set_instance):
5276 5282 fixed (it didn't really do anything, the namespaces were wrong).
5277 5283
5278 5284 * IPython/Debugger.py (__init__): Added workaround for python 2.1
5279 5285
5280 5286 * IPython/__init__.py (__all__): Fixed package namespace, now
5281 5287 'import IPython' does give access to IPython.<all> as
5282 5288 expected. Also renamed __release__ to Release.
5283 5289
5284 5290 * IPython/Debugger.py (__license__): created new Pdb class which
5285 5291 functions like a drop-in for the normal pdb.Pdb but does NOT
5286 5292 import readline by default. This way it doesn't muck up IPython's
5287 5293 readline handling, and now tab-completion finally works in the
5288 5294 debugger -- sort of. It completes things globally visible, but the
5289 5295 completer doesn't track the stack as pdb walks it. That's a bit
5290 5296 tricky, and I'll have to implement it later.
5291 5297
5292 5298 2002-05-05 Fernando Perez <fperez@colorado.edu>
5293 5299
5294 5300 * IPython/Magic.py (Magic.magic_oinfo): fixed formatting bug for
5295 5301 magic docstrings when printed via ? (explicit \'s were being
5296 5302 printed).
5297 5303
5298 5304 * IPython/ipmaker.py (make_IPython): fixed namespace
5299 5305 identification bug. Now variables loaded via logs or command-line
5300 5306 files are recognized in the interactive namespace by @who.
5301 5307
5302 5308 * IPython/iplib.py (InteractiveShell.safe_execfile): Fixed bug in
5303 5309 log replay system stemming from the string form of Structs.
5304 5310
5305 5311 * IPython/Magic.py (Macro.__init__): improved macros to properly
5306 5312 handle magic commands in them.
5307 5313 (Magic.magic_logstart): usernames are now expanded so 'logstart
5308 5314 ~/mylog' now works.
5309 5315
5310 5316 * IPython/iplib.py (complete): fixed bug where paths starting with
5311 5317 '/' would be completed as magic names.
5312 5318
5313 5319 2002-05-04 Fernando Perez <fperez@colorado.edu>
5314 5320
5315 5321 * IPython/Magic.py (Magic.magic_run): added options -p and -f to
5316 5322 allow running full programs under the profiler's control.
5317 5323
5318 5324 * IPython/ultraTB.py (FormattedTB.__init__): Added Verbose_novars
5319 5325 mode to report exceptions verbosely but without formatting
5320 5326 variables. This addresses the issue of ipython 'freezing' (it's
5321 5327 not frozen, but caught in an expensive formatting loop) when huge
5322 5328 variables are in the context of an exception.
5323 5329 (VerboseTB.text): Added '--->' markers at line where exception was
5324 5330 triggered. Much clearer to read, especially in NoColor modes.
5325 5331
5326 5332 * IPython/Magic.py (Magic.magic_run): bugfix: -n option had been
5327 5333 implemented in reverse when changing to the new parse_options().
5328 5334
5329 5335 2002-05-03 Fernando Perez <fperez@colorado.edu>
5330 5336
5331 5337 * IPython/Magic.py (Magic.parse_options): new function so that
5332 5338 magics can parse options easier.
5333 5339 (Magic.magic_prun): new function similar to profile.run(),
5334 5340 suggested by Chris Hart.
5335 5341 (Magic.magic_cd): fixed behavior so that it only changes if
5336 5342 directory actually is in history.
5337 5343
5338 5344 * IPython/usage.py (__doc__): added information about potential
5339 5345 slowness of Verbose exception mode when there are huge data
5340 5346 structures to be formatted (thanks to Archie Paulson).
5341 5347
5342 5348 * IPython/ipmaker.py (make_IPython): Changed default logging
5343 5349 (when simply called with -log) to use curr_dir/ipython.log in
5344 5350 rotate mode. Fixed crash which was occuring with -log before
5345 5351 (thanks to Jim Boyle).
5346 5352
5347 5353 2002-05-01 Fernando Perez <fperez@colorado.edu>
5348 5354
5349 5355 * Released 0.2.11 for these fixes (mainly the ultraTB one which
5350 5356 was nasty -- though somewhat of a corner case).
5351 5357
5352 5358 * IPython/ultraTB.py (AutoFormattedTB.text): renamed __text to
5353 5359 text (was a bug).
5354 5360
5355 5361 2002-04-30 Fernando Perez <fperez@colorado.edu>
5356 5362
5357 5363 * IPython/UserConfig/GnuplotMagic.py (magic_gp): Minor fix to add
5358 5364 a print after ^D or ^C from the user so that the In[] prompt
5359 5365 doesn't over-run the gnuplot one.
5360 5366
5361 5367 2002-04-29 Fernando Perez <fperez@colorado.edu>
5362 5368
5363 5369 * Released 0.2.10
5364 5370
5365 5371 * IPython/__release__.py (version): get date dynamically.
5366 5372
5367 5373 * Misc. documentation updates thanks to Arnd's comments. Also ran
5368 5374 a full spellcheck on the manual (hadn't been done in a while).
5369 5375
5370 5376 2002-04-27 Fernando Perez <fperez@colorado.edu>
5371 5377
5372 5378 * IPython/Magic.py (Magic.magic_logstart): Fixed bug where
5373 5379 starting a log in mid-session would reset the input history list.
5374 5380
5375 5381 2002-04-26 Fernando Perez <fperez@colorado.edu>
5376 5382
5377 5383 * IPython/iplib.py (InteractiveShell.wait): Fixed bug where not
5378 5384 all files were being included in an update. Now anything in
5379 5385 UserConfig that matches [A-Za-z]*.py will go (this excludes
5380 5386 __init__.py)
5381 5387
5382 5388 2002-04-25 Fernando Perez <fperez@colorado.edu>
5383 5389
5384 5390 * IPython/iplib.py (InteractiveShell.__init__): Added __IPYTHON__
5385 5391 to __builtins__ so that any form of embedded or imported code can
5386 5392 test for being inside IPython.
5387 5393
5388 5394 * IPython/UserConfig/GnuplotMagic.py: (magic_gp_set_instance):
5389 5395 changed to GnuplotMagic because it's now an importable module,
5390 5396 this makes the name follow that of the standard Gnuplot module.
5391 5397 GnuplotMagic can now be loaded at any time in mid-session.
5392 5398
5393 5399 2002-04-24 Fernando Perez <fperez@colorado.edu>
5394 5400
5395 5401 * IPython/numutils.py: removed SIUnits. It doesn't properly set
5396 5402 the globals (IPython has its own namespace) and the
5397 5403 PhysicalQuantity stuff is much better anyway.
5398 5404
5399 5405 * IPython/UserConfig/example-gnuplot.py (g2): Added gnuplot
5400 5406 embedding example to standard user directory for
5401 5407 distribution. Also put it in the manual.
5402 5408
5403 5409 * IPython/numutils.py (gnuplot_exec): Changed to take a gnuplot
5404 5410 instance as first argument (so it doesn't rely on some obscure
5405 5411 hidden global).
5406 5412
5407 5413 * IPython/UserConfig/ipythonrc.py: put () back in accepted
5408 5414 delimiters. While it prevents ().TAB from working, it allows
5409 5415 completions in open (... expressions. This is by far a more common
5410 5416 case.
5411 5417
5412 5418 2002-04-23 Fernando Perez <fperez@colorado.edu>
5413 5419
5414 5420 * IPython/Extensions/InterpreterPasteInput.py: new
5415 5421 syntax-processing module for pasting lines with >>> or ... at the
5416 5422 start.
5417 5423
5418 5424 * IPython/Extensions/PhysicalQ_Interactive.py
5419 5425 (PhysicalQuantityInteractive.__int__): fixed to work with either
5420 5426 Numeric or math.
5421 5427
5422 5428 * IPython/UserConfig/ipythonrc-numeric.py: reorganized the
5423 5429 provided profiles. Now we have:
5424 5430 -math -> math module as * and cmath with its own namespace.
5425 5431 -numeric -> Numeric as *, plus gnuplot & grace
5426 5432 -physics -> same as before
5427 5433
5428 5434 * IPython/Magic.py (Magic.magic_magic): Fixed bug where
5429 5435 user-defined magics wouldn't be found by @magic if they were
5430 5436 defined as class methods. Also cleaned up the namespace search
5431 5437 logic and the string building (to use %s instead of many repeated
5432 5438 string adds).
5433 5439
5434 5440 * IPython/UserConfig/example-magic.py (magic_foo): updated example
5435 5441 of user-defined magics to operate with class methods (cleaner, in
5436 5442 line with the gnuplot code).
5437 5443
5438 5444 2002-04-22 Fernando Perez <fperez@colorado.edu>
5439 5445
5440 5446 * setup.py: updated dependency list so that manual is updated when
5441 5447 all included files change.
5442 5448
5443 5449 * IPython/ipmaker.py (make_IPython): Fixed bug which was ignoring
5444 5450 the delimiter removal option (the fix is ugly right now).
5445 5451
5446 5452 * IPython/UserConfig/ipythonrc-physics.py: simplified not to load
5447 5453 all of the math profile (quicker loading, no conflict between
5448 5454 g-9.8 and g-gnuplot).
5449 5455
5450 5456 * IPython/CrashHandler.py (CrashHandler.__call__): changed default
5451 5457 name of post-mortem files to IPython_crash_report.txt.
5452 5458
5453 5459 * Cleanup/update of the docs. Added all the new readline info and
5454 5460 formatted all lists as 'real lists'.
5455 5461
5456 5462 * IPython/ipmaker.py (make_IPython): removed now-obsolete
5457 5463 tab-completion options, since the full readline parse_and_bind is
5458 5464 now accessible.
5459 5465
5460 5466 * IPython/iplib.py (InteractiveShell.init_readline): Changed
5461 5467 handling of readline options. Now users can specify any string to
5462 5468 be passed to parse_and_bind(), as well as the delimiters to be
5463 5469 removed.
5464 5470 (InteractiveShell.__init__): Added __name__ to the global
5465 5471 namespace so that things like Itpl which rely on its existence
5466 5472 don't crash.
5467 5473 (InteractiveShell._prefilter): Defined the default with a _ so
5468 5474 that prefilter() is easier to override, while the default one
5469 5475 remains available.
5470 5476
5471 5477 2002-04-18 Fernando Perez <fperez@colorado.edu>
5472 5478
5473 5479 * Added information about pdb in the docs.
5474 5480
5475 5481 2002-04-17 Fernando Perez <fperez@colorado.edu>
5476 5482
5477 5483 * IPython/ipmaker.py (make_IPython): added rc_override option to
5478 5484 allow passing config options at creation time which may override
5479 5485 anything set in the config files or command line. This is
5480 5486 particularly useful for configuring embedded instances.
5481 5487
5482 5488 2002-04-15 Fernando Perez <fperez@colorado.edu>
5483 5489
5484 5490 * IPython/Logger.py (Logger.log): Fixed a nasty bug which could
5485 5491 crash embedded instances because of the input cache falling out of
5486 5492 sync with the output counter.
5487 5493
5488 5494 * IPython/Shell.py (IPythonShellEmbed.__init__): added a debug
5489 5495 mode which calls pdb after an uncaught exception in IPython itself.
5490 5496
5491 5497 2002-04-14 Fernando Perez <fperez@colorado.edu>
5492 5498
5493 5499 * IPython/iplib.py (InteractiveShell.showtraceback): pdb mucks up
5494 5500 readline, fix it back after each call.
5495 5501
5496 5502 * IPython/ultraTB.py (AutoFormattedTB.__text): made text a private
5497 5503 method to force all access via __call__(), which guarantees that
5498 5504 traceback references are properly deleted.
5499 5505
5500 5506 * IPython/Prompts.py (CachedOutput._display): minor fixes to
5501 5507 improve printing when pprint is in use.
5502 5508
5503 5509 2002-04-13 Fernando Perez <fperez@colorado.edu>
5504 5510
5505 5511 * IPython/Shell.py (IPythonShellEmbed.__call__): SystemExit
5506 5512 exceptions aren't caught anymore. If the user triggers one, he
5507 5513 should know why he's doing it and it should go all the way up,
5508 5514 just like any other exception. So now @abort will fully kill the
5509 5515 embedded interpreter and the embedding code (unless that happens
5510 5516 to catch SystemExit).
5511 5517
5512 5518 * IPython/ultraTB.py (VerboseTB.__init__): added a call_pdb flag
5513 5519 and a debugger() method to invoke the interactive pdb debugger
5514 5520 after printing exception information. Also added the corresponding
5515 5521 -pdb option and @pdb magic to control this feature, and updated
5516 5522 the docs. After a suggestion from Christopher Hart
5517 5523 (hart-AT-caltech.edu).
5518 5524
5519 5525 2002-04-12 Fernando Perez <fperez@colorado.edu>
5520 5526
5521 5527 * IPython/Shell.py (IPythonShellEmbed.__init__): modified to use
5522 5528 the exception handlers defined by the user (not the CrashHandler)
5523 5529 so that user exceptions don't trigger an ipython bug report.
5524 5530
5525 5531 * IPython/ultraTB.py (ColorTB.__init__): made the color scheme
5526 5532 configurable (it should have always been so).
5527 5533
5528 5534 2002-03-26 Fernando Perez <fperez@colorado.edu>
5529 5535
5530 5536 * IPython/Shell.py (IPythonShellEmbed.__call__): many changes here
5531 5537 and there to fix embedding namespace issues. This should all be
5532 5538 done in a more elegant way.
5533 5539
5534 5540 2002-03-25 Fernando Perez <fperez@colorado.edu>
5535 5541
5536 5542 * IPython/genutils.py (get_home_dir): Try to make it work under
5537 5543 win9x also.
5538 5544
5539 5545 2002-03-20 Fernando Perez <fperez@colorado.edu>
5540 5546
5541 5547 * IPython/Shell.py (IPythonShellEmbed.__init__): leave
5542 5548 sys.displayhook untouched upon __init__.
5543 5549
5544 5550 2002-03-19 Fernando Perez <fperez@colorado.edu>
5545 5551
5546 5552 * Released 0.2.9 (for embedding bug, basically).
5547 5553
5548 5554 * IPython/Shell.py (IPythonShellEmbed.__call__): Trap SystemExit
5549 5555 exceptions so that enclosing shell's state can be restored.
5550 5556
5551 5557 * Changed magic_gnuplot.py to magic-gnuplot.py to standardize
5552 5558 naming conventions in the .ipython/ dir.
5553 5559
5554 5560 * IPython/iplib.py (InteractiveShell.init_readline): removed '-'
5555 5561 from delimiters list so filenames with - in them get expanded.
5556 5562
5557 5563 * IPython/Shell.py (IPythonShellEmbed.__call__): fixed bug with
5558 5564 sys.displayhook not being properly restored after an embedded call.
5559 5565
5560 5566 2002-03-18 Fernando Perez <fperez@colorado.edu>
5561 5567
5562 5568 * Released 0.2.8
5563 5569
5564 5570 * IPython/iplib.py (InteractiveShell.user_setup): fixed bug where
5565 5571 some files weren't being included in a -upgrade.
5566 5572 (InteractiveShell.init_readline): Added 'set show-all-if-ambiguous
5567 5573 on' so that the first tab completes.
5568 5574 (InteractiveShell.handle_magic): fixed bug with spaces around
5569 5575 quotes breaking many magic commands.
5570 5576
5571 5577 * setup.py: added note about ignoring the syntax error messages at
5572 5578 installation.
5573 5579
5574 5580 * IPython/UserConfig/magic_gnuplot.py (magic_gp): finished
5575 5581 streamlining the gnuplot interface, now there's only one magic @gp.
5576 5582
5577 5583 2002-03-17 Fernando Perez <fperez@colorado.edu>
5578 5584
5579 5585 * IPython/UserConfig/magic_gnuplot.py: new name for the
5580 5586 example-magic_pm.py file. Much enhanced system, now with a shell
5581 5587 for communicating directly with gnuplot, one command at a time.
5582 5588
5583 5589 * IPython/Magic.py (Magic.magic_run): added option -n to prevent
5584 5590 setting __name__=='__main__'.
5585 5591
5586 5592 * IPython/UserConfig/example-magic_pm.py (magic_pm): Added
5587 5593 mini-shell for accessing gnuplot from inside ipython. Should
5588 5594 extend it later for grace access too. Inspired by Arnd's
5589 5595 suggestion.
5590 5596
5591 5597 * IPython/iplib.py (InteractiveShell.handle_magic): fixed bug when
5592 5598 calling magic functions with () in their arguments. Thanks to Arnd
5593 5599 Baecker for pointing this to me.
5594 5600
5595 5601 * IPython/numutils.py (sum_flat): fixed bug. Would recurse
5596 5602 infinitely for integer or complex arrays (only worked with floats).
5597 5603
5598 5604 2002-03-16 Fernando Perez <fperez@colorado.edu>
5599 5605
5600 5606 * setup.py: Merged setup and setup_windows into a single script
5601 5607 which properly handles things for windows users.
5602 5608
5603 5609 2002-03-15 Fernando Perez <fperez@colorado.edu>
5604 5610
5605 5611 * Big change to the manual: now the magics are all automatically
5606 5612 documented. This information is generated from their docstrings
5607 5613 and put in a latex file included by the manual lyx file. This way
5608 5614 we get always up to date information for the magics. The manual
5609 5615 now also has proper version information, also auto-synced.
5610 5616
5611 5617 For this to work, an undocumented --magic_docstrings option was added.
5612 5618
5613 5619 2002-03-13 Fernando Perez <fperez@colorado.edu>
5614 5620
5615 5621 * IPython/ultraTB.py (TermColors): fixed problem with dark colors
5616 5622 under CDE terminals. An explicit ;2 color reset is needed in the escapes.
5617 5623
5618 5624 2002-03-12 Fernando Perez <fperez@colorado.edu>
5619 5625
5620 5626 * IPython/ultraTB.py (TermColors): changed color escapes again to
5621 5627 fix the (old, reintroduced) line-wrapping bug. Basically, if
5622 5628 \001..\002 aren't given in the color escapes, lines get wrapped
5623 5629 weirdly. But giving those screws up old xterms and emacs terms. So
5624 5630 I added some logic for emacs terms to be ok, but I can't identify old
5625 5631 xterms separately ($TERM=='xterm' for many terminals, like konsole).
5626 5632
5627 5633 2002-03-10 Fernando Perez <fperez@colorado.edu>
5628 5634
5629 5635 * IPython/usage.py (__doc__): Various documentation cleanups and
5630 5636 updates, both in usage docstrings and in the manual.
5631 5637
5632 5638 * IPython/Prompts.py (CachedOutput.set_colors): cleanups for
5633 5639 handling of caching. Set minimum acceptabe value for having a
5634 5640 cache at 20 values.
5635 5641
5636 5642 * IPython/iplib.py (InteractiveShell.user_setup): moved the
5637 5643 install_first_time function to a method, renamed it and added an
5638 5644 'upgrade' mode. Now people can update their config directory with
5639 5645 a simple command line switch (-upgrade, also new).
5640 5646
5641 5647 * IPython/Magic.py (Magic.magic_pfile): Made @pfile an alias to
5642 5648 @file (convenient for automagic users under Python >= 2.2).
5643 5649 Removed @files (it seemed more like a plural than an abbrev. of
5644 5650 'file show').
5645 5651
5646 5652 * IPython/iplib.py (install_first_time): Fixed crash if there were
5647 5653 backup files ('~') in .ipython/ install directory.
5648 5654
5649 5655 * IPython/ipmaker.py (make_IPython): fixes for new prompt
5650 5656 system. Things look fine, but these changes are fairly
5651 5657 intrusive. Test them for a few days.
5652 5658
5653 5659 * IPython/Prompts.py (CachedOutput.__init__): Massive rewrite of
5654 5660 the prompts system. Now all in/out prompt strings are user
5655 5661 controllable. This is particularly useful for embedding, as one
5656 5662 can tag embedded instances with particular prompts.
5657 5663
5658 5664 Also removed global use of sys.ps1/2, which now allows nested
5659 5665 embeddings without any problems. Added command-line options for
5660 5666 the prompt strings.
5661 5667
5662 5668 2002-03-08 Fernando Perez <fperez@colorado.edu>
5663 5669
5664 5670 * IPython/UserConfig/example-embed-short.py (ipshell): added
5665 5671 example file with the bare minimum code for embedding.
5666 5672
5667 5673 * IPython/Shell.py (IPythonShellEmbed.set_dummy_mode): added
5668 5674 functionality for the embeddable shell to be activated/deactivated
5669 5675 either globally or at each call.
5670 5676
5671 5677 * IPython/Prompts.py (Prompt1.auto_rewrite): Fixes the problem of
5672 5678 rewriting the prompt with '--->' for auto-inputs with proper
5673 5679 coloring. Now the previous UGLY hack in handle_auto() is gone, and
5674 5680 this is handled by the prompts class itself, as it should.
5675 5681
5676 5682 2002-03-05 Fernando Perez <fperez@colorado.edu>
5677 5683
5678 5684 * IPython/Magic.py (Magic.magic_logstart): Changed @log to
5679 5685 @logstart to avoid name clashes with the math log function.
5680 5686
5681 5687 * Big updates to X/Emacs section of the manual.
5682 5688
5683 5689 * Removed ipython_emacs. Milan explained to me how to pass
5684 5690 arguments to ipython through Emacs. Some day I'm going to end up
5685 5691 learning some lisp...
5686 5692
5687 5693 2002-03-04 Fernando Perez <fperez@colorado.edu>
5688 5694
5689 5695 * IPython/ipython_emacs: Created script to be used as the
5690 5696 py-python-command Emacs variable so we can pass IPython
5691 5697 parameters. I can't figure out how to tell Emacs directly to pass
5692 5698 parameters to IPython, so a dummy shell script will do it.
5693 5699
5694 5700 Other enhancements made for things to work better under Emacs'
5695 5701 various types of terminals. Many thanks to Milan Zamazal
5696 5702 <pdm-AT-zamazal.org> for all the suggestions and pointers.
5697 5703
5698 5704 2002-03-01 Fernando Perez <fperez@colorado.edu>
5699 5705
5700 5706 * IPython/ipmaker.py (make_IPython): added a --readline! option so
5701 5707 that loading of readline is now optional. This gives better
5702 5708 control to emacs users.
5703 5709
5704 5710 * IPython/ultraTB.py (__date__): Modified color escape sequences
5705 5711 and now things work fine under xterm and in Emacs' term buffers
5706 5712 (though not shell ones). Well, in emacs you get colors, but all
5707 5713 seem to be 'light' colors (no difference between dark and light
5708 5714 ones). But the garbage chars are gone, and also in xterms. It
5709 5715 seems that now I'm using 'cleaner' ansi sequences.
5710 5716
5711 5717 2002-02-21 Fernando Perez <fperez@colorado.edu>
5712 5718
5713 5719 * Released 0.2.7 (mainly to publish the scoping fix).
5714 5720
5715 5721 * IPython/Logger.py (Logger.logstate): added. A corresponding
5716 5722 @logstate magic was created.
5717 5723
5718 5724 * IPython/Magic.py: fixed nested scoping problem under Python
5719 5725 2.1.x (automagic wasn't working).
5720 5726
5721 5727 2002-02-20 Fernando Perez <fperez@colorado.edu>
5722 5728
5723 5729 * Released 0.2.6.
5724 5730
5725 5731 * IPython/OutputTrap.py (OutputTrap.__init__): added a 'quiet'
5726 5732 option so that logs can come out without any headers at all.
5727 5733
5728 5734 * IPython/UserConfig/ipythonrc-scipy.py: created a profile for
5729 5735 SciPy.
5730 5736
5731 5737 * IPython/iplib.py (InteractiveShell.embed_mainloop): Changed so
5732 5738 that embedded IPython calls don't require vars() to be explicitly
5733 5739 passed. Now they are extracted from the caller's frame (code
5734 5740 snatched from Eric Jones' weave). Added better documentation to
5735 5741 the section on embedding and the example file.
5736 5742
5737 5743 * IPython/genutils.py (page): Changed so that under emacs, it just
5738 5744 prints the string. You can then page up and down in the emacs
5739 5745 buffer itself. This is how the builtin help() works.
5740 5746
5741 5747 * IPython/Prompts.py (CachedOutput.__call__): Fixed issue with
5742 5748 macro scoping: macros need to be executed in the user's namespace
5743 5749 to work as if they had been typed by the user.
5744 5750
5745 5751 * IPython/Magic.py (Magic.magic_macro): Changed macros so they
5746 5752 execute automatically (no need to type 'exec...'). They then
5747 5753 behave like 'true macros'. The printing system was also modified
5748 5754 for this to work.
5749 5755
5750 5756 2002-02-19 Fernando Perez <fperez@colorado.edu>
5751 5757
5752 5758 * IPython/genutils.py (page_file): new function for paging files
5753 5759 in an OS-independent way. Also necessary for file viewing to work
5754 5760 well inside Emacs buffers.
5755 5761 (page): Added checks for being in an emacs buffer.
5756 5762 (page): fixed bug for Windows ($TERM isn't set in Windows). Fixed
5757 5763 same bug in iplib.
5758 5764
5759 5765 2002-02-18 Fernando Perez <fperez@colorado.edu>
5760 5766
5761 5767 * IPython/iplib.py (InteractiveShell.init_readline): modified use
5762 5768 of readline so that IPython can work inside an Emacs buffer.
5763 5769
5764 5770 * IPython/ultraTB.py (AutoFormattedTB.__call__): some fixes to
5765 5771 method signatures (they weren't really bugs, but it looks cleaner
5766 5772 and keeps PyChecker happy).
5767 5773
5768 5774 * IPython/ipmaker.py (make_IPython): added hooks Struct to __IP
5769 5775 for implementing various user-defined hooks. Currently only
5770 5776 display is done.
5771 5777
5772 5778 * IPython/Prompts.py (CachedOutput._display): changed display
5773 5779 functions so that they can be dynamically changed by users easily.
5774 5780
5775 5781 * IPython/Extensions/numeric_formats.py (num_display): added an
5776 5782 extension for printing NumPy arrays in flexible manners. It
5777 5783 doesn't do anything yet, but all the structure is in
5778 5784 place. Ultimately the plan is to implement output format control
5779 5785 like in Octave.
5780 5786
5781 5787 * IPython/Magic.py (Magic.lsmagic): changed so that bound magic
5782 5788 methods are found at run-time by all the automatic machinery.
5783 5789
5784 5790 2002-02-17 Fernando Perez <fperez@colorado.edu>
5785 5791
5786 5792 * setup_Windows.py (make_shortcut): documented. Cleaned up the
5787 5793 whole file a little.
5788 5794
5789 5795 * ToDo: closed this document. Now there's a new_design.lyx
5790 5796 document for all new ideas. Added making a pdf of it for the
5791 5797 end-user distro.
5792 5798
5793 5799 * IPython/Logger.py (Logger.switch_log): Created this to replace
5794 5800 logon() and logoff(). It also fixes a nasty crash reported by
5795 5801 Philip Hisley <compsys-AT-starpower.net>. Many thanks to him.
5796 5802
5797 5803 * IPython/iplib.py (complete): got auto-completion to work with
5798 5804 automagic (I had wanted this for a long time).
5799 5805
5800 5806 * IPython/Magic.py (Magic.magic_files): Added @files as an alias
5801 5807 to @file, since file() is now a builtin and clashes with automagic
5802 5808 for @file.
5803 5809
5804 5810 * Made some new files: Prompts, CrashHandler, Magic, Logger. All
5805 5811 of this was previously in iplib, which had grown to more than 2000
5806 5812 lines, way too long. No new functionality, but it makes managing
5807 5813 the code a bit easier.
5808 5814
5809 5815 * IPython/iplib.py (IPythonCrashHandler.__call__): Added version
5810 5816 information to crash reports.
5811 5817
5812 5818 2002-02-12 Fernando Perez <fperez@colorado.edu>
5813 5819
5814 5820 * Released 0.2.5.
5815 5821
5816 5822 2002-02-11 Fernando Perez <fperez@colorado.edu>
5817 5823
5818 5824 * Wrote a relatively complete Windows installer. It puts
5819 5825 everything in place, creates Start Menu entries and fixes the
5820 5826 color issues. Nothing fancy, but it works.
5821 5827
5822 5828 2002-02-10 Fernando Perez <fperez@colorado.edu>
5823 5829
5824 5830 * IPython/iplib.py (InteractiveShell.safe_execfile): added an
5825 5831 os.path.expanduser() call so that we can type @run ~/myfile.py and
5826 5832 have thigs work as expected.
5827 5833
5828 5834 * IPython/genutils.py (page): fixed exception handling so things
5829 5835 work both in Unix and Windows correctly. Quitting a pager triggers
5830 5836 an IOError/broken pipe in Unix, and in windows not finding a pager
5831 5837 is also an IOError, so I had to actually look at the return value
5832 5838 of the exception, not just the exception itself. Should be ok now.
5833 5839
5834 5840 * IPython/ultraTB.py (ColorSchemeTable.set_active_scheme):
5835 5841 modified to allow case-insensitive color scheme changes.
5836 5842
5837 5843 2002-02-09 Fernando Perez <fperez@colorado.edu>
5838 5844
5839 5845 * IPython/genutils.py (native_line_ends): new function to leave
5840 5846 user config files with os-native line-endings.
5841 5847
5842 5848 * README and manual updates.
5843 5849
5844 5850 * IPython/genutils.py: fixed unicode bug: use types.StringTypes
5845 5851 instead of StringType to catch Unicode strings.
5846 5852
5847 5853 * IPython/genutils.py (filefind): fixed bug for paths with
5848 5854 embedded spaces (very common in Windows).
5849 5855
5850 5856 * IPython/ipmaker.py (make_IPython): added a '.ini' to the rc
5851 5857 files under Windows, so that they get automatically associated
5852 5858 with a text editor. Windows makes it a pain to handle
5853 5859 extension-less files.
5854 5860
5855 5861 * IPython/iplib.py (InteractiveShell.init_readline): Made the
5856 5862 warning about readline only occur for Posix. In Windows there's no
5857 5863 way to get readline, so why bother with the warning.
5858 5864
5859 5865 * IPython/Struct.py (Struct.__str__): fixed to use self.__dict__
5860 5866 for __str__ instead of dir(self), since dir() changed in 2.2.
5861 5867
5862 5868 * Ported to Windows! Tested on XP, I suspect it should work fine
5863 5869 on NT/2000, but I don't think it will work on 98 et al. That
5864 5870 series of Windows is such a piece of junk anyway that I won't try
5865 5871 porting it there. The XP port was straightforward, showed a few
5866 5872 bugs here and there (fixed all), in particular some string
5867 5873 handling stuff which required considering Unicode strings (which
5868 5874 Windows uses). This is good, but hasn't been too tested :) No
5869 5875 fancy installer yet, I'll put a note in the manual so people at
5870 5876 least make manually a shortcut.
5871 5877
5872 5878 * IPython/iplib.py (Magic.magic_colors): Unified the color options
5873 5879 into a single one, "colors". This now controls both prompt and
5874 5880 exception color schemes, and can be changed both at startup
5875 5881 (either via command-line switches or via ipythonrc files) and at
5876 5882 runtime, with @colors.
5877 5883 (Magic.magic_run): renamed @prun to @run and removed the old
5878 5884 @run. The two were too similar to warrant keeping both.
5879 5885
5880 5886 2002-02-03 Fernando Perez <fperez@colorado.edu>
5881 5887
5882 5888 * IPython/iplib.py (install_first_time): Added comment on how to
5883 5889 configure the color options for first-time users. Put a <return>
5884 5890 request at the end so that small-terminal users get a chance to
5885 5891 read the startup info.
5886 5892
5887 5893 2002-01-23 Fernando Perez <fperez@colorado.edu>
5888 5894
5889 5895 * IPython/iplib.py (CachedOutput.update): Changed output memory
5890 5896 variable names from _o,_oo,_ooo,_o<n> to simply _,__,___,_<n>. For
5891 5897 input history we still use _i. Did this b/c these variable are
5892 5898 very commonly used in interactive work, so the less we need to
5893 5899 type the better off we are.
5894 5900 (Magic.magic_prun): updated @prun to better handle the namespaces
5895 5901 the file will run in, including a fix for __name__ not being set
5896 5902 before.
5897 5903
5898 5904 2002-01-20 Fernando Perez <fperez@colorado.edu>
5899 5905
5900 5906 * IPython/ultraTB.py (VerboseTB.linereader): Fixed printing of
5901 5907 extra garbage for Python 2.2. Need to look more carefully into
5902 5908 this later.
5903 5909
5904 5910 2002-01-19 Fernando Perez <fperez@colorado.edu>
5905 5911
5906 5912 * IPython/iplib.py (InteractiveShell.showtraceback): fixed to
5907 5913 display SyntaxError exceptions properly formatted when they occur
5908 5914 (they can be triggered by imported code).
5909 5915
5910 5916 2002-01-18 Fernando Perez <fperez@colorado.edu>
5911 5917
5912 5918 * IPython/iplib.py (InteractiveShell.safe_execfile): now
5913 5919 SyntaxError exceptions are reported nicely formatted, instead of
5914 5920 spitting out only offset information as before.
5915 5921 (Magic.magic_prun): Added the @prun function for executing
5916 5922 programs with command line args inside IPython.
5917 5923
5918 5924 2002-01-16 Fernando Perez <fperez@colorado.edu>
5919 5925
5920 5926 * IPython/iplib.py (Magic.magic_hist): Changed @hist and @dhist
5921 5927 to *not* include the last item given in a range. This brings their
5922 5928 behavior in line with Python's slicing:
5923 5929 a[n1:n2] -> a[n1]...a[n2-1]
5924 5930 It may be a bit less convenient, but I prefer to stick to Python's
5925 5931 conventions *everywhere*, so users never have to wonder.
5926 5932 (Magic.magic_macro): Added @macro function to ease the creation of
5927 5933 macros.
5928 5934
5929 5935 2002-01-05 Fernando Perez <fperez@colorado.edu>
5930 5936
5931 5937 * Released 0.2.4.
5932 5938
5933 5939 * IPython/iplib.py (Magic.magic_pdef):
5934 5940 (InteractiveShell.safe_execfile): report magic lines and error
5935 5941 lines without line numbers so one can easily copy/paste them for
5936 5942 re-execution.
5937 5943
5938 5944 * Updated manual with recent changes.
5939 5945
5940 5946 * IPython/iplib.py (Magic.magic_oinfo): added constructor
5941 5947 docstring printing when class? is called. Very handy for knowing
5942 5948 how to create class instances (as long as __init__ is well
5943 5949 documented, of course :)
5944 5950 (Magic.magic_doc): print both class and constructor docstrings.
5945 5951 (Magic.magic_pdef): give constructor info if passed a class and
5946 5952 __call__ info for callable object instances.
5947 5953
5948 5954 2002-01-04 Fernando Perez <fperez@colorado.edu>
5949 5955
5950 5956 * Made deep_reload() off by default. It doesn't always work
5951 5957 exactly as intended, so it's probably safer to have it off. It's
5952 5958 still available as dreload() anyway, so nothing is lost.
5953 5959
5954 5960 2002-01-02 Fernando Perez <fperez@colorado.edu>
5955 5961
5956 5962 * Released 0.2.3 (contacted R.Singh at CU about biopython course,
5957 5963 so I wanted an updated release).
5958 5964
5959 5965 2001-12-27 Fernando Perez <fperez@colorado.edu>
5960 5966
5961 5967 * IPython/iplib.py (InteractiveShell.interact): Added the original
5962 5968 code from 'code.py' for this module in order to change the
5963 5969 handling of a KeyboardInterrupt. This was necessary b/c otherwise
5964 5970 the history cache would break when the user hit Ctrl-C, and
5965 5971 interact() offers no way to add any hooks to it.
5966 5972
5967 5973 2001-12-23 Fernando Perez <fperez@colorado.edu>
5968 5974
5969 5975 * setup.py: added check for 'MANIFEST' before trying to remove
5970 5976 it. Thanks to Sean Reifschneider.
5971 5977
5972 5978 2001-12-22 Fernando Perez <fperez@colorado.edu>
5973 5979
5974 5980 * Released 0.2.2.
5975 5981
5976 5982 * Finished (reasonably) writing the manual. Later will add the
5977 5983 python-standard navigation stylesheets, but for the time being
5978 5984 it's fairly complete. Distribution will include html and pdf
5979 5985 versions.
5980 5986
5981 5987 * Bugfix: '.' wasn't being added to sys.path. Thanks to Prabhu
5982 5988 (MayaVi author).
5983 5989
5984 5990 2001-12-21 Fernando Perez <fperez@colorado.edu>
5985 5991
5986 5992 * Released 0.2.1. Barring any nasty bugs, this is it as far as a
5987 5993 good public release, I think (with the manual and the distutils
5988 5994 installer). The manual can use some work, but that can go
5989 5995 slowly. Otherwise I think it's quite nice for end users. Next
5990 5996 summer, rewrite the guts of it...
5991 5997
5992 5998 * Changed format of ipythonrc files to use whitespace as the
5993 5999 separator instead of an explicit '='. Cleaner.
5994 6000
5995 6001 2001-12-20 Fernando Perez <fperez@colorado.edu>
5996 6002
5997 6003 * Started a manual in LyX. For now it's just a quick merge of the
5998 6004 various internal docstrings and READMEs. Later it may grow into a
5999 6005 nice, full-blown manual.
6000 6006
6001 6007 * Set up a distutils based installer. Installation should now be
6002 6008 trivially simple for end-users.
6003 6009
6004 6010 2001-12-11 Fernando Perez <fperez@colorado.edu>
6005 6011
6006 6012 * Released 0.2.0. First public release, announced it at
6007 6013 comp.lang.python. From now on, just bugfixes...
6008 6014
6009 6015 * Went through all the files, set copyright/license notices and
6010 6016 cleaned up things. Ready for release.
6011 6017
6012 6018 2001-12-10 Fernando Perez <fperez@colorado.edu>
6013 6019
6014 6020 * Changed the first-time installer not to use tarfiles. It's more
6015 6021 robust now and less unix-dependent. Also makes it easier for
6016 6022 people to later upgrade versions.
6017 6023
6018 6024 * Changed @exit to @abort to reflect the fact that it's pretty
6019 6025 brutal (a sys.exit()). The difference between @abort and Ctrl-D
6020 6026 becomes significant only when IPyhton is embedded: in that case,
6021 6027 C-D closes IPython only, but @abort kills the enclosing program
6022 6028 too (unless it had called IPython inside a try catching
6023 6029 SystemExit).
6024 6030
6025 6031 * Created Shell module which exposes the actuall IPython Shell
6026 6032 classes, currently the normal and the embeddable one. This at
6027 6033 least offers a stable interface we won't need to change when
6028 6034 (later) the internals are rewritten. That rewrite will be confined
6029 6035 to iplib and ipmaker, but the Shell interface should remain as is.
6030 6036
6031 6037 * Added embed module which offers an embeddable IPShell object,
6032 6038 useful to fire up IPython *inside* a running program. Great for
6033 6039 debugging or dynamical data analysis.
6034 6040
6035 6041 2001-12-08 Fernando Perez <fperez@colorado.edu>
6036 6042
6037 6043 * Fixed small bug preventing seeing info from methods of defined
6038 6044 objects (incorrect namespace in _ofind()).
6039 6045
6040 6046 * Documentation cleanup. Moved the main usage docstrings to a
6041 6047 separate file, usage.py (cleaner to maintain, and hopefully in the
6042 6048 future some perlpod-like way of producing interactive, man and
6043 6049 html docs out of it will be found).
6044 6050
6045 6051 * Added @profile to see your profile at any time.
6046 6052
6047 6053 * Added @p as an alias for 'print'. It's especially convenient if
6048 6054 using automagic ('p x' prints x).
6049 6055
6050 6056 * Small cleanups and fixes after a pychecker run.
6051 6057
6052 6058 * Changed the @cd command to handle @cd - and @cd -<n> for
6053 6059 visiting any directory in _dh.
6054 6060
6055 6061 * Introduced _dh, a history of visited directories. @dhist prints
6056 6062 it out with numbers.
6057 6063
6058 6064 2001-12-07 Fernando Perez <fperez@colorado.edu>
6059 6065
6060 6066 * Released 0.1.22
6061 6067
6062 6068 * Made initialization a bit more robust against invalid color
6063 6069 options in user input (exit, not traceback-crash).
6064 6070
6065 6071 * Changed the bug crash reporter to write the report only in the
6066 6072 user's .ipython directory. That way IPython won't litter people's
6067 6073 hard disks with crash files all over the place. Also print on
6068 6074 screen the necessary mail command.
6069 6075
6070 6076 * With the new ultraTB, implemented LightBG color scheme for light
6071 6077 background terminals. A lot of people like white backgrounds, so I
6072 6078 guess we should at least give them something readable.
6073 6079
6074 6080 2001-12-06 Fernando Perez <fperez@colorado.edu>
6075 6081
6076 6082 * Modified the structure of ultraTB. Now there's a proper class
6077 6083 for tables of color schemes which allow adding schemes easily and
6078 6084 switching the active scheme without creating a new instance every
6079 6085 time (which was ridiculous). The syntax for creating new schemes
6080 6086 is also cleaner. I think ultraTB is finally done, with a clean
6081 6087 class structure. Names are also much cleaner (now there's proper
6082 6088 color tables, no need for every variable to also have 'color' in
6083 6089 its name).
6084 6090
6085 6091 * Broke down genutils into separate files. Now genutils only
6086 6092 contains utility functions, and classes have been moved to their
6087 6093 own files (they had enough independent functionality to warrant
6088 6094 it): ConfigLoader, OutputTrap, Struct.
6089 6095
6090 6096 2001-12-05 Fernando Perez <fperez@colorado.edu>
6091 6097
6092 6098 * IPython turns 21! Released version 0.1.21, as a candidate for
6093 6099 public consumption. If all goes well, release in a few days.
6094 6100
6095 6101 * Fixed path bug (files in Extensions/ directory wouldn't be found
6096 6102 unless IPython/ was explicitly in sys.path).
6097 6103
6098 6104 * Extended the FlexCompleter class as MagicCompleter to allow
6099 6105 completion of @-starting lines.
6100 6106
6101 6107 * Created __release__.py file as a central repository for release
6102 6108 info that other files can read from.
6103 6109
6104 6110 * Fixed small bug in logging: when logging was turned on in
6105 6111 mid-session, old lines with special meanings (!@?) were being
6106 6112 logged without the prepended comment, which is necessary since
6107 6113 they are not truly valid python syntax. This should make session
6108 6114 restores produce less errors.
6109 6115
6110 6116 * The namespace cleanup forced me to make a FlexCompleter class
6111 6117 which is nothing but a ripoff of rlcompleter, but with selectable
6112 6118 namespace (rlcompleter only works in __main__.__dict__). I'll try
6113 6119 to submit a note to the authors to see if this change can be
6114 6120 incorporated in future rlcompleter releases (Dec.6: done)
6115 6121
6116 6122 * More fixes to namespace handling. It was a mess! Now all
6117 6123 explicit references to __main__.__dict__ are gone (except when
6118 6124 really needed) and everything is handled through the namespace
6119 6125 dicts in the IPython instance. We seem to be getting somewhere
6120 6126 with this, finally...
6121 6127
6122 6128 * Small documentation updates.
6123 6129
6124 6130 * Created the Extensions directory under IPython (with an
6125 6131 __init__.py). Put the PhysicalQ stuff there. This directory should
6126 6132 be used for all special-purpose extensions.
6127 6133
6128 6134 * File renaming:
6129 6135 ipythonlib --> ipmaker
6130 6136 ipplib --> iplib
6131 6137 This makes a bit more sense in terms of what these files actually do.
6132 6138
6133 6139 * Moved all the classes and functions in ipythonlib to ipplib, so
6134 6140 now ipythonlib only has make_IPython(). This will ease up its
6135 6141 splitting in smaller functional chunks later.
6136 6142
6137 6143 * Cleaned up (done, I think) output of @whos. Better column
6138 6144 formatting, and now shows str(var) for as much as it can, which is
6139 6145 typically what one gets with a 'print var'.
6140 6146
6141 6147 2001-12-04 Fernando Perez <fperez@colorado.edu>
6142 6148
6143 6149 * Fixed namespace problems. Now builtin/IPyhton/user names get
6144 6150 properly reported in their namespace. Internal namespace handling
6145 6151 is finally getting decent (not perfect yet, but much better than
6146 6152 the ad-hoc mess we had).
6147 6153
6148 6154 * Removed -exit option. If people just want to run a python
6149 6155 script, that's what the normal interpreter is for. Less
6150 6156 unnecessary options, less chances for bugs.
6151 6157
6152 6158 * Added a crash handler which generates a complete post-mortem if
6153 6159 IPython crashes. This will help a lot in tracking bugs down the
6154 6160 road.
6155 6161
6156 6162 * Fixed nasty bug in auto-evaluation part of prefilter(). Names
6157 6163 which were boud to functions being reassigned would bypass the
6158 6164 logger, breaking the sync of _il with the prompt counter. This
6159 6165 would then crash IPython later when a new line was logged.
6160 6166
6161 6167 2001-12-02 Fernando Perez <fperez@colorado.edu>
6162 6168
6163 6169 * Made IPython a package. This means people don't have to clutter
6164 6170 their sys.path with yet another directory. Changed the INSTALL
6165 6171 file accordingly.
6166 6172
6167 6173 * Cleaned up the output of @who_ls, @who and @whos. @who_ls now
6168 6174 sorts its output (so @who shows it sorted) and @whos formats the
6169 6175 table according to the width of the first column. Nicer, easier to
6170 6176 read. Todo: write a generic table_format() which takes a list of
6171 6177 lists and prints it nicely formatted, with optional row/column
6172 6178 separators and proper padding and justification.
6173 6179
6174 6180 * Released 0.1.20
6175 6181
6176 6182 * Fixed bug in @log which would reverse the inputcache list (a
6177 6183 copy operation was missing).
6178 6184
6179 6185 * Code cleanup. @config was changed to use page(). Better, since
6180 6186 its output is always quite long.
6181 6187
6182 6188 * Itpl is back as a dependency. I was having too many problems
6183 6189 getting the parametric aliases to work reliably, and it's just
6184 6190 easier to code weird string operations with it than playing %()s
6185 6191 games. It's only ~6k, so I don't think it's too big a deal.
6186 6192
6187 6193 * Found (and fixed) a very nasty bug with history. !lines weren't
6188 6194 getting cached, and the out of sync caches would crash
6189 6195 IPython. Fixed it by reorganizing the prefilter/handlers/logger
6190 6196 division of labor a bit better. Bug fixed, cleaner structure.
6191 6197
6192 6198 2001-12-01 Fernando Perez <fperez@colorado.edu>
6193 6199
6194 6200 * Released 0.1.19
6195 6201
6196 6202 * Added option -n to @hist to prevent line number printing. Much
6197 6203 easier to copy/paste code this way.
6198 6204
6199 6205 * Created global _il to hold the input list. Allows easy
6200 6206 re-execution of blocks of code by slicing it (inspired by Janko's
6201 6207 comment on 'macros').
6202 6208
6203 6209 * Small fixes and doc updates.
6204 6210
6205 6211 * Rewrote @history function (was @h). Renamed it to @hist, @h is
6206 6212 much too fragile with automagic. Handles properly multi-line
6207 6213 statements and takes parameters.
6208 6214
6209 6215 2001-11-30 Fernando Perez <fperez@colorado.edu>
6210 6216
6211 6217 * Version 0.1.18 released.
6212 6218
6213 6219 * Fixed nasty namespace bug in initial module imports.
6214 6220
6215 6221 * Added copyright/license notes to all code files (except
6216 6222 DPyGetOpt). For the time being, LGPL. That could change.
6217 6223
6218 6224 * Rewrote a much nicer README, updated INSTALL, cleaned up
6219 6225 ipythonrc-* samples.
6220 6226
6221 6227 * Overall code/documentation cleanup. Basically ready for
6222 6228 release. Only remaining thing: licence decision (LGPL?).
6223 6229
6224 6230 * Converted load_config to a class, ConfigLoader. Now recursion
6225 6231 control is better organized. Doesn't include the same file twice.
6226 6232
6227 6233 2001-11-29 Fernando Perez <fperez@colorado.edu>
6228 6234
6229 6235 * Got input history working. Changed output history variables from
6230 6236 _p to _o so that _i is for input and _o for output. Just cleaner
6231 6237 convention.
6232 6238
6233 6239 * Implemented parametric aliases. This pretty much allows the
6234 6240 alias system to offer full-blown shell convenience, I think.
6235 6241
6236 6242 * Version 0.1.17 released, 0.1.18 opened.
6237 6243
6238 6244 * dot_ipython/ipythonrc (alias): added documentation.
6239 6245 (xcolor): Fixed small bug (xcolors -> xcolor)
6240 6246
6241 6247 * Changed the alias system. Now alias is a magic command to define
6242 6248 aliases just like the shell. Rationale: the builtin magics should
6243 6249 be there for things deeply connected to IPython's
6244 6250 architecture. And this is a much lighter system for what I think
6245 6251 is the really important feature: allowing users to define quickly
6246 6252 magics that will do shell things for them, so they can customize
6247 6253 IPython easily to match their work habits. If someone is really
6248 6254 desperate to have another name for a builtin alias, they can
6249 6255 always use __IP.magic_newname = __IP.magic_oldname. Hackish but
6250 6256 works.
6251 6257
6252 6258 2001-11-28 Fernando Perez <fperez@colorado.edu>
6253 6259
6254 6260 * Changed @file so that it opens the source file at the proper
6255 6261 line. Since it uses less, if your EDITOR environment is
6256 6262 configured, typing v will immediately open your editor of choice
6257 6263 right at the line where the object is defined. Not as quick as
6258 6264 having a direct @edit command, but for all intents and purposes it
6259 6265 works. And I don't have to worry about writing @edit to deal with
6260 6266 all the editors, less does that.
6261 6267
6262 6268 * Version 0.1.16 released, 0.1.17 opened.
6263 6269
6264 6270 * Fixed some nasty bugs in the page/page_dumb combo that could
6265 6271 crash IPython.
6266 6272
6267 6273 2001-11-27 Fernando Perez <fperez@colorado.edu>
6268 6274
6269 6275 * Version 0.1.15 released, 0.1.16 opened.
6270 6276
6271 6277 * Finally got ? and ?? to work for undefined things: now it's
6272 6278 possible to type {}.get? and get information about the get method
6273 6279 of dicts, or os.path? even if only os is defined (so technically
6274 6280 os.path isn't). Works at any level. For example, after import os,
6275 6281 os?, os.path?, os.path.abspath? all work. This is great, took some
6276 6282 work in _ofind.
6277 6283
6278 6284 * Fixed more bugs with logging. The sanest way to do it was to add
6279 6285 to @log a 'mode' parameter. Killed two in one shot (this mode
6280 6286 option was a request of Janko's). I think it's finally clean
6281 6287 (famous last words).
6282 6288
6283 6289 * Added a page_dumb() pager which does a decent job of paging on
6284 6290 screen, if better things (like less) aren't available. One less
6285 6291 unix dependency (someday maybe somebody will port this to
6286 6292 windows).
6287 6293
6288 6294 * Fixed problem in magic_log: would lock of logging out if log
6289 6295 creation failed (because it would still think it had succeeded).
6290 6296
6291 6297 * Improved the page() function using curses to auto-detect screen
6292 6298 size. Now it can make a much better decision on whether to print
6293 6299 or page a string. Option screen_length was modified: a value 0
6294 6300 means auto-detect, and that's the default now.
6295 6301
6296 6302 * Version 0.1.14 released, 0.1.15 opened. I think this is ready to
6297 6303 go out. I'll test it for a few days, then talk to Janko about
6298 6304 licences and announce it.
6299 6305
6300 6306 * Fixed the length of the auto-generated ---> prompt which appears
6301 6307 for auto-parens and auto-quotes. Getting this right isn't trivial,
6302 6308 with all the color escapes, different prompt types and optional
6303 6309 separators. But it seems to be working in all the combinations.
6304 6310
6305 6311 2001-11-26 Fernando Perez <fperez@colorado.edu>
6306 6312
6307 6313 * Wrote a regexp filter to get option types from the option names
6308 6314 string. This eliminates the need to manually keep two duplicate
6309 6315 lists.
6310 6316
6311 6317 * Removed the unneeded check_option_names. Now options are handled
6312 6318 in a much saner manner and it's easy to visually check that things
6313 6319 are ok.
6314 6320
6315 6321 * Updated version numbers on all files I modified to carry a
6316 6322 notice so Janko and Nathan have clear version markers.
6317 6323
6318 6324 * Updated docstring for ultraTB with my changes. I should send
6319 6325 this to Nathan.
6320 6326
6321 6327 * Lots of small fixes. Ran everything through pychecker again.
6322 6328
6323 6329 * Made loading of deep_reload an cmd line option. If it's not too
6324 6330 kosher, now people can just disable it. With -nodeep_reload it's
6325 6331 still available as dreload(), it just won't overwrite reload().
6326 6332
6327 6333 * Moved many options to the no| form (-opt and -noopt
6328 6334 accepted). Cleaner.
6329 6335
6330 6336 * Changed magic_log so that if called with no parameters, it uses
6331 6337 'rotate' mode. That way auto-generated logs aren't automatically
6332 6338 over-written. For normal logs, now a backup is made if it exists
6333 6339 (only 1 level of backups). A new 'backup' mode was added to the
6334 6340 Logger class to support this. This was a request by Janko.
6335 6341
6336 6342 * Added @logoff/@logon to stop/restart an active log.
6337 6343
6338 6344 * Fixed a lot of bugs in log saving/replay. It was pretty
6339 6345 broken. Now special lines (!@,/) appear properly in the command
6340 6346 history after a log replay.
6341 6347
6342 6348 * Tried and failed to implement full session saving via pickle. My
6343 6349 idea was to pickle __main__.__dict__, but modules can't be
6344 6350 pickled. This would be a better alternative to replaying logs, but
6345 6351 seems quite tricky to get to work. Changed -session to be called
6346 6352 -logplay, which more accurately reflects what it does. And if we
6347 6353 ever get real session saving working, -session is now available.
6348 6354
6349 6355 * Implemented color schemes for prompts also. As for tracebacks,
6350 6356 currently only NoColor and Linux are supported. But now the
6351 6357 infrastructure is in place, based on a generic ColorScheme
6352 6358 class. So writing and activating new schemes both for the prompts
6353 6359 and the tracebacks should be straightforward.
6354 6360
6355 6361 * Version 0.1.13 released, 0.1.14 opened.
6356 6362
6357 6363 * Changed handling of options for output cache. Now counter is
6358 6364 hardwired starting at 1 and one specifies the maximum number of
6359 6365 entries *in the outcache* (not the max prompt counter). This is
6360 6366 much better, since many statements won't increase the cache
6361 6367 count. It also eliminated some confusing options, now there's only
6362 6368 one: cache_size.
6363 6369
6364 6370 * Added 'alias' magic function and magic_alias option in the
6365 6371 ipythonrc file. Now the user can easily define whatever names he
6366 6372 wants for the magic functions without having to play weird
6367 6373 namespace games. This gives IPython a real shell-like feel.
6368 6374
6369 6375 * Fixed doc/?/?? for magics. Now all work, in all forms (explicit
6370 6376 @ or not).
6371 6377
6372 6378 This was one of the last remaining 'visible' bugs (that I know
6373 6379 of). I think if I can clean up the session loading so it works
6374 6380 100% I'll release a 0.2.0 version on c.p.l (talk to Janko first
6375 6381 about licensing).
6376 6382
6377 6383 2001-11-25 Fernando Perez <fperez@colorado.edu>
6378 6384
6379 6385 * Rewrote somewhat oinfo (?/??). Nicer, now uses page() and
6380 6386 there's a cleaner distinction between what ? and ?? show.
6381 6387
6382 6388 * Added screen_length option. Now the user can define his own
6383 6389 screen size for page() operations.
6384 6390
6385 6391 * Implemented magic shell-like functions with automatic code
6386 6392 generation. Now adding another function is just a matter of adding
6387 6393 an entry to a dict, and the function is dynamically generated at
6388 6394 run-time. Python has some really cool features!
6389 6395
6390 6396 * Renamed many options to cleanup conventions a little. Now all
6391 6397 are lowercase, and only underscores where needed. Also in the code
6392 6398 option name tables are clearer.
6393 6399
6394 6400 * Changed prompts a little. Now input is 'In [n]:' instead of
6395 6401 'In[n]:='. This allows it the numbers to be aligned with the
6396 6402 Out[n] numbers, and removes usage of ':=' which doesn't exist in
6397 6403 Python (it was a Mathematica thing). The '...' continuation prompt
6398 6404 was also changed a little to align better.
6399 6405
6400 6406 * Fixed bug when flushing output cache. Not all _p<n> variables
6401 6407 exist, so their deletion needs to be wrapped in a try:
6402 6408
6403 6409 * Figured out how to properly use inspect.formatargspec() (it
6404 6410 requires the args preceded by *). So I removed all the code from
6405 6411 _get_pdef in Magic, which was just replicating that.
6406 6412
6407 6413 * Added test to prefilter to allow redefining magic function names
6408 6414 as variables. This is ok, since the @ form is always available,
6409 6415 but whe should allow the user to define a variable called 'ls' if
6410 6416 he needs it.
6411 6417
6412 6418 * Moved the ToDo information from README into a separate ToDo.
6413 6419
6414 6420 * General code cleanup and small bugfixes. I think it's close to a
6415 6421 state where it can be released, obviously with a big 'beta'
6416 6422 warning on it.
6417 6423
6418 6424 * Got the magic function split to work. Now all magics are defined
6419 6425 in a separate class. It just organizes things a bit, and now
6420 6426 Xemacs behaves nicer (it was choking on InteractiveShell b/c it
6421 6427 was too long).
6422 6428
6423 6429 * Changed @clear to @reset to avoid potential confusions with
6424 6430 the shell command clear. Also renamed @cl to @clear, which does
6425 6431 exactly what people expect it to from their shell experience.
6426 6432
6427 6433 Added a check to the @reset command (since it's so
6428 6434 destructive, it's probably a good idea to ask for confirmation).
6429 6435 But now reset only works for full namespace resetting. Since the
6430 6436 del keyword is already there for deleting a few specific
6431 6437 variables, I don't see the point of having a redundant magic
6432 6438 function for the same task.
6433 6439
6434 6440 2001-11-24 Fernando Perez <fperez@colorado.edu>
6435 6441
6436 6442 * Updated the builtin docs (esp. the ? ones).
6437 6443
6438 6444 * Ran all the code through pychecker. Not terribly impressed with
6439 6445 it: lots of spurious warnings and didn't really find anything of
6440 6446 substance (just a few modules being imported and not used).
6441 6447
6442 6448 * Implemented the new ultraTB functionality into IPython. New
6443 6449 option: xcolors. This chooses color scheme. xmode now only selects
6444 6450 between Plain and Verbose. Better orthogonality.
6445 6451
6446 6452 * Large rewrite of ultraTB. Much cleaner now, with a separation of
6447 6453 mode and color scheme for the exception handlers. Now it's
6448 6454 possible to have the verbose traceback with no coloring.
6449 6455
6450 6456 2001-11-23 Fernando Perez <fperez@colorado.edu>
6451 6457
6452 6458 * Version 0.1.12 released, 0.1.13 opened.
6453 6459
6454 6460 * Removed option to set auto-quote and auto-paren escapes by
6455 6461 user. The chances of breaking valid syntax are just too high. If
6456 6462 someone *really* wants, they can always dig into the code.
6457 6463
6458 6464 * Made prompt separators configurable.
6459 6465
6460 6466 2001-11-22 Fernando Perez <fperez@colorado.edu>
6461 6467
6462 6468 * Small bugfixes in many places.
6463 6469
6464 6470 * Removed the MyCompleter class from ipplib. It seemed redundant
6465 6471 with the C-p,C-n history search functionality. Less code to
6466 6472 maintain.
6467 6473
6468 6474 * Moved all the original ipython.py code into ipythonlib.py. Right
6469 6475 now it's just one big dump into a function called make_IPython, so
6470 6476 no real modularity has been gained. But at least it makes the
6471 6477 wrapper script tiny, and since ipythonlib is a module, it gets
6472 6478 compiled and startup is much faster.
6473 6479
6474 6480 This is a reasobably 'deep' change, so we should test it for a
6475 6481 while without messing too much more with the code.
6476 6482
6477 6483 2001-11-21 Fernando Perez <fperez@colorado.edu>
6478 6484
6479 6485 * Version 0.1.11 released, 0.1.12 opened for further work.
6480 6486
6481 6487 * Removed dependency on Itpl. It was only needed in one place. It
6482 6488 would be nice if this became part of python, though. It makes life
6483 6489 *a lot* easier in some cases.
6484 6490
6485 6491 * Simplified the prefilter code a bit. Now all handlers are
6486 6492 expected to explicitly return a value (at least a blank string).
6487 6493
6488 6494 * Heavy edits in ipplib. Removed the help system altogether. Now
6489 6495 obj?/?? is used for inspecting objects, a magic @doc prints
6490 6496 docstrings, and full-blown Python help is accessed via the 'help'
6491 6497 keyword. This cleans up a lot of code (less to maintain) and does
6492 6498 the job. Since 'help' is now a standard Python component, might as
6493 6499 well use it and remove duplicate functionality.
6494 6500
6495 6501 Also removed the option to use ipplib as a standalone program. By
6496 6502 now it's too dependent on other parts of IPython to function alone.
6497 6503
6498 6504 * Fixed bug in genutils.pager. It would crash if the pager was
6499 6505 exited immediately after opening (broken pipe).
6500 6506
6501 6507 * Trimmed down the VerboseTB reporting a little. The header is
6502 6508 much shorter now and the repeated exception arguments at the end
6503 6509 have been removed. For interactive use the old header seemed a bit
6504 6510 excessive.
6505 6511
6506 6512 * Fixed small bug in output of @whos for variables with multi-word
6507 6513 types (only first word was displayed).
6508 6514
6509 6515 2001-11-17 Fernando Perez <fperez@colorado.edu>
6510 6516
6511 6517 * Version 0.1.10 released, 0.1.11 opened for further work.
6512 6518
6513 6519 * Modified dirs and friends. dirs now *returns* the stack (not
6514 6520 prints), so one can manipulate it as a variable. Convenient to
6515 6521 travel along many directories.
6516 6522
6517 6523 * Fixed bug in magic_pdef: would only work with functions with
6518 6524 arguments with default values.
6519 6525
6520 6526 2001-11-14 Fernando Perez <fperez@colorado.edu>
6521 6527
6522 6528 * Added the PhysicsInput stuff to dot_ipython so it ships as an
6523 6529 example with IPython. Various other minor fixes and cleanups.
6524 6530
6525 6531 * Version 0.1.9 released, 0.1.10 opened for further work.
6526 6532
6527 6533 * Added sys.path to the list of directories searched in the
6528 6534 execfile= option. It used to be the current directory and the
6529 6535 user's IPYTHONDIR only.
6530 6536
6531 6537 2001-11-13 Fernando Perez <fperez@colorado.edu>
6532 6538
6533 6539 * Reinstated the raw_input/prefilter separation that Janko had
6534 6540 initially. This gives a more convenient setup for extending the
6535 6541 pre-processor from the outside: raw_input always gets a string,
6536 6542 and prefilter has to process it. We can then redefine prefilter
6537 6543 from the outside and implement extensions for special
6538 6544 purposes.
6539 6545
6540 6546 Today I got one for inputting PhysicalQuantity objects
6541 6547 (from Scientific) without needing any function calls at
6542 6548 all. Extremely convenient, and it's all done as a user-level
6543 6549 extension (no IPython code was touched). Now instead of:
6544 6550 a = PhysicalQuantity(4.2,'m/s**2')
6545 6551 one can simply say
6546 6552 a = 4.2 m/s**2
6547 6553 or even
6548 6554 a = 4.2 m/s^2
6549 6555
6550 6556 I use this, but it's also a proof of concept: IPython really is
6551 6557 fully user-extensible, even at the level of the parsing of the
6552 6558 command line. It's not trivial, but it's perfectly doable.
6553 6559
6554 6560 * Added 'add_flip' method to inclusion conflict resolver. Fixes
6555 6561 the problem of modules being loaded in the inverse order in which
6556 6562 they were defined in
6557 6563
6558 6564 * Version 0.1.8 released, 0.1.9 opened for further work.
6559 6565
6560 6566 * Added magics pdef, source and file. They respectively show the
6561 6567 definition line ('prototype' in C), source code and full python
6562 6568 file for any callable object. The object inspector oinfo uses
6563 6569 these to show the same information.
6564 6570
6565 6571 * Version 0.1.7 released, 0.1.8 opened for further work.
6566 6572
6567 6573 * Separated all the magic functions into a class called Magic. The
6568 6574 InteractiveShell class was becoming too big for Xemacs to handle
6569 6575 (de-indenting a line would lock it up for 10 seconds while it
6570 6576 backtracked on the whole class!)
6571 6577
6572 6578 FIXME: didn't work. It can be done, but right now namespaces are
6573 6579 all messed up. Do it later (reverted it for now, so at least
6574 6580 everything works as before).
6575 6581
6576 6582 * Got the object introspection system (magic_oinfo) working! I
6577 6583 think this is pretty much ready for release to Janko, so he can
6578 6584 test it for a while and then announce it. Pretty much 100% of what
6579 6585 I wanted for the 'phase 1' release is ready. Happy, tired.
6580 6586
6581 6587 2001-11-12 Fernando Perez <fperez@colorado.edu>
6582 6588
6583 6589 * Version 0.1.6 released, 0.1.7 opened for further work.
6584 6590
6585 6591 * Fixed bug in printing: it used to test for truth before
6586 6592 printing, so 0 wouldn't print. Now checks for None.
6587 6593
6588 6594 * Fixed bug where auto-execs increase the prompt counter by 2 (b/c
6589 6595 they have to call len(str(sys.ps1)) ). But the fix is ugly, it
6590 6596 reaches by hand into the outputcache. Think of a better way to do
6591 6597 this later.
6592 6598
6593 6599 * Various small fixes thanks to Nathan's comments.
6594 6600
6595 6601 * Changed magic_pprint to magic_Pprint. This way it doesn't
6596 6602 collide with pprint() and the name is consistent with the command
6597 6603 line option.
6598 6604
6599 6605 * Changed prompt counter behavior to be fully like
6600 6606 Mathematica's. That is, even input that doesn't return a result
6601 6607 raises the prompt counter. The old behavior was kind of confusing
6602 6608 (getting the same prompt number several times if the operation
6603 6609 didn't return a result).
6604 6610
6605 6611 * Fixed Nathan's last name in a couple of places (Gray, not Graham).
6606 6612
6607 6613 * Fixed -Classic mode (wasn't working anymore).
6608 6614
6609 6615 * Added colored prompts using Nathan's new code. Colors are
6610 6616 currently hardwired, they can be user-configurable. For
6611 6617 developers, they can be chosen in file ipythonlib.py, at the
6612 6618 beginning of the CachedOutput class def.
6613 6619
6614 6620 2001-11-11 Fernando Perez <fperez@colorado.edu>
6615 6621
6616 6622 * Version 0.1.5 released, 0.1.6 opened for further work.
6617 6623
6618 6624 * Changed magic_env to *return* the environment as a dict (not to
6619 6625 print it). This way it prints, but it can also be processed.
6620 6626
6621 6627 * Added Verbose exception reporting to interactive
6622 6628 exceptions. Very nice, now even 1/0 at the prompt gives a verbose
6623 6629 traceback. Had to make some changes to the ultraTB file. This is
6624 6630 probably the last 'big' thing in my mental todo list. This ties
6625 6631 in with the next entry:
6626 6632
6627 6633 * Changed -Xi and -Xf to a single -xmode option. Now all the user
6628 6634 has to specify is Plain, Color or Verbose for all exception
6629 6635 handling.
6630 6636
6631 6637 * Removed ShellServices option. All this can really be done via
6632 6638 the magic system. It's easier to extend, cleaner and has automatic
6633 6639 namespace protection and documentation.
6634 6640
6635 6641 2001-11-09 Fernando Perez <fperez@colorado.edu>
6636 6642
6637 6643 * Fixed bug in output cache flushing (missing parameter to
6638 6644 __init__). Other small bugs fixed (found using pychecker).
6639 6645
6640 6646 * Version 0.1.4 opened for bugfixing.
6641 6647
6642 6648 2001-11-07 Fernando Perez <fperez@colorado.edu>
6643 6649
6644 6650 * Version 0.1.3 released, mainly because of the raw_input bug.
6645 6651
6646 6652 * Fixed NASTY bug in raw_input: input line wasn't properly parsed
6647 6653 and when testing for whether things were callable, a call could
6648 6654 actually be made to certain functions. They would get called again
6649 6655 once 'really' executed, with a resulting double call. A disaster
6650 6656 in many cases (list.reverse() would never work!).
6651 6657
6652 6658 * Removed prefilter() function, moved its code to raw_input (which
6653 6659 after all was just a near-empty caller for prefilter). This saves
6654 6660 a function call on every prompt, and simplifies the class a tiny bit.
6655 6661
6656 6662 * Fix _ip to __ip name in magic example file.
6657 6663
6658 6664 * Changed 'tar -x -f' to 'tar xvf' in auto-installer. This should
6659 6665 work with non-gnu versions of tar.
6660 6666
6661 6667 2001-11-06 Fernando Perez <fperez@colorado.edu>
6662 6668
6663 6669 * Version 0.1.2. Just to keep track of the recent changes.
6664 6670
6665 6671 * Fixed nasty bug in output prompt routine. It used to check 'if
6666 6672 arg != None...'. Problem is, this fails if arg implements a
6667 6673 special comparison (__cmp__) which disallows comparing to
6668 6674 None. Found it when trying to use the PhysicalQuantity module from
6669 6675 ScientificPython.
6670 6676
6671 6677 2001-11-05 Fernando Perez <fperez@colorado.edu>
6672 6678
6673 6679 * Also added dirs. Now the pushd/popd/dirs family functions
6674 6680 basically like the shell, with the added convenience of going home
6675 6681 when called with no args.
6676 6682
6677 6683 * pushd/popd slightly modified to mimic shell behavior more
6678 6684 closely.
6679 6685
6680 6686 * Added env,pushd,popd from ShellServices as magic functions. I
6681 6687 think the cleanest will be to port all desired functions from
6682 6688 ShellServices as magics and remove ShellServices altogether. This
6683 6689 will provide a single, clean way of adding functionality
6684 6690 (shell-type or otherwise) to IP.
6685 6691
6686 6692 2001-11-04 Fernando Perez <fperez@colorado.edu>
6687 6693
6688 6694 * Added .ipython/ directory to sys.path. This way users can keep
6689 6695 customizations there and access them via import.
6690 6696
6691 6697 2001-11-03 Fernando Perez <fperez@colorado.edu>
6692 6698
6693 6699 * Opened version 0.1.1 for new changes.
6694 6700
6695 6701 * Changed version number to 0.1.0: first 'public' release, sent to
6696 6702 Nathan and Janko.
6697 6703
6698 6704 * Lots of small fixes and tweaks.
6699 6705
6700 6706 * Minor changes to whos format. Now strings are shown, snipped if
6701 6707 too long.
6702 6708
6703 6709 * Changed ShellServices to work on __main__ so they show up in @who
6704 6710
6705 6711 * Help also works with ? at the end of a line:
6706 6712 ?sin and sin?
6707 6713 both produce the same effect. This is nice, as often I use the
6708 6714 tab-complete to find the name of a method, but I used to then have
6709 6715 to go to the beginning of the line to put a ? if I wanted more
6710 6716 info. Now I can just add the ? and hit return. Convenient.
6711 6717
6712 6718 2001-11-02 Fernando Perez <fperez@colorado.edu>
6713 6719
6714 6720 * Python version check (>=2.1) added.
6715 6721
6716 6722 * Added LazyPython documentation. At this point the docs are quite
6717 6723 a mess. A cleanup is in order.
6718 6724
6719 6725 * Auto-installer created. For some bizarre reason, the zipfiles
6720 6726 module isn't working on my system. So I made a tar version
6721 6727 (hopefully the command line options in various systems won't kill
6722 6728 me).
6723 6729
6724 6730 * Fixes to Struct in genutils. Now all dictionary-like methods are
6725 6731 protected (reasonably).
6726 6732
6727 6733 * Added pager function to genutils and changed ? to print usage
6728 6734 note through it (it was too long).
6729 6735
6730 6736 * Added the LazyPython functionality. Works great! I changed the
6731 6737 auto-quote escape to ';', it's on home row and next to '. But
6732 6738 both auto-quote and auto-paren (still /) escapes are command-line
6733 6739 parameters.
6734 6740
6735 6741
6736 6742 2001-11-01 Fernando Perez <fperez@colorado.edu>
6737 6743
6738 6744 * Version changed to 0.0.7. Fairly large change: configuration now
6739 6745 is all stored in a directory, by default .ipython. There, all
6740 6746 config files have normal looking names (not .names)
6741 6747
6742 6748 * Version 0.0.6 Released first to Lucas and Archie as a test
6743 6749 run. Since it's the first 'semi-public' release, change version to
6744 6750 > 0.0.6 for any changes now.
6745 6751
6746 6752 * Stuff I had put in the ipplib.py changelog:
6747 6753
6748 6754 Changes to InteractiveShell:
6749 6755
6750 6756 - Made the usage message a parameter.
6751 6757
6752 6758 - Require the name of the shell variable to be given. It's a bit
6753 6759 of a hack, but allows the name 'shell' not to be hardwired in the
6754 6760 magic (@) handler, which is problematic b/c it requires
6755 6761 polluting the global namespace with 'shell'. This in turn is
6756 6762 fragile: if a user redefines a variable called shell, things
6757 6763 break.
6758 6764
6759 6765 - magic @: all functions available through @ need to be defined
6760 6766 as magic_<name>, even though they can be called simply as
6761 6767 @<name>. This allows the special command @magic to gather
6762 6768 information automatically about all existing magic functions,
6763 6769 even if they are run-time user extensions, by parsing the shell
6764 6770 instance __dict__ looking for special magic_ names.
6765 6771
6766 6772 - mainloop: added *two* local namespace parameters. This allows
6767 6773 the class to differentiate between parameters which were there
6768 6774 before and after command line initialization was processed. This
6769 6775 way, later @who can show things loaded at startup by the
6770 6776 user. This trick was necessary to make session saving/reloading
6771 6777 really work: ideally after saving/exiting/reloading a session,
6772 6778 *everything* should look the same, including the output of @who. I
6773 6779 was only able to make this work with this double namespace
6774 6780 trick.
6775 6781
6776 6782 - added a header to the logfile which allows (almost) full
6777 6783 session restoring.
6778 6784
6779 6785 - prepend lines beginning with @ or !, with a and log
6780 6786 them. Why? !lines: may be useful to know what you did @lines:
6781 6787 they may affect session state. So when restoring a session, at
6782 6788 least inform the user of their presence. I couldn't quite get
6783 6789 them to properly re-execute, but at least the user is warned.
6784 6790
6785 6791 * Started ChangeLog.
General Comments 0
You need to be logged in to leave comments. Login now