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